色yeye在线视频观看_亚洲人亚洲精品成人网站_一级毛片免费播放_91精品一区二区中文字幕_一区二区三区日本视频_成人性生交大免费看

當前位置:首頁 > 嵌入式培訓 > 嵌入式學習 > 講師博文 > Android動畫

Android動畫 時間:2018-09-26      來源:未知

補間動畫(Tween Animation)

補間動畫有以下四種

Alpha透明度動畫

Scale尺寸縮放動畫

Translate位置移動動畫

Rotate旋轉動畫

補間動畫的共同屬性

Duration:動畫持續時間(單位:毫秒)

fillAfter:設置為true,動畫轉化在動畫結束后被應用

interpolator:動畫插入器(加速、減速插入器)

repeatCount:動畫重復次數

repeatMode:順序重復/倒序重復

startOffset:動畫之間的時間間隔(應用于組合動畫)

動畫實現方式

配置文件(/res/anim)——alpha、scale、translate、rotate (更簡單)

Java代碼實現——AlphaAnimation、ScaleAnimation、TranslateAnimation、RotateAnimation

(更靈活)

例如

用Java代碼去創建

//創建Alpha動畫(透明度為10%-100%)

Animation alpha = new AlphaAnimation(0.1f,1.0f);

//設置動畫時間為5秒

alpha.setDuration(5000);

//開始播放

img.startAnimation(alpha);

加載配置文件

Animation scale = AnimationUtils.loadAnimation(context, R.anim.scale_anim);

//開始動畫

img.startAnimation(scale);

AlphaAnimation

fromAlpha動畫起始時的透明度 (1.0表示完全不透明)

toAlpha動畫終止時的透明度 (0.0表示完全透明)

ScaleAnimation

fromX,toX分別是起始和結束時x坐標上的伸縮尺寸

fromY,toY分別是起始和結束時y坐標上的伸縮尺寸

pivotX,pivotY分別為伸縮動畫相對于x,y軸開始位置

Translate

fromXDelta,fromYDelta分別是起始的X,Y的坐標

toXDelta,toYDelta分別是結束時X,Y的坐標

RotateAnimation

fromDegrees

toDegrees

pivotX,pivotY分別為旋轉動畫相對于x,y的坐標開始位置

動畫監聽器

AnimationListener

幀動畫(Frame Animation)

概念

逐幀動畫是一種常見的動畫形式(Frame By Frame),其原理是在“連續的關鍵幀”中分解動畫動作,也就是在時間軸的每幀上逐幀繪制不同的內容,使其連續播放而成動畫。

幀動畫實現

使用加載配置文件

將圖片資源拷貝到drawable資源目錄中

在drawable目錄中創建幀動畫配置文件,在該文件中配置動畫所需圖片,以及每個圖片停留時間。

<animation-list xmlns:android="//schemas.android.com/apk/res/android" >

<item

android:drawable="幀圖片的資源id"

android:duration="播放該幀的時間"/>

<><item

android:drawable="幀圖片的資源id"

android:duration="播放該幀的時間"/>

</animation-list>

//載入xml逐幀動畫資源

imageView.setImageResource(R.drawable.btn_animation);

aniDrawable = (AnimationDrawable) imageView.getDrawable();

//播放動畫

aniDrawable.setOneShot(true);

aniDrawable.start();

//停止動畫

//aniDrawable.stop();

//檢查動畫是否正在播放

//aniDrawable.isRunning();

使用Java代碼創建

//創建動畫對象

AnimationDrawable aniDrawable = new AnimationDrawable();

//設置每一幀的幀圖片,每一幀播放時間

aniDrawable.addFrame(this.getResources().getDrawable(R.drawable.inc_btn_emphasize_normal), 100);

aniDrawable.addFrame(this.getResources().getDrawable(R.drawable.inc_btn_emphasize_pressed), 100);

aniDrawable.addFrame(this.getResources().getDrawable(R.drawable.inc_btn_normal), 100);

aniDrawable.addFrame(this.getResources().getDrawable(R.drawable.inc_btn_pressed), 100);

imageView.setImageDrawable(aniDrawable);

練習

制作不會說話的湯姆貓

屬性動畫(Property Animation)

概念

andorid3.0引入。屬性動畫改變對象的一個field值實現動畫。指定你想要的屬性,多長時間,動畫的值就可以實現了。

Animation的局限性

一個屬性動畫的實現

//參數:

//動畫作用目標

//屬性

//屬性值

ObjectAnimator animator = ObjectAnimator.ofFloat(iv, "translationX", 0, 100);

animator.setDuration(2000);

animator.start();

Animation動畫框架僅僅只是讓圖像發生位移,而監聽事件依然在原地。而屬性動畫可以移動讓監聽事件也跟著移動。

多個屬性動畫實現01

PropertyValuesHolder p01 = PropertyValuesHolder.ofFloat("translationX", 0, 100);

PropertyValuesHolder p02 = PropertyValuesHolder.ofFloat("translationY", 0, 100);

PropertyValuesHolder p03 = PropertyValuesHolder.ofFloat("rotation", 0, 360);

ObjectAnimator animator = ObjectAnimator.ofPropertyValuesHolder(iv, p01, p02, p03);

animator.setDuration(2000);

animator.start();

多個屬性動畫實現02

ObjectAnimator oa01 = ObjectAnimator.ofFloat(iv, "translationX", 0, 50);

ObjectAnimator oa02 = ObjectAnimator.ofFloat(iv, "translationY", 0, 50);

ObjectAnimator oa03 = ObjectAnimator.ofFloat(iv, "rotation", 0, 360);

AnimatorSet set = new AnimatorSet();

//同時播放

//set.playTogether(oa01, oa02, oa03);

//按順序播放(先播01,再播02,后播03)

//set.playSequentially(oa01, oa02, oa03);

//按指定順序播放 (01和02同時播放,后播放03)

set.play(oa01).with(oa02);

set.play(oa03).after(oa01);

set.setDuration(1000);

set.start();

動畫監聽事件

透明度屬性動畫

ObjectAnimator animator = ObjectAnimator.ofFloat(v, "alpha", 0, 1);

animator.setDuration(1000);

//添加屬性動畫的監聽

animator.addListener(new AnimatorListener() {

@Override

public void onAnimationStart(Animator animation) {

// TODO Auto-generated method stub

}

@Override

public void onAnimationRepeat(Animator animation) {

// TODO Auto-generated method stub

}

//動畫結束之后調用該方法

@Override

public void onAnimationEnd(Animator animation) {

// TODO Auto-generated method stub

Toast.makeText(MainActivity.this, "click", Toast.LENGTH_SHORT).show();

}

@Override

public void onAnimationCancel(Animator animation) {

// TODO Auto-generated method stub

}

});

animator.start();

使用ValueAnimator改變文字顏色

ValueAnimator valueAni = ValueAnimator.ofInt(0, 255);

valueAni.setDuration(2000);

valueAni.addUpdateListener(new AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

// TODO Auto-generated method stub

tv.setTextColor(Color.rgb((Integer)animation.getAnimatedValue(), 0, 0));

}

});

valueAni.start();

上一篇:DOM 元素尺寸與位置

下一篇:交叉編譯器解析

熱點文章推薦
華清學員就業榜單
高薪學員經驗分享
熱點新聞推薦
前臺專線:010-82525158 企業培訓洽談專線:010-82525379 院校合作洽談專線:010-82525379 Copyright © 2004-2022 北京華清遠見科技集團有限公司 版權所有 ,京ICP備16055225號-5京公海網安備11010802025203號

回到頂部

主站蜘蛛池模板: 国内美女人妻一级毛片免费看 | 亚洲AV乱码专区国产乱码 | 中文日产幕无线码一二 | 强奷漂亮人妻系列老师 | 蜜芽国产尤物AV尤物在线看 | 国产精品人成视频免费播放 | 中国chinese4p交换video | 四虎影院在线免费播放 | 国产精品无码人妻系列AV | 国产青青在线 | 欧美精品一区二区三区制服首页 | XX性欧美肥妇精品久久久久久 | 亚洲精品无码成人a片 | 小荡货腿张开给我cao免费视频 | 日本欧美精品 | 亚洲AV成人午夜福利在线观看 | 国产精品123 | 最新av网站在线观看 | 大波大乳video | 欧美巨大xxxxbbb| 8x成人网| 国产成人无码18禁午夜福利网址 | 日本护士野外奶水HD | 丰满少妇做爰视频爽爽和 | 亚洲综合无码一区二区三区 | 国产精品a免费一区久久网址 | 波多野结衣AV手机在线观看 | 国产亚洲欧美日韩精品一区二区 | 永久免费精品精品永久-夜色 | 免费黄毛片 | 欧美成人秋霞久久AA片 | 在线观看免费一区 | 麻豆一区二区三区在线观看 | jizzjizzjizzjizz日本老师 | 凸凹隐藏撒尿xxxx偷拍 | 国产区在线视频 | 内射一区二区精品视频在线观看 | 中文字幕婷婷日韩欧美亚洲 | 久久久无码精品无码国产人妻丝瓜 | 奇米四色影院 | 国产免费观看AV大片的网站 |