鸿蒙 Video组件的基本使用(HarmonyOS-VideoView)

项目创建传送门(非小白可忽略):

鸿蒙基础UI控件(Text相关-含项目创建流程)-CSDN博客https://blog.csdn.net/qq_39731011/article/details/157513416

传送门内容概览:

1、增加权限(sec/main /module.json5) <-网络视频播放所需
TypeScript 复制代码
{
  "module": {
    "requestPermissions": [
      {
        "name": "ohos.permission.INTERNET"
      }
    ],
    
    ...
    
  }
}
2、代码示例:pages目录下的Index.ets
  • 举例Video的资源引用,如:src : $rawfile('xxx.mp4') 等
  • 举例Video的本身方法调用,如:播放停止监听:onStop() 等
  • 举例Video控制器方法调用,如:this.controller.setCurrentTime(value) 等
TypeScript 复制代码
@Entry
@Component
struct Index {
  // 控制器
  controller: VideoController = new VideoController();
  // 当前时常
  @State currentTime: number = 0;
  // 总时长
  @State durationTime: number = 0;
  build() {
    Column() { //垂直居中
      // --------------------- Video -------------------------
      //src : $rawfile('xxx.mp4') //本地视频
      //src : 'file:///data/storage/el2/base/haps/entry/files/xxx.mp4' //沙箱路径视频
      //previewUri :  $r('app.media.xxx') //预览图(封面)
      Video({
        src: 'http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4',
        controller: this.controller, //设置视频控制器,可以控制视频的播放状态
        currentProgressRate: PlaybackSpeed.Speed_Forward_1_00_X, //设置视频播放倍速
      })
      //相关属性------
        .muted(false) // 设置是否静音
        .controls(false) // 设置是否显示默认控制条
        .autoPlay(false) // 设置是否自动播放
        .loop(false) // 设置是否循环播放
        .objectFit(ImageFit.Contain) // 设置视频填充模式
        //相关事件------
        .onUpdate((event) => { // 更新事件
          if (event) {
            // 同步当前播放中的时常
            this.currentTime = event.time
          }
        })
        .onPrepared((event) => { // 准备就绪
          if (event) {
            // 获取总时长
            this.durationTime = event.duration
          }
        })
        .onError(() => { // 失败/异常
        })
        .onStart(() => { // 开始
        })
        .onStop(() => { // 停止
        })
      //控制器相关------
      Row() { // 自定义播放进度条
        Text(JSON.stringify(this.currentTime) + 's')
        // 播放进度条
        Slider({
          value: this.currentTime,
          min: 0,
          max: this.durationTime
        })
          .onChange((value: number, mode: SliderChangeMode) => {
            this.controller.setCurrentTime(value); // 设置视频播放的进度跳转到value处
          })
          .width('90%')
        Text(JSON.stringify(this.durationTime) + 's')
      }
      .opacity(0.8)
      .width('100%')
      //自定义播放按钮:
      //点击开始播放:this.controller.start()
      //点击暂停播放:this.controller.pause()
      //点击停止播放:this.controller.stop()

    }

  }
}

如果您感觉文章有用的话,麻烦点个赞吧!
如果您发现文章有任何错误或建议,请评论区留言或者私信!
深海谢过各位的支持,一起加油!

相关推荐
nashane8 小时前
HarmonyOS 6学习:PC端悬浮窗模式与智能长截图的协同优化实战
学习·华为·harmonyos
阿钱真强道12 小时前
23 鸿蒙LiteOS 消息队列(Queue)实战教程:任务间数据传递详解
harmonyos·鸿蒙·消息·队列·liteos·rk2206·瑞星微
前端不太难12 小时前
AI 不只是聊天框:鸿蒙 App 新入口
人工智能·状态模式·harmonyos
leon_teacher13 小时前
HarmonyOS 6 实战:基于 Ads Kit 的插屏广告(视频 + 图片)架构与实现全解析
架构·音视频·harmonyos
Hoxy.R14 小时前
银河麒麟 V10 离线安装 s3cmd 踩坑记录+存储负载均衡测试
linux·运维·华为·存储
大师兄666814 小时前
HarmonyOS 服务卡片开发之JS 卡片开发
javascript·华为·harmonyos·harmonyos6·formkit
程序猿追14 小时前
HarmonyOS 6.0 NEXT:基于 Map Kit 实现一款“手绘路线”骑行导航应用
华为·harmonyos
轻口味15 小时前
HarmonyOS 6.1 全栈实战录 - 08 视讯巅峰:Media Kit 视频缩略图批量提取与 HDR 渲染链路实战
华为·音视频·harmonyos
想你依然心痛16 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“医智助手“——医疗影像AI智能体辅助诊断平台
人工智能·华为·harmonyos
nashane16 小时前
HarmonyOS 6学习:卡片组件圆角白边问题的诊断与修复实战
人工智能·pytorch·深度学习·harmonyos