博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实现viewpager下的圆点滑动
阅读量:5049 次
发布时间:2019-06-12

本文共 3455 字,大约阅读时间需要 11 分钟。

在Drawable目录下创建资源文件 使用shape标签画出背景圆点与当前圆点

背景圆点:

当前圆点:
布局界面:
LinearLayout:用来在代码中添加背景点
代码中: 先画背景点:
for (int i = 0; i < list_photo.size(); i++) {
View point = new View(this); point.setBackgroundResource(R.drawable.shape_point_gray);// 设置引导页默认圆点 LinearLayout.LayoutParams params = new LinearLayout.LayoutParams( DensityUtils.dp2px(this, 10), DensityUtils.dp2px(this, 10)); if (i > 0) {
params.leftMargin = DensityUtils.dp2px(this, 10);// 设置圆点间隔 } point.setLayoutParams(params);// 设置圆点的大小 ll_point_group.addView(point);// 将圆点添加给线性布局 } // 获取视图树, 对layout结束事件进行监听 ll_point_group.getViewTreeObserver().addOnGlobalLayoutListener( new ViewTreeObserver.OnGlobalLayoutListener() {
// 当layout执行结束后回调此方法 @Override public void onGlobalLayout() {
System.out.println("layout 结束"); ll_point_group.getViewTreeObserver() .removeGlobalOnLayoutListener(this); mPointWidth = ll_point_group.getChildAt(1).getLeft() - ll_point_group.getChildAt(0).getLeft(); System.out.println("圆点距离:" + mPointWidth); } }); 对图片使用点击事件的监听避免点击后不会循环播放
class MyTouchListener implements View.OnTouchListener {
@Override public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN: System.out.println("按下"); mHandler.removeCallbacksAndMessages(null);// 删除Handler中的所有消息 break; case MotionEvent.ACTION_CANCEL: System.out.println("事件取消"); mHandler.sendEmptyMessageDelayed(0, 3000); break; case MotionEvent.ACTION_UP: System.out.println("抬起"); mHandler.sendEmptyMessageDelayed(0, 3000); break; default: break; } return true; } } 重写viewpager的滑动事件实时改变红点的位置
class MyPageListener implements ViewPager.OnPageChangeListener {
// 滑动事件 @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
// System.out.println("当前位置:" + position + ";百分比:" + positionOffset // + ";移动距离:" + positionOffsetPixels); int len = (int) (mPointWidth * positionOffset) + position * mPointWidth; RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) viewRedPoint .getLayoutParams();// 获取当前红点的布局参数 params.leftMargin = len;// 设置左边距 viewRedPoint.setLayoutParams(params);// 重新给小红点设置布局参数 } 定时循环播放viewpager的图片
// 自动轮播条显示 if (mHandler == null) {
mHandler = new Handler() {
public void handleMessage(android.os.Message msg) {
int currentItem = viewPager.getCurrentItem(); if (currentItem < list_photo.size() - 1) {
currentItem++; } else {
currentItem = 0; } viewPager.setCurrentItem(currentItem);// 切换到下一个页面 mHandler.sendEmptyMessageDelayed(0, 3000);// 继续延时3秒发消息, // 形成循环 }; }; mHandler.sendEmptyMessageDelayed(0, 3000);// 延时3秒后发消息 }

转载于:https://www.cnblogs.com/xiguameng/p/5738244.html

你可能感兴趣的文章
IOS-每个程序员的编程之路上都应该看这11本书
查看>>
自定义tabbar(纯代码)
查看>>
extjs fieldset 和 radio
查看>>
小程序底部导航栏
查看>>
Codeforces Gym101505G:Orchard Division(扫描线+线段树第k大)
查看>>
ibatis学习笔记
查看>>
18-ES6(1)
查看>>
poj1611 简单并查集
查看>>
tensorflow实现迁移学习
查看>>
Ubuntu 14.04下安装CUDA8.0
查看>>
跨平台开发 -- C# 使用 C/C++ 生成的动态链接库
查看>>
关于Redis处理高并发
查看>>
C# BS消息推送 SignalR介绍(一)
查看>>
asp.net core 系列 16 Web主机 IWebHostBuilder
查看>>
WPF星空效果
查看>>
WPF Layout 系统概述——Arrange
查看>>
PIGOSS
查看>>
几款Http小服务器
查看>>
iOS 数组排序
查看>>
第三节
查看>>