热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:Android之ViewPager的简单使用

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Android之ViewPager的简单使用相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Android之ViewPager的简单使用相关的知识,希望对你有一定的参考价值。






android ViewPager的简单使用

Android 3.0后引入的一个UI控件——ViewPager(视图滑动切换工具)

功能:通过手势滑动可以完成View的切换,一般是用来做APP 的引导页或者实现图片轮播,因为是3.0后引入的,如果想在低版本下使用,就需要引入v4 兼容包

ViewPager就是一个简单的页面切换组件,我们可以往里面填充多个View,然后我们可以左 右滑动,从而切换不同的View,我们可以通过setPageTransformer()方法为我们的ViewPager 设置切换时的动画效果。

和ListView,GridView一样,我们也需要一个Adapter (适配器)将我们的View和ViewPager进行绑定,而ViewPager则有一个特定的Adapter—— PagerAdapter


一、实例1.ViewPager简单的切换

通过滑动去切换View

运行效果:
在这里插入图片描述


  1. 编写activity_main.xml布局


<LinearLayout
xmlns:android&#61;"http://schemas.android.com/apk/res/android"
xmlns:app&#61;"http://schemas.android.com/apk/res-auto"
xmlns:tools&#61;"http://schemas.android.com/tools"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent"
tools:context&#61;".MainActivity"
android:orientation&#61;"vertical">

<androidx.viewpager.widget.ViewPager
android:id&#61;"&#64;&#43;id/viewpager"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"600dp"/>

<Button
android:layout_width&#61;"wrap_content"
android:layout_height&#61;"wrap_content"
android:text&#61;"ViewPagre"
android:layout_gravity&#61;"center"/>

LinearLayout>

  1. 编写三个布局layout1.xml、layout2.xml、layout3.xml

三个布局都差不多&#xff0c;就只放一个布局了。


<LinearLayout
xmlns:android&#61;"http://schemas.android.com/apk/res/android"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent"
android:orientation&#61;"vertical">

<TextView
android:background&#61;"#72C43C"
android:layout_width&#61;"wrap_content"
android:layout_height&#61;"wrap_content"
android:text&#61;"我是第一个分页"
android:textColor&#61;"#ff0000"
android:textSize&#61;"30sp"
android:layout_marginTop&#61;"200dp"
android:layout_gravity&#61;"center"/>

LinearLayout>

  1. 编写MainActivity活动类

package com.mq.viewpager;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.viewpager.widget.PagerAdapter;
import androidx.viewpager.widget.ViewPager;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ViewPager mViewPager;
private List<View> mViews; //存放视图的数组
private View view1,view2,view3;
private PagerAdapter mPagerAdapter;//适配器
&#64;Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mViewPager&#61;findViewById(R.id.viewpager);// 实例化viewpager控件
LayoutInflater inflater &#61; getLayoutInflater();//获取布局对象管理
view1&#61;inflater.inflate(R.layout.layout1,null);//实例化view
view2&#61;inflater.inflate(R.layout.layout2,null);
view3&#61;inflater.inflate(R.layout.layout3,null);
mViews&#61;new ArrayList<View>();//将要显示的布局存放到list数组
mViews.add(view1);
mViews.add(view2);
mViews.add(view3);
//实例化一个PagerAdapter的适配器
mPagerAdapter&#61;new PagerAdapter() {
&#64;Override //返回要滑动的VIew的个数
public int getCount() {
return mViews.size();
}
&#64;Override //来判断pager的一个view是否和instantiateItem方法返回的object有关联
public boolean isViewFromObject(&#64;NonNull View view, &#64;NonNull Object object) {
return view&#61;&#61;object;
}
&#64;Override //从当前container中删除指定位置&#xff08;position&#xff09;的View;
public void destroyItem(&#64;NonNull ViewGroup container, int position, &#64;NonNull Object object) {
container.removeView(mViews.get(position));
}
&#64;NonNull
&#64;Override //第一&#xff1a;将当前视图添加到container中&#xff0c;第二&#xff1a;返回当前View
public Object instantiateItem(&#64;NonNull ViewGroup container, int position) {
container.addView(mViews.get(position));
return mViews.get(position);
}
};
mViewPager.setAdapter(mPagerAdapter);//设置适配器
}
}

注意&#xff1a;

使用PagerAdapter必须重写的四个方法&#xff1a;

getCount(): 获得viewpager中有多少个view

destroyItem(): 移除一个给定位置的页面。适配器有责任从容器中删除这个视图。 这是为了确保在finishUpdate(viewGroup)返回时视图能够被移除。

instantiateItem(): ①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来 ②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了,当然你也可以 自定义自己的key,但是key和每个view要一一对应的关系

isViewFromObject(): 判断instantiateItem(ViewGroup, int position)函数所返回来的Key与一个页面视图是否是 代表的同一个视图(即它俩是否是对应的&#xff0c;对应的表示同一个View),通常我们直接写 return view &#61;&#61; object!


二、实例2.标题栏——PagerTitleStrip与PagerTabStrip

跟随着ViewPager滑动而滑动的标题咯&#xff0c;这两个是官方提供的&#xff0c;一个是普通文字&#xff0c; 一个是带有下划线&#xff0c;以及可以点击文字可切换页面

PagerTitleStrip 运行效果&#xff1a;
在这里插入图片描述


  1. 三个view的布局文件还是和实例1中的一样
  2. 修改activity_main.xml布局文件


<LinearLayout
xmlns:android&#61;"http://schemas.android.com/apk/res/android"
xmlns:app&#61;"http://schemas.android.com/apk/res-auto"
xmlns:tools&#61;"http://schemas.android.com/tools"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent"
tools:context&#61;".MainActivity"
android:orientation&#61;"vertical">

<TextView
android:layout_width&#61;"match_parent"
android:layout_height&#61;"48dp"
android:background&#61;"#CCFF99"
android:gravity&#61;"center"
android:text&#61;"PagerTitleStrip效果演示"
android:textColor&#61;"#000000"
android:textSize&#61;"18sp" />

<androidx.viewpager.widget.ViewPager
android:id&#61;"&#64;&#43;id/viewpager"
android:layout_width&#61;"wrap_content"
android:layout_height&#61;"wrap_content"
android:layout_gravity&#61;"center">

<androidx.viewpager.widget.PagerTitleStrip
android:id&#61;"&#64;&#43;id/pagertitle"
android:layout_width&#61;"wrap_content"
android:layout_height&#61;"40dp"
android:layout_gravity&#61;"top"
android:textColor&#61;"#000000" />

androidx.viewpager.widget.ViewPager>
LinearLayout>

  1. 自定义一个MyPagerAdapter适配器

package com.mq.viewpager;
import android.view.View;
import android.view.ViewGroup;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.viewpager.widget.PagerAdapter;
import java.util.ArrayList;
public class MyPagerAdapter extends PagerAdapter {
private ArrayList<View> mViewlist;
private ArrayList<String> mtitlelist;
public MyPagerAdapter() {
}
public MyPagerAdapter(ArrayList<View> viewlist, ArrayList<String> mtitlelist) {
mViewlist &#61; viewlist;
this.mtitlelist &#61; mtitlelist;
}
&#64;Override
public int getCount() {
return mViewlist.size();//返回view数组大小
}
&#64;Override
public boolean isViewFromObject(&#64;NonNull View view, &#64;NonNull Object object) {
return view&#61;&#61;object;
}
&#64;NonNull
&#64;Override
public Object instantiateItem(&#64;NonNull ViewGroup container, int position) {
container.addView(mViewlist.get(position));
return mViewlist.get(position);
}
&#64;Override
public void destroyItem(&#64;NonNull ViewGroup container, int position, &#64;NonNull Object object) {
container.removeView(mViewlist.get(position));
}
&#64;Nullable
&#64;Override
public CharSequence getPageTitle(int position) {
return mtitlelist.get(position);
}
}

  1. 编写MainActivity代码

package com.mq.viewpager;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.viewpager.widget.PagerAdapter;
import androidx.viewpager.widget.ViewPager;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ViewPager mViewPager;
private ArrayList<View> mViews; //存放视图的数组
private View view1,view2,view3;
private MyPagerAdapter mAdapter;//适配器
private ArrayList<String> mtitle;//存放标题的数组
&#64;Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mViewPager &#61; findViewById(R.id.viewpager);// 实例化viewpager控件
LayoutInflater inflater &#61; getLayoutInflater();//获取布局对象管理
view1 &#61; inflater.inflate(R.layout.layout1, null);//实例化view
view2 &#61; inflater.inflate(R.layout.layout2, null);
view3 &#61; inflater.inflate(R.layout.layout3, null);
mViews &#61; new ArrayList<View>();//将要显示的布局存放到list数组
mViews.add(view1);
mViews.add(view2);
mViews.add(view3);
mtitle &#61; new ArrayList<String>();//存放标题的数组
mtitle.add("推荐");
mtitle.add("热门");
mtitle.add("直播");
mAdapter&#61;new MyPagerAdapter(mViews,mtitle);//实例化适配器
mViewPager.setAdapter(mAdapter);//设置适配器
}
}

PagerTabStrip &#xff1a;就是比PagerTitleStrip多一个下划线
运行效果&#xff1a;

在这里插入图片描述

只要修改activity_main.xml的PagerTitleStrip为PagerTabStrip即可

在这里插入图片描述

这些简单的使用样式都太丑&#xff0c;在我们的开发中往往都会和其他控件一起使用。

今天的分享就到这了&#xff01;ε&#61;ε&#61;ε&#61;ε&#61;ε&#61;ε&#61;┌(;&#xffe3;◇&#xffe3;)┘






推荐阅读
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 带添加按钮的GridView,item的删除事件
    先上图片效果;gridView无数据时显示添加按钮,有数据时,第一格显示添加按钮,后面显示数据:布局文件:addr_manage.xml<?xmlve ... [详细]
author-avatar
fuxw
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有