android中實(shí)現(xiàn)在ImageView上隨意畫線涂鴉的方法
我實(shí)現(xiàn)的思路:
1.繼承ImageView類
2.重寫onTouchEvent方法,在ACTION_MOVE(即移動(dòng)時(shí)),記錄下所經(jīng)過的點(diǎn)坐標(biāo),在ACTION_UP時(shí)(即手指離開時(shí),這時(shí)一條線已經(jīng)畫完),將所畫的線(點(diǎn)的集合)保存在一個(gè)集合中
3.重寫onDraw方法,利用canvas和所記錄下的線和點(diǎn)畫出線來
可能我講的十分籠統(tǒng),下面來看看實(shí)際的代碼吧
//代表ImageView上的一點(diǎn) public class ViewPoint { float x; float y; } //表示一條線 public class Line { ArrayList<ViewPoint> points = new ArrayList<ViewPoint>(); }
如上所示,ViewPoint表示一點(diǎn),而Line表示一條線
然后在擴(kuò)展的ImageView類上聲明如下:
public class HandWritingImageView extends ImageView { private Paint paint; //當(dāng)前正在畫的線 private Line current = new Line(); //所有畫過的線 private ArrayList<Line> lines = new ArrayList<Line>(); }
隨后重寫onTouchEvent方法
@Override public boolean onTouchEvent(MotionEvent event) { //獲取坐標(biāo) clickX = event.getX(); clickY = event.getY(); if (event.getAction() == MotionEvent.ACTION_DOWN) { invalidate(); return true; } else if (event.getAction() == MotionEvent.ACTION_MOVE) { ViewPoint point = new ViewPoint(); point.x = clickX; point.y = clickY; //在移動(dòng)時(shí)添加所經(jīng)過的點(diǎn) current.points.add(point); invalidate(); return true; } else if (event.getAction() == MotionEvent.ACTION_UP) { //添加畫過的線 lines.add(current); current = new Line(); invalidate(); } return super.onTouchEvent(event); }
可以看到當(dāng)我們手指移動(dòng)時(shí),獲取保存所經(jīng)過的點(diǎn)并調(diào)用invalidate方法進(jìn)行屏幕刷新(可以使onDraw方法被調(diào)用,稍后可以看到),當(dāng)我們手指離開時(shí)添加之前的所畫的線到集合中,并調(diào)用invalidate方法
接下來看看所重寫的onDraw方法,它利用所保存的線的信息進(jìn)行畫線
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); //畫出之前所有的線 for (int i = 0; i < lineData.lines.size(); i++) { drawLine(canvas, lines.get(i)); } //畫出當(dāng)前的線 drawLine(canvas, current); } private void drawLine(Canvas canvas, Line line) { for (int i = 0; i < line.points.size() - 1; i++) { float x = line.points.get(i).x; float y = line.points.get(i).y; float nextX = line.points.get(i + 1).x; float nextY = line.points.get(i + 1).y; canvas.drawLine(x, y, nextX, nextY, paint); } }
這樣就可以在ImageView上隨意涂鴉了,并且還可以通過刪除lines中的最后條line來實(shí)現(xiàn)撤銷功能。
以上這篇android中實(shí)現(xiàn)在ImageView上隨意畫線涂鴉的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Android編程實(shí)現(xiàn)帶有單選按鈕和復(fù)選按鈕的dialog功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)帶有單選按鈕和復(fù)選按鈕的dialog功能,結(jié)合具體實(shí)例形式分析了Android實(shí)現(xiàn)帶有單選按鈕的dialog對(duì)話框及帶有復(fù)選按鈕的dialog對(duì)話框相關(guān)操作技巧,需要的朋友可以參考下2017-09-09Android View的事件分發(fā)機(jī)制深入分析講解
事件分發(fā)從手指觸摸屏幕開始,即產(chǎn)生了觸摸信息,被底層系統(tǒng)捕獲后會(huì)傳遞給Android的輸入系統(tǒng)服務(wù)IMS,通過Binder把消息發(fā)送到activity,activity會(huì)通過phoneWindow、DecorView最終發(fā)送給ViewGroup。這里就直接分析ViewGroup的事件分發(fā)2023-01-01Android 8.0實(shí)現(xiàn)發(fā)送通知
這篇文章主要為大家詳細(xì)介紹了Android 8.0實(shí)現(xiàn)發(fā)送通知,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07基于android示例程序(bitmapfun) 高效加載圖片讓人無語地方
嘗試了使用git上的一個(gè)開源項(xiàng)目afinal(bitmapfun的封裝版)來加載圖片,但是在測(cè)試的時(shí)候發(fā)現(xiàn)了一個(gè)問題,新的圖片加載器(bitmapfun)比之前用的ImageDownloader要慢很多,特別是在網(wǎng)絡(luò)狀況不好的時(shí)候,那簡(jiǎn)直是太讓人無語了2013-04-04Android搭建本地Tomcat服務(wù)器及相關(guān)配置
這篇文章主要介紹了Android搭建本地Tomcat服務(wù)器及相關(guān)配置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07Android中應(yīng)用前后臺(tái)切換監(jiān)聽的實(shí)現(xiàn)詳解
這篇文章主要給大家介紹了關(guān)于Android中應(yīng)用前后臺(tái)切換監(jiān)聽實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-07-07Android自定義view制作抽獎(jiǎng)轉(zhuǎn)盤
這篇文章主要為大家詳細(xì)介紹了Android自定義view制作抽獎(jiǎng)轉(zhuǎn)盤,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Android studio實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器
這篇文章主要為大家詳細(xì)介紹了Android studio實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03