##鸿蒙核心技术##运动开发##Media Kit(媒体服务)#

在当今数字化时代,运动健身已经成为许多人生活的一部分。今天我将在应用中添加视频播放器,帮助用户在运动前、运动后更好地进行热身和拉伸。这篇文章将从代码核心点入手,带你一步步了解开发过程中的关键技术和实现细节。

在这里插入图片描述

一、项目背景与需求分析

在开发任何应用之前,明确需求是至关重要的。对于运动视频播放器,我们需要考虑以下几个核心功能:

  1. 视频播放:支持播放运动相关的视频,如热身、拉伸等。
  2. 用户交互:提供简单的按钮操作,如播放、暂停、继续等。

二、代码核心点梳理与解析

接下来,我们将通过代码的核心部分,逐步解析实现运动视频播放器的关键步骤。

(一)页面布局与导航

在鸿蒙开发中,页面布局是用户体验的基础。我们使用了LibNavLibPage来构建页面的导航和内容布局。以下是代码的核心部分:

@Component
export struct SportHelperPage {@BuilderpageNavBuilder(){LibNav({pageTitle: "运动助手"}).width("100%")}@BuilderpageContentBuilder(){Column() {Text('运动助手').fontSize(20).fontWeight(FontWeight.Bold).margin({ top: 20 })Button('跑前热身').onClick(() => this.playVideo('https://video.111.com/p/bms/warmup_before_running.mp4')).margin({ top: 10 })Button('跑后拉伸').onClick(() => this.playVideo('https://video.111.com/p/bms/stretch_after_running.mp4')).margin({ top: 10 })Button('暂停播放').onClick(() => {this.avPlayer?.pause()})Button('继续播放').onClick(() => {this.avPlayer?.play()})XComponent({ type: XComponentType.SURFACE, controller: mXComponentController }).width('100%').height(300)}.padding(20).backgroundColor(Color.White)}
}
  1. 页面导航:通过LibNav设置页面标题为“运动助手”,并将其宽度设置为100%,以确保导航栏能够覆盖整个屏幕顶部。
  2. 页面内容:使用Column布局,将文本、按钮和视频播放组件(XComponent)依次排列。每个按钮都绑定了点击事件,用于触发视频播放或控制播放状态。

(二)视频播放器的初始化与控制

视频播放是应用的核心功能,我们使用了鸿蒙的media.AVPlayer来实现。以下是初始化和播放控制的代码:

async initPlay() {try {this.avPlayer = await media.createAVPlayer();this.setAVPlayerCallback(this.avPlayer);} catch (error) {console.error('初始化视频失败:', error);}
}async playVideo(url: string) {try {if(this.avPlayer){this.avPlayer.url = url;this.avPlayer.play();}} catch (error) {console.error('播放视频失败:', error);}
}
  1. 初始化播放器:通过media.createAVPlayer()创建一个AVPlayer实例,并注册回调函数来监听播放状态的变化。
  2. 播放视频:通过设置avPlayer.url属性为视频的URL,并调用play()方法开始播放。这里需要注意的是,视频URL必须是有效的,否则会导致播放失败。

(三)状态机回调与错误处理

在视频播放过程中,可能会出现各种状态变化和错误。通过注册回调函数,我们可以更好地管理这些情况:

setAVPlayerCallback(avPlayer: media.AVPlayer) {avPlayer.on('startRenderFrame', () => {console.info(`AVPlayer start render frame`);});avPlayer.on('seekDone', (seekDoneTime: number) => {console.info(`AVPlayer seek succeeded, seek time is ${seekDoneTime}`);});avPlayer.on('error', (err: BusinessError) => {console.error(`Invoke avPlayer failed, code is ${err.code}, message is ${err.message}`);avPlayer.reset();});avPlayer.on('stateChange', async (state: string, reason: media.StateChangeReason) => {switch (state) {case 'idle':avPlayer.release();break;case 'initialized':const id = mXComponentController.getXComponentSurfaceId();avPlayer.surfaceId = id;avPlayer.prepare();break;case 'prepared':avPlayer.play();break;case 'paused':console.info('AVPlayer state paused called.');break;case 'completed':avPlayer.stop();break;case 'stopped':avPlayer.reset();break;case 'released':console.info('AVPlayer state released called.');break;default:console.info('AVPlayer state unknown called.');break;}});
}
  1. 状态回调:通过监听stateChange事件,我们可以根据不同的状态(如initializedpreparedplaying等)执行相应的操作。例如,在initialized状态时,设置播放画面的surfaceId,并调用prepare()方法准备播放。
  2. 错误处理:通过监听error事件,捕获播放过程中可能出现的错误,并调用reset()方法重置播放器状态。

三、开发中的注意事项与优化建议

在开发过程中,我们需要注意以下几个关键点,以确保应用的稳定性和用户体验:

  1. 视频URL的有效性:在调用playVideo()方法时,必须确保传入的URL是有效的。如果URL无效或网络不可用,播放器将无法正常工作。建议在实际开发中,对视频URL进行校验,并提供友好的错误提示。
  2. 性能优化:为了减少视频加载时间,可以考虑在应用启动时预先加载视频资源。此外,合理管理播放器的生命周期,避免在不需要时占用系统资源。
  3. 用户体验:在页面布局中,按钮和文本的排布要简洁明了,避免过于复杂的操作。同时,可以考虑添加进度条、音量控制等功能,进一步提升用户体验。

四、总结

在实际开发中,开发者可以根据需求进一步扩展功能,例如添加更多运动视频类别、支持离线下载等。

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

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

相关文章

一个包含15个界面高质量的电商APP客户端UI解决方案

一个包含15个界面高质量的电商APP客户端UI解决方案 您可以将其用于电商APP应用项目。包含一系列完整的界面设计元素,包括欢迎页、登录、注册、首页、产品分类、产品详情、尺码选择、购物车、订单、支付,覆盖电商APP的大部分界面。每个部分都精心设计&…

执行 PGPT_PROFILES=ollama make run下面报错,

执行 PGPT_PROFILESollama make run 下面报错, File "/home/powersys/.cache/pypoetry/virtualenvs/private-gpt-ZIwX6JeM-py3.11/lib/python3.11/site-packages/qdrant_client/http/api_client.py", line 108, in send_inner raise ResponseHandling…

【Docker基础】Docker核心概念:命名空间(Namespace)之User详解

目录 引言 1 基础概念回顾 1.1 命名空间概述 1.2 命名空间的类型 2 User命名空间详解 2.1 基本概念 2.2 工作原理 User命名空间的工作流程 User命名空间架构 3 应用场景 4 配置与使用 5 总结 引言 随着容器化技术的广泛应用,Docker已成为现代软件开发、…

DIDCTF-应急响应

前言 最近在学长分享应急响应与电子取证的知识,又恰逢期末周没有课,记录自己在取证道路的成长。 linux-basic-command 下载附件,得到Apache 服务器访问日志文件,根据题目要求找出排名前五的ip,题目提示写脚本&#…

MybatisPlus深入学习

今天深入的学习了一下mp,从头开始学习!哈哈哈哈哈 本节只讲干的! 我们上来先看一段代码,不知道你能不能看明白! package com.itheima.mp.mapper;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapp…

安卓9.0系统修改定制化____安卓9.0系统精简 了解系统app组件构成 系统app释义 常识篇 一

在安卓 9.0 系统的使用过程中,许多用户都希望能够对系统进行深度定制,让手机系统更加贴合个人需求。而系统精简作为定制化的重要一环,不仅能够释放手机存储空间,还能提升系统运行速度,优化资源分配。想要安全有效地对安卓 9.0 系统进行精简,深入了解系统 app 组件的构成是…

2.4 Windows Conan编译FFmpeg 4.4.1

Conan的安装与使用参考之前的文章:Conan简单使用 一、Conan编译ffmpeg 1.1 Conan的配置文件 创建配置文件:C:\Users\wujh\.conan2\profiles\vs2019 [settings] archx86_64 build_typeRelease compilermsvc compiler.cppstd14 compiler.runtimedynami…

社群经济视域下开源链动2+1模式与AI智能名片赋能S2B2C商城小程序的创新发展研究

摘要:在数字经济蓬勃发展的背景下,社群经济作为连接用户情感与价值反哺的新型经济形态,正通过技术创新与模式重构实现深度演化。本文基于社群经济“创造有价值连接”的本质特征,系统探讨“开源链动21模式”“AI智能名片”与“S2B2…

【计算机网络】——reactor模式高并发网络服务器设计

🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:计算机网络 🌹往期回顾🌹:【计算机网络】非阻塞IO——epoll 编程与ET模式详解——(easy)高并发网络服务器设计 🔖流水不…

Uniapp跨端兼容性全方位解决方案

在当今多端融合的移动互联网时代,Uniapp作为一款优秀的跨平台开发框架,已成为许多开发者的首选。然而,真正的挑战在于如何优雅地处理不同平台之间的差异。本文将全面剖析Uniapp跨端开发的兼容性处理方案,提供从基础到高级的完整解…

迅为RK3576开发板NPUrknn-toolkit2环境搭建和使用docker环境安装

开发板采用核心板底板结构,在我们的资料里提供了底板的原理图工程以及PCB工程,可以实现真正意义上的裁剪、定制属于自己的产品,满足更多应用场合。 迅为针对RK3576开发板整理出了相应的开发流程以及开发中需要用到的资料,并进行详…

什么是 OpenFeigin ?微服务中的具体使用方式

什么是Feign? Feign 是一种声明式的 HTTP 客户端框架,主要用于简化微服务架构中服务之间的远程调用,也可以通过定义接口和注解的方式调用远程服务,无需手动构建 HTTP 请求或解析响应数据。Spring Cloud 对 Feign 进行了增强&…

对抗性提示:进阶守护大语言模型

人工智能模型正快速进化 —— 变得更具帮助性、更流畅,并且更深入地融入我们的日常生活和商业运营中。但随着其能力的提升,风险也在增加。在维护安全可信的人工智能方面,最紧迫的挑战之一是对抗性提示:这是一种微妙且通常富有创意…

运营商频段

以下是三大运营商(中国移动、中国电信、中国联通)及中国广电的 5G 主要频段 及其所属运营商的整理表格: 运营商频段上行频率 (MHz)下行频率 (MHz)带宽备注广电n28703-733758-788230MHz移动共享n794900-4960-60MHz-移动n412515-2675-160MHz-n7…

项目拓展-Apache对象池,对象池思想结合ThreadLocal复用日志对象

优化日志对象创建以及日志对象复用 日志对象上下文实体类 traceId 请求到达时间戳 请求完成时间戳 请求总共耗费时长 get/post/put/delete请求方式 Http状态码 原始请求头中的所有键值对 请求体内容 响应体内容 失败Exception信息详细记录 是否命中缓存 package c…

Javaweb - Vue入门

Vue是一款用于构建用户界面的渐进式的JavaScript框架。 使用步骤 引入Vue模块,创建Vue的应用实例,定义元素,交给Vue控制。 一、引入Vue模块 因为使用的是模块化的JavaScript,因此在script标签内要声明一个属性:typ…

C++ 标准模板库各个容器的应用场景分析

C 标准模板库(STL)中的容器分为序列式容器、关联式容器和无序容器,各自适用于不同场景。以下是主要容器的应用场景及案例: 一、序列式容器 元素按插入顺序存储,支持线性访问。 1. vector 场景:动态数组…

安装前端vite框架,后端安装fastapi框架

前期准备 首先新建一个文件夹,文件夹里面新建一个文件夹,用于安装依赖 安装vite框架 npm init -y 目的是安装package.json配置文件 npm install vite --save-dev 安装vite框架 安装完是这个样子 新建了一个文件夹和js文件 后端内容 main.js document.…

深度学习:基础与概念(第1章:深度学习革命)

目录 第1章:深度学习革命 1.1深度学习的影响 1.1.1医疗诊断 1.1.2蛋白质结构预测 1.1.3图像合成 1.1.4大语言模型 1.2一个教学示例 1.2.1合成数据 1.2.2线性模型 1.2.3误差函数 1.2.4模型复杂度 1.2.5正则化 1.2.6模型选择 1.3机器学习简史 1.3.1单层…

通过触发器统计访问数据库的客户端IP地址

通过触发器统计访问数据库的客户端IP地址 创建用户登录审计表创建登录审计触发器查看登录审计结果禁用和启用触发器创建用户登录审计表 创建记录表: create table appuser1.user_login_audit (login_time DATE,session_id number,username VARCHAR2(30),os_user VARCHAR2(30…