1.示意图

          

          

2.实现分析

(1).xml配置

  1. <!-- 配置container和pager的clipChildren=false, 并且指定marginLeft 和 marginRight 的值-->
  2. <LinearLayout
  3. android:id="@+id/container"
  4. android:layout_width="match_parent"
  5. android:layout_height="100dp"
  6. android:clipChildren="false"
  7. android:gravity="center_horizontal"
  8. android:layerType="software"
  9. android:orientation="horizontal" >
  10. <android.support.v4.view.ViewPager
  11. android:id="@+id/viewpager"
  12. android:layout_width="match_parent"
  13. android:layout_height="match_parent"
  14. android:layout_marginLeft="110dp"
  15. android:layout_marginRight="110dp"
  16. android:clipChildren="false" >
  17. </android.support.v4.view.ViewPager>
  18. </LinearLayout>

(2).java代码

  1. // 1.设置幕后item的缓存数目
  2. viewPager.setOffscreenPageLimit(3);
  3. // 2.设置页与页之间的间距
  4. viewPager.setPageMargin(10);
  5. // 3.将父类的touch事件分发至viewPgaer,否则只能滑动中间的一个view对象
  6. container.setOnTouchListener(new View.OnTouchListener() {
  7. @Override
  8. public boolean onTouch(View v, MotionEvent event) {
  9. return viewPager.dispatchTouchEvent(event);
  10. }
  11. });

3.代码实现

  1. /**
  2. * MainActivity.java
  3. *
  4. * @author http://blog.csdn.net/zimo2013
  5. *
  6. */
  7. public class MainActivity extends Activity implements OnPageChangeListener {
  8. private ViewPager viewPager;
  9. private List<View> views = new ArrayList<View>();
  10. private LinearLayout container;
  11. private TextView tvTitle;
  12. private LayoutInflater inflater;
  13. private String dir;
  14. @Override
  15. protected void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. setContentView(R.layout.activity_main);
  18. inflater = getLayoutInflater();
  19. container = (LinearLayout) findViewById(R.id.container);
  20. viewPager = (ViewPager) findViewById(R.id.viewpager);
  21. tvTitle = (TextView) findViewById(R.id.title);
  22. //这里预先在sdcard准备一些轮播图片资源
  23. dir = Environment.getExternalStorageDirectory().getAbsolutePath();
  24. // 得到views集合
  25. views = new ArrayList<View>();
  26. //此处可以根据需要自由设定,这里只是简单的测试
  27. for (int i = 1; i <= 12; i++) {
  28. View view = inflater.inflate(R.layout.guide_item, null);
  29. views.add(view);
  30. }
  31. /////////////////////主要配置//////////////////////////////////////
  32. // 1.设置幕后item的缓存数目
  33. viewPager.setOffscreenPageLimit(3);
  34. // 2.设置页与页之间的间距
  35. viewPager.setPageMargin(10);
  36. // 3.将父类的touch事件分发至viewPgaer,否则只能滑动中间的一个view对象
  37. container.setOnTouchListener(new View.OnTouchListener() {
  38. @Override
  39. public boolean onTouch(View v, MotionEvent event) {
  40. return viewPager.dispatchTouchEvent(event);
  41. }
  42. });
  43. ////////////////////////////////////////////////////////////////
  44. viewPager.setAdapter(new MyAdapter()); // 为viewpager设置adapter
  45. viewPager.setOnPageChangeListener(this);// 设置监听器
  46. }
  47. // PagerAdapter是object的子类
  48. class MyAdapter extends PagerAdapter {
  49. /**
  50. * PagerAdapter管理数据大小
  51. */
  52. @Override
  53. public int getCount() {
  54. return views.size();
  55. }
  56. /**
  57. * 关联key 与 obj是否相等,即是否为同一个对象
  58. */
  59. @Override
  60. public boolean isViewFromObject(View view, Object obj) {
  61. return view == obj; // key
  62. }
  63. /**
  64. * 销毁当前page的相隔2个及2个以上的item时调用
  65. */
  66. @Override
  67. public void destroyItem(ViewGroup container, int position, Object object) {
  68. container.removeView((View) object); // 将view 类型 的object熊容器中移除,根据key
  69. }
  70. /**
  71. * 当前的page的前一页和后一页也会被调用,如果还没有调用或者已经调用了destroyItem
  72. */
  73. @Override
  74. public Object instantiateItem(ViewGroup container, int position) {
  75. System.out.println("pos:" + position);
  76. View view = views.get(position);
  77. // 如果访问网络下载图片,此处可以进行异步加载
  78. ImageView img = (ImageView) view.findViewById(R.id.icon);
  79. img.setImageBitmap(BitmapFactory.decodeFile(dir + getFile(position)));
  80. container.addView(view);
  81. return views.get(position); // 返回该view对象,作为key
  82. }
  83. }
  84. public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
  85. if (viewPager != null) {
  86. viewPager.invalidate();
  87. }
  88. }
  89. // 一个新页被调用时执行,仍为原来的page时,该方法不被调用
  90. public void onPageSelected(int position) {
  91. tvTitle.setText(getFile(position));
  92. }
  93. /*
  94. * SCROLL_STATE_IDLE: pager处于空闲状态 SCROLL_STATE_DRAGGING: pager处于正在拖拽中
  95. * SCROLL_STATE_SETTLING: pager正在自动沉降,相当于松手后,pager恢复到一个完整pager的过程
  96. */
  97. public void onPageScrollStateChanged(int state) {
  98. }
  99. public String getFile(int position) {
  100. return "/img" + ((position + 1) >= 10 ? (position + 1) : "0" + (position + 1)) + ".png";
  101. }
  102. }
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:layout_width="match_parent"
  3. android:layout_height="match_parent"
  4. android:layout_marginLeft="15dp"
  5. android:layout_marginRight="15dp"
  6. android:layout_marginTop="50dp"
  7. android:orientation="vertical" >
  8. <View
  9. android:layout_width="match_parent"
  10. android:layout_height="2dp"
  11. android:background="#ffbd2021" />
  12. <!-- 配置container和pager的clipChildren=false, 并且指定marginLeft 和 marginRight 的值 -->
  13. <LinearLayout
  14. android:id="@+id/container"
  15. android:layout_width="match_parent"
  16. android:layout_height="100dp"
  17. android:clipChildren="false"
  18. android:gravity="center_horizontal"
  19. android:layerType="software"
  20. android:orientation="horizontal" >
  21. <android.support.v4.view.ViewPager
  22. android:id="@+id/viewpager"
  23. android:layout_width="match_parent"
  24. android:layout_height="match_parent"
  25. android:layout_marginLeft="110dp"
  26. android:layout_marginRight="110dp"
  27. android:clipChildren="false" >
  28. </android.support.v4.view.ViewPager>
  29. </LinearLayout>
  30. <View
  31. android:layout_width="match_parent"
  32. android:layout_height="2dp"
  33. android:background="#ffbd2021" />
  34. <ImageView
  35. android:layout_width="match_parent"
  36. android:layout_height="wrap_content"
  37. android:background="@drawable/line" />
  38. <TextView
  39. android:id="@+id/title"
  40. android:layout_width="match_parent"
  41. android:layout_height="wrap_content"
  42. android:layout_gravity="center"
  43. android:gravity="center_horizontal"
  44. android:scaleType="fitXY"
  45. android:src="@drawable/ic_launcher"
  46. android:text="baidu"
  47. android:textSize="18sp" />
  48. </LinearLayout>

Android_ViewPager_实现多个图片水平滚动的更多相关文章

  1. [iOS] UICollectionView实现图片水平滚动

    最新更新: 简单封装了一下代码,参考新文章:UICollectionView实现图片水平滚动 先简单看一下效果: 新博客:http://wossoneri.github.io 准备数据 首先先加入一些 ...

  2. 【demo练习三】:图片水平滚动、点击按钮变更图片动画

    要求:四张图片水平滚动,每隔5秒进行一次循环,点击按钮随机变更图片. XAML前台代码: <Window x:Class="图片滚动.MainWindow" xmlns=&q ...

  3. JS特效——图片水平滚动

    具体源码如下: <!doctype html> <html lang="en"> <head> <meta http-equiv=&quo ...

  4. [iOS] WSHorizontalPickerView 图片水平滚动封装

    之前这篇文章传送门本来是记录自己练手的demo的,后来很多人来问我要代码.今天就抽时间封装了一下,没有考虑太多情况,等我有空再去仔细考虑吧. 代码在:Github 用法很简单,创建对象,设置数据源,记 ...

  5. Android ViewPager实现多个图片水平滚动

    1.示意图                       2.实现分析 (1).xml配置 <!-- 配置container和pager的clipChildren=false, 并且指定margi ...

  6. ASP.NET中使用JavaScript实现图片自动水平滚动效果

    参照网上的资料,在ASP.NET中使用JavaScript实现图片自动水平滚动效果. 1.页面前台代码: <%@ Page Language="C#" AutoEventWi ...

  7. 使用Recyclerview实现图片水平自动循环滚动

    简介: 本篇博客主要介绍的是如何使用RecyclerView实现图片水平方向自动循环(跑马灯效果) 效果图: 思路: 1.准备m张图片 1.使用Recyclerview实现,返回无数个(实际Inter ...

  8. Android中如何实现多行、水平滚动的分页的Gridview?

    功能要求: (1)比如每页显示2X2,总共2XN,每个item显示图片+文字(点击有链接). 如果单行水平滚动,可以用Horizontalscrollview实现. 如果是多行水平滚动,则结合Grid ...

  9. jquery 文字滚动大全 scroll 支持文字或图片 单行滚动 多行滚动 带按钮控制滚动

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. js检测来源网址,如果是搜索引擎跳转到新地址

    [js]代码 <script> var regexp=/\.(sogou|soso|baidu|google|youdao|yahoo|bing|118114|biso|gougou|if ...

  2. 转:nginx基础概念(lingering_close)

    lingering_close,字面意思就是延迟关闭,也就是说,当nginx要关闭连接时,并非立即关闭连接,而是再等待一段时间后才真正关掉连接.为什么要这样呢?我们先来看看这样一个场景.nginx在接 ...

  3. sublime text执行PHP代码

    新建编译系统 { "cmd": ["php", "$file"], "file_regex": "php$&q ...

  4. vue初始化数据加载

    使用created钩子 import AppLayout from '@/components/app-layout' import axios from 'axios' export default ...

  5. Sakila——MySQL样例数据库解析(已经迁移)

    一.Introduction Sakila可以作为数据库设计的参考,也可作为实验数据.我是用作数据仓库和ODI学习的实验数据. The Sakila sample database was devel ...

  6. 【Linux】常见Linux默认的shell

    常见的操作系统下的shell: Linux下默认的shell是Bourne Again shell(bash) Solaris和FreeBSD下默认的是Bourne shell(sh) AIX系统下默 ...

  7. Android开发之使用Intent进行自定义类型数据传输

    一.引言 我相信一定有人想通过Intent传送自定义类型的数据,但是苦于无法找到putExtra(String name,Object value)这个方法,最后都会妥协,采用字典或者全局变量来 解决 ...

  8. 2011的n次方

    题目:http://noi.openjudge.cn/ch0204/2991/ 总时间限制:1000ms  内存限制: 65536kB 描述 已知长度最大为200位的正整数n,请求出2011^n的后四 ...

  9. windows下Oracle Tuxedo编译应用前需要配置的相关环境变量

    rem (c) BEA Systems, Inc. All Rights Reserved. rem Copyright (c) BEA Systems, Inc. rem All Rights Re ...

  10. 项目更改版本号之后打包失败 resolution will not be reattempted until the update interval of nexus has elapsed or updates are forced

    在修改项目的版本号之后,如pom.xml中<version>1.2.0-SNAPSHOT</version>替换为<version>1.0.0-RELEASE< ...