栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android ViewPager 的使用总结

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android ViewPager 的使用总结

在一个窗口里面添加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 pageList = new ArrayList();
 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 mListViews; 
  
  public MyViewPagerAdapter(List 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布局文件


 

    

    

    
  
   
 



View1的布局




由于用于演示,所以view的布局只是用不同的背景色来区分,开发中具体要展示的布局可以直接在view的布局文件里面改。demo中的view都是参考第一个来写的,类似

总结。

实际开发中,虽然官方提供了很多api,真正等到要自己用的时候,还是自己在依照习惯再包装一层,成为自己的工具,这样以后就可以直接用了,上面的例子是我在实习期间总结的,鄙陋之处敬请原谅,也欢迎大家指出,一起学习(^_^)

代码链接:http://pan.baidu.com/s/1pJAF6Gz

以上就是对Android ViewPager 的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/161325.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号