Android ViewPager 的使用总结
短信预约 -IT技能 免费直播动态提醒
在一个窗口里面添加tab便签,完成便签切换来实现页面的切换,这样的好处是可以在同一个窗口里面有多个页面,这些页面共享同一个窗口的资源,同使用多个窗口来实现这个功能来得更加流畅!!
主要产生的类文件有activity,n个view,adapter,自定义的ViewPager,n+1个布局文件
demo所用到文件
步骤:
创建activity
package com.example.myviewpager;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TextView;
public class MainActivity extends Activity implements OnClickListener {
private Context mContext;
private MyViewPager mPager;// 页面内容
private MyViewPagerAdapter pagerAdapter = null;
private TextView t1, t2, t3;// 页卡头标
private List<View> pageList = new ArrayList<View>();
private View1 mView1;
private View2 mView2;
private View3 mView3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mContext = this;
initViews();
initEvents();
initViewPager();
}
private void initViews() {
// TODO Auto-generated method stub
t1 = (TextView) findViewById(R.id.text1);
t2 = (TextView) findViewById(R.id.text2);
t3 = (TextView) findViewById(R.id.text3);
mPager = (MyViewPager) findViewById(R.id.vPager);
// 设置ViewPager不允许滑动
//mPager.setCanScroll(false);
//一开始进入窗口的时候,默认第一个便签被选中
t1.setBackgroundColor(Color.parseColor("#FFFF00"));
t2.setBackgroundColor(Color.parseColor("#FFFFFF"));
t3.setBackgroundColor(Color.parseColor("#FFFFFF"));
}
private void initEvents() {
// TODO Auto-generated method stub
t1.setOnClickListener(this);
t2.setOnClickListener(this);
t3.setOnClickListener(this);
}
private void initViewPager() {
// TODO Auto-generated method stub
pageList.clear();
if (mView1 == null) {
mView1 = new View1(mContext);
}
if (mView2 == null) {
mView2 = new View2(mContext);
}
if (mView3 == null) {
mView3 = new View3(mContext);
}
pageList.add(mView1.getView());
pageList.add(mView2.getView());
pageList.add(mView3.getView());
pagerAdapter = new MyViewPagerAdapter(pageList);
// 缓存页面,如果想全部都缓存的话,参数等于页卡数减一,系统默认参数为1,保存两个
mPager.setOffscreenPageLimit(2);
mPager.setAdapter(pagerAdapter);
// 设置Page改变监听器
mPager.setOnPageChangeListener(onPageChangeListener);
}
ViewPager.SimpleOnPageChangeListener onPageChangeListener = new ViewPager.SimpleOnPageChangeListener() {
@Override
public void onPageSelected(int position) {
initTab(position);
}
// 初始化便签颜色
private void initTab(int position) {
// TODO Auto-generated method stub
if (position == 0) {
t1.setBackgroundColor(Color.parseColor("#FFFF00"));
t2.setBackgroundColor(Color.parseColor("#FFFFFF"));
t3.setBackgroundColor(Color.parseColor("#FFFFFF"));
} else if (position == 1) {
t1.setBackgroundColor(Color.parseColor("#FFFFFF"));
t2.setBackgroundColor(Color.parseColor("#FFFF00"));
t3.setBackgroundColor(Color.parseColor("#FFFFFF"));
} else {
t1.setBackgroundColor(Color.parseColor("#FFFFFF"));
t2.setBackgroundColor(Color.parseColor("#FFFFFF"));
t3.setBackgroundColor(Color.parseColor("#FFFF00"));
}
}
};
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.text1:// 点击第一个便签
mPager.setCurrentItem(0, false);
break;
case R.id.text2:// 点击第二个便签
mPager.setCurrentItem(1, false);
break;
case R.id.text3:// 点击第三个便签
mPager.setCurrentItem(2, false);
break;
default:
break;
}
}
}
自定义MyViewPager
package com.example.myviewpager;
import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.MotionEvent;
public class MyViewPager extends ViewPager {
private boolean isCanScroll = true;
public MyViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyViewPager(Context context) {
super(context);
}
public boolean isCanScroll() {
return isCanScroll;
}
public void setCanScroll(boolean isCanScroll) {
this.isCanScroll = isCanScroll;
}
@Override
public void scrollTo(int x, int y) {
super.scrollTo(x, y);
}
// 设置禁止滑动的关键
@Override
public boolean onTouchEvent(MotionEvent arg0) {
if (!isCanScroll)
return true;
return super.onTouchEvent(arg0);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent arg0) {
return super.onInterceptTouchEvent(arg0);
}
@Override
public void setCurrentItem(int item, boolean smoothScroll) {
super.setCurrentItem(item, smoothScroll);
}
@Override
public void setCurrentItem(int item) {
super.setCurrentItem(item);
}
}
适配器:
package com.example.myviewpager;
import java.util.List;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
public class MyViewPagerAdapter extends PagerAdapter{
private List<View> mListViews;
public MyViewPagerAdapter(List<View> mListViews) {
this.mListViews = mListViews;//构造方法,参数是我们的页卡,这样比较方便
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(mListViews.get(position));//删除页卡
}
@Override
public Object instantiateItem(ViewGroup container, int position) { //这个方法用来实例化页卡
container.addView(mListViews.get(position), 0);//添加页卡
return mListViews.get(position);
}
@Override
public int getCount() {
return mListViews.size();//返回页卡的数目
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0==arg1;//官方提示这样写
}
}
第一个view
package com.example.myviewpager;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
public class View1 {
private Context mContext;
private View rootView;
public View1(Context mContext) {
// TODO Auto-generated constructor stub
this.mContext=mContext;
//加载布局
rootView = LayoutInflater.from(mContext).inflate(
R.layout.view1_layout, null);
}
public View getView(){
return rootView;
}
}
activity布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
>
<LinearLayout
android:id="@+id/linearLayout1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="#FFFFFF" >
<TextView
android:id="@+id/text1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_weight="1.0"
android:gravity="center"
android:text="页卡1"
android:textColor="#000000"
android:textSize="20sp" />
<TextView
android:id="@+id/text2"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_weight="1.0"
android:gravity="center"
android:text="页卡2"
android:textColor="#000000"
android:textSize="20sp" />
<TextView
android:id="@+id/text3"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_weight="1.0"
android:gravity="center"
android:text="页卡3"
android:textColor="#000000"
android:textSize="20sp" />
</LinearLayout>
<com.example.myviewpager.MyViewPager
android:id="@+id/vPager"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1.0"
android:background="#000000"
android:flipInterval="30"
/>
</LinearLayout>
View1的布局
<?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"
android:background="#123456" >
</LinearLayout>
由于用于演示,所以view的布局只是用不同的背景色来区分,开发中具体要展示的布局可以直接在view的布局文件里面改。demo中的view都是参考第一个来写的,类似
总结。
实际开发中,虽然官方提供了很多api,真正等到要自己用的时候,还是自己在依照习惯再包装一层,成为自己的工具,这样以后就可以直接用了,上面的例子是我在实习期间总结的,鄙陋之处敬请原谅,也欢迎大家指出,一起学习(^_^)
代码链接:http://pan.baidu.com/s/1pJAF6Gz
以上就是对Android ViewPager 的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!
您可能感兴趣的文章:Android this与Activity.this的区别Android布局居中的几种做法Android自定义进度条的圆角横向进度条实例详解Android Studio查看Android 5.x源码的步骤详解Android6.0 屏幕固定功能详解Android实现音频条形图效果(仿音频动画无监听音频输入)浅谈Android中视图动画的属性与使用Android string-array数据源简单使用
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341