Android Drawable之TransitionDrawable

Overview

从Drawable的类继承图上可以看到TransitionDrawable是LayerDrawable的子类,但是不像LayerDrawable可以有多层drawable,TransitionDrawable只能管理两层drawable,并且提供了一个透明度变化的动画,可以控制从一层drawable过度到另外一层drawable的渐变动画效果。

在xml文件中使用<transition>作为根节点来定义TransitionDrawable,通过item子节点定义两层使用的drawable。

创建和使用

TransitionDrawable同样可以使用xml文件或直接在代码中创建,但推荐使用xml文件的方式,除非你有特别的需求,需要在代码中设置或修改TransitionDrawable的属性等。
语法:

 
 
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <transition
  3. xmlns:android="http://schemas.android.com/apk/res/android" >
  4. <item
  5. android:drawable="@[package:]drawable/drawable_resource"
  6. android:id="@[+][package:]id/resource_name"
  7. android:top="dimension"
  8. android:right="dimension"
  9. android:bottom="dimension"
  10. android:left="dimension" />
  11. </transition>

元素:
<transition>
必须的。 必须作为根节点,包含一个或多个<item>元素。我们上面介绍了TransitionDrawable只能管理两层drawable,这里又说一个或多个是否矛盾了。在<transition>节点下确实可以有多个<item>元素,但是只会显示前面的两个<item>,后面添加的<item>虽然不会出错,但不会显示。
<item>
定义一个TransitionDrawable中所使用的一个drawable。必须是子节点。也可以接受子节点。item的属性如下:

  • android:id 资源ID。drawable资源的唯一标识。
  • android:drawable Drawable 资源。 必须的。引用一个Drawable资源。
  • android:top Integer。 与顶部的距离
  • android:right Integer。与右边的距离
  • android:bottom Integer。 与下边的距离
  • android:left Integer。与左边的距离

使用举例:
新建一个xml文件保存为:res/drawable/transition.xml:

 
 
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <transition xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:drawable="@drawable/onboarding_slide1"/>
  4. <item android:drawable="@drawable/onboarding_slide2"/>
  5. </transition>

在layout中使用:

 
 
  1. <ImageView
  2. android:id="@+id/imageview"
  3. android:scaleType="centerCrop"
  4. android:src="@drawable/transition"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"/>

如下的代码会执行从第一个item到第二个item 5秒的过渡。

 
 
  1. ImageView mImageView = (ImageView) findViewById(R.id.imageview);
  2. TransitionDrawable trans = (TransitionDrawable) mImageView.getDrawable();
  3. trans.startTransition(5000);

可重复渐变的TransitionDrawable

TransitionDrawable一般只能设置两张背景图片,而且动画效果不能重复。但是我们可以通过Handler+Thread实现TransitionDrawable循环渐变的效果。

 
 
  1. public class MainActivity extends Activity {
  2. private ImageView mImageView;
  3. private TransitionDrawable trans;
  4. private int count;
  5. @Override
  6. protected void onCreate(Bundle savedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. setTheme(android.R.style.Theme_NoTitleBar_Fullscreen);
  9. setContentView(R.layout.activity_main);
  10. mImageView = (ImageView) findViewById(R.id.imageview);
  11. trans = (TransitionDrawable) mImageView.getDrawable();
  12. mHandler.post(splashThread);
  13. }
  14. Handler mHandler = new Handler(new Handler.Callback() {
  15. @Override
  16. public boolean handleMessage(Message msg) {
  17. if (msg.arg1 % 2 == 0) {
  18. trans.reverseTransition(msg.arg2); // 反转动画,即从第二张过渡到第一张
  19. }else{
  20. trans.startTransition(msg.arg2); // 再从第一次过渡到第二张
  21. }
  22. mHandler.postDelayed(splashThread, msg.arg2);
  23. return false;
  24. }
  25. });
  26. Thread splashThread = new Thread(new Runnable() {
  27. @Override
  28. public void run() {
  29. Message msg = mHandler.obtainMessage();
  30. count++;
  31. msg.arg1 = count;
  32. msg.arg2 = 8000; // 过渡时间为8秒
  33. mHandler.sendMessage(msg);
  34. }
  35. });
  36. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值