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);

        }
    }
}




  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龙潭一条鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值