Android教程之Image Switcher和Text Switcher

Android教程之Image Switcher和Text Switcher

    首先来看Demo中view包下面的ImageSwitcher1.java,这个DEMO实现的效果就是在Activity下面有一个小的图片索引列表,用鼠标点击列表中任意一个图片便可以对该图片进行显示,在每次显示图片的时候总有一个渐变的动画效果。首先来看下它的布局文件:

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout

       xmlns:android="http://schemas.android.com/apk/res/android"

       android:layout_width="fill_parent"

       android:layout_height="fill_parent">

       <ImageSwitcher android:id="@+id/switcher"

              android:layout_width="fill_parent" android:layout_height="fill_parent"

              android:layout_alignParentTop="true"

              android:layout_alignParentLeft="true" />

       <Gallery android:id="@+id/gallery" android:background="#55000000"

              android:layout_width="fill_parent" android:layout_height="60dp"

              android:layout_alignParentBottom="true"

              android:layout_alignParentLeft="true"

              android:gravity="center_vertical" android:spacing="16dp" />

</RelativeLayout>

       在这个布局文件里,外层的大的RelativeLayout包含了两个控件:分别是ImageSwithcer和Gallery。ImageSwithcer是用来图片显示那块区域的控件,Gallery是来控制底下那个图标索引列表索引用的。

       在ImageSwitcher1.java中,requestWindowFeature(Window.FEATURE_NO_TITLE)是使得这个Activity没有titlebar,进而这个图片显示区域会增大。Gallery这个类和ListView这个类用起来差不多,也是要利用setAdapter来进行资源的设置。这里对BaseAdapter进行了封装,这里通过getView这个函数来返回要显示的那个ImageView的。如下所示:

public View getView(int position, View convertView, ViewGroup parent) {

ImageView imageView;

imageView = new ImageView(mContext);

imageView.setLayoutParams(new GridView.LayoutParams(105,105));

imageView.setAdjustViewBounds(true);

imageView.setScaleType(ImageView.ScaleType.FIT_XY);

imageView.setPadding(0,0,0,0);

imageView.setImageResource(mThumbIds[position]);

imageView.setBackgroundResource(mGalleryItemBackground);

return imageView;

}

       getView方法里动态生成一个ImageView,然后利用setLayoutParams ,setImageResource和setBackgroundResource分别设定要图片大小,图片源文件和图片背景。当图片被显示到当前屏幕的时候这个函数就会被自动回调来提供要显示的ImageView。下面就来说说ImageSwitcher,在ImageSwitcher1中实现了ViewSwitcher.ViewFactory这个接口,这个接口里有个方法makeView,来看下这个方法:

    public View makeView() {

        ImageView i = new ImageView(this);

        i.setBackgroundColor(0xFF000000);

        i.setScaleType(ImageView.ScaleType.FIT_CENTER);

        i.setLayoutParams(new ImageSwitcher.LayoutParams(LayoutParams.FILL_PARENT,

                LayoutParams.FILL_PARENT));

        return i;

}

       这个方法为ImageSwitcher返回了一个View。ImageSwitcher调用过程是这样的,首先要有一个Factory为它提供一个View,然后ImageSwitcher就可以初始化各种资源了。

mSwitcher = (ImageSwitcher) findViewById(R.id.switcher);

mSwitcher.setFactory(this);

mSwitcher.setInAnimation(AnimationUtils.loadAnimation(this,android.R.anim.fade_in));

mSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this,android.R.anim.fade_out));

       注意在使用一个ImageSwitcher之前,一定要调用setFactory方法,要不setImageResource这个方法会报空指针异常。ImageSwitcher的切换效果就是由上面最后两句实现的,这里的setInAnimation是资源被读入到这个ImageSwitcher的时候动画,setOutAnimation是资源文件从这个ImageSwitcher里消失的时候要实现的动画效果,这里所有的动画都是从android.R系统文件里读取的。

       ImageSwitcher就说到这里,TextViewSwitcher和ImageSwitcher用法大同小异,下面介绍下怎样自己写Animation。

       在view包中的Animation2这个类使用了一些自己写的Animation,这些Animation也是一些xml文件,下面便是一例:

<set xmlns:android="http://schemas.android.com/apk/res/android">

       <translate android:fromYDelta="100%p" android:toYDelta="0" android:duration="300"/>

       <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="300" />

</set>

       Translate 这个标签里说明字体相对于控件的高度由原来高度的100%变换到0%。Alpha是设定转换时候的透明位,如果从ImageSwitcher里消失的话透明位就从1.0到0.0,如果是进入时的动画,那么透明位就从0.0变换到1.0。这个Animation是竖向的,同样fromXDelta和toXDelta这个属性可以进行横向动画的设定。大家可以写些例子来看看这些Animation的各种效果。

你可能感兴趣的:(android,xml)