相信大家都对android桌面左右划屏操作很羡慕吧,QQ,新浪weibo,AndroidMarket都有这种操作,而且很多都作为主界面使用,可见其用户交互性特别好。
今天就把这种操作亲手实现,大家共同学习。ViewPage是Google最近在Compatibilit package发布的,支持android1.6+,可以在SDK安装目录下找到
\android-sdk-windows\extras\android\compatibility\v4,把这个jar包导入项目就可以了(这个就不用说了吧)
我们先看一看运行结果吧:如下:
好了 ,上面这就是我们今天要做的,首先我们先进行分析,看到头部三个页卡,及白色背景,那是最上层,中间是一个游标,一个长条图片,下面滑动的就是ViewPage了。
我们先将这个布局布好:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <LinearLayout android:id="@+id/nav" android:layout_width="fill_parent" android:layout_height="50dp" android:background="#efefef"> <TextView android:id="@+id/tab1" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:textColor="#000000" android:text="页片1" /> <TextView android:id="@+id/tab2" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:textColor="#000000" android:text="页片2" /> <TextView android:id="@+id/tab3" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:textColor="#000000" android:text="页片3" /> </LinearLayout> <ImageView android:id="@+id/cursor" android:layout_width="fill_parent" android:layout_height="wrap_content" android:scaleType="matrix" android:src="@drawable/cursor"/> <android.support.v4.view.ViewPager android:id="@+id/page" android:layout_width="fill_parent" android:layout_height="fill_parent"> </android.support.v4.view.ViewPager> </LinearLayout>下面滑动的部分就是3个Layout:为了方便我们就用不同的背景色来区分吧
Layout1:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:background="#565656"> </LinearLayout>
Layout2:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:background="#abab00"> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:background="#00abcd"> </LinearLayout>
private ViewPager myviewpage; private MyPagerAdapter mypagetadapter; private LayoutInflater inflater; private List<View> listviews; private View layout1=null,layout2=null,layout3=null; private TextView page1,page2,page3; private ImageView cursor; 图片游标 private int offset=0; //动画图片偏移量 private int currIndex=0; //当前卡片编号 private int bmgW; //动画图片宽度
//初始化动画 private void initAnima(){ cursor = (ImageView)findViewById(R.id.cursor); //初始化游标图片 bmgW = BitmapFactory.decodeResource(getResources(), R.drawable.cursor).getWidth(); //得到游标的宽度 DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); int screenW = dm.widthPixels; //屏幕宽度 offset=(screenW/3-bmgW)/2; //游标偏移量 Matrix matrix=new Matrix(); matrix.postTranslate(offset, 0); cursor.setImageMatrix(matrix); 游标初始位置 }
初始化
initAnima(); myviewpage = (ViewPager)findViewById(R.id.page); listviews = new ArrayList<View>(); inflater = getLayoutInflater(); layout1=inflater.inflate(R.layout.layout1, null); layout2=inflater.inflate(R.layout.layout2, null); layout3=inflater.inflate(R.layout.layout3, null); listviews.add(layout1); listviews.add(layout2); listviews.add(layout3); page1=(TextView)findViewById(R.id.tab1); page2=(TextView)findViewById(R.id.tab2); page3=(TextView)findViewById(R.id.tab3); page1.setOnClickListener(new MyNavOnClickListener(0)); page2.setOnClickListener(new MyNavOnClickListener(1)); page3.setOnClickListener(new MyNavOnClickListener(2)); mypagetadapter = new MyPagerAdapter(listviews); myviewpage.setAdapter(mypagetadapter); myviewpage.setOnPageChangeListener(new OnPageChangeListener() { int one = offset*2+bmgW; //页片1->页片2 偏移量 int two=one*2; //页片1->页片3偏移量 @Override public void onPageSelected(int pos) { // TODO Auto-generated method stub Animation animation = null; switch (pos) { case 0: if(currIndex==1){ animation=new TranslateAnimation(one, 0, 0, 0); }else if(currIndex==2){ animation=new TranslateAnimation(two, 0, 0, 0); } break; case 1: if(currIndex==0){ animation=new TranslateAnimation(offset, one, 0, 0); }else if(currIndex==2){ animation=new TranslateAnimation(two, one, 0, 0); } break; case 2: if(currIndex==1){ animation=new TranslateAnimation(one, two, 0, 0); }else if(currIndex==0){ animation=new TranslateAnimation(offset, two, 0, 0); } break; default: break; } currIndex=pos; animation.setFillAfter(true); animation.setDuration(300); cursor.setAnimation(animation); } @Override public void onPageScrolled(int arg0, float arg1, int arg2) { // TODO Auto-generated method stub } @Override public void onPageScrollStateChanged(int arg0) { // TODO Auto-generated method stub } });
设置ViewPage适配器
class MyPagerAdapter extends PagerAdapter{ List<View> views; public MyPagerAdapter(List<View> v) { super(); // TODO Auto-generated constructor stub views = v; } @Override public void destroyItem(View v, int pos, Object arg2) { // TODO Auto-generated method stub ((ViewPager) v).removeView(views.get(pos)); } @Override public void finishUpdate(View arg0) { // TODO Auto-generated method stub } @Override public int getCount() { // TODO Auto-generated method stub return views.size(); } @Override public Object instantiateItem(View v, int pos) { // TODO Auto-generated method stub ((ViewPager) v).addView(views.get(pos)); return views.get(pos); } @Override public boolean isViewFromObject(View arg0, Object arg1) { // TODO Auto-generated method stub return arg0==arg1; } @Override public void restoreState(Parcelable arg0, ClassLoader arg1) { // TODO Auto-generated method stub } @Override public Parcelable saveState() { // TODO Auto-generated method stub return null; } @Override public void startUpdate(View arg0) { // TODO Auto-generated method stub } }