版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
【移动应用开发技术】怎么在Android中使用ViewPager实现微信页面切换效果
怎么在Android中使用ViewPager实现微信页面切换效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。首先在布局文件activity_main.xml添加ViewPager
ViewPager是页面,PagerTabStrip和PagerTitleStrip是设置标题的<?xml
version="1.0"
encoding="utf-8"?>
<RelativeLayout
xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!--页卡-->
<android.support.v4.view.ViewPager
android:id="@+id/view1"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<!--页卡标题-->
<!rTitleStrip和PagerTabStrip功能差不多一致,使用了PagerTitleStrip那PagerTabStrip会失效-->
<android.support.v4.view.PagerTabStrip
android:id="@+id/pagerTabStrip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</android.support.v4.view.ViewPager>
</RelativeLayout>接下里创建3个布局文件,给ViewPager的适配器引用view1.xml<?xml
version="1.0"
encoding="utf-8"?>
<LinearLayout
xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/img1"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:background="@drawable/img1"
android:layout_marginLeft="30dp"/>
</LinearLayout>view2.xml<?xml
version="1.0"
encoding="utf-8"?>
<LinearLayout
xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/img2"
android:layout_height="match_parent"
android:layout_width="match_parent"
android:background="@drawable/img2"/>
</LinearLayout>view3.xml<?xml
version="1.0"
encoding="utf-8"?>
<LinearLayout
xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/img3"
android:layout_height="match_parent"
android:layout_width="match_parent"
android:background="@drawable/img3"/>
</LinearLayout>创建3个类继承Fragment,通过Fragment实现onCreateView方法把view.xml布局转换成ViewMyFragment1.javapackage
com.rui.viewpagerdemo;
import
android.os.Bundle;
import
android.support.annotation.Nullable;
import
android.support.v4.app.Fragment;
import
android.view.LayoutInflater;
import
android.view.View;
import
android.view.ViewGroup;
/**
*
Created
by
qqazl001
on
2018/3/26.
*/
public
class
MyFragment1
extends
Fragment{
@Nullable
@Override
public
View
onCreateView(LayoutInflater
inflater,
@Nullable
ViewGroup
container,
@Nullable
Bundle
savedInstanceState)
{
//布局文件转成View
//参数1:Fragment需要加载的布局文件
//参数2:加载layout的父ViewGroup
//参数1:是否返回父ViewGroup对象,false为不
View
view
=
inflater.inflate(R.layout.view1,container,false);
return
view;
}
}MyFragment2.javapackage
com.rui.viewpagerdemo;
import
android.os.Bundle;
import
android.support.annotation.Nullable;
import
android.support.v4.app.Fragment;
import
android.view.LayoutInflater;
import
android.view.View;
import
android.view.ViewGroup;
/**
*
Created
by
qqazl001
on
2018/3/26.
*/
public
class
MyFragment2
extends
Fragment{
@Nullable
@Override
public
View
onCreateView(LayoutInflater
inflater,
@Nullable
ViewGroup
container,
@Nullable
Bundle
savedInstanceState)
{
//布局文件转成View
//参数1:Fragment需要加载的布局文件
//参数2:加载layout的父ViewGroup
//参数1:是否返回父ViewGroup对象,false为不
View
view
=
inflater.inflate(R.layout.view2,container,false);
return
view;
}
}MyFragment3.javapackage
com.rui.viewpagerdemo;
import
android.os.Bundle;
import
android.support.annotation.Nullable;
import
android.support.v4.app.Fragment;
import
android.view.LayoutInflater;
import
android.view.View;
import
android.view.ViewGroup;
/**
*
Created
by
qqazl001
on
2018/3/26.
*/
public
class
MyFragment3
extends
Fragment{
@Nullable
@Override
public
View
onCreateView(LayoutInflater
inflater,
@Nullable
ViewGroup
container,
@Nullable
Bundle
savedInstanceState)
{
//布局文件转成View
//参数1:Fragment需要加载的布局文件
//参数2:加载layout的父ViewGroup
//参数1:是否返回父ViewGroup对象,false为不
View
view
=
inflater.inflate(R.layout.view3,container,false);
return
view;
}
}创建适配器,新建类(MyAdapter),继承FragmentPagerAdapterpackage
com.rui.viewpagerdemo;
import
android.support.v4.app.Fragment;
import
android.support.v4.app.FragmentManager;
import
android.support.v4.app.FragmentPagerAdapter;
import
android.support.v4.view.PagerAdapter;
import
android.view.View;
import
android.view.ViewGroup;
import
java.util.ArrayList;
import
java.util.List;
/**
*
Created
by
qqazl001
on
2018/3/26.
*/
public
class
MyAdapter
extends
FragmentPagerAdapter{
List<Fragment>
listFragment;
List<String>
listTab
=
new
ArrayList<String>();
public
MyAdapter(FragmentManager
fm,List<Fragment>
listFragment,List<String>listTab)
{
super(fm);
this.listFragment=listFragment;
this.listTab=listTab;
}
@Override
public
CharSequence
getPageTitle(int
position)
{
//返回标题名称
return
listTab.get(position);
}
@Override
public
Fragment
getItem(int
position)
{
//返回页面内容
return
listFragment.get(position);
}
@Override
public
int
getCount()
{
//一共多少个页面
return
listFragment.size();
}
}在Activity实例化组件和适配器并添加监听,添加各种数据源等监听实现接口OnPageChangeListenerViewPager,添加监听方法setOnPageChangeListener()方法已经被AS移除了,建议使用addOnPageChangeListener()方法。MainActivity.javapackage
com.rui.viewpagerdemo;
import
android.annotation.SuppressLint;
import
android.graphics.Color;
import
android.support.v4.app.Fragment;
import
android.support.v4.view.PagerTabStrip;
import
android.support.v4.view.ViewPager;
import
android.support.v7.app.AppCompatActivity;
import
android.os.Bundle;
import
android.view.View;
import
android.widget.Toast;
import
java.util.ArrayList;
import
java.util.List;
//调用接口监听,并实现方法
public
class
MainActivity
extends
AppCompatActivity
implements
ViewPager.OnPageChangeListener{
private
List<Fragment>
listFragment;//声明List,存放Fagment
private
ViewPager
viewPager;//声明ViewPager
private
PagerTabStrip
pagerTabStrip;//声明PagerTabStrip
private
List<String>
listTab;//声明List,存放标题
@SuppressLint("ResourceType")
@Override
protected
void
onCreate(Bundle
savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//实例化List
listFragment
=
new
ArrayList<Fragment>();
//view加入list
listFragment.add(new
MyFragment1());
listFragment.add(new
MyFragment2());
listFragment.add(new
MyFragment3());
//标题加入list
listTab
=
new
ArrayList<String>();
listTab.add("第一页");
listTab.add("第二页");
listTab.add("第三页");
//为PagerTabStrip设置属性
pagerTabStrip
=
(PagerTabStrip)findViewById(R.id.pagerTabStrip);
//pagerTabStrip.setBackgroundColor(color.white);
设置背景色
pagerTabStrip.setTextColor(Color.RED);
//设置标题文字颜色
pagerTabStrip.setDrawFullUnderline(false);//是否显示一条横线
pagerTabStrip.setTabIndicatorColor(Color.GREEN);//标题下的短粗线颜色
//实例化适配器
MyAdapter
myAdapter
=
new
MyAdapter(getSupportFragmentManager(),listFragment,listTab);
//实例化ViewPager
viewPager
=
(ViewPager)
findViewById(R.id.view1);
//为viewPager加载适配器
viewPager.setAdapter(myAdapter);
//加载监听事件
viewPager.addOnPa
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 校园安全主题班会报告总结
- 2024年汽车座椅调角器行业企业战略风险管理报告
- 第01单元 时、分、秒 第1课时 时与分2023-2024学年三年级上册数学【智优教案】 人教新课标
- 幼儿园中班户外活动亲子游方案
- 《小数的近似数(例1)》(教案)四年级下册数学人教版
- 地铁隧道二维位移自动监测系统相关项目实施方案
- 包装容器制造机械相关行业项目操作方案
- 兽用化学药相关项目实施方案
- 第四单元 比例的意义 教学设计2023-2024学年数学六年级下册 青岛版
- STD温盐深剖面仪行业相关项目实施计划
- DB11-T 1998-2022既有公共建筑节能绿色化改造技术规程
- 煤矿预防机电运输灾害及处理措施
- 人教版道德与法治六年级下册早期文明发祥地教学设计
- 药品不良反应及事件报告表
- 医学伦理学100个案例分析(全)
- 物理化学------各个实验实验报告参考答案
- 动火作业许可证制度
- 工商企业管理毕业论文
- 骨关节炎病例分析
- 联合利华未来领导人培养项目Unilever Future Leaders Programme
- 液压机技术规格书DOC
评论
0/150
提交评论