前言
本代码适用于1920*1080的视频,如果是其他尺寸的视频,需要更改js代码里的几个数字,重新计算视频宽高
效果图
如图所示,
在长屏手机里,横过来的视频高度充满,宽度自适应后居中;
在短屏手机里,横过来的视频宽度充满,高度自适应后居中;
代码HTML
<!-- 跳过视频按钮 --> <img src="next.png" alt="" class="btn_video vertical_middle"> <!-- 视频页 --> <div class="page page_video"> <!-- 视频开始按钮 --> <img src="start_video.png" alt="" class="start_video"> <div class="video_info">横屏观看效果更佳</div> <!-- 视频 --> <video id="video" style="object-fit:fill;" playsinline="true" webkit-playsinline="true" x-webkit-airplay="allow" airplay="allow" x5-video-player-type="h5" x5-video-player-fullscreen="true" x5-video-orientation="portrait" poster="./images/video1.png" src="./video/1.mp4"> </video>
下面是video里面属性的注释:
style="object-fit:fill;" /*视频在微信里全屏*/ playsinline="true" /*支持小窗播放*/ airplay="allow"/*支持Airplay的设备*/ x5-video-player-type="h5" /*启用H5播放器*/ x5-video-player-fullscreen="true" /*全屏设置,防止横屏*/ x5-video-orientation="portrait" /*播放器横竖屏方向, landscape横屏,portraint竖屏,默认值为竖屏*/
CSS
/*页面全屏*/ .page { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; /*background-size: 100% 100%;*/ } /*垂直居中*/ .vertical_middle{ top: 50%; transform: translateY(-50%); } /* 视频 */ .page_video{ width: 100%; background: #000000; position: absolute; left: 0; top: 0; text-align: center; } /*视频是以(0,0)为中心旋转的90度,所以left为100%*/ #video{ position: absolute; /* margin-left: 4px; */ left: 100%; z-index: 1; } .btn_video{ width: 10%; position: absolute; left: 5%; z-index: 10; /*display:none;*/ } /*视频播放按钮*/ .start_video{ width: 100px; height: 100px; position: absolute; left: 10%; right: 0; top: 0; bottom: 0; margin: auto; z-index: 100; } /*横屏观看更佳的提示文字*/ .video_info{ height: 30px; font-size: 30px; position: absolute; top: 0%; bottom: 0; margin: auto; left: 30%; z-index: 100; color: #fff; transform:rotate(90deg); -ms-transform:rotate(90deg); /* Internet Explorer */ -moz-transform:rotate(90deg); /* Firefox */ -webkit-transform:rotate(90deg); /* Safari 和 Chrome */ -o-transform:rotate(90deg); /* Opera */ }
JS
/* 获取屏幕高度 */ var phone_height = document.documentElement.clientHeight; if(phone_height<1496){ // console.log('屏幕高度<1496'); var back_up = (1496-phone_height)/2; $(".page_video").css("backgroundPosition","0 -"+back_up+"px"); if( phone_height >= 1360 ){ //华为手机&&苹果x } }else{ // console.log('屏幕高度>1496'); $(".page_video").css("backgroundSize","100% 100%"); } //视频横屏 var width = document.documentElement.clientWidth; var height = document.documentElement.clientHeight; $(".page_video").height(height+"px"); var video_width; var video_height; var video_top = 0; var video_left = 0; // 设置视频倒过来 if( width < height ){ //一个1920*1080的视频,到手机上高750时,宽度是1333.333 if( height < 1334 ){ console.log("手机分辨率高度 < 1333.33,视频横过来后宽度铺满,高度自适应后铺不满屏幕,所以向左平移一些居中"); $("#video").width(height); video_width = $("#video").width(); // 等比例自适应数值不是正好的,那就手动定高度 video_height = video_width/1920*1080; $("#video").height(video_height); //设置视频水平居中 video_left = -(width - video_height)/2; }else{ console.log("手机分辨率高度 > 1333.33,视频横过来后高度铺满,宽度自适应后铺不满屏幕,所以向下平移一些居中"); $("#video").height(width); video_height = $("#video").height(); // 等比例自适应数值不是正好的,那就手动定宽度 video_width = (1920/1080)*$("#video").height(); $("#video").width(video_width); //设置视频垂直居中 video_top = (height - video_width)/2; } //把调整好的数值赋给视频 $("#video").css({'left': "100%","top":video_top+"px","marginLeft":video_left+"px",'transform':'rotate(90deg)','transformOrigin':'0 0'} ); } //视频页 var myVideo = document.getElementById('video'); //点击播放按钮 $(".start_video").click(function(){ $(".start_video").hide(); $(".video_info").hide(); myVideo.play(); }) //监听视频被点击 myVideo.addEventListener('touchstart', function () { $(".start_video").hide(); $(".video_info").hide(); myVideo.play(); }); //点击跳过按钮 $(".btn_video").click(function(){ video_end(); }) //视频播放结束 myVideo.addEventListener('ended', function () { video_end(); }, false); //视频播放结束的函数 function video_end(){ myVideo.pause(); console.log("视频播放结束"); }
总结
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“html5视频自动横过来自适应页面且点击播放功能的实现”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2024年11月23日
2024年11月23日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]