Android 塗鴉最佳實踐


Android中實現手勢繪圖一般都兩種方式,一是直接在View上繪制,而是使用SurfaceView。兩者還是有一些區別的,簡單介紹下。View:顯示視圖,內置畫布,提供圖形繪制函數、觸屏事件、按鍵事件函數等;必須在UI主線程內更新畫面,速度較慢。 SurfaceView:基於view視圖進行拓展的視圖類,更適合2D游戲的開發;是view的子類,使用雙緩機制,在新的線程中更新畫面所以刷新界面速度比view快。所以呢,要實現塗鴉的功能優先選擇后者。

在開始碼代碼之前,先簡單理下要實現的功能。

1、可以自定義畫筆的顏色

2、可以自定義畫筆的粗細

3、可以實現各種常見形狀的繪制

4、允許畫布的回退,就是回到上一步

5、要支持橡皮擦功能

6、已作完的畫,要支持保存

下面我們就逐步去實現這五個功能點。

一、關於自定義畫筆的顏色和粗細,這個最簡單,只須調用Paint的setColor(int color)和setStrokeWidth(float width)這兩個方法即可。需要主要的是,使用SurfaceView繪圖需要注意是通過SurfaceHolder獲得Canvas實例,這時可以通過Canvas實例去繪圖,繪制結束調用unlockCanvasAndPost(canvas)去提交改變。

二、支持自由曲線、直線、矩形、圓形、實心矩形、實心圓形,很方便的進行擴展。這里先抽象出一個基類Action,每一次的繪制都是一個action實例,我們的畫板就是一個action的列表,這樣就能很好的支持回退功能。

三、畫布的回退。如果畫布上的action列表大小不為0,表示畫布目前是支持回退的,只須把列表中最后一個action給remove掉,重新繪制就OK了

四、橡皮擦。這里我取了個巧,畫布的背景是白色的,所以橡皮擦的實現也是一個action,形狀為自由曲線,顏色也為白色,這樣就營造了一種被擦除的效果,其實只是被白色的曲線給遮蓋住了。按照第三點的實現,橡皮擦也支持回退。

五、保存畫板。畫布上畫滿了你的各種圖形,最后一步就是保存了,但是View和SurfaceView的截取是不同的,View是靜態的被動的,SurfaceView是主動的動態的,如果使用View的截圖方法只能得到一個黑屏。這時好辦法就是把咱們保存的action列表重新繪制出來。代碼如下

 

代碼地址:https://github.com/JackCho/AndroidDoodle

如果覺得對你有所幫助,歡迎大家訂閱我的微信公眾賬號——Android干貨分享(ID:android_share)。下面是微信的二維碼,為你提供及時高質的Android干貨。

技術交流QQ群:318588906,歡迎大家加群,共同探討下Android和Java技術,一起壯大我們的微信干貨分享社區。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM