Android仿“守望先鋒”加載動畫

效果圖

這里寫圖片描述
這里寫圖片描述
這里寫圖片描述

實現(xiàn)思路

  • 畫一個小六邊形
  • 按效果圖位置畫七個小六邊形
  • 實現(xiàn)一個小六邊形的顯示與隱藏動畫
  • 按順序播放七個小六邊形的動畫

詳解

畫一個小六邊形

畫一個六邊形只需要知道位置與大小。
位置這里使用中心點旗扑,大小使用中心點到頂點的距離。根據(jù)這兩個數(shù)據(jù)就可以通過數(shù)學(xué)方法很容易的求出6個頂點坐標(biāo)眠菇。

求出6個頂點坐標(biāo)后可以通過canvas.drawPath來畫出六邊形:

        Paint mPaint = new Paint();
        mPaint.setColor(mLoadingView.color);
        mPaint.setStrokeWidth(3);
        mPaint.setAlpha(0);
        CornerPathEffect corEffect = new CornerPathEffect(length / CORNER_PATH_EFFECT_SCALE);
        mPaint.setPathEffect(corEffect);

        PointF[] points = getHexagonPoints(centerPoint, length);
        Path mPath = new Path();
        mPath.moveTo(points[1].x, points[1].y);
        mPath.lineTo(points[2].x, points[2].y);
        mPath.lineTo(points[3].x, points[3].y);
        mPath.lineTo(points[4].x, points[4].y);
        mPath.lineTo(points[5].x, points[5].y);
        mPath.lineTo(points[6].x, points[6].y);
        mPath.close();
        
        canvas.drawPath(mPath, mPaint);

按效果圖位置畫七出個小六邊形

仔細(xì)觀察效果圖可以發(fā)現(xiàn)七個小六邊形其實就是一個旋轉(zhuǎn)后的大六邊形的6個頂點+1個中心點捎废,如下圖所示:


這里寫圖片描述

這里有個坑就是主意大六邊形和小六邊形的變長問題!

其實用純數(shù)學(xué)算出6個小六邊形的中心點也是很容易的登疗。

實現(xiàn)一個小六邊形的顯示與隱藏動畫

動畫效果分兩種,一個是顯示断傲,一個是隱藏智政。這里使用ValueAnimator來實現(xiàn):

顯示:

先放大并改變透明度

        ValueAnimator mShowAnimation = ValueAnimator.ofFloat(0, 1);
        mShowAnimation.setDuration(ANIMATION_DURATION);
        mShowAnimation.setInterpolator(new DecelerateInterpolator());
        mShowAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator animation) {
                float animValue = (float) animation.getAnimatedValue();
                mScale = 0.5f + animValue / 2;
                mPaint.setAlpha((int) (animValue * 255));
                mLoadingView.invalidate();
            }
        });

隱藏:

        ValueAnimator mHideAnimation = ValueAnimator.ofFloat(1, 0);
        mHideAnimation.setDuration(ANIMATION_DURATION);
        mHideAnimation.setInterpolator(new DecelerateInterpolator());
        mHideAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator animation) {
                float animValue = (float) animation.getAnimatedValue();
                mScale = 0.5f + animValue / 2;
                mPaint.setAlpha((int) (animValue * 255));
                mLoadingView.invalidate();
            }
        });

隱藏動畫其實就是把顯示動畫倒過來续捂,因此直接將顯示動畫reverse也可。

按順序播放七個小六邊形的動畫

根據(jù)效果圖牙瓢,我們將7個小六邊形編號為1,2页慷,3聂渊,4,5汉嗽,6,7饼暑。則一輪動畫為:

1顯示 -> 2顯示 -> 3顯示 -> 4顯示 -> 5顯示 -> 6顯示 -> 7顯示 -> 1隱藏 -> 2隱藏 -> 3隱藏 -> 4隱藏 -> 5隱藏 -> 6隱藏 -> 7隱藏

Android中可以使用AnimatorSetplaySequentially方法來播放一組順序動畫弓叛,所以我們只要不停的播放這個動畫序列就ok了!
代碼如下:

        AnimatorSet mPlayAnimator = new AnimatorSet();
        ArrayList<Animator> animators = new ArrayList<>();
        // add show animation
        for (OverWatchViewItem item : items) {
            animators.add(item.getShowAnimation());
        }

        // add hide animation
        for (OverWatchViewItem item : items) {
            animators.add(item.getHideAnimation());
        }

        // 播放動畫序列
        mPlayAnimator.playSequentially(animators);
        mPlayAnimator.start();

最后

Github地址:
https://github.com/a396901990/LoadingView-OverWatch

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末陈惰,一起剝皮案震驚了整個濱河市毕籽,隨后出現(xiàn)的幾起案子井辆,更是在濱河造成了極大的恐慌溶握,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件萍肆,死亡現(xiàn)場離奇詭異,居然都是意外死亡塘揣,警方通過查閱死者的電腦和手機宿崭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人琅摩,你說我怎么就攤上這事⊥扇埃” “怎么了轰异?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長搭独。 經(jīng)常有香客問我,道長唉俗,這世上最難降的妖魔是什么配椭? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮衡楞,結(jié)果婚禮上敦姻,老公的妹妹穿的比我還像新娘歧杏。我一直安慰自己,他們只是感情好得滤,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布盒犹。 她就那樣靜靜地躺著,像睡著了一般沮协。 火紅的嫁衣襯著肌膚如雪卓嫂。 梳的紋絲不亂的頭發(fā)上慷暂,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天行瑞,我揣著相機與錄音餐禁,去河邊找鬼。 笑死帮非,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的筑舅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼翠拣,長吁一口氣:“原來是場噩夢啊……” “哼游盲!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起优烧,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤链峭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體杖刷,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡驳癌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了表窘。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片甜滨。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖衣摩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情既琴,我是刑警寧澤泡嘴,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響纹腌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜升薯,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一涎劈、第九天 我趴在偏房一處隱蔽的房頂上張望广凸。 院中可真熱鬧蛛枚,春花似錦、人聲如沸蹦浦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至浦旱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間颁湖,已是汗流浹背尼酿。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留裳擎,地道東北人。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓羡微,卻偏偏與公主長得像惶我,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子绸贡,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,501評論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫听怕、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,022評論 4 62
  • 人生之事,皆逃不過“俗”疏旨。 之所以有這種感受,大抵是因為終于意識到學(xué)生氣的自己有太多與這個世界背道而馳的品格了檐涝。 ...
    Lllllssmin閱讀 569評論 0 0
  • @王然然媽 你的打卡讓我想起來霞玄,我們班的班會會在自習(xí)開始的前十分鐘拉岁,老師布置布置學(xué)校任務(wù),獎懲一下同學(xué)們喊暖,就草草結(jié)...
    番茄麻麻_香雪冰芬閱讀 362評論 0 0
  • 一巩掺、請不要把明星想得那么完美 今天早上新浪微博推送了一則消息,文章的大致內(nèi)容出現(xiàn)了這幾個關(guān)鍵詞:“林丹出軌”胖替、“密...
    百川與海閱讀 719評論 4 3