SeekBar 实现网络获取图片随thumb滑动,,并位于中间位置

2023-11-21 05:18

本文主要是介绍SeekBar 实现网络获取图片随thumb滑动,,并位于中间位置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 demo介绍

此demo实现了seekbar 滑动效果,图片随thumb 滑动而滑动,位于seekbar中间位置:
效果图如下:

这里写图片描述

二.代码介绍:

1.xml文件:
 <SeekBarandroid:id="@+id/seekbar_progress"android:layout_width="match_parent"android:layout_height="wrap_content"android:focusable="true"android:maxHeight="7dp"android:minHeight="7dp"android:paddingEnd="15dp"android:paddingStart="15dp"android:progressDrawable="@drawable/progress_test        android:thumb="@drawable/progress_theme_bar"android:thumbOffset="15dip" />

seekbar默认两边会有间隙,因为我想覆盖住两边的小红点,所以设置了

android:paddingStart="15dp"
android:paddingEnd="15dp"

如果你不想要两边的空隙,设置:

android:paddingStart="0dp"
android:paddingEnd="0dp"

一般情况下, thumb滑块不能显示完全,一部分被隐藏掉,设置:

android:thumbOffset="0dip"  

我想设置thumb覆盖在两边红点上,则设置了:

android:thumbOffset="15dip"
2.java文件

1.Glide 加载圆形图片

        Glide.with(MainActivity.this).load(imgurl).diskCacheStrategy(DiskCacheStrategy.ALL).error(R.mipmap.ic_launcher).centerCrop().transform(new GlideRoundTransformUtil(MainActivity.this)).into(ivHead);

2.seekbar 监听,设置滑动区间

seekbarProgress.setOnSeekBarChangeListener(new OnSeekBarChangeListenermy());seekbarProgress.setMax(100);seekbarProgress.setProgress(0);

3.测量seekbar 控件的宽度 获取每个百分比的宽度

 ViewTreeObserver vto2 = seekbarProgress.getViewTreeObserver();vto2.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {@Overridepublic void onGlobalLayout() {seekbarProgress.getViewTreeObserver().removeGlobalOnLayoutListener(this);seekbarProgress.getWidth();mseekWidth = seekbarProgress.getWidth();// 获取thumb drawable 占用的空间Drawable drawable = getResources().getDrawable(R.drawable.progress_theme_bar);mDrawableWidth = drawable.getIntrinsicWidth();mDrawableHeight = drawable.getIntrinsicHeight();//每个百分比所占的宽度mMoveStep = ((mseekWidth - mDrawableWidth) / (double) 100);//头像初始位置ivHead.layout(0, 0, mDrawableWidth, mDrawableHeight);}});

4.监听滑动,设置图片位置:

 int layoutLeft = (int) (progress * mMoveStep);//随着滑动 图片位置改变ivHead.layout(layoutLeft, 0, layoutLeft + mDrawableWidth, mDrawableHeight);

下面附下dem地址:
http://download.csdn.net/download/shanshan_1117/10164478

这篇关于SeekBar 实现网络获取图片随thumb滑动,,并位于中间位置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/400063

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin