zoukankan      html  css  js  c++  java
  • 一手遮天 Android

    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

    一手遮天 Android - view(集合类): ViewPager 基础 1

    示例如下:

    /view/collection/ViewPagerDemo1.java

    /**
     * ViewPager - 页面切换控件
     *     setCurrentItem() - 指定 ViewPager 当前显示的页面的索引位置
     *     setAdapter() - 指定用于为 ViewPager 呈现数据的 PagerAdapter 对象
     *
     * 本例演示
     * 1、如何通过自定义的 PagerAdapter 来为 ViewPager 对象提供数据
     * 2、PagerAdapter 会缓存 3 个页,即当前页、左边页和右边页
     *    需要被缓存就调用 instantiateItem(),不需要被缓存就调用 destroyItem()
     * 3、如何为 ViewPager 的每个页面添加类似 Tab 控件的标题
     */
    
    package com.webabcd.androiddemo.view.collection;
    
    import androidx.viewpager.widget.PagerAdapter;
    import androidx.viewpager.widget.ViewPager;
    import androidx.appcompat.app.AppCompatActivity;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.ViewGroup;
    
    import com.webabcd.androiddemo.R;
    
    import java.util.ArrayList;
    
    public class ViewPagerDemo1 extends AppCompatActivity {
    
        private final String LOG_TAG = "ViewPagerDemo1";
    
        private ViewPager mViewPager1;
        private ViewPager mViewPager2;
        private ViewPager mViewPager3;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_view_collection_viewpagerdemo1);
    
            mViewPager1 = findViewById(R.id.viewPager1);
            mViewPager2 = findViewById(R.id.viewPager2);
            mViewPager3 = findViewById(R.id.viewPager3);
    
            sample();
        }
    
        private void sample() {
            ViewPager[] viewPagerList = {mViewPager1, mViewPager2, mViewPager3};
            for (ViewPager viewPager: viewPagerList) {
                // 用于保存 ViewPager 的每个 view
                ArrayList viewList = new ArrayList<View>();
                LayoutInflater layoutInflater = getLayoutInflater();
                viewList.add(layoutInflater.inflate(R.layout.activity_view_collection_viewpagerdemo1_page1, null, false));
                viewList.add(layoutInflater.inflate(R.layout.activity_view_collection_viewpagerdemo1_page2, null, false));
                viewList.add(layoutInflater.inflate(R.layout.activity_view_collection_viewpagerdemo1_page3, null, false));
    
                // 用于保存 ViewPager 的每个 view 的标题
                ArrayList titleList = new ArrayList<String>();
                titleList.add("红色");
                titleList.add("绿色");
                titleList.add("蓝色");
    
                // 实例化自定义的 PagerAdapter
                MyPagerAdapter myPagerAdapter = new MyPagerAdapter(viewList, titleList);
                // 指定 ViewPager 的 PagerAdapter
                viewPager.setAdapter(myPagerAdapter);
            }
        }
    
        /**
         * 自定义 PagerAdapter 用于为 ViewPager 提供数据
         */
        class MyPagerAdapter extends PagerAdapter {
    
            private ArrayList<View> mViewList;
            private ArrayList<String> mTitleList;
    
            public MyPagerAdapter() {
            }
    
            public MyPagerAdapter(ArrayList<View> viewList, ArrayList<String> titleList) {
                super();
    
                this.mViewList = viewList;
                this.mTitleList = titleList;
            }
    
            // ViewPager 的页面的数量
            @Override
            public int getCount() {
                return mViewList.size();
            }
    
            // 固定这么写就好
            @Override
            public boolean isViewFromObject(View view, Object object) {
                return view == object;
            }
    
            // 将 ViewPager 的指定索引位置的 view 添加进容器,并返回这个 view
            @Override
            public Object instantiateItem(ViewGroup container, int position) {
                View view = mViewList.get(position);
                container.addView(view);
    
                // 用于验证 PagerAdapter 会缓存 3 个页,即当前页、左边页和右边页
                Log.d(LOG_TAG, "instantiateItem: " + position);
    
                return view;
            }
    
            // 将 ViewPager 的指定索引位置的 view 从容器中删除
            @Override
            public void destroyItem(ViewGroup container, int position, Object object) {
                container.removeView(mViewList.get(position));
    
                // 用于验证 PagerAdapter 会缓存 3 个页,即当前页、左边页和右边页
                Log.d(LOG_TAG, "destroyItem: " + position);
            }
    
            // 返回 ViewPager 的指定索引位置的 view 的标题
            @Override
            public CharSequence getPageTitle(int position) {
                return mTitleList.get(position);
            }
        }
    }
    
    

    /layout/activity_view_collection_viewpagerdemo1.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:orientation="vertical">
    
        <!--
            ViewPager - 页面切换控件
        -->
        <androidx.viewpager.widget.ViewPager
            android:id="@+id/viewPager1"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1">
        </androidx.viewpager.widget.ViewPager>
    
        <!--
            ViewPager - 页面切换控件
                PagerTitleStrip - 为 ViewPager 增加不同页面的标题(类似 Tab 控件),标题无下划线
        -->
        <androidx.viewpager.widget.ViewPager
            android:id="@+id/viewPager2"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1">
            <androidx.viewpager.widget.PagerTitleStrip
                android:layout_width="wrap_content"
                android:layout_height="32dp"
                android:background="@color/orange"
                android:textColor="@color/white" />
        </androidx.viewpager.widget.ViewPager>
    
    
        <!--
            ViewPager - 页面切换控件
                PagerTabStrip - 为 ViewPager 增加不同页面的标题(类似 Tab 控件),标题有下划线
        -->
        <androidx.viewpager.widget.ViewPager
            android:id="@+id/viewPager3"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1">
            <androidx.viewpager.widget.PagerTabStrip
                android:layout_width="wrap_content"
                android:layout_height="32dp"
                android:background="@color/orange"
                android:textColor="@color/white" />
        </androidx.viewpager.widget.ViewPager>
    
    </LinearLayout>
    
    

    /layout/activity_view_collection_viewpagerdemo1_page1.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:background="@color/red"
        android:orientation="vertical">
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="page 1"
            android:textColor="@color/white"
            android:textSize="24sp"/>
    
    </LinearLayout>
    
    

    /layout/activity_view_collection_viewpagerdemo1_page2.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:background="@color/green"
        android:orientation="vertical">
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="page 2"
            android:textColor="@color/white"
            android:textSize="24sp"/>
    
    </LinearLayout>
    
    

    /layout/activity_view_collection_viewpagerdemo1_page3.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:background="@color/blue"
        android:orientation="vertical">
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="page 3"
            android:textColor="@color/white"
            android:textSize="24sp"/>
    
    </LinearLayout>
    
    

    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

  • 相关阅读:
    web页面与多页应用(布局示例普通文档流)
    web页面与多页应用(一)
    Flutter,webview里面实现上传和下载的功能
    Flutter项目删除了相关的dart文件之后运行flutter run或者 F5编译运行时会报这个错误.... were declared as an inputs, but did not exist. Check the definition of target:kernel_snapshot for errors
    vue项目中,点击输入框的时候,弹出的键盘挡住了输入框,需要把输入框展示在可见区域中,不被遮挡
    在IE浏览器上,min-hheight:unset/line-hight:unset不生效问题解决,把unset换成auto,问题只要时IE浏览器设置unset不生效
    本人修改了,需要把新的AndroidManifest.xml 覆盖原来的,AndroidManifest.xml 覆盖问题
    使用Filter来过滤掉需要排除的数组对象
    深拷贝和浅拷贝
    正则表达式
  • 原文地址:https://www.cnblogs.com/webabcd/p/android_view_collection_ViewPagerDemo1.html
Copyright © 2011-2022 走看看