`

android学习之TransitionDrawable 实现变化效果

阅读更多
Drawable的例子,体现出Drawable的强大功能。Android SDK中说明了Drawable主要的作用是:在XML中定义各种动画,然后把 XML当作Drawable资源来读取,通过Drawable显示动画。

下面举个使用TransitionDrawable 的例子,创建一个Android工程,然后再这个工程的基础上修改,修改过程如下:
1、去掉layout/main.xml中的TextView,增加ImagView,如下:
<ImageView
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”
android:tint=”#55ff0000″
android:src=”@drawable/my_image”/>

2、创建一个XML文件,命名为expand_collapse.xml,内容如下:
<?xml version=”1.0″ encoding=”UTF-8″?>
<transition xmlns:android=”http://schemas.android.com/apk/res/android”>
<item android:drawable=”@drawable/image_expand”/>
<item android:drawable=”@drawable/image_collapse”/>
</transition>
需要3张png图片,存放到res\drawable目录下,3张图片分别命名为:my_image.png、image_expand.png、image_collapse.png。

3、修改Activity中的代码,内容如下:
LinearLayout mLinearLayout;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mLinearLayout = new LinearLayout(this);
ImageView i = new ImageView(this);
i.setAdjustViewBounds(true);
i.setLayoutParams(new Gallery.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
mLinearLayout.addView(i);
setContentView(mLinearLayout);
Resources res = getResources();
TransitionDrawable transition =
(TransitionDrawable) res.getDrawable(R.drawable.expand_collapse);
i.setImageDrawable(transition);
ansition.startTransition(10000);
}

4、如果修改的没有错误,运行程序,结果显示如下:
初始图片



过渡中的图片



最后的图片




屏幕上动画显示的是:从图片image_expand.png过渡到image_collapse.png,也就是我们在expand_collapse.xml中定义的一个transition动画。看完这个例子,你对Drawable的理解是否又深入些?这里提供这个程序的源代码,供大家下载,可以在这个例子的基础上去体会其他的Drawable,来加深对Drawable的理解。

总结说明
通过以上2个例子程序,相信对Drawable会有一定的认识了,在以后的篇幅中会介绍更多的例子,更加深入的学习和理解Drawable。具体还有哪些Drawable,大家到Android SDK去深入学习吧。



转贴至:http://www.moandroid.com/?p=784

实例:







实现上图效果:

xml部份文件:

 <SlidingDrawer  
     android:id="@+id/slidingdrawer" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:orientation="horizontal" 
     android:handle="@+id/handle" 
     android:content="@+id/content">  
     <ImageView  
              android:id="@+id/handle" 
              android:layout_width="56dip"
              android:layout_height="fill_parent"
              android:background="@drawable/handle"
                 
              android:focusable="true"
              android:clickable="true"
                
              android:scaleType="center"    
              android:src="@drawable/handle_icon"
         />  
     <LinearLayout  
         android:id="@+id/content" 
         android:layout_width="fill_parent" 
         android:layout_height="fill_parent" 
         android:background="#778899">  
         <Button  
             android:id="@+id/button" 
             android:layout_width="wrap_content" 
             android:layout_height="wrap_content" 
             android:text="Button" 
         />  
         <EditText  
             android:id="@+id/editText" 
             android:layout_width="fill_parent" 
             android:layout_height="wrap_content" 
         />  
     </LinearLayout>  
 </SlidingDrawer>  




hand_icon.xml

<?xml version="1.0" encoding="utf-8"?>
<transition xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/ic_tray_expand"  />
    <item android:drawable="@drawable/ic_tray_collapse"  />
</transition>



hand.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_window_focused="false" android:state_enabled="true" android:drawable="@drawable/tray_handle_normal" />
    <item android:state_pressed="true" android:drawable="@drawable/tray_handle_pressed" />
    <item android:state_focused="true" android:state_enabled="true" android:drawable="@drawable/tray_handle_selected" />
    <item android:state_enabled="true" android:drawable="@drawable/tray_handle_normal" />
    <item android:state_focused="true" android:drawable="@drawable/tray_handle_selected" />
</selector>


代码部份:

 
mDrawer = (SlidingDrawer) findViewById(R.id.slidingdrawer);
  final SlidingDrawer drawer = mDrawer;

  mLinearLayout = (LinearLayout) drawer.getContent();
  final LinearLayout grid = mLinearLayout;

 

  mImageView = (ImageView) drawer.findViewById(R.id.handle);
  mHandleIcon = (TransitionDrawable) mImageView.getDrawable();
  mHandleIcon.setCrossFadeEnabled(true);

 

  final DrawerManager drawerManager = new DrawerManager();
  drawer.setOnDrawerOpenListener(drawerManager);
  drawer.setOnDrawerCloseListener(drawerManager);
  drawer.setOnDrawerScrollListener(drawerManager);


 

private class DrawerManager implements SlidingDrawer.OnDrawerOpenListener,
   SlidingDrawer.OnDrawerCloseListener,
   SlidingDrawer.OnDrawerScrollListener {
  private boolean mOpen;

  public void onDrawerOpened() {
   Log.v(tag, "onDrawerOpened");
   if (!mOpen) {
    mHandleIcon.reverseTransition(150);
    mOpen = true;
   }
  }

  private void offsetBoundsToDragLayer(Rect bounds, View view) {
   view.getDrawingRect(bounds);
   Log.v(tag, "offsetBoundsToDragLayer");
  }

  public void onDrawerClosed() {
   Log.v(tag, "onDrawerClosed");
   if (mOpen) {
    mHandleIcon.reverseTransition(150);
    mOpen = false;
   }

  }

  public void onScrollStarted() {
   if (PROFILE_DRAWER) {
    android.os.Debug.startMethodTracing("/sdcard/launcher-drawer");
   }
  }

  public void onScrollEnded() {
   if (PROFILE_DRAWER) {
    android.os.Debug.stopMethodTracing();
   }
  }
 }
  • 大小: 5.1 KB
  • 大小: 4.9 KB
  • 大小: 5.4 KB
  • 大小: 21.7 KB
  • 大小: 99.8 KB
分享到:
评论

相关推荐

    Android使用TransitionDrawable渐变切换多张图片

    Android平台上的图片切换效果是非常常见的,TransitionDrawable是一个非常实用的工具类,用于实现图片的渐变切换。下面我们来详细介绍Android使用TransitionDrawable渐变切换多张图片的实现方法。 1. 基础知识:...

    Android应用源码按钮点击WIN8 磁贴效果.zip

    在Android中,可以通过ColorDrawable或者GradientDrawable来实现颜色的过渡效果,或者使用TransitionDrawable进行两个Drawable之间的平滑切换。 5. **布局管理**:为了保证界面的整体性,可能使用LinearLayout、...

    Android animation图片移动效果.rar

    "Android animation图片移动效果.rar"这个压缩包文件提供了一个关于如何在Android应用中实现图片平移移动效果的源码示例。这个示例对于初学者和有经验的开发者来说,都是一个很好的学习资源,可以帮助他们深入理解...

    Android的Drawable学习Demo

    同时,Android也提供了BitmapShader来实现位图的复杂渲染效果,如平铺、缩放等。 除此之外,Drawable还有动态变化的能力。LevelListDrawable可以根据指定的级别显示不同的Drawable;TransitionDrawable可以实现两个...

    android仿IOS7解锁界面

    在Android平台上实现一个类似iOS 7的解锁界面是一项有趣且具有挑战性的任务,因为它涉及到对用户界面设计的深入理解和对Android开发技术的熟练掌握。在这个项目中,我们将探讨如何使用Android SDK来创建一个模仿iOS ...

    android demo,imageview的使用的源代码

    在分析这个demo时,我们可以学习如何处理ImageView的点击事件、如何根据设备方向变化调整图片显示、如何实现图片的缓存策略等。同时,了解这些库(如Glide)的工作原理和优化策略,对提升应用性能有很大帮助。 总的...

    Android源码——仿团购应用图片菜单效果源码.rar

    在Android开发中,创建...综上所述,这个"Android源码——仿团购应用图片菜单效果源码"涵盖了Android UI设计、图片加载、事件监听、状态管理、数据绑定等多个核心知识点,是学习和提高Android开发技能的一个宝贵资源。

    Android 带图片的按钮源码.zip源码资源下载

    这个源码资源可能还包含了对按钮图片的动画效果,例如使用`TransitionDrawable`来实现点击按钮时图片的变化。`TransitionDrawable`是一个可以过渡两个或多个颜色或图片的Drawable对象,通过`startTransition()`方法...

    Android应用源码之MyToggleButton.zip

    5. **动画效果**:自定义的Toggle Button可能会包含切换状态时的动画效果,这可能通过`TransitionDrawable`或`Animator`实现,使用户交互更佳。 6. **代码结构**:查看`MainActivity.java`或类似的类,可以了解如何...

    DrawableDemo.zip

    - 使用TransitionDrawable实现过渡效果,例如在启动页做启动动画,通过`crossFade()`方法进行淡入淡出效果。 此外,还可以结合`android:drawableStart`、`android:drawableEnd`等属性在TextView中插入Drawable,...

    Android应用源码之MenuItemSample.zip

    Android允许开发者自定义菜单项的显示动画,例如使用`TransitionDrawable`来实现点击时的背景颜色变化。 8. **Material Design指南**: 遵循Material Design规范,菜单项的设计和行为会有相应的调整,如颜色、...

    android中实现背景图片颜色渐变方法

    在Android开发中,为背景图片实现颜色渐变的方法通常是通过使用`&lt;gradient&gt;`标签在XML资源文件中定义一个形状(`&lt;shape&gt;`),然后在布局文件中引用这个资源作为背景。这种方法可以让开发者轻松地控制渐变的颜色、...

    Android 自定义ToggleButton

    在“Android 自定义ToggleButton”这一主题中,我们将探讨如何通过Java或Kotlin代码以及XML布局文件来实现自定义`ToggleButton`。主要涉及以下知识点: 1. **自定义视图(Custom View)**:自定义`ToggleButton`...

    安卓Android源码——StateListDrawableSample.rar

    在Android应用开发中,StateListDrawable常用于按钮、背景和其他视图元素,以实现视觉反馈和交互效果。本项目"StateListDrawableSample"是一个示例,旨在深入解析并演示如何使用StateListDrawable。 首先,我们需要...

    Android安卓经典设计例程源代码-SelecterDrawableSample.rar

    7. **动画效果**:还可以结合`TransitionDrawable`,实现状态切换时的过渡动画,提升用户体验。 通过这个`SelecterDrawableSample`项目,开发者可以学习到如何创建、应用和控制`Selector Drawable`,从而在实际项目...

    Android源码——天气预报加widget源码.zip

    此外,为了提高用户体验,开发者可能会使用动画效果来展示天气变化,比如使用TransitionDrawable来平滑切换不同天气状态的图片。还有,考虑到电量和性能,Widget的更新频率需要合理设置,以免过于频繁地唤醒设备。 ...

    Android Drawable Test

    自Android Lollipop(API 21)开始,可以通过`tint`属性为Drawable添加颜色,实现主题色的动态变化。 5. **Nine-Patch Drawable**: 九宫格图像是可伸缩的Drawable,允许开发者指定可拉伸区域和内容区域,常用于...

    应用源码之MyToggleButton.zip

    本资源“应用源码之MyToggleButton.zip”聚焦于自定义的ToggleButton,通过源码学习,我们可以深入了解Android UI组件的工作原理,以及如何进行定制化开发。这篇文章将对其中的关键知识点进行详细讲解。 首先,`...

    Android代码-TV端GridView焦点移动事件处理.rar

    2. **自定义Adapter**:为了实现TV端特有的焦点效果,如高亮、缩放等,我们通常需要创建一个自定义的Adapter。在这个Adapter中,我们可以根据焦点状态改变视图的显示。 ```java public class MyGridViewAdapter ...

    DrawableDemo2

    在这个项目中,开发者可以学习到如何在Android应用中有效地利用Drawable资源,实现各种图形、颜色和状态的变化。 在Android开发中,Drawable是用于表示图形元素的接口,它包括了BitmapDrawable、ColorDrawable、...

Global site tag (gtag.js) - Google Analytics