「Mac畅玩鸿蒙与硬件28」UI互动应用篇5 - 滑动选择器实现

简介: 本篇将带你实现一个滑动选择器应用,用户可以通过滑动条选择不同的数值,并实时查看选定的值和提示。这是一个学习如何使用 Slider 组件、状态管理和动态文本更新的良好实践。

本篇将带你实现一个滑动选择器应用,用户可以通过滑动条选择不同的数值,并实时查看选定的值和提示。这是一个学习如何使用 Slider 组件、状态管理和动态文本更新的良好实践。

20241105_000144.gif


关键词
  • UI互动应用
  • Slider 组件
  • 状态管理
  • 动态数值更新
  • 用户交互

一、功能说明

在这个滑动选择器应用中,用户通过滑动条选择值,应用实时更新并显示当前选择的值。根据不同的数值范围,文本提示会变化,增加交互效果。


二、所需组件

  • @Entry@Component 装饰器
  • ColumnRow 布局组件
  • Text 组件用于显示文本
  • Slider 组件用于滑动选择
  • @State 修饰符用于状态管理

项目结构

  • 项目名称SliderSelectorApp
  • 自定义组件名称SliderSelectorPage
  • 代码文件SliderSelectorPage.etsIndex.ets

三、代码实现

// 文件名:SliderSelectorPage.ets

// 定义滑动选择器页面组件
@Component
export struct SliderSelectorPage {
   
  // 定义一个状态变量 selectedValue,用 @State 修饰符管理其状态变化
  @State selectedValue: number = 50; // 初始值设为 50

  // build() 方法构建页面布局和组件
  build() {
   
    Column({
    space: 20 }) {
    // 创建垂直布局容器,子组件之间的间距为 20
      // 显示当前选择的数值
      Row() {
   
        Text(`当前选择的值: ${
     this.selectedValue}`) // 显示选定的值
          .fontSize(24) // 设置字体大小
          .fontWeight(FontWeight.Bold) // 设置字体为粗体
          .alignSelf(ItemAlign.Center) // 水平居中对齐
          .fontColor(Color.Black); // 设置文本颜色为黑色
      }

      // 滑动选择器组件
      Slider({
    min: 0, max: 100, value: this.selectedValue }) // 创建滑动选择器,范围为 0-100
        .onChange((value: number) => {
    // 滑动时触发事件
          this.selectedValue = value; // 更新选定的值
        })
        .blockColor(Color.Blue) // 设置滑块颜色
        .trackColor(Color.Gray) // 设置滑动条背景颜色
        .width('80%') // 设置宽度为 80%
        .alignSelf(ItemAlign.Center); // 水平居中对齐

      // 动态显示提示文本,根据选定的值显示不同的提示和颜色
      Row() {
   
        Text(this.getFeedbackMessage()) // 获取反馈文本
          .fontSize(18) // 设置字体大小
          .alignSelf(ItemAlign.Center) // 水平居中对齐
          .fontColor(this.getFeedbackColor()); // 设置文本颜色
      }
    }
    .padding(20) // 设置内边距
    .width('100%') // 设置容器宽度为 100%
    .height('100%') // 设置容器高度为 100%
    .alignItems(HorizontalAlign.Center); // 垂直居中对齐
  }

  // 根据当前值返回不同的提示信息
  private getFeedbackMessage(): string {
   
    if (this.selectedValue > 75) {
   
      return '高值选择';
    } else if (this.selectedValue < 25) {
   
      return '低值选择';
    } else {
   
      return '中间值';
    }
  }

  // 根据当前值返回不同的文本颜色
  private getFeedbackColor(): Color {
   
    if (this.selectedValue > 75) {
   
      return Color.Red; // 返回红色
    } else if (this.selectedValue < 25) {
   
      return Color.Blue; // 返回蓝色
    } else {
   
      return Color.Green; // 返回绿色
    }
  }
}
// 文件名:Index.ets

// 导入滑动选择器页面组件
import {
    SliderSelectorPage } from './SliderSelectorPage'

// 定义应用入口组件
@Entry
@Component
struct Index {
   
  // build() 方法构建页面布局和组件
  build() {
   
    Column() {
   
      SliderSelectorPage() // 引用自定义的滑动选择器组件
    }
    .padding(20) // 设置页面内边距
  }
}

效果示例:用户拖动滑动条时,选定的值会实时更新并显示。根据值的范围,文本提示内容和颜色会动态变化。

20241105_000144.gif


四、代码解读

  • @State selectedValue
    定义一个状态变量,用于保存当前滑动条的值。状态变化时,UI 会自动刷新。
  • Slider 组件
    实现滑动选择功能,并通过 onChange 事件更新 selectedValue
  • getFeedbackMessage()getFeedbackColor() 方法
    根据 selectedValue 返回不同的提示文本和颜色,实现动态反馈。

五、优化建议

  1. 自定义滑动条样式:通过 blockColortrackColor 自定义滑动条的外观,提升视觉效果。
  2. 添加最小和最大值标签:在滑动条的两端添加文本标签,如“0”和“100”。
  3. 滑动动画:为滑动条添加动画过渡,使用户体验更流畅。
  4. 多语言支持:根据用户的语言环境显示不同语言的提示文本。

六、相关知识点


小结

本篇教程通过滑动选择器应用的实现,你学会了如何使用 Slider 组件来实现动态数值选择和显示。这为开发更复杂的交互式应用打下了基础。


下一篇预告

下一篇「UI互动应用篇6 - 多选问卷小应用」将展示如何实现用户多选问卷功能,并显示提交后的结果。


上一篇: 「Mac畅玩鸿蒙与硬件27」UI互动应用篇4 - 猫与灯的互动应用

下一篇: 「Mac畅玩鸿蒙与硬件29」UI互动应用篇6 - 多选问卷小应用


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=284
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
9月前
|
Android开发 容器
鸿蒙开发:使用nestedScroll解决滑动冲突
nestedScroll属性的作用,主要是,用于设置嵌套滚动选项,设置前后两个方向的嵌套滚动模式,实现与父组件的滚动联动。
280 19
鸿蒙开发:使用nestedScroll解决滑动冲突
|
9月前
HarmonyOS实战:Tab顶部滑动悬停功能实现
在鸿蒙开发中,实现Scroll嵌套List列表滑动时顶部悬停的效果是一个常见需求。本文详细介绍了如何通过布局和事件处理来实现这一功能。首先,使用Scroll嵌套List和Tab布局来构建基础页面。然后,通过设置nestedScroll属性为NestedScrollMode.PARENT_FIRST,确保外层Scroll优先滑动。接着,通过监听List和Scroll的滑动事件,处理滑动冲突,确保在特定条件下Scroll停止滑动,将滑动事件交给List处理。最终,实现了在上下滑动时优先让Scroll滑动的效果,并提供了扩展思路,如优先让List滑动等。
430 10
HarmonyOS实战:Tab顶部滑动悬停功能实现
|
8月前
|
人机交互 UED 索引
41.[HarmonyOS NEXT Row案例九] 打造流畅可滑动列表项:滑动操作按钮的高级实现
在现代移动应用中,可滑动列表项是一种常见且高效的交互方式,它允许用户通过水平滑动列表项来显示隐藏的操作按钮,如删除、置顶、归档等。本教程将详细讲解如何使用HarmonyOS NEXT的Row组件结合手势和动画创建一个流畅的可滑动列表项,实现滑动操作按钮的高级交互效果。
226 8
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
780 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
8月前
|
索引
鸿蒙开发:自定义切换动画实现Swiper层叠滑动效果
customContentTransition不仅仅可以实现平移上的改变,很多的效果,我们都可以实现,比如放大缩小,旋转等等。
409 2
鸿蒙开发:自定义切换动画实现Swiper层叠滑动效果
|
人工智能 自然语言处理 API
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
UI-TARS Desktop 是一款基于视觉语言模型的 GUI 代理应用,支持通过自然语言控制电脑操作,提供跨平台支持、实时反馈和精准的鼠标键盘控制。
4438 17
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
366 13
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
334 10
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
|
5月前
|
前端开发 安全 测试技术
Postman Mac 版安装终极指南:从下载到流畅运行,一步到位
Postman 是 API 开发与测试的高效工具,支持各类 HTTP 请求调试与团队协作。本文详解 Mac 版下载、安装步骤,助你快速上手。同时推荐一体化 API 协作平台 Apifox,集文档、调试、测试于一体,提升开发效率与团队协同能力。

热门文章

最新文章