Jessibuca 视频插件Vue2使用

官网: http://jessibuca.com/document.html#window-jessibuca-is-not-a-constructor

使用环境  vue2,

第一步、需要如下三个文件,

 

 

第二步、在index.html中引入 jessibuca.js

 <script src="./jessibuca.js"></script>

 

第三步,随便建个文件初始化,Icon使用的是iView组件,

<template>
	<div>
		<div class="videoCanvas" ref="bigVideo">
			<div class="playBt">
				<Icon size="28" v-if="hdHandle && hdHandle.isPlaying()" @click="hdHandle.pause()" type="md-pause">
				</Icon>
				<Icon size="28" v-else-if="hdHandle && !hdHandle.isPlaying()" type="md-play" @click="hdHandle.play()">
				</Icon>
			</div>
			<div class="closeBt">
				<Icon size="28" type="md-close" @click="hdShow = false"></Icon>
			</div>
			<div class="screenshotBt">
				<Icon size="28" type="md-camera" @click="screenshot()"></Icon>
			</div>
		</div>


		<div class="screenshot" v-if="shotURL">
			<!-- <Spin v-if="loading" fix></Spin> -->
			<div class="closeBt">
				<Icon size="28" type="md-close" @click="shotURL = null"></Icon>
			</div>
			<div class="playBt">
				<Icon size="28" type="md-cloud-upload" @click="upload"></Icon>
			</div>
			<img style="width:100%;display: block;" :src="shotURL" id="shotId">
		</div>


	</div>
</template>

<script>
	export default {
		data() {
			return {
				hdHandle: null,
				videoUrl: "https://XXXXXX.flv",
				shotURL: '',
			}
		},
		mounted() {
			this.init()
		},
		methods: {
			upload() {//截图上传
				let myform = new FormData()
				if (this.shotURL) {
					myform.append('file', this.dataURLToBlob(this.shotURL))
					
					//调用接口上传图片
					// uploadScreenshot(myform).then(res => {
					// 	this.loading = false
					// 	if (res?.result_code === '0') {
					// 		this.shotURL = null
					// 		this.$Message.success({
					// 			content: '上传成功',
					// 			duration: 3
					// 		})
					// 	} else {
					// 		this.$Message.error({
					// 			content: '上传失败',
					// 			duration: 3
					// 		})
					// 	}
					// })
				}
			},
			dataURLToBlob(fileDataURL) {
				let arr = fileDataURL.split(','),
					mime = arr[0].match(/:(.*?);/)[1],
					bstr = atob(arr[1]),
					n = bstr.length,
					u8arr = new Uint8Array(n);
				while (n--) {
					u8arr[n] = bstr.charCodeAt(n)
				}
				return new Blob([u8arr], {
					type: mime
				})
			},
			screenshot() { //截图
				if (this.hdHandle) {
					const b64 =
						this.hdHandle.screenshot('test', 'jpeg', 'base64')
					this.shotURL = b64
				}
			},
			init() { //初始化组件
				this.hdHandle = new window.Jessibuca(
					Object.assign({
						container: this.$refs['bigVideo'],
						isResize: true,
						// isFullResize: true,
						controlAutoHide: true,
						videoBuffer: 2,
						text: "",
						// background: "bg.jpg",
						loadingText: "loading...",
						// hasAudio:false,
						// debug: true,
						supportDblclickFullscreen: false,
						// showBandwidth: true, // 显示网速
						operateBtns: {
							// fullscreen: true,
							// screenshot: true,
							// play: true,
							// audio: true,
						},
						forceNoOffscreen: true,
						isNotMute: false,
						timeout: 10,
						useWebFullScreen: true,
						useMSE: true,
						useWCS: true,
						autoWasm: true,
					}, {})
				);
				
				this.hdHandle.play(this.videoUrl)
			},
		}
	}
</script>

<style>
	.screenshot {
		position: absolute;
		border: 5px solid #FFFFFF;
		z-index: 10000;
		width: 80vw;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		animation: scalekey 0.2s ease-in;
		// transition: width 3.8s
	}
</style>

 

最终展示视频如下,图片后面的视频是摄像头视频,不能展示,可以右上角暂停,截图等。

posted @ 2024-06-04 15:07  伟衙内  阅读(401)  评论(0编辑  收藏  举报