欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android 滑動小圓點ViewPager的兩種設(shè)置方法詳解流程

 更新時間:2021年11月09日 08:49:06   作者:彬sir哥  
Viewpager,視圖翻頁工具,提供了多頁面切換的效果。Android 3.0后引入的一個UI控件,位于v4包中。低版本使用需要導(dǎo)入v4包,現(xiàn)在我們一般不再兼容3.0及以下版本,另外使用Android studio開發(fā),默認導(dǎo)入v7包,v7包含了v4,所以不用導(dǎo)包,越來越方便了

第一種方法:

一、測試如下,直接設(shè)置小圓點不是圖標

二、準備工作

1.在drawable創(chuàng)建dot.xml,設(shè)置小圓點,比較方便

<?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.布局小圓點的狀態(tài)可以被左右滑動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)首先是一個ViewPager,用于結(jié)合GridView實現(xiàn)左右滑動菜單
(2)下面是一個LinearLayout,有多少個ViewPager的頁面就會inflate出多少個小圓點,并且在ViewPager翻頁時,也就是說在左右滑動時,下面小圓點的狀態(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;//默認三個小點
    /**
     * 當前顯示的是第幾頁
     */
    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:藍
        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è)置圓點
        setDotLayout();
    }

    /**
     * 設(shè)置圓點
     */
    public void setDotLayout() {
        for (int i = 0; i < pageCount; i++) {
            mLlDots.addView(inflater.inflate(R.layout.dotview, null));
        }
        // 默認顯示第一頁
        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) {
                // 取消原點選中
                mLlDots.getChildAt(curIndex).setSelected(false);
                // 原點選中
                mLlDots.getChildAt(position).setSelected(true);
                curIndex = position;
            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
    }
}

這代碼中一句,布局LinearLayout隨著左右滑動小圓點翻頁

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"/>

第二種方法:

一、測試如下,小圓點圖標

二、dotview.xml

......
<ImageView
        android:id="@+id/v_dot"
        android:layout_width="10dp"
        android:layout_height="10dp"/>
......

三、設(shè)置二個小圓點圖標(黑白)

點擊鏈接:二個小圓點圖標.zip

        // 默認顯示第一頁
        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) {
                // 取消圓點選中
                mLlDots.getChildAt(curIndex)
                        .findViewById(R.id.v_dot)
                        .setBackgroundResource(R.drawable.dot_selected);
                // 圓點選中
                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 滑動小圓點ViewPager的兩種設(shè)置方法詳解流程的文章就介紹到這了,更多相關(guān)Android 滑動小圓點內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Android 自定義輸入手機號自動添加分隔符

    Android 自定義輸入手機號自動添加分隔符

    這篇文章主要介紹了Android 自定義輸入手機號自動添加分隔符的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • Android之自定義實現(xiàn)BaseAdapter(通用適配器二)

    Android之自定義實現(xiàn)BaseAdapter(通用適配器二)

    這篇文章主要為大家詳細介紹了Android之自定義實現(xiàn)BaseAdapter通用適配器第二篇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 淺談Android開發(fā)者2017年最值得關(guān)注的25個實用庫

    淺談Android開發(fā)者2017年最值得關(guān)注的25個實用庫

    本篇文章主要介紹了Android開發(fā)者2017年最值得關(guān)注的25個庫,非常具有實用價值,需要的朋友可以參考下
    2017-09-09
  • Android編程實現(xiàn)讀取工程中的txt文件功能

    Android編程實現(xiàn)讀取工程中的txt文件功能

    這篇文章主要介紹了Android編程實現(xiàn)讀取工程中的txt文件功能,結(jié)合實例形式詳細分析了Android讀取txt文件的原理、操作步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2017-02-02
  • Kotlin對象比較注意點示例詳解

    Kotlin對象比較注意點示例詳解

    你知道在kotlin中,如何來比較對象相等嗎?下面這篇文章主要給大家介紹了關(guān)于Kotlin對象比較注意點的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • Android項目實戰(zhàn)教程之高仿網(wǎng)易云音樂啟動頁實例代碼

    Android項目實戰(zhàn)教程之高仿網(wǎng)易云音樂啟動頁實例代碼

    這篇文章主要給大家介紹了關(guān)于Android項目實戰(zhàn)教程之高仿網(wǎng)易云音樂啟動頁的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • Android WebView 緩存詳解

    Android WebView 緩存詳解

    這篇文章主要介紹了 Android WebView 緩存詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • android使用TextView實現(xiàn)跑馬燈效果

    android使用TextView實現(xiàn)跑馬燈效果

    這篇文章主要為大家詳細介紹了android使用TextView實現(xiàn)跑馬燈效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • Android基于OpenCV實現(xiàn)Harris角點檢測

    Android基于OpenCV實現(xiàn)Harris角點檢測

    角點就是極值點,即在某方面屬性特別突出的點。當然,你可以自己定義角點的屬性(設(shè)置特定熵值進行角點檢測)。角點可以是兩條線的交叉處,也可以是位于相鄰的兩個主要方向不同的事物上的點。本文介紹如何基于OpenCV實現(xiàn)Harris角點檢測
    2021-06-06
  • 在Android模擬器上模擬GPS功能總是null的解決方法

    在Android模擬器上模擬GPS功能總是null的解決方法

    在我們開發(fā)時需要在模擬器上模擬GPS,可在Location的時候總是null,下面與大家分享下具體的解決方法,感興趣的朋友可以參考下哈
    2013-06-06

最新評論