Android ViewPager自定義輪播圖并解決播放沖突
本文實(shí)例為大家分享了Android ViewPager自定義輪播圖,并解決播放沖突,供大家參考
首先介紹一下這篇小代碼:
注釋全面,簡(jiǎn)單易學(xué),適用初學(xué)者,圖片自擬?。?!
一定要將ArrayList集合&Handler機(jī)制傳到適配器,否則無(wú)法完成展示,也解決不了滑動(dòng)沖突,代碼有點(diǎn)多,但是它通俗易懂啊
layout布局內(nèi)寫法:
<?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.support.v4.view.ViewPager android:id="@+id/pager01" android:layout_width="match_parent" android:layout_height="300dp" /> <RadioGroup android:id="@+id/radioGroup" android:gravity="center" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > </RadioGroup> </LinearLayout>
Activity內(nèi)寫法:
public class Frag_01 extends Fragment { private RadioGroup radioGroup; private ViewPager pager; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.frag_01, container, false); // 找Viewpager控件 radioGroup = (RadioGroup) view.findViewById(R.id.radioGroup); pager = (ViewPager) view.findViewById(R.id.pager01); // 圖片數(shù)據(jù)自擬-->drawable文件夾下 int arr[] = { R.drawable.a1, R.drawable.a2, R.drawable.a3, R.drawable.a4, R.drawable.a5 }; final ArrayList<ImageView> list = new ArrayList<ImageView>(); for (int i = 0; i < arr.length; i++) { ImageView imageView = new ImageView(getActivity()); imageView.setImageResource(arr[i]); list.add(imageView); // 生成小圓點(diǎn) RadioButton radioButton = new RadioButton(getActivity()); radioGroup.addView(radioButton); } // 默認(rèn)選中第一個(gè) radioGroup.check(radioGroup.getChildAt(0).getId()); // 適配器 pager.setAdapter(new MyPagerAdapter(list, handler)); // 頁(yè)面切換監(jiān)聽(tīng) pager.setOnPageChangeListener(new OnPageChangeListener() { @Override public void onPageSelected(int arg0) { //根據(jù)頁(yè)面索引控制小圓點(diǎn)切換 arg0 %= list.size(); radioGroup.check(radioGroup.getChildAt(arg0).getId()); } @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 } }); //handler發(fā)送消息 handler.sendEmptyMessageDelayed(0, 3000); return view; } //Handler機(jī)制----------------------------------------- Handler handler = new Handler() { public void handleMessage(android.os.Message msg) { switch (msg.what) { case 0: //獲取到下一頁(yè)的條目--->賦值給當(dāng)前條目 int currentItem = pager.getCurrentItem() + 1; pager.setCurrentItem(currentItem); handler.sendEmptyMessageDelayed(0, 3000); break; default: break; } }; }; }
PagerAdapter適配器的寫法:(內(nèi)含滑動(dòng)沖突解決方案)
public class MyPagerAdapter extends PagerAdapter { private ArrayList<ImageView> list; private Handler handler; //構(gòu)造 public MyPagerAdapter(ArrayList<ImageView> list, Handler handler) { super(); this.list = list; this.handler = handler; } @Override public int getCount() { // 設(shè)置最大值 return Integer.MAX_VALUE; } @Override public boolean isViewFromObject(View arg0, Object arg1) { //當(dāng)前視圖和新加載視圖判斷-->為真才能去銷毀 return arg0 == arg1; } // 添加視圖 // ----該方法內(nèi)包含滑動(dòng)沖突---- @Override public Object instantiateItem(ViewGroup container, int position) { position %= list.size(); ImageView imageView = list.get(position); imageView.setOnTouchListener(new OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { // 獲取事件 int action = event.getAction(); switch (action) { case MotionEvent.ACTION_MOVE:// 滑動(dòng) handler.removeCallbacksAndMessages(null); break; case MotionEvent.ACTION_DOWN:// 按下 handler.removeCallbacksAndMessages(null); break; case MotionEvent.ACTION_CANCEL:// 非人為操作 handler.sendEmptyMessageDelayed(0, 3000); break; case MotionEvent.ACTION_UP:// 抬起 handler.sendEmptyMessageDelayed(0, 3000); break; } return true; } }); //獲取的圖片存進(jìn)容器 container.addView(imageView); return imageView; } // 銷毀視圖 @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView((View) object); } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android開(kāi)發(fā)之ViewPager實(shí)現(xiàn)滑動(dòng)切換頁(yè)面
- Android性能優(yōu)化之ViewPagers?+?Fragment緩存優(yōu)化
- android?viewpager實(shí)現(xiàn)輪播效果
- Android使用ViewPager實(shí)現(xiàn)翻頁(yè)效果
- Android ViewPager實(shí)現(xiàn)頁(yè)面左右切換效果
- android?ViewPager實(shí)現(xiàn)一個(gè)無(wú)限輪播圖
- Android實(shí)現(xiàn)自動(dòng)變換大小的ViewPager
相關(guān)文章
Android View進(jìn)行手勢(shì)識(shí)別詳解
本文主要介紹 Android View進(jìn)行手勢(shì)識(shí)別,這里整理了相關(guān)資料和簡(jiǎn)單示例,有興趣的小伙伴可以參考下2016-08-08Android實(shí)現(xiàn)手機(jī)定位的案例代碼
今天小編就為大家分享一篇關(guān)于Android實(shí)現(xiàn)手機(jī)定位的案例代碼,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03解決Android Studio導(dǎo)入項(xiàng)目非常慢的辦法
在使用Android studio的時(shí)候常常遇到這樣的問(wèn)題,從其他地方導(dǎo)入項(xiàng)目,Android studio呈現(xiàn)非常慢的現(xiàn)象!當(dāng)遇到這種情況時(shí),可以看看是下面這篇文章,再按照方法來(lái)解決!2016-09-09Android中Market的Loading效果實(shí)現(xiàn)方法
這篇文章主要介紹了Android中Market的Loading效果實(shí)現(xiàn)方法,較為詳細(xì)的分析了Android中l(wèi)oading效果的相關(guān)布局及功能實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10Android使用MediaPlayer和TextureView實(shí)現(xiàn)視頻無(wú)縫切換
這篇文章主要為大家詳細(xì)介紹了Android使用MediaPlayer和TextureView實(shí)現(xiàn)視頻無(wú)縫切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10Android app應(yīng)用多語(yǔ)言切換功能實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Android app應(yīng)用多語(yǔ)言切換功能實(shí)現(xiàn)代碼,感興趣的小伙伴們可以參考一下2016-08-08Android時(shí)間對(duì)話框TimePickerDialog詳解
這篇文章主要為大家詳細(xì)介紹了Android時(shí)間對(duì)話框TimePickerDialog的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02