uniapp强制操作DOM使播放器微信内置浏览器页内旋转全屏横屏播放
主要代码块:
ComedyScreen(status){
let _this = this;
if(status){
this.$nextTick(function(){
let that = this;
uni.getSystemInfo({
success: function (res) {
that.$refs.videoRef.$el.style.width = res.windowHeight+"px";
that.$refs.videoRef.$el.style.height = res.windowWidth+"px";
that.$refs.videoRef.$el.style.position = "absolute";
let top = (res.windowHeight-res.screenWidth)/2;
that.$refs.videoBox.$el.style.width = res.windowHeight+"px";
that.$refs.videoBox.$el.style.height = res.windowWidth+"px";
that.$refs.videoBox.$el.style.position = "fixed";
that.$refs.videoBox.$el.style.top = top+"px";
that.$refs.videoBox.$el.style.left = -top+"px";
that.$refs.videoBox.$el.style.transform = "rotate(90deg)";
that.ComedyScreenStatus = true;
}
});
});
}
if(!status){
let _this = this;
this.$nextTick(function(){
let that = this;
uni.getSystemInfo({
success: function (res) {
that.$refs.videoRef.$el.style.width = "100%";
that.$refs.videoRef.$el.style.height = "220px";
that.$refs.videoRef.$el.style.position = "relative";
that.$refs.videoBox.$el.style.width = "100%";
that.$refs.videoBox.$el.style.height = "220px";
that.$refs.videoBox.$el.style.position = "fixed";
that.$refs.videoBox.$el.style.top = "0px";
that.$refs.videoBox.$el.style.left = "0px";
that.$refs.videoBox.$el.style.transform = "rotate(0deg)";
that.ComedyScreenStatus = false;
}
});
});
}
},
<view class="videoBox" ref="videoBox" >
<video id="myVideo" src="http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"
controls object-fit="contain"
preload="auto"
:loop="false"
:playsinline="true"
:webkit-playsinline="true"
:x-webkit-airplay="true"
style="object-fit: contain;"
:show-center-play-btn="false"
:custom-cache="false"
ref="videoRef"
:show-fullscreen-btn="false" >
<cover-view class="">
Comedy
</cover-view>
</video>
<view class="ComedyScreenBox" >
<view class="ComedyScreen" @click.stop="ComedyScreen(1)" v-show="!ComedyScreenStatus"></view>
<view class="ComedyReturn" @click.stop="ComedyScreen(0)" v-show="ComedyScreenStatus"></view>
</view>
</view>
完整代码:
<template>
<view class="content">
<view class="videoBox" ref="videoBox" >
<video id="myVideo" src="http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"
controls object-fit="contain"
preload="auto"
:loop="false"
:playsinline="true"
:webkit-playsinline="true"
:x-webkit-airplay="true"
style="object-fit: contain;"
:show-center-play-btn="false"
:custom-cache="false"
ref="videoRef"
:show-fullscreen-btn="false" >
<cover-view class="">
Comedy
</cover-view>
</video>
<view class="ComedyScreenBox" >
<view class="ComedyScreen" @click.stop="ComedyScreen(1)" v-show="!ComedyScreenStatus"></view>
<view class="ComedyReturn" @click.stop="ComedyScreen(0)" v-show="ComedyScreenStatus"></view>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
ComedyScreenStatus:false,
}
},
onReady: function (res) {
this.videoContext = uni.createVideoContext('myVideo')
},
methods: {
// 判断是否是微信
isWechart() {
var rst = true;
if (
window.navigator.userAgent.match(
/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
)
) {
var ua = navigator.userAgent.toLowerCase();
if (!(ua.match(/MicroMessenger/i) == 'micromessenger')) {
rst = false;
}
} else {
rst = false;
}
return rst;
},
ComedyScreen(status){
let _this = this;
if(status){
this.$nextTick(function(){
let that = this;
uni.getSystemInfo({
success: function (res) {
that.$refs.videoRef.$el.style.width = res.windowHeight+"px";
that.$refs.videoRef.$el.style.height = res.windowWidth+"px";
that.$refs.videoRef.$el.style.position = "absolute";
let top = (res.windowHeight-res.screenWidth)/2;
that.$refs.videoBox.$el.style.width = res.windowHeight+"px";
that.$refs.videoBox.$el.style.height = res.windowWidth+"px";
that.$refs.videoBox.$el.style.position = "fixed";
that.$refs.videoBox.$el.style.top = top+"px";
that.$refs.videoBox.$el.style.left = -top+"px";
that.$refs.videoBox.$el.style.transform = "rotate(90deg)";
that.ComedyScreenStatus = true;
}
});
});
}
if(!status){
let _this = this;
this.$nextTick(function(){
let that = this;
uni.getSystemInfo({
success: function (res) {
that.$refs.videoRef.$el.style.width = "100%";
that.$refs.videoRef.$el.style.height = "220px";
that.$refs.videoRef.$el.style.position = "relative";
that.$refs.videoBox.$el.style.width = "100%";
that.$refs.videoBox.$el.style.height = "220px";
that.$refs.videoBox.$el.style.position = "fixed";
that.$refs.videoBox.$el.style.top = "0px";
that.$refs.videoBox.$el.style.left = "0px";
that.$refs.videoBox.$el.style.transform = "rotate(0deg)";
that.ComedyScreenStatus = false;
}
});
});
}
},
// 判断是否是微信
isWechart() {
var rst = true;
if (
window.navigator.userAgent.match(
/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
)
) {
var ua = navigator.userAgent.toLowerCase();
if (!(ua.match(/MicroMessenger/i) == 'micromessenger')) {
rst = false;
}
} else {
rst = false;
}
return rst;
},
GoRouter(){
uni.navigateTo({
url: '/pages/test/test'
});
}
},
}
</script>
<style>
.ComedyScreenBox{
z-index: 998;
position: absolute;
right: 0;
top: 0;
width: 20px;
height: 20px;
padding:5px;
}
.ComedyScreen{
width: 100%;
height: 100%;
box-sizing: content-box;
background-image: url();
background-size: 50%;
background-position: 50% 50%;
background-repeat: no-repeat;
cursor: pointer;
position: absolute;
right: 0;
transform: rotate(90deg);
}
.ComedyReturn{
width: 100%;
height: 100%;
box-sizing: content-box;
background-image: url();
background-size: 50%;
background-position: 50% 50%;
background-repeat: no-repeat;
cursor: pointer;
position: absolute;
right: 0;
transform: rotate(90deg);
}
#myVideo{
width:100%;
height:220px;
z-index: 99;
display: flex;
align-items: center;
justify-content: center;
position: relative;
}
.transform{
transform: rotate(90deg);
width: 820px;
height: 517px;
}
.videoBox {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 220px;
z-index:99;
}
.logo {
height: 200rpx;
width: 200rpx;
margin-top: 200rpx;
margin-left: auto;
margin-right: auto;
margin-bottom: 50rpx;
}
.text-area {
display: flex;
justify-content: center;
}
.title {
font-size: 36rpx;
color: #8f8f94;
}
.boxbox{
position: absolute;
top: 220px;
}
</style>