Drawable + Animatable實(shí)現(xiàn)動(dòng)畫

看看效果

Demo效果圖

總體的實(shí)現(xiàn)思路

  • 用一個(gè)View(ImageView)容器來呈現(xiàn)動(dòng)畫
  • ImageView設(shè)置一個(gè)Drawable(在這個(gè)drawable里面實(shí)現(xiàn)所有的繪制邏輯)
  • 實(shí)現(xiàn)動(dòng)畫的效果的核心就是,當(dāng)ImageView調(diào)用Drawable的draw(系統(tǒng)自動(dòng)調(diào)用)方法的時(shí)候再次調(diào)用ImageView的重繪方法就實(shí)現(xiàn)了動(dòng)畫效果了

看看這個(gè)demo的實(shí)現(xiàn)

  • 重寫了一個(gè)ImageView僅僅就是為了設(shè)置一個(gè)Drawable,不用重寫也可以。
public class LoadingView extends ImageView{

    public LoadingView(Context context) {
        super(context);
        setImageDrawable(new LoadingDrawable(this));
    }

    public LoadingView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        setImageDrawable(new LoadingDrawable(this));
    }

    public LoadingView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        setImageDrawable(new LoadingDrawable(this));
    }

}
  • 核心就是這個(gè)LoadingDrawable,直接看draw方法吧

    @Override
    public void draw(@NonNull Canvas canvas) {
        //默認(rèn)從左到右
        int width = canvas.getWidth();
        int height = canvas.getHeight();
        int centerX = width / 2;
        int centerY = height / 2;
        //canvas.drawCircle(centerX,centerY,width / 2 - 8,paint);
        for(int i=0;i < lineModels.size();i++){
            drawLine(canvas,lineModels.get(i));
        }
        //updatedata
        contannier.invalidate();
    }


    @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
    private void drawLine(Canvas canvas, LineModel lineModel){
        int width = canvas.getWidth() / 2;
        int height = canvas.getHeight() / 2;
        paint.setColor(lineModel.color);
        canvas.drawArc(
                width - lineModel.raudis - strokeWidth,height - lineModel.raudis - strokeWidth,
                width + lineModel.raudis + strokeWidth,height + lineModel.raudis + strokeWidth,
                lineModel.start,lineModel.end,
                false,paint
        );
        lineModel.updata();
    }
- 這里的**drawLine**就是具體的繪制過程,并且在繪制完成之后更新了下次需要繪制的各種信息
- 繪制完成之后調(diào)用了 **ImageView**的**invalidate**方法進(jìn)行循環(huán)繪制

實(shí)現(xiàn)思路來自

[==↓ ] https://github.com/81813780/AVLoadingIndicatorView


[== ↑] https://github.com/tyrantgit/ExplosionField


Nothing is certain in this life. The only thing i know for sure is that. I love you and my life. That is the only thing i know. have a good day

:)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,361評論 25 708
  • 上周,可以說是一個(gè)比較新的開始。在七月底八月初做月度總結(jié)的,曾經(jīng)和自己說要有所改變,不能總把自己的視線全部關(guān)注在C...
    潔_寞碎閱讀 149評論 0 0
  • 都說少年的文字是無病呻吟,為賦新詞強(qiáng)說愁。 記得大約小學(xué)三年級的樣子,騎車往返學(xué)校。放學(xué)的路上看到春天的綠油油的麥...
    鹿野迷津閱讀 419評論 5 2
  • 10月了。好像每當(dāng)這個(gè)時(shí)節(jié)總是會想起之前許多個(gè)同樣的節(jié)點(diǎn)。不管是四年前和他在一起,還是兩年前換了現(xiàn)在這份工作。全都...
    二月蜜糖閱讀 363評論 0 0
  • 本例中HAWQ環(huán)境采用Ambari方式搭建,實(shí)例分布bd1: HAWQ-Master, Segmentbd2: S...
    dzgdp888閱讀 1,130評論 0 0

友情鏈接更多精彩內(nèi)容