视差动画 - 雅虎新闻摘要加载

private Paint mCirclePaint;

private ValueAnimator va;

private Matrix mSpaceMatrix;

private LoadingState mLoadingState;

//当前中心圆半径

private float mCurCenterRadius;

private float mDiagonal;

private float mLineWidth;

public MyRotateView(Context context) {

super(context);

}

public MyRotateView(Context context, @Nullable AttributeSet attrs) {

super(context, attrs);

}

public MyRotateView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

int width = MeasureSpec.getSize(widthMeasureSpec);

int height = MeasureSpec.getSize(heightMeasureSpec);

//初始化参数

initParams(width, height);

setMeasuredDimension(width, height);

}

private void initParams(int w, int h) {

//设置中心圆半径

CENTER_CIRCLE_RADIUS = 1 / 4.0f * w;

//设置小圆的半径

SMALL_CIRCLE_RADIUS = 1 / 25.0f * w;

//获取小球颜色

mColorArray = getResources().getIntArray(R.array.splash_circle_colors);

//初始化画笔

mCirclePaint = new Paint();

mCirclePaint.setDither(true);

mCirclePaint.setAntiAlias(true);

//初始化旋转矩阵

mSpaceMatrix = new Matrix();

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

if (mLoadingState == null) {

mLoadingState = new RotateState();

}

mLoadingState.onDraw(canvas);

}

//定义 状态 抽象类

private abstract class LoadingState {

public abstract void onDraw(Canvas canvas);

}

//旋转动画

private class RotateState extends LoadingState {

public RotateState() {

//计算每个小球的间隔

double spaceAngle = 360.0d / mColorArray.length;

//初始化旋转矩阵

mSpaceMatrix.reset();

mSpaceMatrix.postRotate((float) spaceAngle, getWidth() / 2, getHeight() / 2);

va = ObjectAnimator.ofFloat(0f, 360.0f);

va.setDuration(SPLASH_CIRCLE_ROTATE_TIME);

va.setRepeatCount(ValueAnimator.INFINITE);

va.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

mCurrentSingle = (float) animation.getAnimatedValue();

invalidate();

}

});

va.setInterpolator(new LinearInterpolator());

va.start();

}

@Override

public void onDraw(Canvas canvas) {

//绘制背景

canvas.drawColor(Color.WHITE);

//利用旋转画布法

canvas.save();

canvas.rotate(mCurrentSingle, getWidth() / 2, getHeight() / 2);

for (int i = 0; i < mColorArray.length; i++) {

canvas.concat(mSpaceMatrix);

//为 每个球 画笔 设置颜色

mCirclePaint.setColor(mColorArray[i]);

//利用旋转画布法

float cx = getWidth() / 2 + CENTER_CIRCLE_RADIUS;

float cy = getHeight() / 2;

canvas.drawCircle(cx, cy, SMALL_CIRCLE_RADIUS, mCirclePaint);

}

canvas.restore();

}

}

//聚合动画

private class ScaleState extends LoadingState {

public ScaleState() {

va = ObjectAnimator.ofFloat(CENTER_CIRCLE_RADIUS,0);

va.setDuration(SPLASH_CIRCLE_ROTATE_TIME);

va.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

mCurCenterRadius = (float) animation.getAnimatedValue();

invalidate();

}

});

va.addListener(new AnimatorListenerAdapter() {

@Override

public void onAnimationEnd(Animator animation) {

mLoadingState = new ExtentState();

}

});

va.setInterpolator(new AnticipateInterpolator());

va.start();

}

@Override

public void onDraw(Canvas canvas) {

//绘制背景

canvas.drawColor(Color.WHITE);

//绘制小圆

canvas.save();

//这句话也不能调,要不然不连贯

canvas.rotate(mCurrentSingle,getWidth()/2,getHeight()/2);

for (int i = 0; i < mColorArray.length; i++) {

mCirclePaint.setColor(mColorArray[i]);

canvas.concat(mSpaceMatrix);

canvas.drawCircle(mCurCenterRadius+getWidth()/2,getHeight()/2,SMALL_CIRCLE_RADIUS,mCirclePaint);

}

canvas.restore();

}

}

//扩展动画

public class ExtentState extends LoadingState{

public ExtentState() {

//初始化对角线

float cx = getWidth()/2.0f;

float cy = getHeight()/2.0f;

mDiagonal = (float) Math.sqrt(Math.pow(cx,2)+Math.pow(cy,2));

va = ObjectAnimator.ofFloat(mDiagonal,0);

va.setDuration(3000);

va.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

mLineWidth = (float) animation.getAnimatedValue();

invalidate();

}

});

va.setInterpolator(new LinearInterpolator());

va.start();

}

@Override

public void onDraw(Canvas canvas) {

mCirclePaint.setColor(Color.WHITE);

mCirclePaint.setStrokeWidth(mLineWidth*2);//元的半径只会到达线宽的中间,所以要乘2

mCirclePaint.setStyle(Paint.Style.STROKE);

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

上面分享的百度、腾讯、网易、字节跳动、阿里等公司2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

【Android高级架构视频学习资源】

Android部分精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
点击传送门,即可获取!

-grfYn4bp-1715391979656)]

【Android高级架构视频学习资源】

Android部分精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值