Android_ViewPager_實現多個圖片水平滾動


1.示意圖

 

          

          

2.實現分析

(1).xml配置


 
  1. <!-- 配置container和pager的clipChildren=false, 並且指定marginLeft 和 marginRight 的值-->  
  2. <LinearLayout  
  3.     android:id="@+id/container"  
  4.     android:layout_width="match_parent"  
  5.     android:layout_height="100dp"  
  6.     android:clipChildren="false"  
  7.     android:gravity="center_horizontal"  
  8.     android:layerType="software"  
  9.     android:orientation="horizontal" >  
  10.   
  11.     <android.support.v4.view.ViewPager  
  12.         android:id="@+id/viewpager"  
  13.         android:layout_width="match_parent"  
  14.         android:layout_height="match_parent"  
  15.         android:layout_marginLeft="110dp"  
  16.         android:layout_marginRight="110dp"  
  17.         android:clipChildren="false" >  
  18.     </android.support.v4.view.ViewPager>  
  19. </LinearLayout>  

(2).java代碼


 
  1. // 1.設置幕后item的緩存數目  
  2. viewPager.setOffscreenPageLimit(3);   
  3. // 2.設置頁與頁之間的間距  
  4. viewPager.setPageMargin(10);  
  5. // 3.將父類的touch事件分發至viewPgaer,否則只能滑動中間的一個view對象  
  6. container.setOnTouchListener(new View.OnTouchListener() {  
  7.     @Override  
  8.     public boolean onTouch(View v, MotionEvent event) {  
  9.         return viewPager.dispatchTouchEvent(event);  
  10.     }  
  11. });  

 

3.代碼實現


 
  1. /** 
  2.  * MainActivity.java 
  3.  *  
  4.  * @author http://blog.csdn.net/zimo2013 
  5.  *  
  6.  */  
  7. public class MainActivity extends Activity implements OnPageChangeListener {  
  8.   
  9.     private ViewPager viewPager;  
  10.     private List<View> views = new ArrayList<View>();  
  11.   
  12.     private LinearLayout container;  
  13.     private TextView tvTitle;  
  14.     private LayoutInflater inflater;  
  15.   
  16.     private String dir;  
  17.   
  18.     @Override  
  19.     protected void onCreate(Bundle savedInstanceState) {  
  20.         super.onCreate(savedInstanceState);  
  21.         setContentView(R.layout.activity_main);  
  22.   
  23.         inflater = getLayoutInflater();  
  24.         container = (LinearLayout) findViewById(R.id.container);  
  25.         viewPager = (ViewPager) findViewById(R.id.viewpager);  
  26.         tvTitle = (TextView) findViewById(R.id.title);  
  27.   
  28.         //這里預先在sdcard准備一些輪播圖片資源  
  29.         dir = Environment.getExternalStorageDirectory().getAbsolutePath();  
  30.         // 得到views集合  
  31.         views = new ArrayList<View>();  
  32.         //此處可以根據需要自由設定,這里只是簡單的測試  
  33.         for (int i = 1; i <= 12; i++) {  
  34.             View view = inflater.inflate(R.layout.guide_item, null);  
  35.             views.add(view);  
  36.         }  
  37.           
  38.         /////////////////////主要配置//////////////////////////////////////  
  39.           
  40.         // 1.設置幕后item的緩存數目  
  41.         viewPager.setOffscreenPageLimit(3);   
  42.         // 2.設置頁與頁之間的間距  
  43.         viewPager.setPageMargin(10);  
  44.         // 3.將父類的touch事件分發至viewPgaer,否則只能滑動中間的一個view對象  
  45.         container.setOnTouchListener(new View.OnTouchListener() {  
  46.             @Override  
  47.             public boolean onTouch(View v, MotionEvent event) {  
  48.                 return viewPager.dispatchTouchEvent(event);  
  49.             }  
  50.         });  
  51.   
  52.         ////////////////////////////////////////////////////////////////  
  53.         viewPager.setAdapter(new MyAdapter()); // 為viewpager設置adapter  
  54.         viewPager.setOnPageChangeListener(this);// 設置監聽器  
  55.     }  
  56.   
  57.     // PagerAdapter是object的子類  
  58.     class MyAdapter extends PagerAdapter {  
  59.   
  60.         /** 
  61.          * PagerAdapter管理數據大小 
  62.          */  
  63.         @Override  
  64.         public int getCount() {  
  65.             return views.size();  
  66.         }  
  67.   
  68.         /** 
  69.          * 關聯key 與 obj是否相等,即是否為同一個對象 
  70.          */  
  71.         @Override  
  72.         public boolean isViewFromObject(View view, Object obj) {  
  73.             return view == obj; // key  
  74.         }  
  75.   
  76.         /** 
  77.          * 銷毀當前page的相隔2個及2個以上的item時調用 
  78.          */  
  79.         @Override  
  80.         public void destroyItem(ViewGroup container, int position, Object object) {  
  81.             container.removeView((View) object); // 將view 類型 的object熊容器中移除,根據key  
  82.         }  
  83.   
  84.         /** 
  85.          * 當前的page的前一頁和后一頁也會被調用,如果還沒有調用或者已經調用了destroyItem 
  86.          */  
  87.         @Override  
  88.         public Object instantiateItem(ViewGroup container, int position) {  
  89.             System.out.println("pos:" + position);  
  90.             View view = views.get(position);  
  91.             // 如果訪問網絡下載圖片,此處可以進行異步加載  
  92.             ImageView img = (ImageView) view.findViewById(R.id.icon);  
  93.             img.setImageBitmap(BitmapFactory.decodeFile(dir + getFile(position)));  
  94.             container.addView(view);  
  95.             return views.get(position); // 返回該view對象,作為key  
  96.         }  
  97.     }  
  98.   
  99.     public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {  
  100.         if (viewPager != null) {  
  101.             viewPager.invalidate();  
  102.         }  
  103.     }  
  104.   
  105.     // 一個新頁被調用時執行,仍為原來的page時,該方法不被調用  
  106.     public void onPageSelected(int position) {  
  107.         tvTitle.setText(getFile(position));  
  108.     }  
  109.   
  110.     /* 
  111.      * SCROLL_STATE_IDLE: pager處於空閑狀態 SCROLL_STATE_DRAGGING: pager處於正在拖拽中 
  112.      * SCROLL_STATE_SETTLING: pager正在自動沉降,相當於松手后,pager恢復到一個完整pager的過程 
  113.      */  
  114.     public void onPageScrollStateChanged(int state) {  
  115.     }  
  116.   
  117.     public String getFile(int position) {  
  118.         return "/img" + ((position + 1) >= 10 ? (position + 1) : "0" + (position + 1)) + ".png";  
  119.     }  
  120. }  
 
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     android:layout_width="match_parent"  
  3.     android:layout_height="match_parent"  
  4.     android:layout_marginLeft="15dp"  
  5.     android:layout_marginRight="15dp"  
  6.     android:layout_marginTop="50dp"  
  7.     android:orientation="vertical" >  
  8.   
  9.     <View  
  10.         android:layout_width="match_parent"  
  11.         android:layout_height="2dp"  
  12.         android:background="#ffbd2021" />  
  13.   
  14.     <!-- 配置container和pager的clipChildren=false, 並且指定marginLeft 和 marginRight 的值 -->  
  15.   
  16.     <LinearLayout  
  17.         android:id="@+id/container"  
  18.         android:layout_width="match_parent"  
  19.         android:layout_height="100dp"  
  20.         android:clipChildren="false"  
  21.         android:gravity="center_horizontal"  
  22.         android:layerType="software"  
  23.         android:orientation="horizontal" >  
  24.   
  25.         <android.support.v4.view.ViewPager  
  26.             android:id="@+id/viewpager"  
  27.             android:layout_width="match_parent"  
  28.             android:layout_height="match_parent"  
  29.             android:layout_marginLeft="110dp"  
  30.             android:layout_marginRight="110dp"  
  31.             android:clipChildren="false" >  
  32.         </android.support.v4.view.ViewPager>  
  33.     </LinearLayout>  
  34.   
  35.     <View  
  36.         android:layout_width="match_parent"  
  37.         android:layout_height="2dp"  
  38.         android:background="#ffbd2021" />  
  39.   
  40.     <ImageView  
  41.         android:layout_width="match_parent"  
  42.         android:layout_height="wrap_content"  
  43.         android:background="@drawable/line" />  
  44.   
  45.     <TextView  
  46.         android:id="@+id/title"  
  47.         android:layout_width="match_parent"  
  48.         android:layout_height="wrap_content"  
  49.         android:layout_gravity="center"  
  50.         android:gravity="center_horizontal"  
  51.         android:scaleType="fitXY"  
  52.         android:src="@drawable/ic_launcher"  
  53.         android:text="baidu"  
  54.         android:textSize="18sp" />  
  55.   
  56. </LinearLayout>  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM