|  | @ -8,18 +8,23 @@ import './videoPlay.less'; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | const timeFormat = 'YYYY-MM-DD HH:mm:ss' |  |  | const timeFormat = 'YYYY-MM-DD HH:mm:ss' | 
			
		
	
		
		
			
				
					|  |  | const yingshiUrl = 'https://open.ys7.com/ezopen/h5/iframe' |  |  | const yingshiUrl = 'https://open.ys7.com/ezopen/h5/iframe' | 
			
		
	
		
		
			
				
					|  |  |  |  |  | const yingshiCloseSoundKey = 'closeSound' | 
			
		
	
		
		
			
				
					|  |  |  |  |  | const yingshiOpenSoundKey = 'openSound' | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | const VideoPlay = ({ |  |  | const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |    height, width, containerId = 'myPlayer', |  |  |    height, width, containerId = 'myPlayer', | 
			
		
	
		
		
			
				
					|  |  |    // playUrl, |  |  |    // playUrl, | 
			
		
	
		
		
			
				
					|  |  |    name, |  |  |    name, | 
			
		
	
		
		
			
				
					|  |  |    videoObj = { |  |  |    videoObj = { | 
			
		
	
		
		
			
				
					|  |  |       type: 'yingshi', |  |  |       type: 'yingshi', | 
			
		
	
		
		
			
				
					
					|  |  |       audio: true, |  |  |       audio: false, | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       yingshiToken: 'at.3j6eyqbn0g5xvcut73v0rzdu1nh0gnxx-4ua03m82o9-12u1t9g-rtzndpyds', |  |  |       serialNo: 'G75922040', // 设备序列号 必须 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       playUrlSd: 'ezopen://open.ys7.com/G75922040/1.live', |  |  |       channelNo: 1, //  | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |       yingshiToken: 'at.3j6eyqbn0g5xvcut73v0rzdu1nh0gnxx-4ua03m82o9-12u1t9g-rtzndpyds', // 萤石必须 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       playUrlSd: 'ezopen://open.ys7.com/G75922040/1.live', // 必须 | 
			
		
	
		
		
			
				
					|  |  |       // playUrl: 'ws://221.230.55.27:8081/jessica/34020000001110000077/34020000001310000003', |  |  |       // playUrl: 'ws://221.230.55.27:8081/jessica/34020000001110000077/34020000001310000003', | 
			
		
	
		
		
			
				
					
					|  |  |       playUrlHd: 'ezopen://open.ys7.com/G75922040/1.hd.live', |  |  |       playUrlHd: 'ezopen://open.ys7.com/G75922040/1.hd.live',  | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       replayUrl: 'ezopen://open.ys7.com/G75922040/1.rec', |  |  |       // replayUrl: 'ezopen://open.ys7.com/G75922040/1.rec', | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |    }, |  |  |    }, | 
			
		
	
		
		
			
				
					|  |  | }) => { |  |  | }) => { | 
			
		
	
		
		
			
				
					|  |  |    const [jessibuca, setjessibuca] = useState(null) |  |  |    const [jessibuca, setjessibuca] = useState(null) | 
			
		
	
	
		
		
			
				
					|  | @ -32,10 +37,18 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |    const [histroyBegain, setHistroyBegain] = useState() |  |  |    const [histroyBegain, setHistroyBegain] = useState() | 
			
		
	
		
		
			
				
					|  |  |    const [resolution, setResolution] = useState('sd') // 标清 sd  高清 hd |  |  |    const [resolution, setResolution] = useState('sd') // 标清 sd  高清 hd | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // 标记萤石操作中,等待ifream返回信息后清空 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const [yingshiPrepare, setYingshiPrepare] = useState('') | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    const operationRef = useRef(null) |  |  |    const operationRef = useRef(null) | 
			
		
	
		
		
			
				
					|  |  |    const processChangeTimeoutRef = useRef(null) |  |  |    const processChangeTimeoutRef = useRef(null) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    // 标记萤石操作中,等待ifream返回信息后清空 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const yingshiPrepareRef = useRef(null) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    const changeSelectState = (key) => { |  |  |    const changeSelectState = (key) => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if (videoObj.type == 'yingshi' && yingshiPrepareRef.current) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          return | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |       const nextOperationState = JSON.parse(JSON.stringify(operationRef.current)) |  |  |       const nextOperationState = JSON.parse(JSON.stringify(operationRef.current)) | 
			
		
	
		
		
			
				
					|  |  |       if (key == 'histroy' && nextOperationState.histroy.select) { |  |  |       if (key == 'histroy' && nextOperationState.histroy.select) { | 
			
		
	
		
		
			
				
					|  |  |          // 取消历史播放 |  |  |          // 取消历史播放 | 
			
		
	
	
		
		
			
				
					|  | @ -71,7 +84,9 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |    }, { |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |       key: 'fullScreen', |  |  |       key: 'fullScreen', | 
			
		
	
		
		
			
				
					|  |  |       click: () => { |  |  |       click: () => { | 
			
		
	
		
		
			
				
					
					|  |  | 
 |  |  |          if (yingshiPrepareRef.current) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |             return | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          } | 
			
		
	
		
		
			
				
					|  |  |          changeSelectState('fullScreen') |  |  |          changeSelectState('fullScreen') | 
			
		
	
		
		
			
				
					|  |  |          let player = document.getElementById('vcmp_videoplay') |  |  |          let player = document.getElementById('vcmp_videoplay') | 
			
		
	
		
		
			
				
					|  |  |          if (screenfull.isEnabled) { |  |  |          if (screenfull.isEnabled) { | 
			
		
	
	
		
		
			
				
					|  | @ -80,14 +95,21 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |    }, { |  |  |    }, { | 
			
		
	
		
		
			
				
					|  |  |       key: 'histroy', |  |  |       key: 'histroy', | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       hide: !Boolean(videoObj.replayUrl), | 
			
		
	
		
		
			
				
					|  |  |       click: () => { |  |  |       click: () => { | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |          changeSelectState('histroy') |  |  |          changeSelectState('histroy') | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiPrepareRef.current = 'play' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          setYingshiPrepare('play') | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |    },] |  |  |    },] | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    useEffect(() => { |  |  |    useEffect(() => { | 
			
		
	
		
		
			
				
					
					|  |  |       create() |  |  |       if (videoObj.type == 'yingshi') { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiPrepareRef.current = 'play' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          setYingshiPrepare('play') | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } else { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          createJessibuca() | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |       let nextOperationState = {} |  |  |       let nextOperationState = {} | 
			
		
	
		
		
			
				
					|  |  |       for (let p of operation) { |  |  |       for (let p of operation) { | 
			
		
	
		
		
			
				
					|  |  |          nextOperationState[p.key] = { |  |  |          nextOperationState[p.key] = { | 
			
		
	
	
		
		
			
				
					|  | @ -108,29 +130,42 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |       // 萤石 ifream 信息监听 |  |  |       // 萤石 ifream 信息监听 | 
			
		
	
		
		
			
				
					
					|  |  |       // const listenYingshiMessage = async (e) => { |  |  |       const listenYingshiMessage = async (e) => { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    const { data, origin } = e |  |  |          const { data, origin } = e | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    console.log(e); |  |  |          console.log(e); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    if (origin !== 'https://open.ys7.com') return |  |  |          if (origin !== 'https://open.ys7.com') return | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    if (data.type == 'stop' && data.code == 1) { |  |  |          if (data.type == "handleSuccess") { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //       setIsPlaying(false) |  |  |             if (yingshiPrepareRef.current == 'play') { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    } |  |  |                setIsPlaying(true) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    if (data.type == 'stop' && data.code == 1) { |  |  |             } | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //       setIsPlaying(false) |  |  |          } else if (data.type == yingshiOpenSoundKey && data.code == 0) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    } |  |  |             if (yingshiPrepareRef.current == yingshiOpenSoundKey) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       // } |  |  |                setVoiceDisY(30) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       // if (videoObj.type == 'yingshi') { |  |  |             } | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    window.addEventListener('message', listenYingshiMessage); |  |  |          } if (data.type == yingshiCloseSoundKey && data.code == 0) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       // } |  |  |             if (yingshiPrepareRef.current == yingshiCloseSoundKey) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       // return () => { |  |  |                setVoiceDisY(0) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       //    window.removeEventListener('message', listenYingshiMessage); |  |  |             } | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       // } |  |  |          } | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiPrepareRef.current = null | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          setYingshiPrepare(null) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          window.addEventListener('message', listenYingshiMessage); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       return () => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          window.removeEventListener('message', listenYingshiMessage); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |    }, []) |  |  |    }, []) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    useEffect(() => { |  |  |    useEffect(() => { | 
			
		
	
		
		
			
				
					|  |  |       if (histroyTime.length) { |  |  |       if (histroyTime.length) { | 
			
		
	
		
		
			
				
					|  |  |          setHistroyBegain(histroyTime[0]) |  |  |          setHistroyBegain(histroyTime[0]) | 
			
		
	
		
		
			
				
					|  |  |          document.getElementById('process_point').style.left = 0 + 'px';   // 重置进度条的位置 |  |  |          document.getElementById('process_point').style.left = 0 + 'px';   // 重置进度条的位置 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             yingshiPrepareRef.current = 'play' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             setYingshiPrepare('play') | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          } | 
			
		
	
		
		
			
				
					|  |  |       } else { |  |  |       } else { | 
			
		
	
		
		
			
				
					|  |  |          setHistroyBegain(null) |  |  |          setHistroyBegain(null) | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
	
		
		
			
				
					|  | @ -138,6 +173,7 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |    useEffect(() => { |  |  |    useEffect(() => { | 
			
		
	
		
		
			
				
					|  |  |       if (operationState && operationState.histroy.select) { |  |  |       if (operationState && operationState.histroy.select) { | 
			
		
	
		
		
			
				
					|  |  |          if (isAdjustProcess) { |  |  |          if (isAdjustProcess) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             // 调整进度条 更新播放开始时间 | 
			
		
	
		
		
			
				
					|  |  |             if (processChangeTimeoutRef.current) { |  |  |             if (processChangeTimeoutRef.current) { | 
			
		
	
		
		
			
				
					|  |  |                clearTimeout(processChangeTimeoutRef.current) |  |  |                clearTimeout(processChangeTimeoutRef.current) | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
	
		
		
			
				
					|  | @ -150,14 +186,19 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |                      ) |  |  |                      ) | 
			
		
	
		
		
			
				
					|  |  |                      .format(timeFormat) |  |  |                      .format(timeFormat) | 
			
		
	
		
		
			
				
					|  |  |                ) |  |  |                ) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   yingshiPrepareRef.current = 'play' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   setYingshiPrepare('play') | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                } | 
			
		
	
		
		
			
				
					|  |  |             }, 300) |  |  |             }, 300) | 
			
		
	
		
		
			
				
					|  |  |          } else { |  |  |          } else { | 
			
		
	
		
		
			
				
					
					|  |  |             document.getElementById('process_point').style.left = processDisX + 'px' |  |  |             // 随播放时间变化更新进度条 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |             document.getElementById('process_point').style.left = processDisX - 4.5 + 'px' | 
			
		
	
		
		
			
				
					|  |  |          } |  |  |          } | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |    }, [processDisX]) |  |  |    }, [processDisX]) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |    const create = () => { |  |  |    const createJessibuca = () => { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |       if (videoObj.type != 'yingshi') { |  |  |       if (videoObj.type != 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |          let $container = document.getElementById('container'); |  |  |          let $container = document.getElementById('container'); | 
			
		
	
		
		
			
				
					|  |  |          const jessibuca = new window.Jessibuca({ |  |  |          const jessibuca = new window.Jessibuca({ | 
			
		
	
	
		
		
			
				
					|  | @ -183,9 +224,8 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |    } |  |  |    } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    const yingshiOperation = (operation) => { |  |  |    const yingshiOperation = (operation) => { | 
			
		
	
		
		
			
				
					
					|  |  |       let a = document.getElementById(containerId).contentWindow.postMessage(operation, yingshiUrl) |  |  |       document.getElementById(containerId).contentWindow.postMessage(operation, yingshiUrl) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |       console.log(a); |  |  |       // setIsPlaying(operation == 'play') | 
			
				
				
			
		
	
		
		
			
				
					|  |  |       setIsPlaying(operation == 'play') |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |    } |  |  |    } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    const play = () => { |  |  |    const play = () => { | 
			
		
	
	
		
		
			
				
					|  | @ -199,13 +239,29 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    const pause = () => { |  |  |    const pause = () => { | 
			
		
	
		
		
			
				
					|  |  |       if (videoObj.type == 'yingshi') { |  |  |       if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					
					|  |  |          yingshiOperation('stop') |  |  |          // yingshiOperation('stop') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |       } else if (jessibuca) { |  |  |       } else if (jessibuca) { | 
			
		
	
		
		
			
				
					|  |  |          jessibuca.pause(); |  |  |          jessibuca.pause(); | 
			
		
	
		
		
			
				
					|  |  |          setIsPlaying(false) |  |  |          setIsPlaying(false) | 
			
		
	
		
		
			
				
					|  |  |       } |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |    } |  |  |    } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const closeSound = () => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiPrepareRef.current = yingshiCloseSoundKey | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          setYingshiPrepare(yingshiCloseSoundKey) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiOperation(yingshiCloseSoundKey) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    const openSound = () => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       if (videoObj.type == 'yingshi') { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiPrepareRef.current = yingshiOpenSoundKey | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          setYingshiPrepare(yingshiOpenSoundKey) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |          yingshiOperation(yingshiOpenSoundKey) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |    } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |    return ( |  |  |    return ( | 
			
		
	
		
		
			
				
					|  |  |       <> |  |  |       <> | 
			
		
	
		
		
			
				
					|  |  |          <div className="vcmp_videoplay" style={{ height: height || '100%', width: width || '100%' }}> |  |  |          <div className="vcmp_videoplay" style={{ height: height || '100%', width: width || '100%' }}> | 
			
		
	
	
		
		
			
				
					|  | @ -215,7 +271,10 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |                   operationState={operationState} changeSelectState={changeSelectState} |  |  |                   operationState={operationState} changeSelectState={changeSelectState} | 
			
		
	
		
		
			
				
					|  |  |                   histroyTime={histroyTime} |  |  |                   histroyTime={histroyTime} | 
			
		
	
		
		
			
				
					|  |  |                   setoperationState={setoperationState} name={name} |  |  |                   setoperationState={setoperationState} name={name} | 
			
		
	
		
		
			
				
					
					|  |  |                   showTime={histroyBegain} |  |  |                   showTime={ | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                      videoObj.type == 'yingshi' && yingshiPrepare == 'play' ? | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         null : (histroyBegain || moment()) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   } | 
			
		
	
		
		
			
				
					|  |  |                   setProcessDisX={setProcessDisX} |  |  |                   setProcessDisX={setProcessDisX} | 
			
		
	
		
		
			
				
					|  |  |                /> |  |  |                /> | 
			
		
	
		
		
			
				
					|  |  |                {/* 视频内容 */} |  |  |                {/* 视频内容 */} | 
			
		
	
	
		
		
			
				
					|  | @ -225,7 +284,7 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |                         frameBorder="0" |  |  |                         frameBorder="0" | 
			
		
	
		
		
			
				
					|  |  |                         id={containerId} |  |  |                         id={containerId} | 
			
		
	
		
		
			
				
					|  |  |                         src={ |  |  |                         src={ | 
			
		
	
		
		
			
				
					
					|  |  |                            `${yingshiUrl}?audio=${videoObj.audio ? '1' : '0'}&url=${operationState && operationState.histroy.select && histroyBegain ? `${videoObj.replayUrl}?begin=${moment(histroyBegain).format("YYYYMMDDHHmmss")}&end=${moment(histroyTime[1]).format("YYYYMMDDHHmmss")}` : resolution == 'sd' ? videoObj.playUrlSd : videoObj.playUrlHd}&autoplay=${'1'}&accessToken=${videoObj.yingshiToken}` |  |  |                            `${yingshiUrl}?audio=${videoObj.audio && operationState && !operationState.histroy.select ? '1' : '0'}&url=${operationState && operationState.histroy.select && histroyBegain ? `${videoObj.replayUrl}?begin=${moment(histroyBegain).format("YYYYMMDDHHmmss")}&end=${moment(histroyTime[1]).format("YYYYMMDDHHmmss")}` : resolution == 'sd' ? videoObj.playUrlSd : videoObj.playUrlHd}&autoplay=${'1'}&accessToken=${videoObj.yingshiToken}` | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                         } |  |  |                         } | 
			
		
	
		
		
			
				
					|  |  |                         // https://open.ys7.com/doc/zh/book/index/live_proto.html  |  |  |                         // https://open.ys7.com/doc/zh/book/index/live_proto.html  | 
			
		
	
		
		
			
				
					|  |  |                         // 单个播放器的长宽比例限制最小为{width: 400px;height: 300px;} |  |  |                         // 单个播放器的长宽比例限制最小为{width: 400px;height: 300px;} | 
			
		
	
	
		
		
			
				
					|  | @ -252,10 +311,11 @@ const VideoPlay = ({ | 
			
		
	
		
		
			
				
					|  |  |                   resolution={resolution} setResolution={setResolution} |  |  |                   resolution={resolution} setResolution={setResolution} | 
			
		
	
		
		
			
				
					|  |  |                   histroyTime={histroyTime} setHistroyTime={setHistroyTime} |  |  |                   histroyTime={histroyTime} setHistroyTime={setHistroyTime} | 
			
		
	
		
		
			
				
					|  |  |                   histroyBegain={histroyBegain} |  |  |                   histroyBegain={histroyBegain} | 
			
		
	
		
		
			
				
					
					|  |  |                   play={play} |  |  |                   play={play} pause={pause} closeSound={closeSound} openSound={openSound} | 
			
				
				
			
		
	
		
		
			
				
					|  |  |                   pause={pause} |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					|  |  |                   isPlaying={isPlaying} |  |  |                   isPlaying={isPlaying} | 
			
		
	
		
		
			
				
					|  |  |                   videoObj={videoObj} |  |  |                   videoObj={videoObj} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   setYingshiPrepare={setYingshiPrepare} | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                   yingshiPrepareRef={yingshiPrepareRef} | 
			
		
	
		
		
			
				
					|  |  |                /> |  |  |                /> | 
			
		
	
		
		
			
				
					|  |  |             </div> |  |  |             </div> | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | 
 |