非常简单的方法实现ViewPager自动循环轮播
非常简单的方法实现ViewPager自动循环轮播,见红色代码部分,其它的代码可以忽略不看。
简洁高效是我解决问题的首要出发点。
- package com.shuivy.happylendandreadbooks.fragment;
- import android.app.Activity;
- import android.app.Fragment;
- import android.os.Bundle;
- import android.os.Handler;
- import android.support.v4.view.ViewPager;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.view.ViewGroup;
- import android.widget.ImageView;
- import android.widget.LinearLayout;
- import android.widget.TextView;
- import com.shuivy.happylendandreadbooks.R;
- import com.shuivy.happylendandreadbooks.adapter.MyViewPagerAdapter;
- import java.util.ArrayList;
- import java.util.List;
- /**
- * Created by stk on 2016/7/22 0022.
- */
- public class HomeFragment extends Fragment {
- private View mRootView;
- private Activity mContext;
- private LayoutInflater mLayoutInflater;
- private int[] mImageIdArray;
- private static final int TIME = 1700;
- private List<View> mLayouts;
- private List<View> mDots;
- private ViewPager mViewPager;
- private int mCount = 3;
- private Handler mHandler = new Handler();
- private int itemPosition;
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
- mContext = getActivity();
- if (mRootView == null) {
- mRootView = inflater.inflate(R.layout.fragment_home, container, false);
- mLayoutInflater = inflater;
- initView();
- } else {
- ViewGroup parent = (ViewGroup) mRootView.getParent();
- if (parent != null) {
- parent.removeView(mRootView);
- }
- }
- return mRootView;
- }
- private void initView() {
- mImageIdArray = new int[]{
- R.mipmap.book_viewpager1,
- R.mipmap.book_viewpager2,
- R.mipmap.book_viewpager3,
- };
- TextView textView = (TextView) mRootView.findViewById(R.id.titleView);
- textView.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View view) {
- mViewPager.setCurrentItem(1);
- }
- });
- initIndex();
- }
- private void initIndex() {
- viewPager();
- mHandler.postDelayed(runnableForViewPager, TIME);
- }
- /**
- * 首页上方的viewpager图片展示
- */
- private void viewPager() {
- ViewGroup viewGroup = (ViewGroup) mRootView.findViewById(R.id.viewGroup);
- mViewPager = (ViewPager) mRootView.findViewById(R.id.viewPager);
- //mCount是订单数量,是从订单处得到的数据,我们默认设为3
- mLayouts = new ArrayList<>();
- mDots = new ArrayList<>();
- for (int i = 0; i < mCount; i++) {
- //下面两句必须放在for里面
- View layoutView = mLayoutInflater.inflate(R.layout.viewpager_item, null);
- View dotView = mLayoutInflater.inflate(R.layout.dot, null);
- ImageView imageView = (ImageView) layoutView.findViewById(R.id.viewpager_image);
- imageView.setImageResource(mImageIdArray[i]);
- if (i == 0) {
- dotView.setBackgroundResource(R.drawable.dot_select);
- } else {
- dotView.setBackgroundResource(R.drawable.dot_no_select);
- }
- LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(
- new ViewGroup.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
- ViewGroup.LayoutParams.WRAP_CONTENT));
- layoutParams.setMargins(20, 0, 20, 0);
- viewGroup.addView(dotView, layoutParams);
- mLayouts.add(layoutView);
- mDots.add(dotView);
- }
- mViewPager.setAdapter(new MyViewPagerAdapter(mLayouts));
- mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
- @Override
- public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
- }
- @Override
- public void onPageSelected(int position) {
- for (int i = 0; i < mCount; i++) {
- if (i == position) {
- mDots.get(i).setBackgroundResource(R.drawable.dot_select);
- } else {
- mDots.get(i).setBackgroundResource(R.drawable.dot_no_select);
- }
- }
- }
- @Override
- public void onPageScrollStateChanged(int state) {
- }
- });
- }
- /**
- * ViewPager的定时器
- */
- Runnable runnableForViewPager = new Runnable() {
- @Override
- public void run() {
- try {
- itemPosition++;
- mHandler.postDelayed(this, TIME);
- mViewPager.setCurrentItem(itemPosition % mCount);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- };
- }
非常简单的方法实现ViewPager自动循环轮播的更多相关文章
- JS-特效 ~ 01. 事件对象、offset偏移/检测、无缝滚动、自动循环轮播图
Math.round ( ) :正书四舍五入,负数五舍六入 用定时器,先清除定时器 事件对象 event event:事件被触动时,鼠标和键盘的状态,通过属性控制 Offset:偏移,检测 1. 获取 ...
- Android RecyclerView 水平滚动+自动循环轮播
主要处理的地方: 1.RecyclerView中Adapter的item个人可以无限轮询. 2.RecyclerView自动滑动 3.手指按下时滑动停止,手指抬起后继续自动滑动 public clas ...
- 用jquery或js实现三个div自动循环轮播
//3个div的统一class = 'div' var index =0; //3秒轮播一次 var timer = setInterval(function(){ index = (inde ...
- Android自动滚动 轮播循环的ViewPager
主要介绍如何实现ViewPager自动播放,循环滚动的效果及使用.顺便解决ViewPager嵌套(ViewPager inside ViewPager)影响触摸滑动及ViewPager滑动速度设置问题 ...
- 解析SwiftUI布局细节(二)循环轮播+复杂布局
前言 上一篇我们总结的主要是VStack里面的东西,由他延伸到 @ViewBuilder, 接着我们上一篇总结的我们这篇内容主要说的是下面的几点,在这些东西说完后我准备解析一下苹果在SiwftUI文档 ...
- Android高仿京东淘宝自动无限循环轮播控件的实现思路和过程
在App的开发中,很多的时候都需要实现类似京东淘宝一样的自动无限轮播的广告栏,所以就自己写了一个,下面是我自定义控件的实现思路和过程. 一.自定义控件属性 新建自定义控件SliderLayout继承于 ...
- Android无限循环轮播广告位Banner
Android无限循环轮播广告位Banner 现在一些app通常会在头部放一个广告位,底部放置一行小圆圈指示器,指示广告位当前的页码,轮播展示一些图片,这些图片来自于网络.这个广告位banner ...
- ios之无限 自动 图片轮播器的实现
比较之前发布的手动无限图片轮播器进行了改进.实现了自动无限轮播的功能.比较适合团购标题分类下面的轮播器功能. 实现思路: * 开启一个定时器,把操作放入消息循环池.每隔一定时间,操作执行一次. * 注 ...
- ViewPager实现无限轮播踩坑记
最近笔者想通过ViewPager来实现一个广告Banner,并实现无限轮播的效果,但是在这个过程中踩了不少的坑,听我慢慢道来.如果大家有遇到和我一样的情况,可以参考我的解决方法,没有那就更好,如果针对 ...
随机推荐
- eclipse删除多余的工作空间
window->preferences->startup and shutdown->workspaces如图:
- js实现弹窗居中
在一些页面中,我们总会遇到一些弹窗不居中的时候,还要根据浏览器的大小来调整弹窗的弹出位置, 之前我也遇到这样的问题,现在我把我知道的呈现给大家 css样式 .windowBox{ width:500p ...
- Date ——日期型函数Date常用API
获取当前时间戳: let now = new Date().getTime() 获取某个时间点(比如12点)的时间戳: let date = new Date('2019-01-12 12:00:0 ...
- 使用NGINX+Openresty和unixhot_waf开源防火墙实现WAF功能
使用NGINX+Openresty实现WAF功能 一.了解WAF1.1 什么是WAF Web应用防护系统(也称:网站应用级入侵防御系统 .英文:Web Application Firewall,简称: ...
- curl, wget常用选项
使用指定的http代理,配合md5sum 对于检查源站与cdn节点资源是否一致很有效 curl -o a.jpg -x http://pbcdn.xximg1.com/v6/global2015/im ...
- OCM_第四天课程:Section2 —》GC 的安装和配置
注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...
- 教你构建好 SpringBoot + SSM 框架
来源:Howie_Y https://juejin.im/post/5b53f677f265da0f8f203914 目前最主流的 java web 框架应该是 SSM,而 SSM 框架由于更轻便与灵 ...
- Django整合Keras报错:ValueError: Tensor Tensor("Placeholder:0", shape=(3, 3, 1, 32), dtype=float32) is not an element of this graph.解决方法
本人在写Django RESful API时,碰到一个难题,老出现,整合Keras,报如下错误:很纠结,探索找资料近一个星期,皇天不负有心人,解决了 Internal Server Error: /p ...
- 在IDEA中实战Git
工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程git仓库上获取项目源码 场景三:小 ...
- Redis、RabbitMQ、Memcached
知识目录: Memcached Redis RabbitMQ Memcached 回到顶部 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中 ...