Android ViewPager 的使用總結
在一個視窗裡面新增tab便籤,完成便籤切換來實現頁面的切換,這樣的好處是可以在同一個視窗裡面有多個頁面,這些頁面共享同一個視窗的資源,同使用多個視窗來實現這個功能來得更加流暢!!
主要產生的類檔案有activity,n個view,adapter,自定義的ViewPager,n+1個佈局檔案
demo所用到檔案
步驟:
建立activity
package com.example.myviewpager; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.content.Context; import android.graphics.Color; import android.os.Bundle; import android.support.v4.view.ViewPager; import android.view.View; import android.view.View.OnClickListener; import android.widget.TextView; /** * 主視窗 * @author cgx * */ public class MainActivity extends Activity implements OnClickListener { private Context mContext; private MyViewPager mPager;// 頁面內容 private MyViewPagerAdapter pagerAdapter = null; private TextView t1, t2, t3;// 頁卡頭標 private List<View> pageList = new ArrayList<View>(); private View1 mView1; private View2 mView2; private View3 mView3; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mContext = this; initViews(); initEvents(); initViewPager(); } private void initViews() { // TODO Auto-generated method stub t1 = (TextView) findViewById(R.id.text1); t2 = (TextView) findViewById(R.id.text2); t3 = (TextView) findViewById(R.id.text3); mPager = (MyViewPager) findViewById(R.id.vPager); // 設定ViewPager不允許滑動 //mPager.setCanScroll(false); //一開始進入視窗的時候,預設第一個便籤被選中 t1.setBackgroundColor(Color.parseColor("#FFFF00")); t2.setBackgroundColor(Color.parseColor("#FFFFFF")); t3.setBackgroundColor(Color.parseColor("#FFFFFF")); } private void initEvents() { // TODO Auto-generated method stub t1.setOnClickListener(this); t2.setOnClickListener(this); t3.setOnClickListener(this); } private void initViewPager() { // TODO Auto-generated method stub pageList.clear(); if (mView1 == null) { mView1 = new View1(mContext); } if (mView2 == null) { mView2 = new View2(mContext); } if (mView3 == null) { mView3 = new View3(mContext); } pageList.add(mView1.getView()); pageList.add(mView2.getView()); pageList.add(mView3.getView()); pagerAdapter = new MyViewPagerAdapter(pageList); // 快取頁面,如果想全部都快取的話,引數等於頁卡數減一,系統預設引數為1,儲存兩個 mPager.setOffscreenPageLimit(2); mPager.setAdapter(pagerAdapter); // 設定Page改變監聽器 mPager.setOnPageChangeListener(onPageChangeListener); } /** * SimpleOnPageChangeListener.該監聽是當我們的viewpager頁面切換的時候會觸發 在裡面我們會去改變 tab的聚焦情況 * 。 因為實現上viewpager與actionbar是獨立的,需要我們手動同步 。 */ ViewPager.SimpleOnPageChangeListener onPageChangeListener = new ViewPager.SimpleOnPageChangeListener() { @Override public void onPageSelected(int position) { /** * setSelectedNavigationItem 方法用於設定ActionBar的聚焦tab . * 在接下來我們判斷了SLidingMenu的手勢力模式, 如果ViewPager已經滑到了最左邊,則我們把手勢設定成全屏的, * 這樣更往左滑動的時候,就會開啟Menu . */ initTab(position); } // 初始化便籤顏色 private void initTab(int position) { // TODO Auto-generated method stub if (position == 0) { t1.setBackgroundColor(Color.parseColor("#FFFF00")); t2.setBackgroundColor(Color.parseColor("#FFFFFF")); t3.setBackgroundColor(Color.parseColor("#FFFFFF")); } else if (position == 1) { t1.setBackgroundColor(Color.parseColor("#FFFFFF")); t2.setBackgroundColor(Color.parseColor("#FFFF00")); t3.setBackgroundColor(Color.parseColor("#FFFFFF")); } else { t1.setBackgroundColor(Color.parseColor("#FFFFFF")); t2.setBackgroundColor(Color.parseColor("#FFFFFF")); t3.setBackgroundColor(Color.parseColor("#FFFF00")); } } }; @Override public void onClick(View v) { // TODO Auto-generated method stub switch (v.getId()) { case R.id.text1:// 點選第一個便籤 mPager.setCurrentItem(0, false); break; case R.id.text2:// 點選第二個便籤 mPager.setCurrentItem(1, false); break; case R.id.text3:// 點選第三個便籤 mPager.setCurrentItem(2, false); break; default: break; } } }
自定義MyViewPager
package com.example.myviewpager; import android.content.Context; import android.support.v4.view.ViewPager; import android.util.AttributeSet; import android.view.MotionEvent; /** * 自定義滑動翻頁可控,可通過設定isCanScroll引數來控制是否允許滑動切換頁面 */ public class MyViewPager extends ViewPager { /** 是否允許滑動翻頁 ,預設可滑動*/ private boolean isCanScroll = true; public MyViewPager(Context context, AttributeSet attrs) { super(context, attrs); } public MyViewPager(Context context) { super(context); } public boolean isCanScroll() { return isCanScroll; } /** 設定是否可以滑動翻頁 */ public void setCanScroll(boolean isCanScroll) { this.isCanScroll = isCanScroll; } @Override public void scrollTo(int x, int y) { super.scrollTo(x, y); } // 設定禁止滑動的關鍵 @Override public boolean onTouchEvent(MotionEvent arg0) { if (!isCanScroll) return true; return super.onTouchEvent(arg0); } @Override public boolean onInterceptTouchEvent(MotionEvent arg0) { return super.onInterceptTouchEvent(arg0); } @Override public void setCurrentItem(int item, boolean smoothScroll) { super.setCurrentItem(item, smoothScroll); } @Override public void setCurrentItem(int item) { super.setCurrentItem(item); } }
介面卡:
package com.example.myviewpager; import java.util.List; import android.support.v4.view.PagerAdapter; import android.view.View; import android.view.ViewGroup; /** * viewpager介面卡 * */ public class MyViewPagerAdapter extends PagerAdapter{ private List<View> mListViews; public MyViewPagerAdapter(List<View> mListViews) { this.mListViews = mListViews;//構造方法,引數是我們的頁卡,這樣比較方便 } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(mListViews.get(position));//刪除頁卡 } @Override public Object instantiateItem(ViewGroup container, int position) { //這個方法用來例項化頁卡 container.addView(mListViews.get(position), 0);//新增頁卡 return mListViews.get(position); } @Override public int getCount() { return mListViews.size();//返回頁卡的數目 } @Override public boolean isViewFromObject(View arg0, Object arg1) { return arg0==arg1;//官方提示這樣寫 } }
第一個view
package com.example.myviewpager; import android.content.Context; import android.view.LayoutInflater; import android.view.View; /** * 第一個 * @author cgx * */ public class View1 { private Context mContext; private View rootView; public View1(Context mContext) { // TODO Auto-generated constructor stub this.mContext=mContext; //載入佈局 rootView = LayoutInflater.from(mContext).inflate( R.layout.view1_layout, null); } public View getView(){ return rootView; } }
activity佈局檔案
<LinearLayout 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:orientation="vertical" > <LinearLayout android:id="@+id/linearLayout1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="#FFFFFF" > <TextView android:id="@+id/text1" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:text="頁卡1" android:textColor="#000000" android:textSize="20sp" /> <TextView android:id="@+id/text2" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:text="頁卡2" android:textColor="#000000" android:textSize="20sp" /> <TextView android:id="@+id/text3" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1.0" android:gravity="center" android:text="頁卡3" android:textColor="#000000" android:textSize="20sp" /> </LinearLayout> <com.example.myviewpager.MyViewPager android:id="@+id/vPager" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_weight="1.0" android:background="#000000" android:flipInterval="30" /> </LinearLayout>
View1的佈局
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#123456" > </LinearLayout>
由於用於演示,所以view的佈局只是用不同的背景色來區分,開發中具體要展示的佈局可以直接在view的佈局檔案裡面改。demo中的view都是參考第一個來寫的,類似
總結
實際開發中,雖然官方提供了很多api,真正等到要自己用的時候,還是自己在依照習慣再包裝一層,成為自己的工具,這樣以後就可以直接用了,上面的例子是我在實習期間總結的,鄙陋之處敬請原諒,也歡迎大家指出,一起學習(^_^)
程式碼連結:http://pan.baidu.com/s/1pJAF6Gz
相關文章
- Android 專案總結(一):弧形ViewPager 和弧形HeaderViewAndroidViewpagerHeader
- Android ViewPager使用詳解AndroidViewpager
- FragmentContainerView、ViewPager、ViewPager2與 BottomNaviagtionView結合使用的區別FragmentAIViewpager
- Android View 使用總結AndroidView
- Android 在 ViewPager 中使用 Fragment 的懶載入AndroidViewpagerFragment
- Android開發之ViewPager簡單使用AndroidViewpager
- 在 Android 中使用 JNI 的總結Android
- Android HandlerThread使用總結Androidthread
- Android Banner - ViewPager 02AndroidViewpager
- Android ShareUserId 使用總結Android
- Android的Paint、Canvas和Path基本使用總結AndroidAICanvas
- Android中使用WebView遇到的問題總結:AndroidWebView
- 關於Android Studio使用Git的總結AndroidGit
- Android的程式與執行緒使用總結Android執行緒
- Android Studio 快捷鍵使用總結Android
- Android中使用RecyclerView + SnapHelper實現類似ViewPager效果AndroidViewpager
- Android使用(TabLayout+ViewPager+fragment)與(FragmentTabHost+ViewPager+Fragment)實現底部狀態列切換AndroidTabLayoutViewpagerFragment
- 關於Android中使用Enum的一點總結Android
- Android 禁止ViewPager左右滑動AndroidViewpager
- Android混合開發之WebView使用總結AndroidWebView
- Android 夜間模式庫 changeskin 使用總結Android模式
- Android ORM 框架 greenDAO 使用經驗總結AndroidORM框架
- 1-VIII–ViewPager的基本使用Viewpager
- Android中的NDK總結Android
- 在Fragment裡使用viewpagerFragmentViewpager
- android webview總結AndroidWebView
- Android面試總結Android面試
- Android 總結 bookAndroid
- Android總結1Android
- Android View總結AndroidView
- ListenalbeFuture的使用總結
- git的使用總結Git
- WebView的使用總結WebView
- JXCategoryView的使用總結GoView
- cmake的使用總結
- 【Android ViewPager】解決ViewPager使用DepthPageTransformer時事件會被下一頁捕獲導致事件錯亂的問題AndroidViewpagerORM事件
- Android ViewPager2 + Fragment 聯動AndroidViewpagerFragment
- Android開發之ViewPager+FragmentAndroidViewpagerFragment