Android如何繪制發(fā)光效果詳解
前言
之前在看別人寫自定義view作繪制的時候,看到別人家的view自帶發(fā)光效果,看起來也是蠻炫酷的,于是自己也抽出時間來試用一下,這里做了一個模仿太陽的各種狀態(tài)樣式。
先上效果先上效果:

實現(xiàn)方式:
public BlurMaskFilter(float radius, Blur style) {
實現(xiàn)是使用的Paint類的setMaskFilter()方法,傳入BlurMaskFilter對象實現(xiàn)高斯模糊發(fā)光。
float radius 設(shè)置模糊半徑 Blur style 設(shè)置發(fā)光樣式,包括 Blur.INNER(內(nèi)發(fā)光),Blur.NORMAL(內(nèi)外發(fā)光) Blur.SOLID(外發(fā)光),Blur.OUTER(僅外發(fā)光可見)貼上代碼
public class MaskFilterView extends View { private Paint lightPaint; private int centerX, centerY; /** 發(fā)光范圍 */ private int radioRadius = 70; public MaskFilterView(Context context) { super(context); init(); } public MaskFilterView(Context context, @Nullable AttributeSet attrs) { super(context, attrs); init(); } private void init() { lightPaint = new Paint(); setLayerType(LAYER_TYPE_SOFTWARE, null); lightPaint.setColor(Color.parseColor('#EC3E3E')); lightPaint.setMaskFilter(new BlurMaskFilter(radioRadius, BlurMaskFilter.Blur.INNER)); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { centerX = getLeft() + getMeasuredWidth()/2; centerY = getTop() + getMeasuredHeight()/2; super.onMeasure(widthMeasureSpec, widthMeasureSpec); } public void setBlurType(int blurType) { switch (blurType) { case 0: lightPaint.setMaskFilter(new BlurMaskFilter(radioRadius, BlurMaskFilter.Blur.INNER)); break; case 1: lightPaint.setMaskFilter(new BlurMaskFilter(radioRadius, BlurMaskFilter.Blur.NORMAL)); break; case 2: lightPaint.setMaskFilter(new BlurMaskFilter(radioRadius, BlurMaskFilter.Blur.SOLID)); break; case 3: lightPaint.setMaskFilter(new BlurMaskFilter(radioRadius, BlurMaskFilter.Blur.OUTER)); break; } invalidate(); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.drawCircle(centerX, centerY, 150, lightPaint); }}
總結(jié)
到此這篇關(guān)于Android如何繪制發(fā)光效果的文章就介紹到這了,更多相關(guān)Android繪制發(fā)光效果內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 什么是python的自省2. php模擬實現(xiàn)斗地主發(fā)牌3. 詳解Android studio 動態(tài)fragment的用法4. spring acegi security 1.0.0 發(fā)布5. MyBatis中的JdbcType映射使用詳解6. vue 使用localstorage實現(xiàn)面包屑的操作7. Vue封裝一個TodoList的案例與瀏覽器本地緩存的應(yīng)用實現(xiàn)8. Vuex localStorage的具體使用9. Python random庫使用方法及異常處理方案10. jQuery 實現(xiàn)DOM元素拖拽交換位置的實例代碼

網(wǎng)公網(wǎng)安備