Android ViewPager控件實現圖片輪播

圖片輪播在很多app中需要使用到,下面源碼是通過Android ViewPgaer控件實現圖片輪播。

源碼下載:http://download.csdn.net/detail/zouchao911/8308427

效果圖:



1、MainActivity.java文件代碼:

[java] view plaincopy
  1. package com.example.picturecarousel;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5. import java.util.concurrent.Executors;  
  6. import java.util.concurrent.ScheduledExecutorService;  
  7. import java.util.concurrent.TimeUnit;  
  8.   
  9. import android.os.Bundle;  
  10. import android.os.Handler;  
  11. import android.os.Message;  
  12. import android.app.Activity;  
  13. import android.support.v4.view.PagerAdapter;  
  14. import android.support.v4.view.ViewPager;  
  15. import android.support.v4.view.ViewPager.OnPageChangeListener;  
  16. import android.view.Menu;  
  17. import android.view.MotionEvent;  
  18. import android.view.View;  
  19. import android.view.View.OnTouchListener;  
  20. import android.view.ViewGroup;  
  21. import android.widget.ImageView;  
  22. import android.widget.ImageView.ScaleType;  
  23. import android.widget.LinearLayout;  
  24. import android.widget.ViewFlipper;  
  25.   
  26. public class MainActivity extends Activity {  
  27.   
  28.     private ViewPager view_pager;  
  29.     private LinearLayout ll_dotGroup;  
  30.   
  31.     private int imgResIds[] = new int[] { R.drawable.a, R.drawable.b,  
  32.             R.drawable.c, R.drawable.d };  
  33.   
  34.     private int curIndex = 0;  
  35.     PicsAdapter picsAdapter;  
  36.   
  37.     @Override  
  38.     protected void onCreate(Bundle savedInstanceState) {  
  39.         super.onCreate(savedInstanceState);  
  40.         setContentView(R.layout.activity_main);  
  41.   
  42.         view_pager = (ViewPager) findViewById(R.id.view_pager);  
  43.         ll_dotGroup = (LinearLayout) findViewById(R.id.dotgroup);  
  44.   
  45.         picsAdapter = new PicsAdapter(); // 創建適配器  
  46.         picsAdapter.setData(imgResIds);  
  47.         view_pager.setAdapter(picsAdapter); // 設置適配器  
  48.   
  49.         view_pager.setOnPageChangeListener(new MyPageChangeListener()); //設置頁面切換監聽器  
  50.   
  51.         initPoints(imgResIds.length); // 初始化圖片小圓點  
  52.         startAutoScroll(); // 開啓自動播放  
  53.   
  54.     }  
  55.   
  56.     // 初始化圖片輪播的小圓點  
  57.     private void initPoints(int count) {  
  58.         for (int i = 0; i < count; i++) {  
  59.   
  60.             ImageView iv = new ImageView(this);  
  61.             LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(  
  62.                     1515);  
  63.             params.setMargins(00200);  
  64.             iv.setLayoutParams(params);  
  65.   
  66.             iv.setImageResource(R.drawable.dot1);  
  67.             ll_dotGroup.addView(iv);  
  68.   
  69.         }  
  70.         ((ImageView) ll_dotGroup.getChildAt(curIndex))  
  71.                 .setImageResource(R.drawable.dot2);  
  72.     }  
  73.   
  74.     // 自動播放  
  75.     private void startAutoScroll() {  
  76.         ScheduledExecutorService scheduledExecutorService = Executors  
  77.                 .newSingleThreadScheduledExecutor();  
  78.         // 每隔2秒鐘切換一張圖片  
  79.         scheduledExecutorService.scheduleWithFixedDelay(new ViewPagerTask(), 2,  
  80.                 10, TimeUnit.SECONDS);  
  81.     }  
  82.   
  83.     // 切換圖片任務  
  84.     private class ViewPagerTask implements Runnable {  
  85.         @Override  
  86.         public void run() {  
  87.   
  88.             runOnUiThread(new Runnable() {  
  89.                 @Override  
  90.                 public void run() {  
  91.                     int count = picsAdapter.getCount();  
  92.                     view_pager.setCurrentItem((curIndex + 1) % count);  
  93.                 }  
  94.             });  
  95.         }  
  96.     }  
  97.   
  98.     // 定義ViewPager控件頁面切換監聽器  
  99.     class MyPageChangeListener implements OnPageChangeListener {  
  100.           
  101.         @Override  
  102.         public void onPageScrolled(int position, float positionOffset,  
  103.                 int positionOffsetPixels) {  
  104.         }  
  105.   
  106.         @Override  
  107.         public void onPageSelected(int position) {  
  108.             ImageView imageView1 = (ImageView) ll_dotGroup.getChildAt(position);  
  109.             ImageView imageView2 = (ImageView) ll_dotGroup.getChildAt(curIndex);  
  110.             if (imageView1 != null) {  
  111.                 imageView1.setImageResource(R.drawable.dot2);  
  112.             }  
  113.             if (imageView2 != null) {  
  114.                 imageView2.setImageResource(R.drawable.dot1);  
  115.             }  
  116.             curIndex = position;  
  117.               
  118.         }  
  119.           
  120.           
  121.         boolean b = false;  
  122.         @Override  
  123.         public void onPageScrollStateChanged(int state) {  
  124.             //這段代碼可不加,主要功能是實現切換到末尾後返回到第一張  
  125.             switch (state) {  
  126.             case 1:// 手勢滑動  
  127.                 b = false;  
  128.                 break;  
  129.             case 2:// 界面切換中  
  130.                 b = true;  
  131.                 break;  
  132.             case 0:// 滑動結束,即切換完畢或者加載完畢  
  133.                 // 當前爲最後一張,此時從右向左滑,則切換到第一張  
  134.                 if (view_pager.getCurrentItem() == view_pager.getAdapter()  
  135.                         .getCount() - 1 && !b) {  
  136.                     view_pager.setCurrentItem(0);  
  137.                 }  
  138.                 // 當前爲第一張,此時從左向右滑,則切換到最後一張  
  139.                 else if (view_pager.getCurrentItem() == 0 && !b) {  
  140.                     view_pager.setCurrentItem(view_pager.getAdapter()  
  141.                             .getCount() - 1);  
  142.                 }  
  143.                 break;  
  144.   
  145.             default:  
  146.                 break;  
  147.             }  
  148.         }  
  149.     }  
  150.   
  151.     // 定義ViewPager控件適配器  
  152.     class PicsAdapter extends PagerAdapter {  
  153.   
  154.         private List<ImageView> views = new ArrayList<ImageView>();  
  155.   
  156.         @Override  
  157.         public int getCount() {  
  158.             if (views == null) {  
  159.                 return 0;  
  160.             }  
  161.             return views.size();  
  162.         }  
  163.   
  164.         public void setData(int[] imgResIds) {  
  165.             for (int i = 0; i < imgResIds.length; i++) {  
  166.                 ImageView iv = new ImageView(MainActivity.this);  
  167.                 ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(  
  168.                         ViewGroup.LayoutParams.MATCH_PARENT,  
  169.                         ViewGroup.LayoutParams.MATCH_PARENT);  
  170.                 iv.setLayoutParams(params);  
  171.                 iv.setScaleType(ScaleType.FIT_XY);  
  172.                 iv.setImageResource(imgResIds[i]);  
  173.                 views.add(iv);  
  174.             }  
  175.         }  
  176.   
  177.         public Object getItem(int position) {  
  178.             if (position < getCount())  
  179.                 return views.get(position);  
  180.             return null;  
  181.         }  
  182.   
  183.         @Override  
  184.         public boolean isViewFromObject(View arg0, Object arg1) {  
  185.             return arg0 == arg1;  
  186.         }  
  187.   
  188.         @Override  
  189.         public void destroyItem(View container, int position, Object object) {  
  190.   
  191.             if (position < views.size())  
  192.                 ((ViewPager) container).removeView(views.get(position));  
  193.         }  
  194.   
  195.         @Override  
  196.         public int getItemPosition(Object object) {  
  197.             return views.indexOf(object);  
  198.         }  
  199.   
  200.         @Override  
  201.         public Object instantiateItem(View container, int position) {  
  202.             if (position < views.size()) {  
  203.                 final ImageView imageView = views.get(position);  
  204.                 ((ViewPager) container).addView(imageView);  
  205.                 return views.get(position);  
  206.             }  
  207.             return null;  
  208.         }  
  209.   
  210.     }  
  211.   
  212. }  


2、主佈局文件activity_main.xml

[html] view plaincopy
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     tools:context=".MainActivity" >  
  6.   
  7.     <RelativeLayout  
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="150dp"  
  10.         android:layout_marginBottom="5dp"  
  11.         android:orientation="vertical" >  
  12.   
  13.         <android.support.v4.view.ViewPager  
  14.             android:id="@+id/view_pager"  
  15.             android:layout_width="match_parent"  
  16.             android:layout_height="match_parent"  
  17.             android:layout_gravity="center" >  
  18.         </android.support.v4.view.ViewPager>  
  19.   
  20.         <LinearLayout  
  21.             android:id="@+id/dotgroup"  
  22.             android:layout_width="match_parent"  
  23.             android:layout_height="wrap_content"  
  24.             android:layout_alignParentBottom="true"  
  25.             android:gravity="center"  
  26.             android:layout_marginBottom="15dp"  
  27.             android:orientation="horizontal" >  
  28.         </LinearLayout>  
  29.     </RelativeLayout>  
  30.   
  31. </RelativeLayout>  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章