700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Android开发--图形图像与动画(三)--Animation效果的XML实现

Android开发--图形图像与动画(三)--Animation效果的XML实现

时间:2022-03-14 19:10:13

相关推荐

Android开发--图形图像与动画(三)--Animation效果的XML实现

使用XML来定义Tween Animation

动画的XML文件在工程中res/anim目录,这个文件必须包含一个根元素,可以使<alpha><scale> <translate> <rotate>插值元素或者是把上面的元素都放入<set>元素组中,默认情况下,所以的动画指令都是同时发生的,为了让他们按序列发生,需要设置一个特殊的属性startOffset。动画的指令定义了你想要发生什么样的转换,当他们发生了,应该执行多长时间,转换可以是连续的也可以使同时的。例如,你让文本内容从左边移动到右边,然后旋转180度,或者在移动的过程中同时旋转,没个转换需要设置一些特殊的参数(开始和结束的大小尺寸的大小变化,开始和结束的旋转角度等等,也可以设置些基本的参数(例如,开始时间与周期),如果让几个转换同时发生,可以给它们设置相同的开始时间,如果按序列的话,计算开始时间加上其周期。

Tween Animation共同的节点属性

下面给出一个完整的XML定义(SDK提供)

<set android:shareInterpolator="false" xmlns:android="/apk/res/android"><scaleandroid:interpolator="@android:anim/accelerate_decelerate_interpolator"android:fromXScale="1.0"android:toXScale="1.4"android:fromYScale="1.0"android:toYScale="0.6"android:pivotX="50%"android:pivotY="50%"android:fillAfter="false"android:duration="700" /><set android:interpolator="@android:anim/decelerate_interpolator"><scaleandroid:fromXScale="1.4" android:toXScale="0.0"android:fromYScale="0.6"android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%" android:startOffset="700"android:duration="400" android:fillBefore="false" /><rotate android:fromDegrees="0" android:toDegrees="-45"android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%"android:startOffset="700"android:duration="400" /></set></set>

一下是实现的一个实例的截图:

所用到的xml文件如下:1.alpha

<set xmlns:android="/apk/res/android"> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:startOffset="500"android:duration="2000" /> </set>

2.rotate

<set xmlns:android="/apk/res/android"> <rotate android:interpolator="@android:anim/accelerate_decelerate_interpolator" android:fromDegrees="0" android:toDegrees="360" android:pivotX="50%" android:pivotY="50%" android:duration="2000" /> </set>

3.scale

<set xmlns:android="/apk/res/android"> <scale android:interpolator="@android:anim/accelerate_decelerate_interpolator" android:fromXScale="0.0" android:toXScale="1.0" android:fromYScale="0.0" android:toYScale="1.0" android:pivotX="50%" android:pivotY="50%" android:fillAfter="false" android:duration="2000" /></set>

4.translate

<set xmlns:android="/apk/res/android"> <translate android:fromXDelta="10" android:toXDelta="100" android:fromYDelta="10" android:toYDelta="100"android:duration="2000" /> </set>

具体的实现源代码如下:

public class Animation_XML_Activity extends Activity {private Button button1;private Button button2;private Button button3;private Button button4;private ImageView imageView;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_animation__xml_);button1=(Button)findViewById(R.id.button_alpha);button2=(Button)findViewById(R.id.button_rotate);button3=(Button)findViewById(R.id.button_scale);button4=(Button)findViewById(R.id.button_translate);imageView=(ImageView)findViewById(R.id.imageview);button1.setOnClickListener(new MyButton());button2.setOnClickListener(new MyButton());button3.setOnClickListener(new MyButton());button4.setOnClickListener(new MyButton());}class MyButton implements OnClickListener{@Overridepublic void onClick(View v) {// TODO Auto-generated method stubswitch (v.getId()) {case R.id.button_alpha:Alpha();break;case R.id.button_rotate:Rotate();break;case R.id.button_scale:Scale();break;case R.id.button_translate:Translate();break;default:break;}}}public void Alpha() {Animation animation=AnimationUtils.loadAnimation(Animation_XML_Activity.this, R.anim.alpha);imageView.startAnimation(animation);}public void Rotate() {Animation animation=AnimationUtils.loadAnimation(Animation_XML_Activity.this, R.anim.rotate);imageView.startAnimation(animation);}public void Scale() {Animation animation=AnimationUtils.loadAnimation(Animation_XML_Activity.this, R.anim.scale);imageView.startAnimation(animation);}public void Translate() {Animation animation=AnimationUtils.loadAnimation(Animation_XML_Activity.this, R.anim.translate);imageView.startAnimation(animation);}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.activity_animation__xml_, menu);return true;}}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。