上文已經繪制了圓環,但仔細分析就知,如果只需要圓環的話,那么只繪制圓環就可以,不用畫內圓和外圓了。事實證明也是如此。
但是要做成和下面的圓環透明度不一的效果上面的方法還是達不中:
用drawCircle不中了,經查android提供了繪制圓弧的函數drawArc,參考http://zhidao.baidu.com/question/469977150.html,也可以看這里http://blog.chinaunix.net/uid-23392298-id-3345789.html
canvas.drawArc(new RectF(0, 0, 128, 128), 0, 360, true, new Paint( Paint.ANTI_ALIAS_FLAG)); 參數1:圓的范圍大小 參數2:起始角度 參數3:圓心角角度,360為圓,180為半圓 參數4:中心 參數5:畫筆Paint,可以設置畫線or填充,設置顏色,設置線的粗細等等第四個參數
最關鍵的是第一個參數RectF,在什么地方繪制圓弧就是由這個矩形的位置確定的。根據 上文 ,這個RectF應該是內切圓弧的外圓(盡管沒畫,但還是有)。所以其左上點及右下點坐標為:
RectF rect2 = new RectF(center-(innerCircle + 1 +ringWidth/2),center-(innerCircle + 1 +ringWidth/2), center+(innerCircle + 1 +ringWidth/2), center+(innerCircle + 1 +ringWidth/2));
為了繪制出透明度不同的圓環分兩部來繪制:
this.paint.setARGB(200, 127, 255, 212);
this.paint.setStrokeWidth(ringWidth);
//繪制不透明部分
canvas.drawArc(rect2, 180+startAngle, 90, false, paint);
canvas.drawArc(rect2, 0+startAngle, 90, false, paint);
//繪制透明部分
this.paint.setARGB(30, 127, 255, 212);
canvas.drawArc(rect2, 90+startAngle, 90, false, paint);
canvas.drawArc(rect2, 270+startAngle, 90, false, paint);
上面的代碼當startAngle = 0時,繪制的是一個靜態的透明度交替的圓弧。接著要讓它轉起來。增加代碼:
startAngle+=10;
if(startAngle == 180)
startAngle = 0;
事實上后兩句也可以不增加,仿照 前文SurfaceView繪制旋轉動畫的例子 用這種求余的思想,(rotate+= 48 )% 360 ,把上面角度也弄個%360,也是可以的。
剩下的事就是讓這個東西循環執行了。在super.onDraw(canvas);這句代碼后面加 invalidate();就可以了!透明圓環就轉起來了。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
