揭露動畫(Reveal Effect)實現(xiàn)時的注意事項(附上bug-logcat)

Debug完成圖:

Debug完成圖

昨天晚上開始學(xué)一下這個揭露動畫灿椅,準(zhǔn)備用在項目中做一個轉(zhuǎn)場钞支,啃完了API之后開始寫個小demo烁挟,距離跑成功一步之遙的當(dāng)兒撼嗓,出了個bug静稻,就怎么點擊按鈕都沒用振湾。

首先上bug圖:

bug:怎么點擊按鈕都沒用押搪,每點擊一次都會出現(xiàn)下面的報錯(2040):

11-07 19:20:49.665 2454-2454/? I/Finsky: [1] com.google.android.finsky.services.j.a(149): Installation state replication succeeded.
11-07 19:20:49.711 7448-7448/? E/hei: 2040
11-07 19:20:49.718 1350-1371/? W/audio_hw_generic: Not supplying enough data to HAL, expected position 5613338 , only wrote 5613120
11-07 19:20:50.376 7448-7448/? E/hei: 2040
11-07 19:20:50.992 7448-7448/? E/hei: 2040
11-07 19:20:51.591 7448-7448/? E/hei: 2040
11-07 19:20:54.790 1350-1372/? W/audio_hw_generic: Not supplying enough data to HAL, expected position 6098164 , only wrote 5856480
11-07 19:20:58.322 7448-7448/? E/hei: 2040
11-07 19:20:58.328 1350-1371/? W/audio_hw_generic: Not supplying enough data to HAL, expected position 5856667 , only wrote 5856480
11-07 19:21:01.540 1350-1372/? W/audio_hw_generic: Not supplying enough data to HAL, expected position 6162708 , only wrote 6010560

activity.java全文:

package com.lwp.justtest;

import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewAnimationUtils;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    boolean flag = false;
    FloatingActionButton fab;
    private View mPuppet;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mPuppet = findViewById(R.id.view_puppet);
        fab = (FloatingActionButton)findViewById(R.id.fab);
        fab.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        doRevealAnimation();
    }

    private void doRevealAnimation() {
        int[] vLocation = new int[2];
        fab.getLocationInWindow(vLocation);
        int centerX = vLocation[0] + fab.getMeasuredWidth() / 2;
        int centerY = vLocation[1] + fab.getMeasuredHeight() / 2;

        int height = mPuppet.getHeight();
        int width = mPuppet.getWidth();
        int maxRradius = (int) Math.hypot(height, width);
        Log.e("hei", maxRradius + "");

        if (flag) {
            Animator animator = ViewAnimationUtils.createCircularReveal(mPuppet, centerX, centerY, maxRradius, 0);
            animator.setDuration(1000);
            animator.addListener(new AnimatorListenerAdapter() {
                @Override
                public void onAnimationEnd(Animator animation) {
                    super.onAnimationEnd(animation);
                    mPuppet.setVisibility(View.GONE);
                }
            });
            animator.start();
            flag = false;
        } else {
            Animator animator = ViewAnimationUtils.createCircularReveal(mPuppet, centerX, centerY, 0, maxRradius);
            animator.setDuration(1000);
            animator.addListener(new Animator.AnimatorListener() {
                @Override
                public void onAnimationStart(Animator animation) {
                    mPuppet.setVisibility(View.VISIBLE);
                }

                @Override
                public void onAnimationEnd(Animator animation) {
                }

                @Override
                public void onAnimationCancel(Animator animation) {

                }

                @Override
                public void onAnimationRepeat(Animator animation) {

                }
            });
            animator.start();
            flag = true;
        }
    }

}

layout.xml全文:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.lwp.justtest.MainActivity">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        android:layout_gravity="center"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <View
        android:id="@+id/view_puppet"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|end"
        android:layout_margin="16dp"
        android:backgroundTint="@color/colorPrimary"
        android:src="@drawable/map"
        app:pressedTranslationZ="10dp" />

</FrameLayout>

觀眾朋友們滥朱,這個看出毛病了嗎徙邻。

我想了一下缰犁,額帅容,會不會我的View沒有設(shè)置顏色啊。遣钳。好的試了一下耍贾,果然是荐开,可以說是很鬼畜了。百侧。

layout.xml里邊的View控件改成下面這樣子能扒,再次運行程序就成了(發(fā)現(xiàn)2040還是會報錯初斑,但是動畫算是完美跑出來了见秤,所以小伙伴們這里記得設(shè)置android:background以及android:visibility噢):

    <View
        android:id="@+id/view_puppet"
        android:background="@color/colorPrimaryDark"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:visibility="gone"/>

效果圖如下:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末乎澄,一起剝皮案震驚了整個濱河市置济,隨后出現(xiàn)的幾起案子浙于,更是在濱河造成了極大的恐慌查库,老刑警劉巖樊销,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異撤师,居然都是意外死亡剃盾,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來意鲸,“玉大人怎顾,你說我怎么就攤上這事槐雾∧记浚” “怎么了钻注?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵杏死,是天一觀的道長捆交。 經(jīng)常有香客問我品追,道長肉瓦,這世上最難降的妖魔是什么泞莉? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任斯嚎,我火速辦了婚禮堡僻,結(jié)果婚禮上钉疫,老公的妹妹穿的比我還像新娘陌选。我一直安慰自己咨油,他們只是感情好役电,可當(dāng)我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著窝剖,像睡著了一般赐纱。 火紅的嫁衣襯著肌膚如雪疙描。 梳的紋絲不亂的頭發(fā)上起胰,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死谱仪,一個胖子當(dāng)著我的面吹牛疯攒,可吹牛的內(nèi)容都是我干的敬尺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼袁串,長吁一口氣:“原來是場噩夢啊……” “哼囱修!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤瓶佳,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鳞青,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體霸饲,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年臂拓,在試婚紗的時候發(fā)現(xiàn)自己被綠了厚脉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡胶惰,死狀恐怖傻工,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤中捆,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布鸯匹,位于F島的核電站,受9級特大地震影響泄伪,放射性物質(zhì)發(fā)生泄漏殴蓬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一蟋滴、第九天 我趴在偏房一處隱蔽的房頂上張望染厅。 院中可真熱鬧,春花似錦津函、人聲如沸肖粮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽尿赚。三九已至,卻和暖如春蕉堰,著一層夾襖步出監(jiān)牢的瞬間凌净,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工屋讶, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留冰寻,地道東北人。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓皿渗,卻偏偏與公主長得像斩芭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子乐疆,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,077評論 2 355

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,185評論 25 707
  • 用兩張圖告訴你划乖,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料? 從這篇文章中你...
    hw1212閱讀 12,732評論 2 59
  • 朋友A君迷殿,這十來年一直在搞紙的批發(fā),到市里到縣城到鎮(zhèn)上各個百貨銷售點鋪貨送貨咖杂,現(xiàn)在生意越做越大庆寺,雖然現(xiàn)在有互聯(lián)網(wǎng)的...
    后者居士閱讀 478評論 3 7
  • 鼓勵失敗,失敗是成功之母诉字,敢于承認失敗懦尝。失敗也何嘗不是一件好事知纷。
    kyle房成閱讀 91評論 0 0