Android属性动画卡,Android Property Animation属性动画初识:位移translation(3)

本文详细介绍了在Android Property Animation中如何实现水平和垂直位移的属性动画。通过示例代码展示了如何使用ObjectAnimator进行动画设置,包括向右移动并复原的动画效果,并添加了动画更新监听器来跟踪动画的进度。文章旨在帮助开发者更好地理解和应用Android的属性动画系统。
摘要由CSDN通过智能技术生成



Android Property Animation属性动画初识:位移translation(3)

和附录的文章1,2相仿,本文介绍常见的位移动画(水平位移或垂直位移)在Android Property Animation属性动画中如何实现。

package zhangphil.anim;

import android.animation.ObjectAnimator;

import android.animation.ValueAnimator;

import android.animation.ValueAnimator.AnimatorUpdateListener;

import android.app.Activity;

import android.os.Bundle;

import android.util.Log;

import android.view.Menu;

import android.view.MenuItem;

import android.widget.TextView;

public class MainActivity extends Activity {

private TextView text;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

text = (TextView) findViewById(R.id.text);

}

// 动画实际执行

private void startPropertyAnim() {

// X轴方向上的坐标

float translationX = text.getTranslationX();

// 向右移动500pix,然后再移动到原来的位置复原。

// 参数“translationX”指明在x坐标轴位移,即水平位移。

ObjectAnimator anim = ObjectAnimator.ofFloat(text, "translationX", translationX, -500f, translationX);

anim.setDuration(5000);

// 回调监听,可以有也可以无。

// 根据情况,如果需要监听动画执行到何种“进度”,那么就监听之。

anim.addUpdateListener(new AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

float value = (Float) animation.getAnimatedValue();

Log.d("zhangphil", value + "");

}

});

// 正式开始启动执行动画

anim.start();

}

@Override

public boolean onOptionsItemSelected(MenuItem item) {

int id = item.getItemId();

if (id == R.id.action_anim) {

// 此处正式启动属性动画

startPropertyAnim();

return true;

}

return super.onOptionsItemSelected(item);

}

@Override

public boolean onCreateOptionsMenu(Menu menu) {

getMenuInflater().inflate(R.menu.main, menu);

return true;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值