自制页面效果图 :

 

一. ViewPager适配页面问题

 

1. ViewPager出现的问题

 

ViewPager占满全屏问题 : ViewPager在XML中定义了android:layout_height 和 android:layout_width 之后, 不论这两个属性的值是 fill_parent 还是 wrap_content, 都会出现ViewPager占满全屏的问题;

 

不使用固定值定义宽高: 为了使ViewPager能适配各种类型的手机, 如果给ViewPager定义了高度和宽度, 与各种手机的界面兼容性肯定要大大的降低, 因此出现了下面的解决方案;

 

2. 解决方案

 

代码中添加组件 : 不在XML界面定义该组件, 可以在布局文件中,定义一个LinearLayout容器, 然后在代码中动态添加ViewPager;

好处 : 这样的好处是可以在代码中获取屏幕的宽高, 我们可以根据比例设定ViewPager的大小, 这样就解决了屏幕适配的问题;

 

3. 代码实现

 

 

//从布局文件中获取ViewPager父容器pagerLayout = (LinearLayout) findViewById(R.id.view_pager_content);//创建ViewPager    adViewPager = new ViewPager(this);        //获取屏幕像素相关信息    DisplayMetrics dm = new DisplayMetrics();        getWindowManager().getDefaultDisplay().getMetrics(dm);            //根据屏幕信息设置ViewPager广告容器的宽高        adViewPager.setLayoutParams(new LayoutParams(dm.widthPixels, dm.heightPixels * 2 / 5));                //将ViewPager容器设置到布局文件父容器中    pagerLayout.addView(adViewPager);



 

 

二. ViewPager广告栏基本解决方案

 

1. ViewPager适配器PagerAdapter

 

自定义PagerAdapter类 : 我们需要自定义一个类, 去继承PageAdapter, 至少实现下面四个方法 :

 

destroyItem(View container, int position, Object object) :

作用 :删除container中指定位置position的页面;

参数 : container 就是容器, 这里指的是ViewPager对象, position就是删除的页面索引;

 

int getCount() :

作用 :获取ViewPager页面的个数;

返回值 : ViewPager页面个数;

 

Object instantiateItem(View container, int position) :

作用 :在给定的位置创建页面, PageAdapter负责向指定的position位置添加View页面;

参数 : container容器就是ViewPager, position指的是ViewPager的索引;

返回值 : 返回代表新的一页的对象;

 

boolean isViewFromObject(View view, Object object) :

作用 :决定instantiateItem()方法返回的Object对象是不是需要显示的页面关联, 这个方法必须要有;

参数 : view 要关联的页面, object instantiateItem()方法返回的对象;

返回值 : 是否要关联显示页面与 instantiateItem()返回值;

 

为PageAdapter关联数据源 : 可以将一个数组或者集合与PageAdapter关联,集合的索引与ViewPager的索引对应, destroyItem()方法中删除集合中对应索引的元素对象, instantiateItem 添加对应索引的元素对象;

 

PageAdapter 代码示例 :

 

    private final class AdvAdapter extends PagerAdapter {          private List views = null;            /**         * 初始化数据源, 即View数组         */        public AdvAdapter(List views) {              this.views = views;          }                  /**         * 从ViewPager中删除集合中对应索引的View对象         */        @Override          public void destroyItem(View container, int position, Object object) {              ((ViewPager) container).removeView(views.get(position));          }            /**         * 获取ViewPager的个数         */        @Override          public int getCount() {              return views.size();          }            /**         * 从View集合中获取对应索引的元素, 并添加到ViewPager中         */        @Override          public Object instantiateItem(View container, int position) {              ((ViewPager) container).addView(views.get(position), 0);              return views.get(position);          }            /**         * 是否将显示的ViewPager页面与instantiateItem返回的对象进行关联         * 这个方法是必须实现的         */        @Override          public boolean isViewFromObject(View view, Object object) {              return view == object;          }      }


创建PageAdapter代码 :

 

 

 

private void initPageAdapter() {pageViews = new ArrayList();ImageView img1 = new ImageView(this);          img1.setBackgroundResource(R.drawable.view_add_1);          pageViews.add(img1);                  ImageView img2 = new ImageView(this);          img2.setBackgroundResource(R.drawable.view_add_2);          pageViews.add(img2);                 ImageView img3 = new ImageView(this);          img3.setBackgroundResource(R.drawable.view_add_3);          pageViews.add(img3);                 ImageView img4 = new ImageView(this);          img4.setBackgroundResource(R.drawable.view_add_4);          pageViews.add(img4);                 ImageView img5 = new ImageView(this);          img5.setBackgroundResource(R.drawable.view_add_5);          pageViews.add(img5);                 ImageView img6 = new ImageView(this);          img6.setBackgroundResource(R.drawable.view_add_6);          pageViews.add(img6);                  adapter = new AdPageAdapter(pageViews);}


 

2. 小圆点导航策略

 

圆点存放策略 : 所有的小圆点都放在一个ViewGroup中, 有两种圆点, 一种是当前显示的, 一种是没激活的, 这里我们将一组圆点分别放入ImageView中, 并且将这些ImageView组装起来放到ViewGroup中即可;

 

圆点导航初始化 : 最初默认显示第一个页面, 第一个圆点激活, 根据ViewPager个数初始化圆点的个数, 组装圆点的时候, 第一个圆点状态激活;

代码如下 :

 

private void initCirclePoint(){ViewGroup group = (ViewGroup) findViewById(R.id.viewGroup);         p_w_picpathViews = new ImageView[pageViews.size()];          //广告栏的小圆点图标        for (int i = 0; i < pageViews.size(); i++) {          //创建一个ImageView, 并设置宽高. 将该对象放入到数组中        p_w_picpathView = new ImageView(this);              p_w_picpathView.setLayoutParams(new LayoutParams(20,20));              p_w_picpathViews[i] = p_w_picpathView;                          //初始值, 默认第0个选中            if (i == 0) {                  p_w_picpathViews[i]                          .setBackgroundResource(R.drawable.point_focused);              } else {                  p_w_picpathViews[i]                          .setBackgroundResource(R.drawable.point_unfocused);              }              //将小圆点放入到布局中            group.addView(p_w_picpathViews[i]);          } }



 

ViewPager页面改变时圆点导航随之改变 : 获取ViewPager当前显示页面索引,重新组装ViewGroup中的圆点排列顺序, 这个方法在ViewPager页面改变监听器中实现;

代码如下 :

 

/** *ViewPager 页面改变监听器  */    private final class AdPageChangeListener implements OnPageChangeListener {          /**     * 页面滚动状态发生改变的时候触发     */        @Override          public void onPageScrollStateChanged(int arg0) {          }            /**         * 页面滚动的时候触发         */        @Override          public void onPageScrolled(int arg0, float arg1, int arg2) {          }            /**         * 页面选中的时候触发         */        @Override          public void onPageSelected(int arg0) {          //获取当前显示的页面是哪个页面            atomicInteger.getAndSet(arg0);              //重新设置原点布局集合            for (int i = 0; i < p_w_picpathViews.length; i++) {                  p_w_picpathViews[arg0]                          .setBackgroundResource(R.drawable.point_focused);                  if (arg0 != i) {                      p_w_picpathViews[i]                              .setBackgroundResource(R.drawable.point_unfocused);                  }              }          }      }



 

3. 自动翻页导航策略

 

线程中处理自动翻页 : 启动一个线程, 获取当前页面显示索引, 计算出下一个显示位置, 显示下一个页面;

.

相关代码 :

线程代码 :

 

    new Thread(new Runnable() {              @Override              public void run() {                  while (true) {                      if (isContinue) {                          viewHandler.sendEmptyMessage(atomicInteger.get());                          atomicOption();                      }                  }              }          }).start();


handler代码 :

 

 

    private void atomicOption() {          atomicInteger.incrementAndGet();          if (atomicInteger.get() > p_w_picpathViews.length - 1) {          atomicInteger.getAndAdd(-5);          }          try {              Thread.sleep(3000);          } catch (InterruptedException e) {                        }      }     /*     * 每隔固定时间切换广告栏图片     */    private final Handler viewHandler = new Handler() {            @Override          public void handleMessage(Message msg) {          adViewPager.setCurrentItem(msg.what);              super.handleMessage(msg);          }        };



 

三. 程序主要代码

 

主Activity源码 :

 

package shuliang.han.myviewpager;import java.util.ArrayList;import java.util.List;import java.util.concurrent.atomic.AtomicInteger;import android.app.Activity;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.support.v4.view.PagerAdapter;import android.support.v4.view.ViewPager;import android.support.v4.view.ViewPager.OnPageChangeListener;import android.util.DisplayMetrics;import android.view.View;import android.view.ViewGroup;import android.view.ViewGroup.LayoutParams;import android.widget.ImageView;import android.widget.LinearLayout;public class MainActivity extends Activity {private ViewPager adViewPager;private LinearLayout pagerLayout;private List pageViews;private ImageView[] p_w_picpathViews;private ImageView p_w_picpathView;  private AdPageAdapter adapter;private AtomicInteger atomicInteger = new AtomicInteger(0);      private boolean isContinue = true; @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initViewPager();}private void initViewPager() {//从布局文件中获取ViewPager父容器pagerLayout = (LinearLayout) findViewById(R.id.view_pager_content);//创建ViewPager    adViewPager = new ViewPager(this);        //获取屏幕像素相关信息    DisplayMetrics dm = new DisplayMetrics();        getWindowManager().getDefaultDisplay().getMetrics(dm);            //根据屏幕信息设置ViewPager广告容器的宽高        adViewPager.setLayoutParams(new LayoutParams(dm.widthPixels, dm.heightPixels * 2 / 5));                //将ViewPager容器设置到布局文件父容器中    pagerLayout.addView(adViewPager);        initPageAdapter();        initCirclePoint();        adViewPager.setAdapter(adapter);    adViewPager.setOnPageChangeListener(new AdPageChangeListener());        new Thread(new Runnable() {              @Override              public void run() {                  while (true) {                      if (isContinue) {                          viewHandler.sendEmptyMessage(atomicInteger.get());                          atomicOption();                      }                  }              }          }).start();  }    private void atomicOption() {          atomicInteger.incrementAndGet();          if (atomicInteger.get() > p_w_picpathViews.length - 1) {          atomicInteger.getAndAdd(-5);          }          try {              Thread.sleep(3000);          } catch (InterruptedException e) {                        }      }     /*     * 每隔固定时间切换广告栏图片     */    private final Handler viewHandler = new Handler() {            @Override          public void handleMessage(Message msg) {          adViewPager.setCurrentItem(msg.what);              super.handleMessage(msg);          }        }; private void initPageAdapter() {pageViews = new ArrayList();ImageView img1 = new ImageView(this);          img1.setBackgroundResource(R.drawable.view_add_1);          pageViews.add(img1);                  ImageView img2 = new ImageView(this);          img2.setBackgroundResource(R.drawable.view_add_2);          pageViews.add(img2);                 ImageView img3 = new ImageView(this);          img3.setBackgroundResource(R.drawable.view_add_3);          pageViews.add(img3);                 ImageView img4 = new ImageView(this);          img4.setBackgroundResource(R.drawable.view_add_4);          pageViews.add(img4);                 ImageView img5 = new ImageView(this);          img5.setBackgroundResource(R.drawable.view_add_5);          pageViews.add(img5);                 ImageView img6 = new ImageView(this);          img6.setBackgroundResource(R.drawable.view_add_6);          pageViews.add(img6);                  adapter = new AdPageAdapter(pageViews);}private void initCirclePoint(){ViewGroup group = (ViewGroup) findViewById(R.id.viewGroup);         p_w_picpathViews = new ImageView[pageViews.size()];          //广告栏的小圆点图标        for (int i = 0; i < pageViews.size(); i++) {          //创建一个ImageView, 并设置宽高. 将该对象放入到数组中        p_w_picpathView = new ImageView(this);              p_w_picpathView.setLayoutParams(new LayoutParams(10,10));              p_w_picpathViews[i] = p_w_picpathView;                          //初始值, 默认第0个选中            if (i == 0) {                  p_w_picpathViews[i]                          .setBackgroundResource(R.drawable.point_focused);              } else {                  p_w_picpathViews[i]                          .setBackgroundResource(R.drawable.point_unfocused);              }              //将小圆点放入到布局中            group.addView(p_w_picpathViews[i]);          } }/** *ViewPager 页面改变监听器  */    private final class AdPageChangeListener implements OnPageChangeListener {          /**     * 页面滚动状态发生改变的时候触发     */        @Override          public void onPageScrollStateChanged(int arg0) {          }            /**         * 页面滚动的时候触发         */        @Override          public void onPageScrolled(int arg0, float arg1, int arg2) {          }            /**         * 页面选中的时候触发         */        @Override          public void onPageSelected(int arg0) {          //获取当前显示的页面是哪个页面            atomicInteger.getAndSet(arg0);              //重新设置原点布局集合            for (int i = 0; i < p_w_picpathViews.length; i++) {                  p_w_picpathViews[arg0]                          .setBackgroundResource(R.drawable.point_focused);                  if (arg0 != i) {                      p_w_picpathViews[i]                              .setBackgroundResource(R.drawable.point_unfocused);                  }              }          }      }     private final class AdPageAdapter extends PagerAdapter {          private List views = null;            /**         * 初始化数据源, 即View数组         */        public AdPageAdapter(List views) {              this.views = views;          }                  /**         * 从ViewPager中删除集合中对应索引的View对象         */        @Override          public void destroyItem(View container, int position, Object object) {              ((ViewPager) container).removeView(views.get(position));          }            /**         * 获取ViewPager的个数         */        @Override          public int getCount() {              return views.size();          }            /**         * 从View集合中获取对应索引的元素, 并添加到ViewPager中         */        @Override          public Object instantiateItem(View container, int position) {              ((ViewPager) container).addView(views.get(position), 0);              return views.get(position);          }            /**         * 是否将显示的ViewPager页面与instantiateItem返回的对象进行关联         * 这个方法是必须实现的         */        @Override          public boolean isViewFromObject(View view, Object object) {              return view == object;          }      }}



 

×××地址 : http://download.csdn.net/detail/han1202012/6835401


更多相关文章

  1. 【阿里云镜像】切换阿里巴巴开源镜像站镜像——Debian镜像
  2. android WebView总结
  3. android 笔记 --- 流量统计
  4. android根据uri或文件绝对路径获取文件基本信息
  5. Android中使用ViewPager制作广告栏滚屏效果
  6. android EditText 取消自动获取焦点
  7. Google Android(安卓)应用程序结构
  8. android 线程中的ui问题 Handler的基本使用 关于获取动态时间在u
  9. 获取Android(安卓)SDK 源代码并在Eclipse中关联查看的方法

随机推荐

  1. Android(安卓)系统framework 概述【转载
  2. 源码茶舍之android:externalService是什
  3. Android(安卓)studio 2.3.3+Dlib
  4. android 回车键事件编程
  5. Android(安卓)多线程AsyncTask详解
  6. android环境变量配置
  7. android的测试工具CTS
  8. JPCT-AE for Android(安卓)3D (一)------
  9. Android的6种布局管理器总结
  10. 前端h5与 Android/iOS 交互传参