第二十七講:Android之Animation(二)

來源:互聯網
上載者:User

標籤:android   style   blog   http   io   color   ar   使用   java   

勿以惡小而為之,勿以善小而不為。惟賢惟德,能服於人。—— 劉  備


本講內容:Animation 動畫 


一、Interpolator 插值器 (定義動畫變化的速率)         我們也可以自訂的插值器

Interpolator對象 資源ID 功能作用
AccelerateDecelerateInterpolator @android:anim/accelerate_decelerate_interpolator 先加速再減速
AccelerateInterpolator @android:anim/accelerate_interpolator 加速
AnticipateInterpolator @android:anim/anticipate_interpolator 先回退一小步然後加速前進
AnticipateOvershootInterpolator @android:anim/anticipate_overshoot_interpolator 在上一個基礎上超出終點一小步再回到終點
BounceInterpolator @android:anim/bounce_interpolator 最後階段彈球效果
CycleInterpolator @android:anim/cycle_interpolator 周期運動
DecelerateInterpolator @android:anim/decelerate_interpolator 減速
LinearInterpolator @android:anim/linear_interpolator 勻速
OvershootInterpolator @android:anim/overshoot_interpolator 速到達終點並超出一小步最後回到終點


二、上一講我們用編碼實現動畫效果,本講將以XML形式定義動畫

我們通過一個例子感受一下,代碼的講解都寫在注釋裡了

下面是res/layout/activity_main.xml 布局檔案:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical"    tools:context="com.example.text.MainActivity$PlaceholderFragment" > <ImageView         android:id="@+id/image"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_gravity="center"        android:src="@drawable/c1"        android:layout_weight="1"/>   <Button        android:id="@+id/translate"        android:layout_width="match_parent"   android:layout_height="wrap_content"   android:text="測試translate動畫效果" />   <Button        android:id="@+id/alpha"        android:layout_width="match_parent"   android:layout_height="wrap_content"   android:text="測試alpha動畫效果" />   <Button        android:id="@+id/rotate"        android:layout_width="match_parent"   android:layout_height="wrap_content"   android:text="測試rotate動畫效果" />   <Button        android:id="@+id/scale"        android:layout_width="match_parent"   android:layout_height="wrap_content"   android:text="測試scale動畫效果" />    </LinearLayout>

在res檔案下建立一個檔案名稱為anim

下面是建立res/anim/alpha.xml檔案:

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"android:interpolator="@android:anim/accelerate_interpolator"><scale android:fromXScale="1.0" android:toXScale="0.0"android:fromYScale="1.0" android:toYScale="0.0" android:pivotX="50%"android:pivotY="50%" android:duration="2000" /></set>

android:interpolator="@android:anim/accelerate_interpolator"   <span style="font-family: Arial; font-size: 14px; line-height: 26px;">定義一個加速插值器</span>


下面是建立res/anim/rotate.xml檔案:

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"android:interpolator="@android:anim/accelerate_interpolator"><rotate android:fromDegrees="0"android:toDegrees="-360"android:pivotX="50%"android:pivotY="50%"android:duration="5000" /></set>

下面是建立res/anim/scale.xml檔案:

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"android:interpolator="@android:anim/accelerate_interpolator"><scale android:fromXScale="1.0" android:toXScale="0.0"android:fromYScale="1.0" android:toYScale="0.0" android:pivotX="50%"android:pivotY="50%" android:duration="2000" /></set>

下面是建立res/anim/translate.xml檔案:

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"android:interpolator="@android:anim/accelerate_interpolator"><translate android:fromXDelta="50%" android:toXDelta="100%" android:fromYDelta="0%" android:toYDelta="100%" android:duration="2000" /></set>

下面是MainActivity.java主介面檔案:

public class MainActivity extends Activity implements OnClickListener {private Button translate;private Button alpha;private Button rotate;private Button scale;private ImageView image;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);image = (ImageView) findViewById(R.id.image);translate = (Button) findViewById(R.id.translate);alpha = (Button) findViewById(R.id.alpha);rotate = (Button) findViewById(R.id.rotate);scale = (Button) findViewById(R.id.scale);translate.setOnClickListener(this);alpha.setOnClickListener(this);rotate.setOnClickListener(this);scale.setOnClickListener(this);}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.translate:// 使用AnimationUtils裝載動畫設定檔案Animation anim1 = (Animation) AnimationUtils.loadAnimation(MainActivity.this, R.anim.translate);image.startAnimation(anim1);break;case R.id.alpha:Animation anim2 = AnimationUtils.loadAnimation(MainActivity.this,R.anim.alpha);image.startAnimation(anim2);break;case R.id.rotate:Animation anim3 = AnimationUtils.loadAnimation(MainActivity.this,R.anim.rotate);image.startAnimation(anim3);break;case R.id.scale:Animation anim4 = AnimationUtils.loadAnimation(MainActivity.this,R.anim.scale);image.startAnimation(anim4);break;}}}

下面是運行結果:



本講到這裡,謝謝大家!

第二十七講:Android之Animation(二)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.