video自定義實現視訊播放功能
import React, {Component} from 'react'
import style from '../style/Video.module.css'
import play from '../../../assets/player/play.png';
import pause from '../../../assets/player/pause.png';
class Video extends Component{
constructor(props) {
super(props);
this.state={
data:{},
isPlay: false,
isShow: true
}
this.video=React.createRef()
this.goPlay=this.goPlay.bind(this)
this.show_hide=this.show_hide.bind(this)
}
render() {
let isShow=this.state.isShow?style.show:style.hide;
return(
<div className={style.container}>
<div className={style.video_content}>
<video src={this.state.data.videoLink} className={style.video} preload="auto" ref={this.video} poster={this.state.data.coverUri}/>
<div className={style.play_img+' '+isShow} onClick={this.show_hide}>
<div onClick={this.goPlay} className={style.toggle_img}>
<img src={this.state.isPlay? pause:play}/>
</div>
</div>
</div>
)
}
show_hide(){
if(this.state.isPlay&&!this.state.isShow){
this.setState({
isShow: true
},()=>{
setTimeout(()=>{
this.setState({
isShow: false
})
},2000)
})
}else if(!this.state.isShow){
this.setState({
isShow: true
})
}
this.showID=setInterval(()=>{
if(!this.state.isPlay&&!this.state.isShow){
this.setState({
isShow: true
})
}
})
}
goPlay(event){
if(this.state.isPlay){
this.video.current.pause()
this.setState({
isPlay: false,
isShow:true
})
}else{
this.video.current.play();
this.setState({
isPlay: true
})
setTimeout(()=>{
this.setState({
isShow:false
})
},2000)
}
this.timeId=setInterval(()=>{
if(this.video.current.ended){
this.setState({
isPlay: false,
isShow: true
})
clearInterval(this.timeId)
}
},1000)
}
componentWillUnmount() {
clearInterval(this.timeId)
clearInterval(this.showID)
}
}
const mapPatchToProps=dispatch=>{
return{
...loadingAndToast(dispatch)
}
}
export default connect(state=>{
return{
axios: state.app.http,
api: state.app.api
}
},mapPatchToProps)(Video)
相關文章
- 自定義視訊播放器播放器
- ReactNative——react-native-video實現視訊全屏播放ReactIDE
- Vue + WebRTC 實現音視訊直播(附自定義播放器樣式)VueWeb播放器
- 自定義視訊播放器與慢放滾輪播放器
- Android進階:十、自定義視訊播放器 1Android播放器
- 短視訊直播原始碼,自定義圖片或視訊的迴圈播放原始碼
- Android進階:自定義視訊播放器開發(上)Android播放器
- Android進階:自定義視訊播放器開發(下)Android播放器
- Flutter:基於video_player實現視訊相關手勢控制、全屏播放FlutterIDE
- Cisdem Video Player for mac(高清視訊播放器)IDEMac播放器
- 短視訊開發app,自定義帶進度條的視訊播放按鈕APP
- vue-自定義指令-實現提示功能Vue
- 實現播放視訊及彈幕
- Nginx+FFmpeg實現rtsp流轉hls流,在WEB通過H5 video實現視訊播放NginxWebH5IDE
- 自定義檔案上傳功能實現方法
- Python進階:自定義物件實現切片功能Python物件
- Elmedia Video Player Pro 專業音視訊播放器IDE播放器
- WebView 視訊全屏播放(基於Html5 video)WebViewHTMLIDE
- mysql使用自定義序列實現row_number功能MySql
- 基於Flutter Video_Player實現倍速播放FlutterIDE
- 如何實現視訊加密全平臺播放加密
- 使用vue控制video視訊和彈幕功能VueIDE
- 帶你用AVPlayer實現音訊和視訊播放音訊
- Vue+Video.js播放m3u8視訊流VueIDEJS
- Elmedia Video Player Pro for Mac(專業音視訊播放器)IDEMac播放器
- Mac專業音視訊播放器:Elmedia Video Player ProMac播放器IDE
- php短視訊原始碼,jQuery實現自定義輪播圖外掛PHP原始碼jQuery
- 自定義限速功能實踐——Caffeine
- SpringBoot自定義攔截器實現IP白名單功能Spring Boot
- 35.FFmpeg+OpenGLES+OpenSLES播放器實現(九.OpenGLES播放視訊)播放器
- video.js 一個頁面同時播放多個視訊IDEJS
- 微信網頁video播放視訊不全屏的解決方法網頁IDE
- Elmedia Video Player pro for mac - 蘋果專用視訊播放器IDEMac蘋果播放器
- vue-video-player,通過自定義按鈕元件實現全屏切換效果VueIDE元件
- web實戰:video結合canvas實現視訊線上截圖WebIDECanvas
- 如何利用 Netty 實現自定義協議通訊?Netty協議
- 自定義限速功能實踐——Map 版本
- 簡單介紹Android自定義View實現時鐘功能AndroidView