`
yidongkaifa
  • 浏览: 4059850 次
文章分类
社区版块
存档分类
最新评论

Android之动画ViewPager小结(QQ续三)

 
阅读更多

点我下载该例源码-->

其实写完这个题目,我也觉得自己光荣的加入标题党了,我这里所谓的动画,其实只是上面的索引小图标的动画而已,先一下效果图吧,由于只是测试效果,我只是把背景颜色改变了而已,并没有添加实际的View。这里我就不介绍什么是ViewPager了,不知道的童鞋,百度一下吧,一大堆的。

好的,下面我们开始实现,先来看一下布局文件部分:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/root"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <RelativeLayout
        android:id="@+id/RelativeLayout1"
        android:layout_width="fill_parent"
        android:layout_height="60dp"
        android:background="@drawable/login_bg" >

        <ImageView
            android:id="@+id/friend_list_myImg"
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:layout_alignParentLeft="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="15dp"
            android:layout_weight="1.0"
            android:background="@drawable/img_select"
            android:src="@drawable/icon" />

        <TextView
            android:id="@+id/friend_list_myName"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_marginLeft="20dp"
            android:layout_toRightOf="@+id/friend_list_myImg"
            android:layout_weight="1.0"
            android:gravity="center"
            android:text="way"
            android:textColor="#ffffff"
            android:textSize="20sp" />

        <ImageView
            android:id="@+id/imageView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_marginLeft="20dp"
            android:layout_toRightOf="@+id/friend_list_myName"
            android:src="@drawable/account_current" />
    </RelativeLayout>

    <RelativeLayout
        android:id="@+id/RelativeLayout1"
        android:layout_width="fill_parent"
        android:layout_height="45dp"
        android:background="@drawable/login_moremenu_back"
        android:orientation="horizontal" >

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_alignParentLeft="true"
            android:layout_alignParentTop="true"
            android:gravity="center" >

            <ImageView
                android:id="@+id/tab1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:src="@drawable/tab1" />

            <ImageView
                android:id="@+id/tab2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:src="@drawable/tab2" />

            <ImageView
                android:id="@+id/tab3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:src="@drawable/tab3" />
        </LinearLayout>


        <ImageView
            android:id="@+id/tab2_bg"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:scaleType="matrix"
            android:src="@drawable/topbar_select" />
    </RelativeLayout>

    <LinearLayout
        android:id="@+id/bodylayout"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="#ffffff"
        android:orientation="vertical" >

        <android.support.v4.view.ViewPager
            android:id="@+id/viewPager"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent" />
    </LinearLayout>

</LinearLayout>

下面是布局文件的效果图:



下面是关于ViewPager的适配器,说实话,我也没有仔细去研究,只是知道它需要传入一个view的数组:

/**
 * 自定义的ViewPager适配器
 * 
 * @author way
 * 
 */
public class MyPagerAdapter extends PagerAdapter {
	private List<View> mListViews;

	public MyPagerAdapter(List<View> mListViews) {// 构造方法
		// TODO Auto-generated constructor stub
		this.mListViews = mListViews;
	}

	@Override
	public void destroyItem(View arg0, int arg1, Object arg2) {
		((ViewPager) arg0).removeView(mListViews.get(arg1));
	}

	@Override
	public void finishUpdate(View arg0) {
	}

	@Override
	public int getCount() {
		return mListViews.size();
	}

	@Override
	public Object instantiateItem(View arg0, int arg1) {
		((ViewPager) arg0).addView(mListViews.get(arg1), 0);
		return mListViews.get(arg1);
	}

	@Override
	public boolean isViewFromObject(View arg0, Object arg1) {
		return arg0 == (arg1);
	}

	@Override
	public void restoreState(Parcelable arg0, ClassLoader arg1) {
	}

	@Override
	public Parcelable saveState() {
		return null;
	}

	@Override
	public void startUpdate(View arg0) {
	}

}

最重要的部分到了,里面注释说得蛮清楚的,关于那个动画的索引图片,如果不是很理解,可以看看最后的那张图片,从别人博客复制过来的,感觉很经典:

/**
 * 主Activity
 * 
 * @author way
 * 
 */
public class MainActivity extends Activity implements OnClickListener {
	private static final int PAGE1 = 0;// 页面1
	private static final int PAGE2 = 1;// 页面2
	private static final int PAGE3 = 2;// 页面3
	private ViewPager mPager;
	private List<View> mListViews;// Tab页面
	private ImageView cursor;// 动画图片
	private ImageView tabBtn1, tabBtn2, tabBtn3;// 页卡图标
	private int currIndex = 1;// 当前页卡编号
	private int offset = 0;// 动画图片偏移量
	private int bmpW;// 动画图片宽度

	@Override
	public void onCreate(Bundle savedInstanceState) {
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		super.onCreate(savedInstanceState);
		setContentView(R.layout.friend_list);
		InitImageView();// 初始化那个可以动的背景动画图片
		initView();
	}

	/**
	 * 初始化动画
	 */
	private void InitImageView() {
		cursor = (ImageView) findViewById(R.id.tab2_bg);
		bmpW = BitmapFactory.decodeResource(getResources(),
				R.drawable.topbar_select).getWidth();// 获取图片宽度
		DisplayMetrics dm = new DisplayMetrics();
		getWindowManager().getDefaultDisplay().getMetrics(dm);
		int screenW = dm.widthPixels;// 获取屏幕分辨率宽度
		offset = (screenW / 3 - bmpW) / 2;// 计算偏移量:屏幕宽度/3,平分为3分,如果是3个view的话,再减去图片宽度,因为图片居中,所以要得到两变剩下的空隙需要再除以2
		Matrix matrix = new Matrix();
		int start = offset * 3 + bmpW;
		matrix.postTranslate(start, 0);// 初始化位置,在中间
		cursor.setImageMatrix(matrix);// 设置动画初始位置
	}

	private void initView() {
		tabBtn1 = (ImageView) findViewById(R.id.tab1);
		tabBtn2 = (ImageView) findViewById(R.id.tab2);
		tabBtn3 = (ImageView) findViewById(R.id.tab3);

		tabBtn1.setOnClickListener(this);
		tabBtn2.setOnClickListener(this);
		tabBtn3.setOnClickListener(this);

		mPager = (ViewPager) findViewById(R.id.viewPager);// 获取我们的viewPager
		mListViews = new ArrayList<View>();
		LayoutInflater inflater = LayoutInflater.from(this);
		View lay1 = inflater.inflate(R.layout.tab1, null);
		View lay2 = inflater.inflate(R.layout.tab2, null);
		View lay3 = inflater.inflate(R.layout.tab3, null);
		mListViews.add(lay1);
		mListViews.add(lay2);
		mListViews.add(lay3);
		mPager.setAdapter(new MyPagerAdapter(mListViews));
		mPager.setCurrentItem(PAGE2);
		mPager.setOnPageChangeListener(new OnPageChangeListener() {
			int one = offset * 2 + bmpW;// 页卡1 -> 页卡2 偏移量

			public void onPageSelected(int arg0) {// 页面选择事件
				// TODO Auto-generated method stub
				Animation animation = null;
				switch (arg0) {
				case PAGE1:// 切换到页卡1
					if (currIndex == PAGE2) {// 如果之前显示的是页卡2
						animation = new TranslateAnimation(0, -one, 0, 0);
					} else if (currIndex == PAGE3) {// 如果之前显示的是页卡3
						animation = new TranslateAnimation(one, -one, 0, 0);
					}
					break;
				case PAGE2:// 切换到页卡2
					if (currIndex == PAGE1) {// 如果之前显示的是页卡1
						animation = new TranslateAnimation(-one, 0, 0, 0);
					} else if (currIndex == PAGE3) {// 如果之前显示的是页卡3
						animation = new TranslateAnimation(one, 0, 0, 0);
					}
					break;
				case PAGE3:// 切换到页卡3
					if (currIndex == PAGE1) {// 如果之前显示的是页卡1
						animation = new TranslateAnimation(-one, one, 0, 0);
					} else if (currIndex == PAGE2) {// 如果之前显示的是页卡2
						animation = new TranslateAnimation(0, one, 0, 0);
					}
					break;
				default:
					break;
				}
				currIndex = arg0;// 动画结束后,改变当前图片位置
				animation.setFillAfter(true);// True:图片停在动画结束位置
				animation.setDuration(300);
				cursor.startAnimation(animation);
			}

			public void onPageScrolled(int arg0, float arg1, int arg2) {
				// TODO Auto-generated method stub

			}

			public void onPageScrollStateChanged(int arg0) {
				// TODO Auto-generated method stub

			}
		});

	}

	public void onClick(View v) {
		// TODO Auto-generated method stub
		switch (v.getId()) {
		case R.id.tab1:
			mPager.setCurrentItem(PAGE1);// 点击页面1
			break;
		case R.id.tab2:
			mPager.setCurrentItem(PAGE2);// 点击页面2
			break;
		case R.id.tab3:
			mPager.setCurrentItem(PAGE3);// 点击页面3
			break;

		default:
			break;
		}
	}
}

根据屏幕的分辨率和图片的宽度计算动画移动的偏移量:



本文参考:http://www.cnblogs.com/dwinter/archive/2012/02/27/2369590.html

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics