Android 滑動(dòng)小圓點(diǎn)ViewPager的兩種設(shè)置方法詳解流程
第一種方法:
一、測(cè)試如下,直接設(shè)置小圓點(diǎn)不是圖標(biāo)
二、準(zhǔn)備工作
1.在drawable創(chuàng)建dot.xml,設(shè)置小圓點(diǎn),比較方便
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_selected="true"> <shape android:shape="oval"> <solid android:color="@color/black" /> <corners android:radius="8dp" /> </shape> </item> <item android:state_selected="false"> <shape android:shape="oval"> <solid android:color="@color/white" /> <corners android:radius="8dp" /> </shape> </item> </selector>
2.布局小圓點(diǎn)的狀態(tài)可以被左右滑動(dòng)dotview.xml
<!--?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:padding="5dp"> <ImageView android:id="@+id/v_dot" android:layout_width="10dp" android:layout_height="10dp" android:src="@drawable/dot"/> </LinearLayout>
3.分頁適配器自定義ViewPagerAdapter.java
public class ViewPagerAdapter extends PagerAdapter { private List<View> mViewList; public ViewPagerAdapter(List<View> mViewList) { this.mViewList = mViewList; } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(mViewList.get(position)); } @Override public Object instantiateItem(ViewGroup container, int position) { container.addView(mViewList.get(position)); return (mViewList.get(position)); } @Override public int getCount() { if (mViewList == null) return 0; return mViewList.size(); } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } }
三、使用工作:
1.activity_main.xml
<?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="wrap_content" android:background="#D4D3D3"> <RelativeLayout android:layout_width="match_parent" android:layout_height="100dp" android:background="#FFFFFF" android:orientation="vertical"> <android.support.v4.view.ViewPager android:id="@+id/viewpager" android:layout_width="match_parent" android:layout_height="wrap_content" /> <LinearLayout android:id="@+id/ll_dots" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:gravity="center" android:orientation="horizontal" /> </RelativeLayout> </LinearLayout>
分析下布局結(jié)構(gòu):
(1)首先是一個(gè)ViewPager,用于結(jié)合GridView實(shí)現(xiàn)左右滑動(dòng)菜單
(2)下面是一個(gè)LinearLayout,有多少個(gè)ViewPager的頁面就會(huì)inflate出多少個(gè)小圓點(diǎn),并且在ViewPager翻頁時(shí),也就是說在左右滑動(dòng)時(shí),下面小圓點(diǎn)的狀態(tài)也要相應(yīng)地做出改變
2.MainActivity.java
public class MainActivity extends AppCompatActivity { private ViewPager mPager; private LinearLayout mLlDots; private LayoutInflater inflater; private List<View> mPagerList; private int pageCount = 3;//默認(rèn)三個(gè)小點(diǎn) /** * 當(dāng)前顯示的是第幾頁 */ private int curIndex = 0; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mPager = (ViewPager) findViewById(R.id.viewpager); mLlDots = (LinearLayout) findViewById(R.id.ll_dots); inflater = LayoutInflater.from(this); mPagerList = new ArrayList<View>(); //#FF9800:黃,#4CAF50:綠,#2196F3:藍(lán) String[] colors = {"#FF9800", "#4CAF50", "#2196F3"}; for (int i = 0; i < pageCount; i++) { LinearLayout mLL = (LinearLayout) inflater.inflate(R.layout.linearlayout, mPager, false); mLL.setBackgroundColor(Color.parseColor(colors[i])); mPagerList.add(mLL); } //設(shè)置適配器 mPager.setAdapter(new ViewPagerAdapter(mPagerList)); //設(shè)置圓點(diǎn) setDotLayout(); } /** * 設(shè)置圓點(diǎn) */ public void setDotLayout() { for (int i = 0; i < pageCount; i++) { mLlDots.addView(inflater.inflate(R.layout.dotview, null)); } // 默認(rèn)顯示第一頁 mLlDots.getChildAt(0).setSelected(true); mPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { // 取消原點(diǎn)選中 mLlDots.getChildAt(curIndex).setSelected(false); // 原點(diǎn)選中 mLlDots.getChildAt(position).setSelected(true); curIndex = position; } @Override public void onPageScrollStateChanged(int state) { } }); } }
這代碼中一句,布局LinearLayout隨著左右滑動(dòng)小圓點(diǎn)翻頁
LinearLayout mLL = (LinearLayout) inflater.inflate(R.layout.linearlayout, mPager, false);
布局linearlayout.xml
<?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"/>
第二種方法:
一、測(cè)試如下,小圓點(diǎn)圖標(biāo)
二、dotview.xml
...... <ImageView android:id="@+id/v_dot" android:layout_width="10dp" android:layout_height="10dp"/> ......
三、設(shè)置二個(gè)小圓點(diǎn)圖標(biāo)(黑白)
點(diǎn)擊鏈接:二個(gè)小圓點(diǎn)圖標(biāo).zip
// 默認(rèn)顯示第一頁 mLlDots.getChildAt(0).findViewById(R.id.v_dot) .setBackgroundResource(R.drawable.dot_normal); mLlDots.getChildAt(1).findViewById(R.id.v_dot) .setBackgroundResource(R.drawable.dot_selected); mLlDots.getChildAt(2).findViewById(R.id.v_dot) .setBackgroundResource(R.drawable.dot_selected); mPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { public void onPageSelected(int position) { // 取消圓點(diǎn)選中 mLlDots.getChildAt(curIndex) .findViewById(R.id.v_dot) .setBackgroundResource(R.drawable.dot_selected); // 圓點(diǎn)選中 mLlDots.getChildAt(position) .findViewById(R.id.v_dot) .setBackgroundResource(R.drawable.dot_normal); curIndex = position; } public void onPageScrolled(int arg0, float arg1, int arg2) { } public void onPageScrollStateChanged(int arg0) { } });
到此這篇關(guān)于Android 滑動(dòng)小圓點(diǎn)ViewPager的兩種設(shè)置方法詳解流程的文章就介紹到這了,更多相關(guān)Android 滑動(dòng)小圓點(diǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Android深入探究自定義View之嵌套滑動(dòng)的實(shí)現(xiàn)
- Android實(shí)現(xiàn)背景顏色滑動(dòng)漸變效果的全過程
- Android直播軟件搭建之實(shí)現(xiàn)背景顏色滑動(dòng)漸變效果的詳細(xì)代碼
- Android HorizontalScrollView滑動(dòng)與ViewPager切換案例詳解
- Android滑動(dòng)拼圖驗(yàn)證碼控件使用方法詳解
- Android之FanLayout制作圓弧滑動(dòng)效果
- Android之ArcSlidingHelper制作圓弧滑動(dòng)效果
- Android 滑動(dòng)Scrollview標(biāo)題欄漸變效果(仿京東toolbar)
- Android 實(shí)現(xiàn)滑動(dòng)的六種方式
相關(guān)文章
Android 自定義輸入手機(jī)號(hào)自動(dòng)添加分隔符
這篇文章主要介紹了Android 自定義輸入手機(jī)號(hào)自動(dòng)添加分隔符的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05Android之自定義實(shí)現(xiàn)BaseAdapter(通用適配器二)
這篇文章主要為大家詳細(xì)介紹了Android之自定義實(shí)現(xiàn)BaseAdapter通用適配器第二篇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08淺談Android開發(fā)者2017年最值得關(guān)注的25個(gè)實(shí)用庫
本篇文章主要介紹了Android開發(fā)者2017年最值得關(guān)注的25個(gè)庫,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09Android編程實(shí)現(xiàn)讀取工程中的txt文件功能
這篇文章主要介紹了Android編程實(shí)現(xiàn)讀取工程中的txt文件功能,結(jié)合實(shí)例形式詳細(xì)分析了Android讀取txt文件的原理、操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-02-02Android項(xiàng)目實(shí)戰(zhàn)教程之高仿網(wǎng)易云音樂啟動(dòng)頁實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于Android項(xiàng)目實(shí)戰(zhàn)教程之高仿網(wǎng)易云音樂啟動(dòng)頁的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09android使用TextView實(shí)現(xiàn)跑馬燈效果
這篇文章主要為大家詳細(xì)介紹了android使用TextView實(shí)現(xiàn)跑馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05Android基于OpenCV實(shí)現(xiàn)Harris角點(diǎn)檢測(cè)
角點(diǎn)就是極值點(diǎn),即在某方面屬性特別突出的點(diǎn)。當(dāng)然,你可以自己定義角點(diǎn)的屬性(設(shè)置特定熵值進(jìn)行角點(diǎn)檢測(cè))。角點(diǎn)可以是兩條線的交叉處,也可以是位于相鄰的兩個(gè)主要方向不同的事物上的點(diǎn)。本文介紹如何基于OpenCV實(shí)現(xiàn)Harris角點(diǎn)檢測(cè)2021-06-06在Android模擬器上模擬GPS功能總是null的解決方法
在我們開發(fā)時(shí)需要在模擬器上模擬GPS,可在Location的時(shí)候總是null,下面與大家分享下具體的解決方法,感興趣的朋友可以參考下哈2013-06-06