亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android實現雅虎新聞摘要加載視差動畫效果

 更新時間:2021年08月09日 17:36:52   作者:我想月薪過萬  
這篇文章主要介紹了Android實現雅虎新聞摘要加載視差動畫效果,通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

基礎知識

 Android實現旋轉動畫的兩種方式 我們了解了 Android實現旋轉的兩種基本方法之后,我們來寫一個綜合案例

效果展示

代碼實現 

實現思路

從效果中我們可以看到 可以將其分為三個動畫:

1、旋轉動畫(Android實現旋轉動畫的兩種方式

2、聚合動畫

3、擴展動畫

代碼展示

package com.wust.mydialog;
 
import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.animation.ObjectAnimator;
import android.animation.ValueAnimator;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.View;
import android.view.WindowManager;
import android.view.animation.AnticipateInterpolator;
import android.view.animation.LinearInterpolator;
 
import androidx.annotation.Nullable;
 
 
/**
 * ClassName: com.wust.mydialog.MyRotateView <br/>
 * Description: <br/>
 * date: 2021/8/7 12:13<br/>
 *
 * @author yiqi<br />
 * @QQ 1820762465
 * @微信 yiqiideallife
 * @技術交流QQ群 928023749
 */
public class MyRotateView extends View {
 
    //設置旋轉間隔時間
    private int SPLASH_CIRCLE_ROTATE_TIME = 1000;
    //設置中心圓半徑
    private float CENTER_CIRCLE_RADIUS;
    private float SMALL_CIRCLE_RADIUS;
    private float mCurrentSingle = 0f;
    private int[] mColorArray;
    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);
    }
 
    //定義 狀態(tài) 抽象類
    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);
            canvas.drawCircle(getWidth()/2,getHeight()/2,mDiagonal,mCirclePaint);
        }
    }
 
    public void dismiss() {
        if (mLoadingState instanceof RotateState){
            //取消旋轉值動畫
            va.cancel();
            //創(chuàng)建縮放動畫
            mLoadingState = new ScaleState();
            //刷新布局、可以寫也可以不寫
//            invalidate();
        }
    }
}

到此這篇關于Android實現雅虎新聞摘要加載視差動畫效果的文章就介紹到這了,更多相關android視覺動畫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • android:TextView簡單設置文本樣式和超鏈接的方法

    android:TextView簡單設置文本樣式和超鏈接的方法

    這篇文章主要介紹了android:TextView簡單設置文本樣式和超鏈接的方法,涉及TextView常見文字屬性的相關操作技巧,需要的朋友可以參考下
    2016-08-08
  • 橫豎屏切換導致頁面頻繁重啟screenLayout解析

    橫豎屏切換導致頁面頻繁重啟screenLayout解析

    這篇文章主要為大家介紹了橫豎屏切換導致頁面頻繁重啟screenLayout解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Android控件實現圖片縮放功能

    Android控件實現圖片縮放功能

    這篇文章主要介紹了Android控件實現對圖片進行縮放功能的相關資料,需要的朋友可以參考下
    2018-01-01
  • Android短信備份及數據插入實現代碼解析

    Android短信備份及數據插入實現代碼解析

    這篇文章主要介紹了Android短信備份及數據插入實現代碼解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • Android開發(fā)之開發(fā)者頭條(一)啟動頁實現

    Android開發(fā)之開發(fā)者頭條(一)啟動頁實現

    這篇文章主要介紹了Android開發(fā)之開發(fā)者頭條(一)啟動頁實現的相關資料,需要的朋友可以參考下
    2016-04-04
  • Android開發(fā)中TextView文本過長滾動顯示實現方法分析

    Android開發(fā)中TextView文本過長滾動顯示實現方法分析

    這篇文章主要介紹了Android開發(fā)中TextView文本過長滾動顯示實現方法,結合實例形式分析了Android項目開發(fā)中TextView顯示超長文本的具體操作技巧與注意事項,需要的朋友可以參考下
    2018-02-02
  • Android:“萬能”Activity重構篇

    Android:“萬能”Activity重構篇

    本文主要介紹了mvp以及每一層,以及使用mvp來重構“萬能”Activity,其實每一層需要注意的東西還有很多,比如model層是最難寫的一層。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • Android12四大組件之Activity生命周期變化詳解

    Android12四大組件之Activity生命周期變化詳解

    雖然說我們天天都在使用Activity,但是你真的對Activity的生命機制完全了解了嗎?Activity的生命周期方法只有七個,但是其實那只是默認的情況。也就是說在其他情況下,Activity的生命周期可能不會是按照我們以前所知道的流程,本章著重講解Activity的生命周期變化
    2022-07-07
  • Android App開發(fā)中ViewPager組件的入門使用教程

    Android App開發(fā)中ViewPager組件的入門使用教程

    這篇文章主要介紹了Android App開發(fā)中ViewPager組件的入門使用教程,ViewPager主要用來實現通過滑動來切換頁面的效果,需要的朋友可以參考下
    2016-03-03
  • Android開發(fā)實現的Intent跳轉工具類實例

    Android開發(fā)實現的Intent跳轉工具類實例

    這篇文章主要介紹了Android開發(fā)實現的Intent跳轉工具類,簡單描述了Intent組件的功能并結合實例形式給出了頁面跳轉、拍照、圖片調用等相關操作技巧,需要的朋友可以參考下
    2017-11-11

最新評論