关于html5 video全屏+自定义控制器

最近整了台nas机,准备自己写个视频网站搭建家庭媒体服务。临时记录下h5 video全屏+自定义控制器的实现的方式,之后会针对实现完整的h5 video播放控制写一些介绍和遇到的坑。
video标签中有controls属性,如果controls=“controls” 则会使用浏览器内嵌的控制器,当然这是最省力的,而且实际使用也没什么问题,但对于喜欢从轮子造起的猴子,还是喜欢全部自定义。
简单的说,全屏用的不是video全屏,而是将div全屏。先入为主以为视频全屏,只有video具有全屏功能,结果搜索了各种video全屏+自定义控制器的方法,要么只有chrome能用,要么就是只有非全屏自定义控制器,全屏还是浏览器的控制器。。
div全屏和video全屏调用方法一样,或者说全屏功能是所有标签的方法,不是video专有的方法。

html

<div class="video-box">
	//视频容器
    <div class="video-main" >
        <video   preload="auto" >
           <source src="" type="video/mp4">
        </video>
    </div>
    //控制器容器
    <div class="video-control">
       
    </div>
</div>

jQuery:

let videoBox=$('videoBox');
if (videoBox.requestFullscreen) {
            videoBox .requestFullscreen();
        } else if (videoBox .mozRequestFullScreen) {
            videoBox .mozRequestFullScreen();
        } else if (videoBox .webkitRequestFullScreen) {
            videoBox .webkitRequestFullScreen();
        }

div全屏可以说是同时解决屏蔽浏览器全屏控制器,同时使用自定义的控制器。嵌套在被全屏的div里面的元素都会在全屏的时候显示,只用把自定义控制器和video共有父容器全屏就可以了。然后就是各种css调整布局。
顺便一提,有很多现成的插件可以实现全屏,自定义控制器这些,像是videojs。只是个人不喜欢而已,而且出bug了都不知道是哪里的问题。自己写的改起来反而得心应手。后面会打算出个造轮子的系列,慢慢讲做一个视频网站遇到的坑。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于视频自定义控件,通常可以使用以下方法来实现: 1. 使用 VideoView 控件:Android 提供了 VideoView 控件,可以用来播放视频。通过设置 VideoView 的相关属性和监听器,可以实现自定义控制视频的功能。例如,可以添加播放、暂停、停止、快进、快退等按钮,并在按钮的点击事件中调用 VideoView 的相应方法来控制视频的播放。 2. 自定义播放器控件:你可以创建一个继承自 View 或 ViewGroup 的自定义控件,用于显示视频播放器的界面,并处理用户交互事件。在自定义控件中,你可以使用 SurfaceView 来渲染视频画面,并使用 MediaPlayer 或 ExoPlayer 等播放器库来实现视频的控制和处理。 3. 使用第三方库:除了 Android 默认提供的 VideoView 和 MediaPlayer,还有一些第三方视频播放库可以使用。例如,IjkPlayer、VLC for Android、ExoPlayer 等,这些库提供了更多的功能和灵活性,可以更容易地实现自定义的视频控制界面。 无论选择哪种方式,你需要考虑以下几个方面: - 视频播放控制:包括开始、暂停、停止、快进、快退等功能。 - 视频进度显示:显示当前播放进度和总时长,并可以拖动进度条进行快进/快退。 - 音量和亮度控制:可以调节视频的音量和屏幕亮度。 - 全屏播放:提供全屏播放功能,并处理屏幕旋转时的适配问题。 - 异常处理:处理视频播放异常、网络异常等情况,并给出用户友好的提示。 希望这些信息能对你有所帮助!如有需要,还请提供更具体的需求,我可以给出更详细的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值