首页前端开发HTMLHTML5在手机端实现视频全屏展示方法

HTML5在手机端实现视频全屏展示方法

时间2024-01-25 07:35:46发布访客分类HTML浏览391
导读:收集整理的这篇文章主要介绍了HTML5在手机端实现视频全屏展示方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 最近做项目,遇到一个问题,在手机上要实现视频的全屏播放功能。测试了很久,终于找到解决办法。第一种:将视频放大来控...
收集整理的这篇文章主要介绍了HTML5在手机端实现视频全屏展示方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

最近做项目,遇到一个问题,在手机上要实现视频的全屏播放功能。测试了很久,终于找到解决办法。

第一种:将视频放大来控制。

视频在播放的时候,全屏是根据高度来的,如果设置视频 video 标签的宽度是 100% 高度是 110% ,可以实现全屏,超过是溢出隐藏就可以了。

确定:手机屏幕尺寸不固定,这个高度110%不好确定。

第二种:使用 object-fIT 来解决

直接上代码:

video PReload='auto' id='video'  src=''  webkit-playsinline='true' playsinline='true'x-webkit-airplay='true' x5-video-player-tyPE='h5' x5-video-player-fullscreen='true'x5-video-ignore-metadata='true'  width='100%' height='100%'>
    p>
     不支持video/p>
     /video>
    

编译后在页面内部播放视频而不会跳出使用系统播放器全屏播放视频了。而且z-index属性也可以正常定义,使其他元素可以覆盖在视频上面。

css:保持画面的原有比例

#my-video{
        object-fit: cover;
        object-position: center center;
    

简单的demo实现:

!doctype htML>
    html lang="en">
    head>
    meta charset="UTF-8">
    meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    title>
    视频播放器/title>
    style type="text/css">
*{
    margin:0px;
     padding:0px;
}
.app{
    width: 100%;
     height:100%;
     position: absolute;
     top:0px;
     right:0px;
     bottom: 0px;
     left:0px;
     overflow: hidden;
}
.video{
    width: 100%;
     height: 100%;
}
#my-video{
    object-fit: cover;
     object-position: center center;
}
    /style>
    /head>
    body>
    div id="app" class="app">
        video preload='auto' id='my-video' ref="video" :src="videoUrl" @click="player" loop autoplay="autoplay" webkit-playsinline='true' playsinline='true'x-webkit-airplay='true' x5-video-player-type='h5' x5-video-player-fullscreen='true'x5-video-ignore-metadata='true'  width='100%' height='100%'>
    p>
     不支持video/p>
     /video>
    /div>
    /body>
    script type="text/javascript" src="./js/vue.min.js">
    /script>
    script type="text/javascript">
// vue 解析VAR Application = new Vue({
    el: "#app",    data: {
        videoUrl:'',        video:null,    }
,    mounted: function(){
            this.videoUrl = "http://gamaru.wpgCMS.COM/media/file/movie/dkSDFdqur5uQKV5p.mp4";
            this.video = this.$refs.video;
    }
,    methods: {
        player:function(){
                console.LOG(this.video.clientWidth);
                console.log(this.video.clientHeight);
            if(this.video.paused){
                    // 播放                this.video.play();
            }
else{
                // 暂停                this.video.pause()            }
    ;
                    }
    }
}
    );
    /script>
    /html>
    

解释下:object-fit

  • fill: 中文释义“填充”。默认值。替换内容拉伸填满整个content box, 不保证保持原有的比例。
  • contain: 中文释义“包含”。保持原有尺寸比例。保证替换内容尺寸一定可以在容器里面放得下。因此,此参数可能会在容器内留下空白。
  • cover: 中文释义“覆盖”。保持原有尺寸比例。保证替换内容尺寸一定大于容器尺寸,宽度和高度至少有一个和容器一致。因此,此参数可能会让替换内容(如图片)部分区域不可见。
  • none: 中文释义“无”。保持原有尺寸比例。同时保持替换内容原始尺寸大小。
  • scale-down: 中文释义“降低”。就好像依次设置了none或contain, 最终呈现的是尺寸比较小的那个

详细了解 object-fit:https://www.cnblogs.com/e0yu/p/10670990.html

到此这篇关于HTML5在手机端实现视频全屏展示方法的文章就介绍到这了,更多相关HTML5视频全屏内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: Canvas实现放大镜效果完整案例分...下一篇:关于HTML5+ API plusready的兼容...猜你在找的html5相关文章 关于移动端h5开发相关内容总结2022-05-17html5教程-学表单的第二天2018-12-10html5教程-HTML5浏览器支持2018-12-10html5教程-HTML5智能表单2018-12-10html5教程-微信H5使用resLoader实现加载页效果2018-12-10html5教程-day01-初级-JS0-热身运动JS入门教程2018-12-10html5教程-html5shiv.js和respond.min.js2018-12-10html5教程-不同浏览器对于html5 audio标签和音频格式的兼容性2018-12-10html5教程-使用Html5实现手风琴案例2018-12-10html5教程-html5笔记2018-12-10 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: HTML5在手机端实现视频全屏展示方法
本文地址: https://pptw.com/jishu/586277.html
Canvas实现放大镜效果完整案例分析(附代码) 使用HTML5加载音频和视频的实现代码

游客 回复需填写必要信息