• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Unity 视频播放器,VideoPlayer,实现滑动进度条,显示视频时长,全屏显示,音量调节

武飞扬头像
JacobKay
帮助3

unity播放视频的方式有很多种,但即轻量又好用的,还是unity自带的VideoPlayer,但没有视频基础操作的UI组件,本篇带大家对视频的播放,以及UI组件的实现

效果展示:

Unity带UI操作,视频播放器

 DEMO下载:https://gitee.com/jacobkay/videoplayer

一、安装方式

1、下载文件

2、将文件拖入工程中

3、将"ZVideoPlayer/Prefabs/VideoPlayer"预制体拖入到场景中的canvas中即可

二、API说明方式

  1. IsVideoPlaying:获取当前播放状态
  2. PlayTime:获取和设置播放时间,单位秒
  3. FullScreen:设置全屏状态
  4. VideoUrl: 设置视频url
  5. VideoVolum: 设置视频音量
  6. VideoClip:设置视频clip
  7. Play():播放视频
  8. Pause(): 暂停视频
  9. Stop():停止视频

三、配置

学新通

 触屏模式打开后,会取消鼠标移入和移出的判断,由点击控制面板的显示也隐藏,视频中央会增加一个大的容易点击的播放按钮,易于点击

学新通

 如果播放器的适配模式为自适应,则需要将自适应模式打开,否则运行会报错

请注意:此方法暂时功能不完全,选择自适应模式后,点击全屏,会适配父对象的尺寸,所以目前只支持,父对象是全屏的情况下,点击全屏后才会全屏

如有任何问题,烦请打开demo文件夹中的help文件

如果只需要完成视频的播放,不需要有UI控制面板,则请按照下方的步骤完成即可

一、视频支持格式

Unity常用视频格式:mov、mpg、mpeg、mp4、avi、asf

二、创建UI

1、Hierarchy中新建VideoPlayer组件

学新通

2、Hierarchy中创建RAWImage

学新通

3、在Assets中新建RenderTexture纹理

 学新通

 4、设置好视频的分辨率

学新通

 5、将建好的纹理拖到第2步中新建的RawImage上

学新通

6、 将建好的纹理拖到第1步中新建的VideoPlayer的TargetTexture上

 学新通

 第5步和第6步的目的是,使VideoPlayer中的视频图像导出到纹理文件中,然后通过RAWImage显示纹理获取到的图像,达到将视频进行播放的效果

 7、将VideoPlayer的AudioOutputMode改成AudioSource,然后在下方挂在AudioSource组件,并赋给AudioSource上

学新通

 至此,视频即可正常播放

三、VideoPlayer常用的属性及方法

1、属性:
Source:视频来源   
        - Video Clip:放入下载好的视频   
        - URL:可以放入网上下载好的视频链接/下载好的视频的存储路径【没试过】
Play On Awake:脚本载入时自动播放
Wait For First Frame:决定是否在第一帧加载完成后才播放,只有在Play On Awake被勾选是才有效
Loop:循环
Playback Speed:播放速度
RenderMode:渲染模式   
        - Camera Far Plane:摄像机的远平面上,用于背景播放器   
        - Camera Near Plane:摄像机的近平面上,用作前景播放器   
        - Render Texture:画面保存在Render Texture上,用来UGUI的播放器   
        - Material Override:视频画面复制给所选Render的Material。需要选择具有Render组件的物体,可以选择赋值的材质属性。可制作360全景视频和VR视频。
Aspect Ratio:自适应分辨率的方式
Audio Output Mode:音频输出方式   
        - Audio Source:音频样本发送到选定音频源,允许应用 Unity 的音频处理。  
        - Direct:音频样本绕过 Unity 的音频处理,直接发送到音频输出硬件。
2、事件:
errorReceived: 错误监听到时被执行
frameDropped :有丢帧发生时被执行
frameReady :新的一帧准备好时被执行
loopPointReached :播放结束或播放到循环的点时被执行
prepareCompleted :视频准备完成时被执行
seekCompleted :查询帧操作完成时被执行
started:在Play方法调用之后立刻调用

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhfhcjaf
系列文章
更多 icon
同类精品
更多 icon
继续加载