「Mac畅玩鸿蒙与硬件47」UI互动应用篇24 - 虚拟音乐控制台

简介: 本篇将带你实现一个虚拟音乐控制台。用户可以通过界面控制音乐的播放、暂停、切换歌曲,并查看当前播放的歌曲信息。页面还支持调整音量和动态显示播放进度,是音乐播放器界面开发的基础功能示例。

本篇将带你实现一个虚拟音乐控制台。用户可以通过界面控制音乐的播放、暂停、切换歌曲,并查看当前播放的歌曲信息。页面还支持调整音量和动态显示播放进度,是音乐播放器界面开发的基础功能示例。

20241219_210458.gif


关键词
  • UI互动应用
  • 音乐控制
  • 播放控制
  • 动态展示
  • 状态管理
  • 按钮与进度条

一、功能说明

虚拟音乐控制台支持以下功能:

  1. 播放/暂停控制:通过按钮切换播放与暂停状态。
  2. 歌曲切换:点击“下一首”按钮切换到歌曲列表中的下一首。
  3. 进度条动态更新:实时显示当前播放进度,播放结束后自动切换到下一首歌曲。
  4. 音量调节:通过滑块调整音量,音量值实时更新在界面上。
  5. 歌曲信息展示:显示当前播放的歌曲名称和状态。
  6. 图片展示:在界面顶部添加一张图片,提升视觉效果。

二、所需组件

  • @Entry@Component 装饰器
  • ColumnRow 布局组件
  • Text 组件用于显示当前歌曲信息
  • Button 组件用于音乐播放控制(播放、暂停、下一首)
  • Slider 组件用于音量调节
  • Progress 组件用于动态显示播放进度
  • Image 组件用于展示示例图片
  • @State 修饰符用于状态管理

三、项目结构

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

四、代码实现

// 文件名:MusicControlPage.ets

@Component
export struct MusicControlPage {
   
  @State isPlaying: boolean = false; // 播放状态
  @State currentSong: string = '歌曲1'; // 当前播放的歌曲
  @State songList: string[] = ['歌曲1', '歌曲2', '歌曲3']; // 歌曲列表
  @State songIndex: number = 0; // 当前歌曲索引
  @State songProgress: number = 0; // 当前播放进度(百分比)
  @State volume: number = 50; // 音量(0-100)

  private intervalId: number | null = null; // 定时器 ID

  // 切换到下一首歌曲
  nextSong(): void {
   
    this.songIndex = (this.songIndex + 1) % this.songList.length;
    this.currentSong = this.songList[this.songIndex];
    this.songProgress = 0; // 播放新歌曲时重置进度条
  }

  // 播放/暂停切换
  togglePlayPause(): void {
   
    this.isPlaying = !this.isPlaying;
    if (this.isPlaying) {
   
      this.startTimer();
    } else {
   
      this.clearTimer();
    }
  }

  // 更新播放进度
  updateProgress(): void {
   
    if (this.isPlaying) {
   
      this.songProgress += 2; // 每秒增加2%
      if (this.songProgress >= 100) {
   
        this.songProgress = 0; // 播放结束时重置进度
        this.nextSong(); // 自动切换到下一首
      }
    }
  }

  // 启动定时器
  startTimer(): void {
   
    if (!this.intervalId) {
   
      this.intervalId = setInterval(() => this.updateProgress(), 1000); // 每秒更新进度
    }
  }

  // 清理定时器
  clearTimer(): void {
   
    if (this.intervalId) {
   
      clearInterval(this.intervalId);
      this.intervalId = null;
    }
  }

  onInit(): void {
   
    this.startTimer(); // 页面加载时启动定时器
  }

  onDestroy(): void {
   
    this.clearTimer(); // 页面销毁时清理定时器
  }

  build(): void {
   
    Column({
    space: 20 }) {
   
      // 添加图片
      Image($r('app.media.cat')) // 添加一张图片
        .width(158)
        .height(188);

      Text('虚拟音乐控制台')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .alignSelf(ItemAlign.Center);

      // 显示当前歌曲信息
      Text(`当前播放: ${
     this.currentSong}`)
        .fontSize(18)
        .alignSelf(ItemAlign.Center);

      // 播放/暂停按钮
      Button(this.isPlaying ? '暂停' : '播放')
        .onClick(() => this.togglePlayPause())
        .margin({
    top: 10 });

      // 下一首按钮
      Button('下一首')
        .onClick(() => this.nextSong())
        .margin({
    top: 10 });

      // 播放进度条
      Progress({
   
        value: this.songProgress,
        total: 100,
        type: ProgressType.Linear,
      })
        .color(Color.Green)
        .height(8)
        .margin({
    top: 10 });

      // 显示音量
      Text(`音量: ${
     this.volume}`)
        .fontSize(18)
        .alignSelf(ItemAlign.Center)
        .margin({
    top: 10 });

      // 音量调节滑块
      Slider({
   
        value: this.volume,
        min: 0,
        max: 100,
      })
        .blockColor(Color.Blue)
        .trackColor(Color.Gray)
        .onChange((value: number) => (this.volume = value));
    }
    .padding(20)
    .width('100%')
    .height('100%');
  }
}
AI 代码解读
// 文件名:Index.ets

import {
    MusicControlPage } from './MusicControlPage';

@Entry
@Component
struct Index {
   
  build() {
   
    Column() {
   
      MusicControlPage() // 调用虚拟音乐控制台页面
    }
    .padding(20)
  }
}
AI 代码解读

效果示例:用户可以通过播放/暂停按钮控制音乐的播放,通过下一首按钮切换歌曲,进度条展示当前播放进度。界面顶部还显示了一张图片,增强了视觉效果。

20241219_210458.gif


五、代码解读

  1. 图片展示

    • 使用 Image 组件加载图片,放置在界面顶部,宽度 158px,高度 188px
  2. 播放控制

    • togglePlayPause() 切换播放和暂停状态,同时启动或清理定时器。
  3. 歌曲切换

    • nextSong() 切换歌曲,重置播放进度,支持循环播放。
  4. 动态进度条

    • Progress 组件绑定 songProgress,实时更新播放进度。
  5. 音量调节

    • Slider 实现音量调节,用户拖动滑块实时调整音量值。
  6. 状态管理

    • 使用 @State 管理播放状态、歌曲信息和音量,实现界面与功能的实时同步。

六、优化建议

  1. 增加“上一首”按钮,支持更多的播放控制功能。
  2. 添加播放列表展示,允许用户选择播放的歌曲。
  3. 通过后端支持真实音频播放,扩展实际应用场景。

七、效果展示

  • 图片展示:顶部显示一张图片,增加视觉元素。
  • 播放控制:用户通过按钮控制播放、暂停和切换歌曲。
  • 动态进度条:实时更新歌曲播放进度。
  • 音量调节:滑块调整音量,实时更新界面显示。

八、相关知识点


小结

通过本篇教程,用户学会了构建一个交互式的虚拟音乐控制台,包括播放控制、动态进度条更新和音量调节功能,展示了鸿蒙 UI 组件的组合使用。


下一篇预告

在下一篇「UI互动应用篇25 - 简易购物车功能实现」中,我们将探讨如何实现一个简易购物车功能,支持商品的添加、移除和总价计算。


上一篇: 「Mac畅玩鸿蒙与硬件46」UI互动应用篇23 - 自定义天气预报组件

下一篇: 「Mac畅玩鸿蒙与硬件48」UI互动应用篇25 - 简易购物车功能实现


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


目录
打赏
0
79
80
2
151
分享
相关文章
44.[HarmonyOS NEXT RelativeContainer案例一] 掌握组件锚点布局:打造灵活精准的UI定位系统
在HarmonyOS NEXT的UI开发中,精确控制组件位置是构建复杂界面的关键。RelativeContainer作为一种强大的布局容器,通过锚点系统提供了精确定位能力,使开发者能够创建出灵活且精准的UI布局。本教程将详细讲解如何使用RelativeContainer的锚点布局功能,帮助你掌握这一核心技术。
61 4
06.HarmonyOS Next UI进阶:Text组件与视觉样式完全指南
在HarmonyOS Next应用开发中,Text组件是最基础也是最常用的UI元素之一。它不仅用于显示文本内容,还可以通过丰富的样式属性实现各种视觉效果。掌握Text组件的样式设置,是构建精美UI界面的基础技能。
95 1
二、探索HarmonyOS Next应用的入口:深度解析Index页面
Index.ets是HarmonyOS Next开发者手册应用的入口页面,它展示了应用的主要导航结构和用户界面设计。本文将深入分析这个文件的代码结构、UI组件使用以及路由实现,帮助开发者理解HarmonyOS应用的基本构建模式。
65 0
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
92 11
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
90 15
鸿蒙5开发宝藏案例分享---应用接续提升内容发布体验
本文分享了鸿蒙应用接续功能的实战经验,帮助开发者实现跨设备流转。文章介绍了该功能的核心要点、开发条件及多个实战案例,如图文草稿跨设备接续、协同文档实时接续和社交通讯录接续,并提供了避坑指南与调试秘籍。通过动态压缩策略优化传输速度,结合AI能力提升体验。适合想了解鸿蒙跨设备开发的开发者参考学习。
鸿蒙5开发宝藏案例分享---一多开发实例(音乐)
鸿蒙开发干货分享:涵盖动态布局、交互动效、服务卡片设计、内存优化、分布式开发及性能加速六大核心主题。从折叠屏适配到手势动画,从服务卡片最佳实践到内存泄漏检测,结合官方100+实战案例与高频痛点解决方案,助你解锁鸿蒙开发隐藏技巧,提升效率与用户体验。快来一起探讨开发中的那些“坑”吧!
|
1月前
|
60.[HarmonyOS NEXT 实战案例四] 天气应用网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的天气应用网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的天气应用界面。
67 0
|
1月前
|
59. [HarmonyOS NEXT 实战案例四] 天气应用网格布局(上)
天气应用是移动设备上常见的应用类型,它需要在有限的屏幕空间内展示多种天气信息,如当前温度、天气状况、未来天气预报、空气质量等。HarmonyOS NEXT提供的GridRow和GridCol组件非常适合实现这种复杂的信息展示布局。本教程将详细讲解如何使用这些组件构建一个美观、实用的天气应用界面。
67 0
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发四
本文介绍了Web组件开发与性能优化的相关内容。在Web组件开发部分,涵盖创建组件、设置样式与属性、添加事件和方法以及场景示例,如动态播放视频。性能提升方面,推荐使用数据懒加载、条件渲染替代显隐控制、Column/Row替代Flex、设置List组件宽高及调整cachedCount减少滑动白块等方法,以优化应用性能与用户体验。
135 56

物联网

+关注
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问