Commit 00893a20 authored by 喻天's avatar 喻天

feat: 视频组件

parent 195a175d
...@@ -105,6 +105,7 @@ export default { ...@@ -105,6 +105,7 @@ export default {
'TreeCustom', 'TreeCustom',
'AlarmScrollAssembly', 'AlarmScrollAssembly',
'DataCarousel', 'DataCarousel',
'TestVideo',
], ],
}, },
{ {
......
const proxyURL = process.env.PANDA_ENV_PROXY || 'http://192.168.8.28:8911'; const proxyURL = process.env.PANDA_ENV_PROXY || 'http://192.168.8.28:8911';
let exUrl = '';
if (proxyURL.includes(proxyURL.toLowerCase().includes('https'))) {
exUrl = proxyURL.replace('https', 'ws');
} else {
exUrl = proxyURL.replace('http', 'ws');
}
const wsServerPath = exUrl;
export default { export default {
'/api': { '/api': {
target: proxyURL, target: proxyURL,
changeOrigin: true, changeOrigin: true,
pathRewrite: { '^/api': '' }, pathRewrite: { '^/api': '' },
}, },
'/jessica': {
target: wsServerPath,
changeOrigin: true,
ws: true,
pathRewrite: {
'/jessica': '/jessica',
},
},
'/PandaMonitor': { '/PandaMonitor': {
target: proxyURL, target: proxyURL,
changeOrigin: true, changeOrigin: true,
......
# `@wisdom-components/TestVideo`
> TODO: description
## Usage
```
const testvideo = require('@wisdom-components/testvideo');
# TestVideo 视频组件
## 视频组件 - 基本
### api 参考 Jessibuca 组件 https://jessibuca.com/api.html
### 在使用该组件时,需将组件中JessibucaVideo文件夹,拷贝至环境根目录public中
```
{
"name": "@wisdom-components/testvideo",
"version": "1.0.0",
"description": "> TODO: description",
"author": "yutian <249303761@qq.com>",
"homepage": "",
"license": "ISC",
"module": "es/index.js",
"main": "lib/index.js",
"sideEffects": [
"*.less"
],
"directories": {
"lib": "lib",
"es": "es",
"dist": "dist",
"test": "__tests__"
},
"files": [
"lib",
"es",
"dist"
],
"publishConfig": {
"registry": "https://g.civnet.cn:4873/"
},
"repository": {
"type": "git",
"url": "https://g.civnet.cn:8443/ReactWeb5/wisdom-components.git"
},
"scripts": {
"test": "node ./__tests__/@wisdom-components/TestVideo.test.js"
},
"dependencies": {
"@babel/runtime": "^7.17.9"
}
}
\ No newline at end of file
import React from 'react';
import style from './App.less';
// import pubsub from 'pubsub-js'
class App extends React.Component {
constructor(props) {
super(props);
this.jessibuca = null;
this.showOperateBtns = true;
this.$container = null;
this.forceNoOffscreen = false;
this.state = {
isPlaying: false,
};
}
createAll() {
let { VideoInfo, JessibucaObj } = this.props;
this.destroy();
if (VideoInfo.url) {
this.create(this.refs[`myVideo` + VideoInfo.key], `key`, JessibucaObj);
setTimeout(() => {
this.play(VideoInfo.url, `key`);
}, 10);
}
}
componentDidMount() {
this.createAll();
}
componentWillUnmount() {
this.destroy();
}
create(dom, key, obj) {
if (this.jessibuca) this.jessibuca.destroy();
let jsc = {
videoBuffer: 0.2, // 缓存时长
isResize: false,
text: '',
isFlv: false,
loadingText: '加载中',
debug: false,
recordType: 'mp4',
loadingTimeout: 60,
loadingText: '视频加载中',
loadingTimeoutReplay: true,
timeout: 60,
controlAutoHide: true,
heartTimeout: 60,
heartTimeoutReplay: true,
showBandwidth: true, // 显示网速
operateBtns: {
fullscreen: true,
screenshot: true,
play: true,
record: true,
audio: true,
},
isNotMute: false,
};
jsc = {
...jsc,
...obj,
container: dom,
decoder: '/JessibucaVideo/decoder.js',
};
if (dom) {
this.jessibuca = new window.Jessibuca(jsc);
}
}
play(url, key) {
if (this.jessibuca) {
this.jessibuca.play(url);
this.setState({
isPlaying: true,
});
}
}
pause() {
if (this.jessibucaArr) {
debugger;
for (let key in this.jessibucaArr) {
this.jessibucaArr[key].pause();
}
this.setState({
isPlaying: false,
});
}
}
destroy() {
if (this.jessibuca) {
this.jessibuca.destroy();
this.setState({
isPlaying: false,
});
}
}
renderCheckedArr() {
let { VideoInfo } = this.props;
return (
<div className={style.containerOut}>
{
<div
className={style.container}
key={VideoInfo.key}
ref={`myVideo` + VideoInfo.key}
></div>
}
</div>
);
}
render() {
return <div className={style.root}>{this.renderCheckedArr()}</div>;
}
}
export default App;
.root {
width: 100%;
height: 100%;
.containerOut {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
width: 100%;
height: 100%;
}
.containerOut .container {
width: 100%;
height: 100%;
background: rgba(13, 14, 27, 0.7);
border: 1px solid transparent;
}
}
This source diff could not be displayed because it is too large. You can view the blob instead.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment