ViewPager制作循环滚动图片

本文介绍了如何利用ViewPager实现图片的循环滚动效果,通过解析其工作原理,详细讲解了设置适配器、处理边界情况以及无缝衔接的关键步骤。
摘要由CSDN通过智能技术生成

原理:



核心代码如下:
private int[] hotIds = new int[] { R.drawable.hot1, R.drawable.hot2,
			R.drawable.hot3, R.drawable.hot4 };
	private List<View> pagerList;
	private LinearLayout pagerPoints;
	
	private void setViewPager() {
		pagerList = new ArrayList<View>();
		for (int i = 0; i < hotIds.length + 2; i++) {
			ImageView iv = new ImageView(SecondActivity.this);
			if (i == 0) {
				iv.setImageResource(hotIds[hotIds.length - 1]);
			} else if (i == hotIds.length + 1) {
				iv.setImageResource(hotIds[0]);
			} else {
				iv.setImageResource(hotIds[i - 1]);
			}
			pagerList.add(iv);
		}

		pagerPoints = (LinearLayout)this.findViewById(R.id.second_pager_point);
		for (int i = 0; i < hotIds.length; i++) {
			ImageView iv = new ImageView(SecondActivity.this);
			iv.setImageResource(R.drawable.selector_pager_point);
			pagerPoints.addView(iv);
		}
		ImageView firstPoint = (ImageView)pagerPoints.getChildAt(0);
		firstPoint.setSelected(true);
		
		mViewPager = (ViewPager) this.findViewById(R.id.second_scroll_picture);

		mViewPager.setAdapter(new PagerAdapter() {

			@Override
			public boolean isViewFromObject(View arg0, Object arg1) {
				// TODO Auto-generated method stub
				return arg0 == arg1;
			}

			@Override
			public int getCount() {
				// TODO Auto-generated method stub
				return pagerList.size();
			}

			@Override
			public Object instantiateItem(ViewGroup container, int position) {
			
				((ViewPager) container).addView(pagerList.get(position));
				return pagerList.get(position);
			}

			@Override
			public void destroyItem(ViewGroup container, int position,
					Object object) {
			
				((ViewPager) container).removeView(pagerList.get(position));
			}
		});
		mViewPager.setCurrentItem(1); // 设置当前pager为1,即开始时就可以向右活动

		mViewPager.setOnPageChangeListener(new OnPageChangeListener() {

			@Override
			public void onPageSelected(int position) {
				// TODO Auto-generated method stub
				// System.out.println("--onPageSelected--" + position);
				for (int i = 0; i < pagerPoints.getChildCount(); i++) {
					pagerPoints.getChildAt(i).setSelected(false);
				}
				//判断是否为最前面的图片,或最后没的图片
				if (position == 0) {
					//pager划到第一页时跳到末尾页
					mViewPager.setCurrentItem(pagerList.size()-2, false);
					//设置所在图片的 点
					pagerPoints.getChildAt( pagerPoints.getChildCount()-1).setSelected(true);
				} else if (position == pagerList.size()-1) {
					//pager划到最后一页时跳到首页
					mViewPager.setCurrentItem(1, false);
					//设置所在图片的 点
					pagerPoints.getChildAt(0).setSelected(true);
				}else{
					//设置所在图片的 点
					pagerPoints.getChildAt(position-1).setSelected(true);
				}

			}

			@Override
			public void onPageScrolled(int arg0, float arg1, int arg2) {
			}

			@Override
			public void onPageScrollStateChanged(int position) {
			}
		});

	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值