Android開(kāi)發(fā)實(shí)現(xiàn)各種圖形繪制功能示例
本文實(shí)例講述了Android開(kāi)發(fā)實(shí)現(xiàn)各種圖形繪制功能。分享給大家供大家參考,具體如下:
這里結(jié)合本人的開(kāi)發(fā)事例,簡(jiǎn)單介紹一下如何在Android平臺(tái)下實(shí)現(xiàn)各種圖形的繪制。
首先自定義一個(gè)View類,這個(gè)view類里面需要一個(gè)Paint對(duì)象來(lái)控制圖形的屬性,需要一個(gè)Path對(duì)象來(lái)記錄圖形繪制的路徑,需要一個(gè)Canvas類來(lái)執(zhí)行繪圖操作,還需要一個(gè)Bitmap類來(lái)盛放繪畫(huà)的結(jié)果。
Paint mPaint = new Paint(); mPaint.setAntiAlias(true); mPaint.setColor(0xFFFF0000); mPaint.setStyle(Paint.Style.STROKE); mPaint.setStrokeWidth(12);
以上代碼初始化了Paint對(duì)象,設(shè)置了畫(huà)筆的顏色、類型和粗細(xì)。
BitmapmForeBitmap = Bitmap.createBitmap(mWidth, mHeight, Bitmap.Config.ARGB_8888); CanvasmCanvas = new Canvas(mForeBitmap); PathmPath = new Path();
以上代碼創(chuàng)建了一個(gè)Bitmap對(duì)象,并將他作為參數(shù)傳給了Canvas對(duì)象,同時(shí)初始化Path對(duì)象。
想讓View響應(yīng)用戶的觸摸事件,需要實(shí)現(xiàn)View類的onTouchEvent函數(shù),代碼如下:
@Override public boolean onTouchEvent(MotionEvent event) { float x = event.getX(); float y = event.getY(); switch (event.getAction()) { case MotionEvent.ACTION_DOWN: touch_start(x, y); invalidate(); break; case MotionEvent.ACTION_MOVE: touch_move(x, y); invalidate(); break; case MotionEvent.ACTION_UP: touch_up(); invalidate(); break; } return true; }
其中touch_start,touch_move和touch_up函數(shù)分別處理按下,移動(dòng)和抬起事件,函數(shù)的實(shí)現(xiàn)將在后面介紹,invalidate函數(shù)會(huì)調(diào)用onDraw函數(shù)保證繪圖效果實(shí)時(shí)顯示出來(lái)。
touch_start函數(shù)實(shí)現(xiàn)如下
mPath.reset(); mPath.moveTo(x,y); mX= x; mY= y;
每次清空Path,移動(dòng)到起點(diǎn)處,并記錄起點(diǎn)。
touch_move函數(shù)實(shí)現(xiàn)如下:
switch(mShape) { case 1: float dx = Math.abs(x - mX); float dy = Math.abs(y - mY); if (dx >= TOUCH_TOLERANCE || dy >= TOUCH_TOLERANCE) { mPath.quadTo(mX, mY, (x + mX)/2, (y + mY)/2); mX = x; mY = y; }break; case 2: mPath.reset(); mPath.moveTo(mX, mY); mPath.lineTo(x, y); break; case 3: mPath.reset(); RectF mRect = new RectF(); mRect.set(mX, mY, x, y); mPath.addOval(mRect, Path.Direction.CW); break; case 4: mPath.reset(); RectF mRect1 = new RectF(); mRect1.set(mX, mY, x, y); mPath.addRect(mRect1, Path.Direction.CW); break; }
根據(jù)mShape的值繪制不同的圖形,為1時(shí)繪制Bezier曲線,為2時(shí)繪制直線,為3時(shí)繪制橢圓,為4是繪制矩形,分別調(diào)用Path類的不同函數(shù)實(shí)現(xiàn)。
touch_up函數(shù)實(shí)現(xiàn)如下:
mCanvas.drawPath(mPath,mPaint); mPath.reset();
將Path繪制到Canvas的Bitmap里
最后在OnDraw函數(shù)里需要把當(dāng)前的Bitmap繪制出來(lái)。
protectedvoid onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); canvas.drawBitmap(mBitmap,0, 0, mBitmapPaint); }
大功告成,截圖如下:
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android圖形與圖像處理技巧總結(jié)》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android調(diào)試技巧與常見(jiàn)問(wèn)題解決方法匯總》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
相關(guān)文章
基于Android實(shí)現(xiàn)顏色漸變動(dòng)畫(huà)效果
本文主要給大家介紹了Android實(shí)現(xiàn)顏色漸變動(dòng)畫(huà)效果,實(shí)現(xiàn)這樣的一個(gè)動(dòng)畫(huà)漸變的效果很簡(jiǎn)單,只需要兩步,第一步用GradientDrawable實(shí)現(xiàn)兩個(gè)顏色之間的漸變效果,第二步用屬性動(dòng)畫(huà)實(shí)現(xiàn)顏色變化的過(guò)程,需要的朋友可以參考下2024-01-01Android實(shí)現(xiàn)美團(tuán)下拉功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)美團(tuán)下拉功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10Android Studio使用教程(五):Gradle命令詳解和導(dǎo)入第三方包
這篇文章主要介紹了Android Studio使用教程(五):Gradle命令詳解和導(dǎo)入第三方包,本文講解了導(dǎo)入Android Studio、Gradle常用命令等內(nèi)容,需要的朋友可以參考下2015-05-05Android應(yīng)用開(kāi)發(fā)之代碼混淆
Android項(xiàng)目中的混淆很easy,之所以寫(xiě)這篇總結(jié)是由于近期發(fā)現(xiàn)公司的代碼居然沒(méi)有混淆,反編譯后代碼隨手可得。很震驚。2014-07-07Android實(shí)現(xiàn)EditText內(nèi)容保存為Bitmap的方法
這篇文章主要介紹了Android實(shí)現(xiàn)EditText內(nèi)容保存為Bitmap的方法,涉及Android中saveBitmap方法的簡(jiǎn)單使用技巧,需要的朋友可以參考下2016-01-01Android TV開(kāi)發(fā):實(shí)現(xiàn)3D仿Gallery效果的實(shí)例代碼
這篇文章主要介紹了Android TV開(kāi)發(fā):實(shí)現(xiàn)3D仿Gallery效果的實(shí)例代碼,效果:滾動(dòng)翻頁(yè)+ 頁(yè)面點(diǎn)擊+頁(yè)碼指示器+焦點(diǎn)控制,主要為了移植到電視上做了按鍵事件和焦點(diǎn)控制。2018-05-05Android 判斷是否是是全漢字、全字母、全數(shù)字、數(shù)字和字母等(代碼)
這篇文章主要介紹了Android 判斷是否是是全漢字、全字母、全數(shù)字、數(shù)字和字母等的實(shí)例代碼,需要的朋友可以參考下2016-12-12Android實(shí)現(xiàn)聲音采集回聲與回聲消除
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)聲音采集回聲與回聲消除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08