`
chengfengyang
  • 浏览: 20979 次
社区版块
存档分类
最新评论

Animations的使用(五)

阅读更多
1 AnimationSet的使用方法

什么是AnimationSet

1 AnimationSet是Animation的子类

2 一个AnimationSet包含了一系列的Animation

3 针对AnimationSet设置一些Animation的常见属性(如StartOffset,duration等),可以被包含在AnimationSet当中的Animation继承

	AnimationSet animationSet = new AnimationSet(ture);
	AlpahaAnimation alpha = new AlphaAnimation(...);
	RotateAnimation rotate = new RotateAnimation(...);
	animationSet.addAnimation(alpha);
	animationSet.addAnimaion(rotate);
	animationSet.setDuration(2000);
	animationSet.setStartOffset(500);
	imageView.startAnimation(animationSet);


2 Interpolator的使用方法

Interpolator定义了动画变化速率,在Animations框架中定义了以下几种Interpolator



AccelerateDecelerateInterpolator:在动画开始和结束的地方速率变化较慢,中间的时候加速

AccelerateInterpolator:在动画开始的地方速率改变较慢,然后加速

CycleInterpolator:动画循环播放特定次数,速率改变沿正弦曲线

DecelerateInterpolator:在动画开始的地方速率改变较慢,然后减速

LinearInterpolator:以均匀的速率改变



设置的地方就在set标签中的 android:interpolator="@android:anim/accelerate_interpolator"

而之后还有一个android:shareInterpolator="true" 从名字就可以看到这是为set中所有的动画设置Interpolator

如果要单独设置 则将shareInterpolator设为false 然后为每个动画中单独定义Interpolator



以上是在xml中设置,如果要在代码中设置

animationSet.setInterpolator(new AccelerateInterpolator());(也可以单独设置)

注意在AnimationSet的构造方法中有一个boolean参数,这个参数就是shareInterpolator的设定



3 Frame-By-Frame Animations的使用方法

1 在res/drawable中创建一个xml文件,定义Animation的动画播放序列 anim_nv.xml

	<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
		android:oneshot="false">
		<item android:drawable="@drawable/nv1"
			android:duration="500" />
		<item android:drawable="@drawable/nv2"
			android:duration="500" />
		<item android:drawable="@drawable/nv3"
			android:duration="500" />
		<item android:drawable="@drawable/nv4"
			android:duration="500" />
	</animation-list>


2 为ImageView设置背景资源
	imageView.setBackgroundResource(R.drawable.anim_nv);


3 通过ImageView得到AnimationDrawable
	AnimationDrawable animationDrawable = (AnimationDrawable) imageView.getBackground();


4 执行动画
	animationDrawable.start();

分享到:
评论

相关推荐

    RPG Character Mecanim Animation Pack 5.4.unitypackage

    所有的角色都采用了Mecanim人形动画的结构,所以你可以很轻松地嵌入你自己的角色,其还支持有五根手指的手以适应有着高细节要求的模型。我们所提供的动画控制器简洁明了,您或可以将动画插入在您的现有设置当中。...

    Autolayout-budejie

    Autolayout 实现百思不得姐总结##精华模块切换子控制器,使用系统的切换方法实现把全部\视频\声音\图片\段子五个topic控制器添加为EssenceVc的子控制器,通过以下方法切换- (void)transitionFromViewController:...

    JavaScript权威指南第五版【新】(犀牛书)

    Display DHTML animations Automate form validation Draw dynamic pie charts Make HTML elements draggable Define keyboard shortcuts for web applications Create Ajax-enabled tool tips Use XPath and ...

    JavaScript权威指南(第五版).chm

    Display DHTML animations Automate form validation Draw dynamic pie charts Make HTML elements draggable Define keyboard shortcuts for web applications Create Ajax-enabled tool tips Use XPath and ...

    简单表示使用СSS3动画滚动页面的可能性。-JavaScript开发

    仅滚动简单指示使用СSS3动画滚动页面的可能性。 功能可以在所有现代和许多较旧的浏览器上使用具有SASS版本以供重建(仅适用于开发人员)包括颜色,帮助Just Scroll Simple指示使用СSS3动画滚动页面的可能性。 功能...

    progress-timeline-bar:高度可定制的进度时间表,强调正当程序

    进度时间表栏高度可定制的动画进度时间轴栏,用于强调应有的流程 ... 否则香草js 设计为可消耗的React组件用于外观定制的模块化模板系统数据是模拟垃圾建模的退货清单去做*做出回应*创建五个皮肤插件*发布完整的api文件

    真棒设计工具:适用于所有事物的最佳设计工具和插件:backhand_index_pointing_right:

    Flawless App是我们的第一家公司,我们为五人团队所取得的成就感到自豪。 自2015年以来,我们为设计师和开发人员推出了功能强大的工具,其中包括 , , 。 我们还在社区推动的计划中投入了大量的爱心和关怀。 很棒...

    Responsive-Clock:Res:timer_clock:响应式时钟,秒表和计时器。 三合一。 :watch::alarm_clock:

    秒表易于使用,您可以使用按钮将其重置。 接触 :telephone_receiver: 名字-Nidhi Gahlawat 领英个人资料-https //www.linkedin.com/in/nidhi-gahlawat-01947818a/ 链接到时钟 :link: 在各种尺寸的设备上都能很...

    easy-css-layout:简易CSS布局

    简易CSS布局 演示版 前言 仅用于练习和备份 关于样式的颜色设置,这里存在一些问题,但是我不想修改它们。 如果您想通过本演示进行练习 首先,您需要在“演示”列中查看演示,并自己写下代码 如果您无法实现这些...

    Javis.jl:Julia动画和可视化

    Javis.jl:Julia动画和可视化

    arcGis教程完整版

    1.1.1ArcView(单用户使用许可)的安装 ....................................................................4 1.1.2ArcGIS(浮动使用许可)的安装 ..............................................................

Global site tag (gtag.js) - Google Analytics