AdapterViewFliper 的用法

AdapperViewFlipper与Gallery的区别, Flipper每次只能显示一个View组键,Gallery显示的是水平的列表选择,通过拖动,选择View组键 ,Flipper继承AdapterViewAnimator,Gallery则继承AbsSpinner,实现方法上基本一致,都是通过BaseAdapter 的一个对象adapter进行setAdapter()


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"

   android:paddingTop="@dimen/activity_vertical_margin"

    tools:context=".MainActivity" >
    <AdapterViewFlipper                        //定义AdapterViewFliper
        android:loopViews="true"                 //定义最后一个组件时掉头到第一个组件,继续执行。
        android:id="@+id/flipper"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:flipInterval="1500"                          //自动播放时间间隔
        android:layout_alignParentTop="true"
        ></AdapterViewFlipper>
    <Button 
        android:id="@+id/previous"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentBottom="true"
        android:onClick="pre"
        android:text="上一张"
        />
    


    <Button
        android:id="@+id/auto"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/flipper"
        android:layout_centerHorizontal="true"
        android:gravity="center"
        android:onClick="auto"
        android:paddingLeft="10dp"
        android:text="自动播放" 
        />
    <Button 
        android:id="@+id/next"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_alignBottom="@id/auto"
        android:paddingLeft="10dp"
        android:onClick="next"
        android:text="下一张"
        />


</RelativeLayout>




package com.example.simpleadapterviewflipper;



import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterViewFlipper;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;


public class MainActivity extends Activity {
    int[] imagesId=new int[]{
    R.drawable.yecun1,
    R.drawable.yecun2,
    R.drawable.yecun3,
    R.drawable.yecun4,
    R.drawable.yecun5,
    R.drawable.yecun6,
    };
    AdapterViewFlipper flipper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); 
flipper=(AdapterViewFlipper)findViewById(R.id.flipper);          // 通过flipper方法找到当前的flipperView
BaseAdapter adapter=new BaseAdapter(){                  //创建Adapter


@Override
public int getCount() {
// TODO Auto-generated method stub
return imagesId.length;                                   //显示的View内容个数
}


@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return position;
}


@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}


@Override   创建image视图的显示方式
public View getView(int arg0, View arg1, ViewGroup arg2) {
// TODO Auto-generated method stub
ImageView imageView=new ImageView(MainActivity.this);      //创建一个视图对象
imageView.setImageResource(imagesId[arg0]);                               //创建View组件的显示方式
imageView.setScaleType(ImageView.ScaleType.FIT_XY);           
imageView.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.MATCH_PARENT));      //定义image组件的布局
return imageView;                    //返回视图
}

};
flipper.setAdapter(adapter);
}
public void pre(View source){
flipper.showPrevious();
flipper.stopFlipping();
}
public void next(View source){
flipper.showNext();
flipper.stopFlipping();
}
public void auto(View source){
flipper.startFlipping();
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}


}

你可能感兴趣的:(AdapterViewFliper 的用法)