当前位置: 代码迷 >> XML/SOAP >> 安卓卡通完全用XML文件配置
  详细解决方案

安卓卡通完全用XML文件配置

热度:133   发布时间:2016-05-23 01:55:13.0
安卓动画完全用XML文件配置

??????????????????????? 前面我们的动画完全用代码实现,看起来又烦又糟糕,又不好修改,能不能定义一种规范,或者模板直接调用呢,这里教你用xml文件配置我们之前实现的所有动画,符合MVC设计原理,又干净整洁大方。

首先定义一个alpha.xml模板

合理我们实现一个淡入淡出的效果,所以呢在res下新建一个文件夹,专门用来定义动画的anim

然后新建alpha.xml

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" ><alpha    android:fromAlpha="1.0"    android:toAlpha="0.0"    android:duration="3000"            /></set>

然后主main.xml放一张图片,定义onclick方法beginxml

主函数Activity代码为:

public class MainActivity extends Activity {		ImageView image;      ViewGroup group;	protected void onCreate(Bundle savedInstanceState) {		super.onCreate(savedInstanceState);		setContentView(R.layout.activity_main);			image=(ImageView)super.findViewById(R.id.image);				//group=(ViewGroup)super.findViewById(R.layout.activity_main);					}	public void beginxml(View v){		Animation a=AnimationUtils.loadAnimation(MainActivity.this, R.anim.alpha);		image.startAnimation(a);			}	

?

短短几行代码就实现了如下效果:



?

?然后我们定义缩放的,异曲同工,建立scale.xml代码如下

 <scale       android:fromXScale="1.0"       android:toXScale="0.0"       android:fromYScale="1.0"       android:toYScale="0.0"       android:repeatCount="3"       android:pivotX="50%"       android:pivotY="50%"       android:startOffset="100"       android:duration="3000"                 />

Activity代码实现同上,只不过位置要变化到scale位置

实现效果如下:



?接下来我们实现旋转

代码:

<rotate    android:fromDegrees="0.0"    android:toDegrees="360.0"    android:pivotX="50%p"    android:pivotY="50%p"    android:duration="3000"xmlns:android="http://schemas.android.com/apk/res/android"/>

?Activity配置同上

效果:

?

?一个个实现是否已经嫌累了,这样,我们定义打包实现,建立all.xml

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android">    <translate      android:fromXDelta="0.0"     android:toXDelta="50%"     android:fromYDelta="0.0"     android:toYDelta="150%"     android:duration="3000" />     <scale       android:fromXScale="1.0"       android:toXScale="0.0"       android:fromYScale="1.0"       android:toYScale="0.0"       android:repeatCount="3"       android:pivotX="50%"       android:pivotY="50%"       android:startOffset="100"       android:duration="3000"                 /></set>

?

实现原理如上,实现效果叠加

?

?

  相关解决方案
本站暂不开放注册!
内测阶段只得通过邀请码进行注册!
 
  • 最近登录:Sat Dec 15 13:24:19 CST 2018
  • 最近登录:Sat Dec 15 13:24:19 CST 2018
  • 最近登录:Sat Dec 15 13:24:19 CST 2018
  • 最近登录:Sat Dec 15 13:24:19 CST 2018
  • 最近登录:Sat Dec 15 13:24:19 CST 2018