Android

关注公众号 jb51net

关闭
首页 > 软件编程 > Android > Animation之TranslateAnimation

Android Animation之TranslateAnimation(平移动画)

作者:长彬

这篇文章主要为大家详细介绍了Animation之TranslateAnimation平移动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

TranslateAnimation(平移动画)的意思无非就是一张图片或其他从一个位置到达另外一个位置。直接代码分析,相关重要属性参数解释都在代码中。

1、首先编写main.xml文件。

<RelativeLayout 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:paddingLeft="@dimen/activity_horizontal_margin" 
  android:paddingRight="@dimen/activity_horizontal_margin" 
  android:paddingTop="@dimen/activity_vertical_margin" 
  android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity"> 

  <ImageView 
    android:id="@+id/image" 
    android:text="@string/hello_world" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:src="@drawable/car_one1"/> 

</RelativeLayout> 

2、接下来编写MainActivity.java文件。

package com.example.dell.bitmapproject; 

import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 
import android.view.animation.Animation; 
import android.view.animation.AnimationSet; 
import android.view.animation.TranslateAnimation; 
import android.widget.ImageView; 

public class MainActivity extends AppCompatActivity { 
  private ImageView image; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    image =(ImageView)findViewById(R.id.image); 
    image.setOnClickListener(new OnClickListenerImpl()); 
  } 
  private class OnClickListenerImpl implements View.OnClickListener { 
    @Override 
    public void onClick(View v) { 
      /* 
        AnimationSet相当于一个动画的集合,true表示使用Animation的interpolator 
        false则是使用自己的。 
        Interpolator 被用来修饰动画效果,定义动画的变化率,可以使存在的动画效果 
        accelerated(加速),decelerated(减速),repeated(重复),bounced(弹跳)等。 
       */ 

      AnimationSet animationSet = new AnimationSet(true); 
      /* 
          Animation还有几个方法 
          setFillAfter(boolean fillAfter) 
          如果fillAfter的值为真的话,动画结束后,控件停留在执行后的状态 
          setFillBefore(boolean fillBefore) 
          如果fillBefore的值为真的话,动画结束后,控件停留在动画开始的状态 
          setStartOffset(long startOffset) 
          设置动画控件执行动画之前等待的时间 
          setRepeatCount(int repeatCount) 
          设置动画重复执行的次数 
       */ 
      TranslateAnimation translateAnimation = new TranslateAnimation( 
          //X轴初始位置 
          Animation.RELATIVE_TO_SELF, 0.0f, 
          //X轴移动的结束位置 
          Animation.RELATIVE_TO_SELF,0.5f, 
          //y轴开始位置 
          Animation.RELATIVE_TO_SELF,0.0f, 
          //y轴移动后的结束位置 
          Animation.RELATIVE_TO_SELF,1.5f); 

      //3秒完成动画 
      translateAnimation.setDuration(2000); 
      //如果fillAfter的值为真的话,动画结束后,控件停留在执行后的状态 
      animationSet.setFillAfter(true); 
      //将AlphaAnimation这个已经设置好的动画添加到 AnimationSet中 
      animationSet.addAnimation(translateAnimation); 
      //启动动画 
      MainActivity.this.image.startAnimation(animationSet); 

    } 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文