布局文件里添加viewPager布局

  1. <android.support.v4.view.ViewPager
  2. android:id="@+id/search_viewpager"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"
  5. android:layout_gravity="center" >
  6. </android.support.v4.view.ViewPager>

再创建两个item布局用于填充在ViewPager里


然后就是Activity了,主要写了左右滑动切换页面,还有一个小图片随页面切换 位移的动画效果

  1. public class SearchAllcityActivity extends Activity {
  2. private KeywordsFlow keywordsFlow;
  3. private ViewPager viewPager;
  4. private ImageView imageView;
  5. private List<View> lists = new ArrayList<View>();
  6. private ViewPagerAdapter adapter;
  7. private Bitmap cursor;
  8. private int offSet;
  9. private int currentItem;
  10. private Matrix matrix = new Matrix();
  11. private int bmWidth;
  12. private Animation animation;
  13. private Button shuaxin_sq, shuaxin_fl;
  14. public void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.search_allcity);
  17. // 随页面滑动图片
  18. imageView = (ImageView) findViewById(R.id.viewpaget_img);
  19. // 热门商圈和热门分类 页面添加到viewPager集合
  20. lists.add(getLayoutInflater().inflate(R.layout.search_hot_shangqu, null));
  21. lists.add(getLayoutInflater().inflate(R.layout.search_hot_fenlei, null));
  22. // 初始化滑动图片位置
  23. initeCursor();
  24. adapter = new ViewPagerAdapter(lists);
  25. viewPager = (ViewPager) findViewById(R.id.search_viewpager);
  26. viewPager.setAdapter(adapter);
  27. // ViewPager滑动监听器
  28. viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
  29. @Override
  30. public void onPageSelected(int arg0) {
  31. // TODO Auto-generated method stub
  32. // 当滑动时,顶部的imageView是通过animation缓慢的滑动
  33. switch (arg0) {
  34. case 0:
  35. if (currentItem == 1) {
  36. animation = new TranslateAnimation(offSet * 2 + bmWidth, 0, 0,0);
  37. } else if (currentItem == 2) {
  38. animation = new TranslateAnimation(offSet * 4 + 2 * bmWidth, 0,0, 0);
  39. }
  40. break;
  41. case 1:
  42. if (currentItem == 0) {
  43. animation = new TranslateAnimation(0, offSet * 2 + bmWidth, 0,0);
  44. } else if (currentItem == 2) {
  45. animation = new TranslateAnimation(4 * offSet + 2 * bmWidth,offSet * 2 + bmWidth, 0, 0);
  46. }
  47. break;
  48. }
  49. currentItem = arg0;
  50. animation.setDuration(500);
  51. animation.setFillAfter(true);
  52. imageView.startAnimation(animation);
  53. }
  54. @Override
  55. public void onPageScrolled(int arg0, float arg1, int arg2) {
  56. // TODO Auto-generated method stub
  57. }
  58. @Override
  59. public void onPageScrollStateChanged(int arg0) {
  60. // TODO Auto-generated method stub
  61. }
  62. });
  63. }
  64. /**
  65. * 计算滑动的图片的位置
  66. */
  67. private void initeCursor() {
  68. cursor = BitmapFactory.decodeResource(getResources(),R.drawable.viewpager_img);
  69. bmWidth = cursor.getWidth();
  70. DisplayMetrics dm;
  71. dm = getResources().getDisplayMetrics();
  72. offSet = (dm.widthPixels - 2 * bmWidth) / 4;
  73. matrix.setTranslate(offSet, 0);
  74. imageView.setImageMatrix(matrix); // 需要iamgeView的scaleType为matrix
  75. currentItem = 0;
  76. }
  77. }

最后,不能忘了ViewPager的Adapter

    1. public class ViewPagerAdapter extends PagerAdapter{
    2. List<View> viewLists;
    3. public ViewPagerAdapter(List<View> lists)
    4. {
    5. viewLists = lists;
    6. }
    7. @Override
    8. public int getCount() {                                                                 //获得size
    9. // TODO Auto-generated method stub
    10. return viewLists.size();
    11. }
    12. @Override
    13. public boolean isViewFromObject(View arg0, Object arg1) {
    14. // TODO Auto-generated method stub
    15. return arg0 == arg1;
    16. }
    17. @Override
    18. public void destroyItem(View view, int position, Object object)                       //销毁Item
    19. {
    20. ((ViewPager) view).removeView(viewLists.get(position));
    21. }
    22. @Override
    23. public Object instantiateItem(View view, int position)                                //实例化Item
    24. {
    25. ((ViewPager) view).addView(viewLists.get(position), 0);
    26. return viewLists.get(position);
    27. }
    28. }

ViewPager的使用方法和实现过程的更多相关文章

  1. 从普通函数到对象方法 ------Windows窗口过程的面向对象封装

    原文地址:http://blog.csdn.net/linzhengqun/article/details/1451088 从普通函数到对象方法 ------Windows窗口过程的面向对象封装 开始 ...

  2. Java中对象方法的调用过程&动态绑定(Dynamic Binding)

    Java面向对象的最重要的一个特点就是多态, 而多态当中涉及到了一个重要的机制是动态绑定(Dynamic binding). 之前只有一个大概的概念, 没有深入去了解动态绑定的机理, 直到很多公司都问 ...

  3. Java 调用对象方法的执行过程

    弄清调用对象方法的执行过程十分重要.下面是调用过程的详细描述: 1) 编译器查看对象的声明类型和方法名.假设调用x.f(param),且隐式参数x声明为C类的对象.需要注意的是:有可能存在多个名为f, ...

  4. ViewPager的setOnPageChangeListener方法详解

    http://www.eoeandroid.com/forum.php?mod=viewthread&tid=548173 ViewPage使用时,最关键的代码就是setOnPageChang ...

  5. fackbook的Fresco的多种图片加载方法以及解码过程

    上篇文章中我们提到了图片加载其实是用了三条线程,如果没看过的同学可以先了解下这里. fackbook的Fresco的Image Pipeline以及自身的缓存机制 那么今天我们就来探索一下如何在代码中 ...

  6. linux 环境下安装oracle11g方法及安装过程中遇上的问题解决方法

     Oralce安装教程 1.先安装需要的依赖包 找到哪个没有安装,直接yum install XX,直到所有的都安装完成.注意,可能一个包安装了,再次执行检查,还是提示没有安装,那么就不需要管他们了, ...

  7. Xen Server虚拟机数据恢复的方法和数据恢复过程

    在服务器运行过程中如果出现意外情况突然断电很容易引起服务器故障,服务器中的硬件设备损坏可以修复或者购买,但是服务器中的数据一旦发生故障丢失,对于企业来说将是不可估量的损失.那么服务器数据一旦丢失就除了 ...

  8. 事件之onTouch方法的执行过程 及和 onClick执行发生冲突的解决办法

    转载:http://blog.csdn.net/jiangwei0910410003/article/details/17504315#quote 博主推荐: 风萧兮兮易水寒,“天真”一去兮不复还.如 ...

  9. 从斐波那契数列看java方法的调用过程

    先看斐波那契数列的定义: 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为 ...

随机推荐

  1. Java集合类具体解释

    假设您喜欢这些文章,欢迎点击此处订阅本Blog 集合类说明及差别 Collection ├List │├LinkedList │├ArrayList │└Vector │ └Stack └Set Ma ...

  2. [转] linux 信号量之SIGNAL

    我们可以使用kill -l查看所有的信号量解释,但是没有看到SIGNAL 0的解释. [root@testdb~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) ...

  3. (转) Android平台上关于IM的实践总结

    前言 IM通信在互联网发展到现在已经是码农的世界里人尽皆知的技术,特别在当下移动互联网迅猛发展的时代这种技术的开发也更加火热,其中老牌的代表作就有QQ和MSN,和最近新崛起的微信,默默,易信,来往等眼 ...

  4. Linux shell入门基础(二)

    二.shell对文本的操作 01.查看文本的命令 #cat /etc/passwd(并非对文本文件操作) #tail -5 /etc/passwd(查看末尾5行) #tail -f /var/log/ ...

  5. css实现鼠标移上去变大,旋转,转别人的额

    <!doctype html><html><head> <meta charset="utf-8"> <title>CS ...

  6. UCOS 中的中断处理

    最近遇到一个问题,当我在UCOS里调用系统延时"OSTimeDlyHMSM(0, 0, 0, 10)",程序进入硬件错误中断“HardFault_Handler”中. 我开始以为是 ...

  7. 对static静态成员的理解

    疑惑: 数据成员可以分静态变量.非静态变量两种.  静态成员:静态类中的成员加入static修饰符,即是静态成员.可以直接使用类名+静态成员名访问此静态成员,因为静态成员存在于内存,非静态成员需要实例 ...

  8. 30款jQuery常用网页焦点图banner图片切换 下载 (转)

    1.jquery 图片滚动特效制作 slide 图片类似窗帘式图片滚动 查看演示 2.jquery幻灯片插件带滚动条的圆形立体图片旋转滚动 查看演示 3.jQuery图片层叠旋转类似洗牌翻转图片幻灯片 ...

  9. java: cannot execute binary file

    转自:http://jxwpx.blog.51cto.com/15242/222572 java: cannot execute binary file 如果遇到这个错,一般是操作系统位数出问题了. ...

  10. Swift - 42 - 类的基本使用

    import Foundation /* 1.class表示类的关键字 2.class后面表示类名 3.类名后面的大括号内表示类的内部 */ /* 1.属性封装了set和get方法 2.方法里面封装了 ...