Android實(shí)現(xiàn)創(chuàng)意LoadingView動(dòng)畫(huà)效果
Android上的熱火鍋煮蘿卜蔬菜的Loading動(dòng)畫(huà)效果。 這是一個(gè)鍋煮蘿卜的Loading動(dòng)畫(huà),效果仿照自之前IOS上看到的一個(gè)效果,覺(jué)得挺有意思,就移植過(guò)來(lái)了,在此完成了Dialog的樣式,方便使用者作為L(zhǎng)oadingView去使用。
關(guān)鍵性代碼:
package yellow5a5.demo.boilingloadingview.View;
import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.animation.ValueAnimator;
import android.content.Context;
import android.graphics.drawable.ClipDrawable;
import android.os.Handler;
import android.os.Message;
import android.util.AttributeSet;
import android.util.TypedValue;
import android.view.LayoutInflater;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import java.util.Timer;
import java.util.TimerTask;
import yellow5a5.demo.boilingloadingview.R;
/**
* Created by Weiwu on 16/1/2.
*/
public class BoilingPanView extends RelativeLayout {
private View mView;
private ClipDrawable mWaterDrawable;
private WaterView mWaterView;
private FlameView mFlameView;
private View mPea1;
private View mPea2;
private ImageView mPotato;
private ImageView mCarrot;
private ImageView mCoverView;
private Animation mLeftInAnim;
private Animation mRightInAnim;
private boolean isRightRotate = true;
private ValueAnimator mCoverAnim;
private BoilingAnimListener mBoilingAnimListener;
public interface BoilingAnimListener {
//初始動(dòng)畫(huà)結(jié)束監(jiān)聽(tīng)
void onFirstAnimEnd();
}
public void setBoilingAnimListener(BoilingAnimListener l) {
this.mBoilingAnimListener = l;
}
private Handler mHandle = new Handler(new Handler.Callback() {
@Override
public boolean handleMessage(Message msg) {
if (msg.what == 0X0000) {
mWaterDrawable.setLevel(mWaterDrawable.getLevel() + 800);
}
return false;
}
});
public BoilingPanView(Context context) {
this(context, null);
}
public BoilingPanView(Context context, AttributeSet attrs) {
this(context, attrs, 0);
}
public BoilingPanView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
mView = LayoutInflater.from(context).inflate(R.layout.boiling_pan, this, true);
initView();
initStartAnim();
initCoverAnim();
}
private void initView() {
mWaterView = (WaterView) mView.findViewById(R.id.img_water);
mFlameView = (FlameView) mView.findViewById(R.id.flame);
mCoverView = (ImageView) mView.findViewById(R.id.img_cover);
mPea1 = mView.findViewById(R.id.img_pea1);
mPea2 = mView.findViewById(R.id.img_pea2);
mPotato = (ImageView) mView.findViewById(R.id.img_potato);
mCarrot = (ImageView) mView.findViewById(R.id.img_carrot);
mWaterDrawable = (ClipDrawable) mWaterView.getDrawable();
}
private void initStartAnim() {
mLeftInAnim = AnimationUtils.loadAnimation(getContext(), R.anim.left_in_anim);
mRightInAnim = AnimationUtils.loadAnimation(getContext(), R.anim.right_in_anim);
}
/*
抖動(dòng)的蓋子
*/
private void initCoverAnim() {
mCoverAnim = ValueAnimator.ofFloat(0f, 1f, 0f).setDuration(800);
mCoverAnim.setRepeatMode(Animation.REVERSE);
mCoverAnim.setRepeatCount(-1);
mCoverAnim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
float value = (float) animation.getAnimatedValue();
if (isRightRotate) {
mCoverView.setRotation(value * 5);
} else {
mCoverView.setRotation(-value * 5);
}
mCoverView.setTranslationY(-value * TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 5, getResources().getDisplayMetrics()));
}
});
mCoverAnim.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationRepeat(Animator animation) {
super.onAnimationRepeat(animation);
isRightRotate = !isRightRotate;
}
});
}
/*
開(kāi)始啟動(dòng)的動(dòng)畫(huà)
*/
public void beginFirstInAnim() {
mPea1.setVisibility(VISIBLE);
mPea2.setVisibility(VISIBLE);
mPotato.setVisibility(VISIBLE);
mCarrot.setVisibility(VISIBLE);
mCoverView.setVisibility(VISIBLE);
mPea1.startAnimation(mLeftInAnim);
mPea2.startAnimation(mLeftInAnim);
mPotato.startAnimation(mLeftInAnim);
mCarrot.startAnimation(mRightInAnim);
mCoverView.startAnimation(mRightInAnim);
mRightInAnim.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
if (mBoilingAnimListener != null) {
//這里是為了給外部留有操作的空間
mBoilingAnimListener.onFirstAnimEnd();
} else {
beginBoilingAnim();
}
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
}
/*
開(kāi)始加水燃火動(dòng)畫(huà)
*/
public void beginBoilingAnim() {
final Timer timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
mHandle.sendEmptyMessage(0X0000);
if (mWaterDrawable.getLevel() >= 10000) {
timer.cancel();
}
}
}, 0, 50);
mFlameView.startFlaming();
mCoverAnim.start();
}
/*
重置動(dòng)畫(huà)
*/
public void resetAnim() {
mWaterDrawable.setLevel(0);
mWaterView.resetBubbleAnim();
mFlameView.stopFlaming();
mPea1.setVisibility(INVISIBLE);
mPea2.setVisibility(INVISIBLE);
mPotato.setVisibility(INVISIBLE);
mCarrot.setVisibility(INVISIBLE);
mCoverView.setVisibility(INVISIBLE);
}
}
希望本文所述對(duì)大家學(xué)習(xí)Android軟件編程有所幫助。
相關(guān)文章
在Android中使用SQLite數(shù)據(jù)庫(kù)及其操作詳解
在?Android?開(kāi)發(fā)中,使用?SQLite?數(shù)據(jù)庫(kù)是一種常見(jiàn)的持久化數(shù)據(jù)存儲(chǔ)方式,本文將通過(guò)代碼示例詳細(xì)講解如何在?Android?中創(chuàng)建數(shù)據(jù)庫(kù)表、插入數(shù)據(jù)、執(zhí)行查詢操作以及驗(yàn)證查詢結(jié)果,需要的朋友可以參考下2024-08-08
使用Composing?builds提升Android編譯速度
這篇文章主要介紹了使用Composing?builds提升Android編譯速度示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Android 監(jiān)聽(tīng)?wèi)?yīng)用前/后臺(tái)切換實(shí)例代碼
本篇文章主要介紹了Android 監(jiān)聽(tīng)?wèi)?yīng)用前/后臺(tái)切換實(shí)例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
Android基于OkHttpUtils網(wǎng)絡(luò)請(qǐng)求的二次封裝
這篇文章主要介紹了Android基于OkHttpUtils網(wǎng)絡(luò)請(qǐng)求的二次封裝,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
Android中okhttp3.4.1+retrofit2.1.0實(shí)現(xiàn)離線緩存
這篇文章主要介紹了Android中okhttp3.4.1結(jié)合retrofit2.1.0實(shí)現(xiàn)離線緩存,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
Kotlin中內(nèi)置函數(shù)的用法和區(qū)別總結(jié)
眾所周知相比Java, Kotlin提供了不少高級(jí)語(yǔ)法特性。對(duì)于一個(gè)Kotlin的初學(xué)者來(lái)說(shuō)經(jīng)常會(huì)寫(xiě)出一些不夠優(yōu)雅的代碼。下面這篇文章主要給大家介紹了關(guān)于Kotlin中內(nèi)置函數(shù)的用法和區(qū)別的相關(guān)資料,需要的朋友可以參考下2018-06-06

