短视频带货源码,模仿点我达开频页加载动画

软件工具
0 20


短视频带货源码中关于模仿点我达开频页加载动画的代码如下:

package com.example.custome_view.diwoda;
 
import android.animation.AnimatorSet;
import android.animation.ValueAnimator;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.os.Handler;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;
 
import com.example.custome_view.R;
import com.fudaojun.fudaojunlib.utils.LibCalcUtil;
 
/**
 * Created by ZhijunHong on 2018/7/5.
 * 一个简单的自定义View + 动画集合
 */
 
public class DiWoDaView extends View {
    //控件宽度
    private int mWidth;
    //控件高度
    private int mHeight;
    //外部圆画笔
    private Paint mOutCirclePaint;
    //外部圆半径
    private float mOutCircleRaduis;
    //外部圆透明度
    private int mTransparency;
    //外部圆颜色
    private int mCircleColor;
 
    //内部圆画笔
    private Paint mInCirclePaint;
    //内部圆半径
    private float mInCicleRadius;
 
    //handler
    private Handler mHandler;
 
    //动画集合
    private AnimatorSet mAnimationSet;
 
    public DiWoDaView(Context context) {
        this(context, null);
    }
 
    public DiWoDaView(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, 0);
    }
 
    public DiWoDaView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
 
        init();
    }
 
    /**
     * 初始化资源
     */
    private void init() {
        mOutCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG | Paint.LINEAR_TEXT_FLAG);
        mOutCirclePaint.setStyle(Paint.Style.FILL);
        mOutCirclePaint.setColor(Color.YELLOW);
 
        mInCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG | Paint.LINEAR_TEXT_FLAG);
        mInCirclePaint.setStyle(Paint.Style.FILL);
        mInCirclePaint.setColor(getResources().getColor(R.color.orange));
 
        mOutCircleRaduis = LibCalcUtil.dp2px(getContext(), 80);
        mInCicleRadius = LibCalcUtil.dp2px(getContext(), 40);
    }
 
    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
        mWidth = w;
        mHeight = h;
    }
 
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        canvas.translate(mWidth / 2, mHeight / 2);
        //画外围大圆
        canvas.drawCircle(0, 0, mOutCircleRaduis, mOutCirclePaint);
        //画里面小圆
        canvas.drawCircle(0, 0, mInCicleRadius, mInCirclePaint);
    }
 
    /**
     * 开始动画
     */
    public void playAnimation() {
        if (mAnimationSet == null) {
            mAnimationSet = new AnimatorSet();
 
            //大圆半径变更动画
            ValueAnimator anim1 = ValueAnimator.ofFloat(0, mOutCircleRaduis);
            //大圆透明度变更动画
            ValueAnimator anim2 = ValueAnimator.ofInt(256, 0);
 
//            //沿Y轴旋转动画
//            ObjectAnimator anim3 = ObjectAnimator.ofFloat(this, "rotationY", 0f, 360f);
//            //设置一起执行动画
//            mAnimationSet.playTogether(anim1, anim2, anim3);
//            anim3.setRepeatCount(ValueAnimator.INFINITE);
 
            mAnimationSet.playTogether(anim1, anim2);
 
            //设置重复执行动画
            anim1.setRepeatCount(ValueAnimator.INFINITE);
            anim2.setRepeatCount(ValueAnimator.INFINITE);
 
            anim1.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
                @Override
                public void onAnimationUpdate(ValueAnimator animation) {
                    if (animation != null) {
                        //改变外围大圆半径
                        mOutCircleRaduis = (float) animation.getAnimatedValue();
                    }
                }
            });
 
            anim2.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
                @Override
                public void onAnimationUpdate(ValueAnimator animation) {
                    //改变外围大圆透明度
                    mTransparency = (int) animation.getAnimatedValue();
                }
            });
        }
 
        //启动动画
        mAnimationSet.setDuration(2000).start();
 
        if (mHandler == null) {
            mHandler = new Handler();
        }
        mHandler.postDelayed(new Runnable() {
            @Override
            public void run() {
                mCircleColor = Color.argb(mTransparency, 255, 143, 5);
                mOutCirclePaint.setColor(mCircleColor);
 
                //重绘
                postInvalidate();
                mHandler.postDelayed(this, 50);
            }
        }, 50);
 
    }
}


以上就是短视频带货源码中关于模仿点我达开频页加载动画的全部代码,更多信息欢迎关注之后的文章


短视频带货源码,模仿点我达开频页加载动画-小师傅资源网--http://bbs.small-master.com/2432.html
精选帖子
十万人搭建支付暗道:跑分模式兴起,为赌博和洗钱提供百亿资金 100
庆余年电视剧提前观看全集 181
蚂蚁任务辅助平台怎么样?微信辅助10元~12.5元一单 137
uTools 一款极简插件化跨平台的现代桌面工具软件 175
我和我的祖国——2019国庆三部曲其三 175
攀登者——2019国庆三部曲其二 165
中国机长——2019国庆三部曲其一 230
甩手赚,原名挂挂赚,强势复活了 375
分享一个微信抖音挂机新平台,一个号日收益在3-5元左右 419
热门帖子
网站如何布局关键词?网站关键词布局的五大要素 24
ZY-Player安卓 一款一键搜索全网影视的播放器 18
Kotlin零基础入门到进阶实战 17
YouTube油管下载神器v5.06.1 直装破解修复版 16
网站的关键词排名和网站收录的多少是否存在关系 16
最新6个免费申请虚拟主机地址 虚拟云服务器 16
防酒店偷拍 针孔探测绿化版 15
泡菜视频v3.5.1 追韩剧神器 15
怎样才能提高网站的权重 15