ArkUI自定义Scroll滑动 指示器

最近项目中有个需求,关于滑动组件 Scroll 底部指示器跟随手势滑动等比例展示的效果,下图展示了要实现的效果。

自定义指示器组件

这里其实不是一个进度条,所以需要我们需要自定义绘制该组件,在鸿蒙中绘制组件单独使用,用于在页面上绘制指定的图形。有7种绘制类型,分别为Circle(圆形)、Ellipse(椭圆形)、Line(直线)、Polyline(折线)、Polygon(多边形)、Path(路径)、Rect(矩形),这里我么使用 Rect 进行矩形绘制,一个黑色的 Rect当做指示器的背景,蓝色当做指示器的进度。然后动态设置进度的左边距。

@Entry
@Component
export struct RectIndicator {@Prop marginLeft: number = 0 //indicator距离进度距离左边间距,默认是 0indicatorHeight: number = 20 //indicator的高度indicatorWidth: number = 200 //indicator的背景宽度indicatorProgressWidth: number = 160 //indicator 的进度宽度build() {Stack() {//绘制矩形背景Rect({ width: this.indicatorWidth, height: this.indicatorHeight }).radius(this.indicatorHeight / 2).fill($r('app.color.bg_gray')).stroke(Color.Transparent)//绘制矩形进度Rect({ width: this.indicatorProgressWidth, height: this.indicatorHeight }).radius(this.indicatorHeight / 2).fill($r('app.color.main_color')).margin({ left: this.marginLeft }).stroke(Color.Transparent)}.alignContent(Alignment.Start)}
}

添加 Scroll 监听

新建一个 RectIndicator 类,需要把两个矩形层叠在一起,所以外层使用Stack布局进行嵌套。调用该自定义组件的时候,可以设置 组件的宽度(indicatorWidth) ,高度(indicatorHeight),进度的宽度(indicatorProgressWidth)以及动态设置进度的左边距(marginLeft),可以通过监听 Scroll 的滑动事件来动态设置 marginLeft。

Scroll(this.scroll) {Row() {ForEach(SUB_MENUS, (item: Menu, index) => {Column() {Image(item.menuIcon).width(28).height(28)Text(item.menuText).fontSize(12).fontColor($r("app.color.text_two")).margin({ top: 5 })}.width("20%").id("item")})}}.scrollable(ScrollDirection.Horizontal).margin({ top: 12 }).scrollBar(BarState.Off)//滑动监听.onDidScroll((_xOffset, _yOffset, scrollState) => {//当前状态为滑动状态if (scrollState == ScrollState.Scroll) {//获取滚动的偏移量,通过控制器获取比较准确const currentOffsetX = this.scroll.currentOffset().xOffsetLogUtil.debug("滑动偏移量", vp2px(currentOffsetX).toString())//子组件宽度*2=未显示出来的组件/指示器灰色部分let ratio = this.itemWidth * 2 / 10//指示器进度的偏移量=scroll 的偏移量/比率this.indicatorLeft = vp2px(currentOffsetX) / ratio}})

onDidScroll 可以对滑动组件(包括但不限于 Scroll)设置监听,这里判断 scrollState 为滑动状态,获取当前滑动的偏移量 currentOffsetX,通过Scroll 的偏移量计算出 指示器的左间距(indicatorLeft)。

使用自定义RectIndicator组件

 RecIndicator({marginLeft: this.indicatorLeft, //左间距indicatorHeight: 4,  //指示器的高度indicatorWidth: 30,  //指示器的背景宽度indicatorProgressWidth: 20  //指示器进度的宽度}).margin({ top: 8, bottom: 8 })

使用方法:调用RecIndicator自定义组件,将高度,宽度等相关参数传递组件内,这里的进度宽度,可以通过 Scroll 组件长度计算出来,这里我就这只给一个宽度,不影响使用。

tips:indicatorLeft需要加一个@State 注解,保证组件可以根据indicatorLeft来实时刷新 UI。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/55972.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

九盾叉车高位显示器:重塑叉车视界,引领高位精准

在繁忙的物流与仓储中,叉车不仅是力量与效率的化身,更是精准与安全的守护者。九盾安防,以科技之名,打造叉车高位显示器,彻底革新了货叉升降的盲区挑战,为物流、仓储及码头等领域带来了前所未有的作业体验。…

arm架构ceph pacific部署

背景 合作伙伴实验室的华为私有云原来使用单点的nfs做为存储设备,现有两方面考量,业务需要使用oss了,k8s集群及其他机器也需要一套可扩展的分布式文件系统 部署ceph 初始机器配置规划 IP配置主机名Role10.17.3.144c8g1T数据盘ceph-node01…

2024java高频面试之JVM

说说 JVM 内存区域 程序计数器 是「程序控制流的指示器,循环,跳转,异常处理,线程的恢复等工作都需要依赖程序计数器去完成」。程序计数器是「线程私有」的,它的「生命周期是和线程保持一致」的,我们知道&a…

大模型落地实践:同花顺大模型技术应用及优化

这份完整版的大模型 LLM 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】 众所周知,大模型参数量大,通用能力强,综合性能好。但在同花顺业务场景中最初使用大模型的时候&#xf…

2024年制冷与空调设备安装修理证模拟考试题库及制冷与空调设备安装修理理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年制冷与空调设备安装修理证模拟考试题库及制冷与空调设备安装修理理论考试试题是由安全生产模拟考试一点通提供,制冷与空调设备安装修理证模拟考试题库是根据制冷与空调设备安装修理最新版教材&#…

2024年最新苹果iOS证书申请创建App详细图文流程

iOS 证书设置指南: 对于开发者来说,在没有Mac电脑或对Xcode等开发工具不熟悉的情况下,如何快速完成IOS证书制作和IPA文件提交至开发者中心一直是一个难题。但是现在,有了初雪云提供的极简工具,您可以轻松实现这两个任…

分布式数据库环境(HBase分布式数据库)的搭建与配置

分布式数据库环境(HBase分布式数据库)的搭建与配置 1. VMWare安装CentOS7.9.20091.1 下载 CentOS7.9.2009 映像文件1.2启动 VMware WorkstationPro,点击“创建新的虚拟机”1.3在新建虚拟机向导界面选择“典型(推荐)”1…

springBoot集成nacos注册中心以及配置中心

一、安装启动nacos 访问&#xff1a;http://127.0.0.1:8848/nacos/index.html#/login 二、工程集成nacos 1、引入依赖 我这里搭建的父子工程哈&#xff0c;在子工程引入 <dependencies><!-- SpringBoot Web --><dependency><groupId>org.sp…

【Golang】关于Gin框架请求参数的获取

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

基于springboot的网上服装购物商城系统

基于springboot的网上服装购物商城系统 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;idea 源码获取&#xff1a; &#x…

【conda环境打包】ubuntu的conda环境打包导出方法 conda-pack

【conda环境打包】ubuntu的conda环境打包导出方法 conda-pack 1.准备工作2.解压3.后续处理参考文献 1.准备工作 安装conda-pack pip install conda-pack激活要被打包的环境&#xff0c;打包环境之前 先激活要打包的环境 conda activate 被打包的环境打包命令 conda pack --…

Java 输入与输出(I\O)之字节缓冲流【BufferedInputStream】【BufferedOutputStream】详解

缓冲流是Java I/O中的一个重要概念&#xff0c;它可以提高文件读写的性能。 由于磁盘的IO处理速度远低于内存的读写速度。 为了提高文件读写性能&#xff0c;我们可以使用缓冲流。缓冲流使用内存缓冲区&#xff0c;可以一次性读取或写入大量数据&#xff0c;从而减少与磁盘的交…

vscode中每个打开的文件都显示在一个单独的标签页中

版本&#xff1a;1.94 实现步骤&#xff1a; 1、打开设置 File-》Preferences-》Settings 2、具体设置 2.1、在配置中搜索 workbench.editor.showTabs 设置为multiple。 2.2、在配置中搜索 workbench.editor.enablePreview 取消勾选。 根据这个功能的说明&#xff0c;在…

24.10.20(换根哈希)

星期一&#xff1a; 阴间场 cf渡劫成功&#xff0c;拿下三题&#xff0c;终于上蓝&#x1f973;&#x1f973;&#x1f973; 贴 cf round978 div2 C cf传送门 答案取到n1但初始化没到n1&#xff0c;wa了一发&#xff0c;很烦&#x1f63f;…

100. UE5 GAS RPG 显示范围魔法的攻击范围

在这一篇里&#xff0c;我们将制作一个范围魔法&#xff0c;释放魔法时&#xff0c;我们将在鼠标拾取位置绘制一个魔法光圈&#xff0c;用于显示技能释放时攻击的范围&#xff0c;然后再次点击可以释放技能。 创建贴花类 魔法范围标识的光圈&#xff0c;我们采用贴花实现&…

利用飞腾派进行OpenCV开发

实验目标&#xff1a; 完成飞腾平台OpenCV开发。 实验大纲&#xff1a; Mat数据结构加载、显示、保存图像读写像素RGB图像分离彩色图转灰度图 Mat数据结构 Mat是一个类&#xff0c;由两个数据部分组成&#xff1a;矩阵头(大小,通道,数据类型等)和数据块(像素 值)。创建示例…

SQL Server-导入和导出excel数据-注意事项

环境&#xff1a; win10&#xff0c;SQL Server 2008 R2 之前写过的放在这里&#xff1a; SqlServer_陆沙的博客-CSDN博客 https://blog.csdn.net/pxy7896/category_12704205.html 最近重启ASP.NET项目&#xff0c;在使用sql server导出和导入数据时遇到一些问题&#xff0c;特…

SDRAM控制器的设计与验证(野火学习笔记)

SDRAM发展至今已历经五代&#xff0c;具有单位存储量大、高数据带宽、读写速度快、价格相对便宜等优点。同时&#xff0c;作为内存条中不可缺少的有一部分&#xff0c;SDRAM在计算机领域也占有一席之地。 &#xff08;SDRAM的内容以及操作时序比较复杂&#xff0c;本文已经尽可…

计算机毕业设计Python+大模型知识图谱中华古诗词可视化 古诗词智能问答系统 古诗词数据分析 古诗词情感分析 PyTorch Tensorflow LSTM

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 开发技术&#xff1a; 前端…

Web前端-JavaScript书写位置

一、JavaScript介绍 1.JavaScript 是什么? 是一种运行在客户端(浏览器)的编程语言&#xff0c;实现人机交互效果。 2.作用 &#xff08;1&#xff09;网页特效(监听用户的一些行为让网页作出对应的反馈) &#xff08;2&#xff09;表单验证(针对表单数据的合法性进行判断…