相关问题
怎样实现视频的播放、暂停和快进功能?
24浏览 • 0回复 待解决
视频播放Player组件如何加速播放或者快进播放
8148浏览 • 1回复 待解决
HarmonyOS 请问如何模拟其他视频播放器,屏幕左边的上下滑动控制屏幕亮度,右边的上下滑动控制音量,左右滑动控制播放进度
693浏览 • 1回复 待解决
HarmonyOS 如何控制屏幕亮度
428浏览 • 1回复 待解决
HarmonyOS 捕获屏幕视频流
520浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何使用视频控制器自定义视频播放控制?
825浏览 • 1回复 待解决
关于屏幕安全区域的问题咨询
899浏览 • 1回复 待解决
对于鸿蒙开发中的多媒体处理,怎样实现视频的播放、暂停和快进功能?
88浏览 • 1回复 待解决
HarmonyOS router回退异常
428浏览 • 1回复 待解决
HarmonyOS 如何获取屏幕下方手势响应区域AvoidArea的高度
834浏览 • 1回复 待解决
HarmonyOS 视频组件无法扩展其安全区域
898浏览 • 1回复 待解决
如何通过代码控制屏幕的横竖屏切换?
932浏览 • 1回复 待解决
HarmonyOS 自定义视频控制器
683浏览 • 1回复 待解决
在跨设备投屏场景中,如何通过 AVSession 管理远程控制指令(播放/暂停/快进)?
134浏览 • 1回复 待解决
HarmonyOS项目架构参考文档Demo或视频
772浏览 • 2回复 待解决
HarmonyOS 在屏幕底部的组件的响应区域是否存在遮挡?
366浏览 • 1回复 待解决
HarmonyOS 视频播放器如何旋转屏幕
795浏览 • 1回复 待解决
HarmonyOS 网页回退的时候,如何判断当前网页还能不能接续回退?
515浏览 • 1回复 待解决
HarmonyOS 如何获取屏幕顶部和底部安全区域的高度
1874浏览 • 1回复 待解决
VideoController如何控制子组件中的视频播放
2011浏览 • 2回复 待解决
HarmonyOS 如何按屏幕来设置最大的一个宽高比区域
379浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何控制鸿蒙应用窗口的屏幕亮度?
506浏览 • 1回复 待解决
HarmonyOS 怎么控制内容只延伸到顶部状态栏区域
421浏览 • 1回复 待解决
有没有获取网络视频封面或截图的方法?
4782浏览 • 1回复 待解决
HarmonyOS 如何保存图片或视频到沙箱指定目录
1150浏览 • 1回复 待解决
应用开发中经常需要给同一个组件划分不同的触摸热区,并且不同热区触发的操作也不同,比如阅读应用通常包含左右两个触摸热区,用户触摸左侧触发向后翻页,触摸右侧触发向前翻页;同样的,视频应用中,长按视频播放器的左侧触发快退播放,长按右侧触发快进播放等等。 当前OpenHarmony提供的热区设置属性(responseRegion)只能在不同的触摸热区中触发相同的事件,那么如何实现不同热区不同事件呢,本例即以上述视频播放场景为例进行说明。
效果说明
开始时视频以正常速度播放,长按播放器右侧触发快进播放,长按播放器左侧触发快退播放。
环境要求
本例基于以下环境开发,开发者也可以基于其他适配的版本进行开发:
l IDE: DevEco Studio 4.1 Release
l SDK: Ohos_sdk_public 4.0.10.13 (API Version 10 Release)
实现思路
几乎组件的所有触摸事件都会返回event,通过返回的event可以获取到触摸点的坐标位置,那么就可以根据坐标位置为不同的组件区域添加不同的交互动作。如图:假设有一个长度为200vp的组件,我们希望点击组件的左侧时触发事件A,点击组件的右侧时触发事件B,那么就可以通过触摸点的坐标来判断,当触摸点的x坐标<=100时,触发事件A,反之触发事件B。
如何为组件的不同触摸区域添加不同交互动作(通过event坐标实现)
本例即采用上述思路为Video组件的左右两侧添加不同的交互动作。从而实现长按视频播放器的左侧触发后退播放,长按右侧触发快进播放。
开发步骤
本例详细开发步骤如下,开发步骤中仅展示相关步骤代码,全量代码请参考完整代码章节的内容。
通过Video组件创建视频播放器,并添加触摸手势,通过触摸控制视频的播放、暂停。
为Video组件添加长按手势,通过长按手势触发播放的快退和快进动作。由于触摸手势和长按手势需要互斥,即一次只能触发一种手势,所以通过GestureGroup来实现手势的互斥。
补充长按手势中的业务逻辑:通过event获取到触摸点的x坐标:localX,当localX>=200时,说明触摸点在组件的右侧,触发快进播放;当localX<200时,说明触摸点在左侧,触发快退播放。当触摸停止时,回归正常播放速度。
完整代码
本例完整代码如下:
说明:
本例中使用的视频等资源需要替换为开发者自己的资源。