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

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

在这里插入图片描述


关键词
  • 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%');
  }
}
// 文件名:Index.ets

import { MusicControlPage } from './MusicControlPage';

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

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

在这里插入图片描述


五、代码解读
  1. 图片展示

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

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

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

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

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

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

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

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

八、相关知识点
  • 「Mac畅玩鸿蒙与硬件15」鸿蒙UI组件篇5 - Slider 和 Progress 组件
  • 「Mac畅玩鸿蒙与硬件11」鸿蒙UI组件篇1 - Text 和 Button 组件详解

小结

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


下一篇预告

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


上一篇: 「Mac畅玩鸿蒙与硬件46」UI互动应用篇23 - 自定义天气预报组件
下一篇: 「Mac畅玩鸿蒙与硬件48」UI互动应用篇25 - 简易购物车功能实现

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


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

用QT制作的倒计时软件

一、pro代码 RC_ICONS countdown.ico 二、mainwindow.cpp代码 #include "mainwindow.h" #include "ui_mainwindow.h"#include <QDateTime> #include <QMessageBox> #include <QSettings>MainWindow::MainWindow(QWidget *parent): QM…

Unbuntu下怎么生成SSL自签证书?

环境&#xff1a; WSL2 Unbuntu 22.04 问题描述&#xff1a; Unbuntu下怎么生成SSL自签证书&#xff1f; 解决方案&#xff1a; 生成自签名SSL证书可以使用OpenSSL工具&#xff0c;这是一个广泛使用的命令行工具&#xff0c;用于创建和管理SSL/TLS证书。以下是生成自签名…

springboot446数字化农家乐管理平台的设计与实现(论文+源码)_kaic

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差&#x…

laya游戏引擎中打包之后图片模糊

如下图正常运行没问题&#xff0c;打包之后却模糊 纹理类型中的默认类型都是精灵纹理&#xff0c;改为默认值即可。注意&#xff1a;要点击“应用”才可有效。精灵纹理类型会对图片进行渲染处理&#xff0c;而默认值 平面类型不会处理图片。

[SZ901]FPGA程序固化工具使用方法

工具为脚本形式&#xff0c;前期需进行vivado版本&#xff0c;下载器端口配置 1&#xff0c;编辑 【SZ901程序固化工具.bat】&#xff0c;设置软件版本 修改软件版本和安装路径 2&#xff0c;设置下载器端口&#xff08;SZ901->USER_TCL->FlashBurn_Config.tcl&#x…

基于微信小程序的小区疫情防控ssm+论文源码调试讲解

第2章 程序开发技术 2.1 Mysql数据库 为了更容易理解Mysql数据库&#xff0c;接下来就对其具备的主要特征进行描述。 &#xff08;1&#xff09;首选Mysql数据库也是为了节省开发资金&#xff0c;因为网络上对Mysql的源码都已进行了公开展示&#xff0c;开发者根据程序开发需…

Arduino ADC模数转换

1.Arduino UNO ADC的配置及原理 1.1ADC配置 1.1.1分辨率 Arduino Uno支持6个adc模数转换,其ADC只有10位分辨率,也就是说我们只能将输入电平分成2^101024份(0~1023),4.88mV的测量精度. 1.1.2输入电压范围 Arduino Uno的引脚输出是5V,同样引脚输入也最多支持5V,我们可以5V电压分…

论文笔记:是什么让多模态学习变得困难?

整理了What Makes Training Multi-modal Classification Networks Hard? 论文的阅读笔记 背景方法OGR基于最小化OGR的多监督信号混合在实践中的应用 实验 背景 直观上&#xff0c;多模态网络接收更多的信息&#xff0c;因此它应该匹配或优于其单峰网络。然而&#xff0c;最好的…

唯品会Android面试题及参考答案

HTTP 和 HTTPS 的区别是什么&#xff1f;你的项目使用的是 HTTP 还是 HTTPS&#xff1f; HTTP 和 HTTPS 主要有以下区别。 首先是安全性。HTTP 是超文本传输协议&#xff0c;数据传输是明文的&#xff0c;这意味着在数据传输过程中&#xff0c;信息很容易被窃取或者篡改。比如&…

LWIP协议:三次握手和四次挥手、TCP/IP模型

一、三次握手&#xff1a;是客户端与服务器建立连接的方式&#xff1b; 1、客户端发送建立TCP连接的请求。seq序列号是由发送端随机生成的&#xff0c;SYN字段置为1表示需要建立TCP连接。&#xff08;SYN1&#xff0c;seqx&#xff0c;x为随机生成数值&#xff09;&#xff1b;…

Kafka Streams 在监控场景的应用与实践

作者&#xff1a;来自 vivo 互联网服务器团队- Pang Haiyun 介绍 Kafka Streams 的原理架构&#xff0c;常见配置以及在监控场景的应用。 一、背景 在当今大数据时代&#xff0c;实时数据处理变得越来越重要&#xff0c;而监控数据的实时性和可靠性是监控能力建设最重要的一环…

Medium是什么,Medium能干嘛,如何用开通medium会员

1.背景介绍 1.1 什么是medium medium是国外一个内容创作和分享平台。 主要用户来自美国&#xff0c;每月有26万的访问量。 网址&#xff1a; Medium官网 平台注重优质、专业的内容。 这个平台有2点比较吸引人&#xff1a; ① 内容优质、专业 ② 在上面写作&#xff0c;能…

【实验17】不同优化算法的比较分析

目录 1 不同优化算法比较分析-2D可视化实验 1.1 优化算法的实验设定(以函数为例) 1.2 学习率调整优化策略 1.1.2 AdaGrad算法 1.1.2 RMSprop算法 1.3 梯度估计修正优化策略 1.3.1 动量法 1.3.2 Adam算法 1.4 完整代码 1.5 函数 的优化算法比较 2 不同优化算法比较分…

复习打卡大数据篇——Hadoop HDFS 01

目录 1. HDFS简介 2. HDFS基本操作 3. HDFS原理 1. HDFS简介 HDFS概念&#xff1a; HDFS是一个分布式的文件系统。分布式意味着多台机器存储&#xff0c;文件系统&#xff0c;就是用来存储文件、存储数据。是大数据最底层一个服务。 HDFS设计目标&#xff1a; 故障的检测…

Odoo:免费开源ERP的AI技术赋能出海企业电子商务应用介绍

概述 伴随电子商务的持续演进&#xff0c;客户对于便利性、速度以及个性化服务的期许急剧攀升。企业务必要探寻创新之途径&#xff0c;以强化自身运营&#xff0c;并优化购物体验。达成此目标的最为行之有效的方式之一&#xff0c;便是将 AI 呼叫助手融入您的电子商务平台。我们…

基于base32的兑换码算法(思路)

base32编码指的是基于32个可打印字符对任意字节数据进行编码&#xff1a;大写字母A-Z以及数字2-7。 兑换码要求:长度为10个字符 如果将这32个字符依次放到一个base数组中&#xff0c;那么最大的下标就是31。我们将要编码的任意字节数据按照五个bit为一组进行划分&#xff0c;…

前端开发环境(vue)

1. 安装nvm管理nodejs的版本 1. 配置nvm 2. 用npm安装nodejs,选则nodejs版本,这是js的运行环境 3 . 安装npm,这是前端的包管理器 npm是nodejs开发的包管理器,现在下载了nodejs就默认下载npm了,绑在一块了,不用 1. npm的中央仓库 2. npm私服仓库 换库 npm config set r…

第十七章:反射+设计模式

一、反射 1. 反射(Reflection)&#xff1a;允许在程序运行状态中&#xff0c;可以获取任意类中的属性和方法&#xff0c;并且可以操作任意对象内部的属 性和方法&#xff0c;这种动态获取类的信息及动态操作对象的属性和方法对应的机制称为反射机制。 2. 类对象 和 类的对象(实…

arduino继电器与电机水泵的使用

首先说一句&#xff0c;真受不了网上的教程&#xff0c;大海里捞金&#xff0c;要不上来了就讲原理&#xff0c;怎么具体使用一句不说&#xff0c;要么炫技来了。 继电器&#xff0c;简单来说把他当开关看&#xff0c;通过小电流控制大电流(原理去看其他视频)&#xff0c;要记…

【Java Web】Axios实现前后端数据异步交互

目录 一、Promise概述 二、Promise基本用法 三、async和await关键字 四、Axios介绍 4.1 Axios基本用法 4.2 Axios简化用法之get和post方法 五、Axios拦截器 六、跨域问题处理 一、Promise概述 axios是代替原生的ajax实现前后端数据交互的一套新解决方案&#xff0c;而…