ViewSwitcher学习笔记

ViewSwitcher 的作用简单来说就是:在两个视图间转换时显示动画 

它的两个子类应该很熟悉,ImageSwitcher:转换图片时增加动画效果TextSwitcher 转换文字时增加动画效果



API翻译

一、结构


public class ViewSwitcher extends ViewAnimator

        

java.lang.Object

android.view.View

         android.view.ViewGroup

                   android.widget.FrameLayout

                            android.widget.ViewAnimator

                                     android.widget.ViewSwitcher

已知直接子类

ImageSwitcherTextSwitcher


 

  二、概述

     在两个视图间转换时显示动画,有一个可以创建这些视图的工厂类。你可以用工厂来创建这些视图,也可以自己创建。一个ViewSwitcher只允许包含两个子视图,且一次仅能显示一个。

  (译者注:与ViewFlipper类相似,但该类不常用,常用其两个子类ImageSwitcher:转换图片时增加动画效果TextSwitcher转换文字时增加动画效果

 

  三、内部类

    interface          ViewSwitcher.ViewFactory     

    在一个ViewSwitcher里创建视图

 

  四、构造函数

public ViewSwitcher (Context context)

    构造一个新的空的视图转换器(ViewSwitcher)

    参数context  上下文

public ViewSwitcher (Context context, AttributeSet attrs)

    构造一个指定上下文、属性集合的空的视图转换器(ViewSwitcher)

    参数

    context    上下文

    attrs        属性集合

 

五、公共方法


public void addView(View child, int index, ViewGroup.LayoutParams params)

   添加一个指定布局参数的子视图

            参数

  child         添加的子视图

  index       添加的子视图的索引

  params    子视图的布局参数

  异常

  IllegalStateException       如果切换器中已经包含了两个视图时。

   

  public View getNextView ()

  返回下一个要显示的视图

  返回值——视图切换之后将要显示出的下一个视图

 

  public void reset ()

  重置视图转换器(ViewSwitcher)来隐藏所有存在的视图,并使转换器达到一次动画都还没有播放的状态。

 

  public void setFactory (ViewSwitcher.ViewFactory factory)

  设置用来生成将在视图转换器中切换的两个视图的工厂。也可以调用两次 addView(android.view.View, int,        android.view.ViewGroup.LayoutParams)来替代使用工厂的方法。

  参数 factory   用来生成转换器内容的视图工厂

下面利用OSChina开源代码中的一部分来演示它的具体使用

“用户登录”

布局xml:

ViewSwitcher学习笔记_第1张图片

 <ViewSwitcher 
        android:id="@+id/logindialog_view_switcher" 
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content">

        <RelativeLayout 

        布局。。。。

        />

        <View 
           android:id="@+id/login_loading" 
           android:layout_width="135.0dip" 
           android:layout_height="135.0dip"
           android:layout_gravity="center" 
           android:background="@anim/login_loading"/>
</ViewSwitcher>
动画类中:


ViewSwitcher学习笔记_第2张图片ViewSwitcher学习笔记_第3张图片

01    动画1                                                          11   动画2

用到图层叠加(因为这里有两个动画效果)

<!-- 动画帧集合对象-->

<?xml version="1.0" encoding="UTF-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
  android:oneshot="false">

<!--动画帧对象 android:duration表示每帧动画显示的时间,放在drawable下的动画图片不能太大,否则会内存爆掉-->    
    <item android:duration="100">
        <layer-list>
            <item android:drawable="@drawable/login_loading_00" />
            <item android:drawable="@drawable/login_loading_10" />
        </layer-list>
    </item>

<item android:duration="100">
        <layer-list>
            <item android:drawable="@drawable/login_loading_01" />
            <item android:drawable="@drawable/login_loading_11" />
        </layer-list>
    </item>

    

    <item android:duration="100">
        <layer-list>
            <item android:drawable="@drawable/login_loading_02" />
            <item android:drawable="@drawable/login_loading_12" />
        </layer-list>
    </item>

</animation-list>

实体类中

初始化

private ViewSwitcher mViewSwitcher;

private View loginLoading;


loginLoading = (View)findViewById(R.id.login_loading);

mViewSwitcher = (ViewSwitcher)findViewById(R.id.logindialog_view_switcher);


loadingAnimation = (AnimationDrawable)loginLoading.getBackground();
       loadingAnimation.start();
       mViewSwitcher.showNext();//当登录成功

       mViewSwitcher.showPrevious();//当登录失败





 

你可能感兴趣的:(ViewSwitcher学习笔记)