ImageView自动来回循环移动,用到Animation

324 查看

我这个移动是只在手机屏幕的最上方移动,需要更改的可以更改。

随着学习,经验是增加了,但是还是很缺少经验,我分享这个代码只是更大家分享小小的成果,顺便永久性保存这个代码,以后用到的时候可以拿来就用,需要改正也是很方便的,毕竟自己动脑子写的,每一步的功能都理解的很清楚。

package com.example.yidong3;

import android.app.Activity;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.Menu;
import android.view.animation.AnimationSet;
import android.view.animation.TranslateAnimation;
import android.widget.ImageView;

public class MainActivity extends Activity {

private ImageView im;
private int ScreenWidth;
private int ScreenHeight;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

                    /*获取屏幕宽高*/
    DisplayMetrics  dm = new DisplayMetrics();      

    getWindowManager().getDefaultDisplay().getMetrics(dm);      

    ScreenWidth = dm.widthPixels;                

    ScreenHeight = dm.heightPixels;  

    im = (ImageView) findViewById(R.id.imageView1);

            Animation();

}

private void Animation() {
    // TODO Auto-generated method stub

    // TODO Auto-generated method stub
    AnimationSet animationSet = new AnimationSet(true);

    TranslateAnimation translateAnimation = new TranslateAnimation(
            // X轴的开始位置
            android.view.animation.Animation.RELATIVE_TO_SELF, -1f,
            // X轴的结束位置
            android.view.animation.Animation.RELATIVE_TO_SELF, ScreenWidth/80,
            // Y轴的开始位置
            android.view.animation.Animation.RELATIVE_TO_SELF, 0f,
            // Y轴的结束位置
            android.view.animation.Animation.RELATIVE_TO_SELF, 0f);
    translateAnimation.setDuration(1000);
    translateAnimation.setRepeatCount(20);  //  设置动画重复次数

    translateAnimation.setRepeatMode(android.view.animation.Animation.REVERSE);
    //translateAnimation.setRepeatMode(Animation.RESTART);    //重新从头执行  
    //translateAnimation.setRepeatMode(Animation.REVERSE);  //反方向执行  

    animationSet.addAnimation(translateAnimation);
    im.setAnimation(animationSet);

}

}