123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340 |
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
- <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
- <title>播放器</title>
- <script src="./vconsole.js"></script>
- <script src="./jessibuca-pro/jessibuca-pro.js"></script>
- <link rel="stylesheet" href="./player.css">
- <style>
- .container-shell:before {
- content: "";
- }
- </style>
- </head>
- <body class="page">
- <div class="root">
- <div class="container-shell">
- <div id="container"></div>
- </div>
- <!-- <br/>-->
- <!-- <br/>-->
- <!-- <div class="post-message-section">-->
- <!-- <p class="desc">网页向应用发送消息。test88</p>-->
- <!-- <div class="btn-list">-->
- <!-- <button class="btn btn-red" type="button" id="wxpostMessage">wxpostMessage</button>-->
- <!--<!– <button class="btn btn-red" type="button" id="unipostMessage">unipostMessage</button>–>-->
- <!-- </div>-->
- <!-- </div>-->
- </div>
- </body>
- <script src="./player.js"></script>
- <!-- uni 的 SDK -->
- <script src="./uni.webview.1.5.5.js"></script>
- <script type="text/javascript">
- var userAgent = navigator.userAgent;
- console.log("userAgent");
- console.log(userAgent);
- if (userAgent.indexOf('AlipayClient') > -1) {
- // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。
- document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>');
- } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) {
- // QQ 小程序
- document.write(
- '<script type="text/javascript" src="https://qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"><\/script>'
- );
- } else if (/miniProgram/i.test(userAgent) && /micromessenger/i.test(userAgent)) {
- console.log("微信小程序 JS-SDK");
- // 微信小程序 JS-SDK 如果不需要兼容微信小程序,则无需引用此 JS 文件。
- document.write('<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"><\/script>');
- wx.miniProgram.getEnv(function(res) {
- console.log(res.miniprogram) // true
- })// true
- } else if (/toutiaomicroapp/i.test(userAgent)) {
- // 头条小程序 JS-SDK 如果不需要兼容头条小程序,则无需引用此 JS 文件。
- document.write(
- '<script type="text/javascript" src="https://s3.pstatp.com/toutiao/tmajssdk/jssdk-1.0.1.js"><\/script>');
- } else if (/swan/i.test(userAgent)) {
- // 百度小程序 JS-SDK 如果不需要兼容百度小程序,则无需引用此 JS 文件。
- document.write(
- '<script type="text/javascript" src="https://b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"><\/script>'
- );
- } else if (/quickapp/i.test(userAgent)) {
- // quickapp
- document.write('<script type="text/javascript" src="https://quickapp/jssdk.webview.min.js"><\/script>');
- }
- if (!/toutiaomicroapp/i.test(userAgent)) {
- console.log("webview post-message-section");
- //document.querySelector('.post-message-section').style.visibility = 'visible';
- }
- </script>
- <script type="text/javascript">
- var container = document.getElementById('container');
- var showOperateBtns = true; // 是否显示按钮
- var jessibuca = null;
- var rotate = 90;
- var playTimes = null;
- var playUrl = null;
- console.log("jessibuca webview");
- var data = getQuery('data');
- if (data != null) {
- console.log(data);
- var json = JSON.parse(data);
- playurl(json, json.playUrl);
- }
- function getQuery(name) {
- let reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
- let r = window.location.search.substr(1).match(reg);
- if (r != null) {
- return decodeURIComponent(r[2]);
- }
- return null;
- }
- function replay() {
- if (jessibuca != null) {
- jessibuca.destroy();
- }
- create()
- }
- function setplayTimes(times) {
- console.log("set playTimes:" + times);
- playTimes = times;
- }
- function setplayUrl(url) {
- console.log("set playUrl:" + url);
- playUrl = url;
- }
- function playurl(json, url) {
- setplayUrl(url);
- replay();
- console.log(json.type);
- if (json.type == "play") {
- play(url);
- } else if (json.type == "playback"){
- playback(url,json.playTimes);
- }
- }
- function create() {
- console.log("jessibuca create");
- jessibuca = new JessibucaPro({
- container: container,
- videoBuffer: 0.2, // 缓存时长
- decoder: './jessibuca-pro/decoder-pro.js',
- useSIMD: true,
- //useWCS: true,
- //useMSE: true,
- isResize: false,
- isFullResize: false,
- forceNoOffscreen: true,
- useWebFullScreen: true,
- useVideoRender: true,
- useCanvasRender: false,
- isNotMute: false,
- text: "",
- loadingText: "加载中",
- debug: true,
- debugLevel: 'debug',
- showBandwidth: showOperateBtns, // 显示网速
- operateBtns: {
- fullscreen: showOperateBtns,
- screenshot: showOperateBtns,
- play: showOperateBtns,
- audio: showOperateBtns,
- fullscreenFn: function () {
- console.log('fullscreenFn');
- jessibuca.setFullscreen(true);
- },
- fullscreenExitFn: function () {
- console.log('fullscreenExitFn');
- jessibuca.setFullscreen(false);
- jessibuca.setRotate(0);
- rotate = 90;
- },
- },
- extendOperateBtns: [{
- name: '横竖屏切换',
- index: 3,
- icon: '',
- iconHover: '',
- iconTitle: '横竖屏切换',
- click: () => {
- console.log('点击了横竖屏切换');
- jessibuca.setRotate(rotate);
- if (rotate == 90) {
- rotate = 0
- } else if (rotate == 0) {
- rotate = 90
- }
- }
- },],
- },);
- console.log("jessibuca create 22222");
- jessibuca.on('error', function (error) {
- console.log('error')
- console.log(error)
- })
- jessibuca.on("fetchError", function (data) {
- console.log('fetchError:', data)
- })
- jessibuca.on("start", function () {
- console.log('start render')
- })
- jessibuca.on("play", function (flag) {
- console.log('play')
- })
- jessibuca.on('crashLog', (data) => {
- console.log('crashLog is', data);
- })
- jessibuca.onLog = msg => console.error(msg);
- jessibuca.onRecord = (status) => console.log('onRecord', status);
- jessibuca.onPause = () => console.log('onPause');
- jessibuca.onPlay = () => console.log('onPlay');
- jessibuca.onMute = msg => console.log('onMute', msg);
- jessibuca.on("fullscreen", function (flag) {
- console.log('is fullscreen', flag)
- })
- jessibuca.on("webFullscreen", function (flag) {
- console.log('is webFullscreen', flag)
- })
- console.log("jessibuca create2");
- }
- function seekPlay(timeObj) {
- uni.postMessage({
- data: {
- action: 'seekPlay',
- msg: timeObj
- }
- });
- }
- function play(url) {
- console.log("play");
- console.log(url);
- if (url) {
- const status = jessibuca.getStatus();
- console.log(status);
- jessibuca.play(url).then(() => {
- console.log('play success')
- }).catch((e) => {
- console.log('play error', e)
- })
- }
- }
- function playback(url, times) {
- if (url) {
- jessibuca.playback(url, {
- playList: times,
- fps: 20, //FPS(定频(本地设置)生效)
- showControl: true,
- showRateBtn: true,
- isUseFpsRender: true, // 是否使用固定的fps渲染,如果设置的fps小于流推过来的,会造成内存堆积甚至溢出
- isCacheBeforeDecodeForFpsRender: false, // rfs渲染时,是否在解码前缓存数据
- supportWheel: true, // 是否支持滚动轴切换精度。
- rateConfig: [
- {label: '正常', value: 1},
- {label: '2倍', value: 2},
- {label: '4倍', value: 4},
- {label: '8倍', value: 8},
- ],
- })
- }
- }
- function test() {
- console.log("test");
- }
- function test2(msg) {
- console.log("test1"+msg);
- }
- window.msgFromUniapp = (res) =>{
- console.log("原生传递过来的数据:",res)
- }
- document.getElementById('wxpostMessage').addEventListener('click', function() {
- console.log("wx postMessage");
- wx.miniProgram.postMessage({
- data: {
- action: 'test'
- }
- });
- console.log("wx navigateBack");
- wx.miniProgram.navigateBack({delta: 1});
- });
- // document.getElementById('postMessage').addEventListener('click', function() {
- // console.log("postMessage");
- // //wx.miniProgram.navigateTo
- // //wx.miniProgram.navigateBack
- // //wx.miniProgram.switchTab
- // });
- // document.getElementById('unipostMessage').addEventListener('click', function() {
- // console.log("uni postMessage");
- // uni.postMessage({
- // data: {
- // action: 'test'
- // }
- // });
- // });
- document.addEventListener("UniAppJSBridgeReady", function () {
- console.log("UniAppJSBridgeReady");
- uni.postMessage({
- data: {
- action: 'message'
- }
- });
- uni.getEnv(function(res) {
- console.log('当前环境:' + JSON.stringify(res));
- });
- // uni.switchTab({
- // url: '/pages/tabBar/API/API'
- // });
- // uni.reLaunch({
- // url: '/pages/tabBar/component/component'
- // });
- // uni.navigateBack({
- // delta: 1
- // });
- // uni[action]({
- // url: '/pages/component/button/button'
- // });
- })
- //微信小程序
- function ready() {
- console.log(window.__wxjs_environment === 'miniprogram')
- }
- if (!window.WeixinJSBridge || !WeixinJSBridge.invoke) {
- document.addEventListener('WeixinJSBridgeReady', ready, false)
- } else {
- ready()
- }
- window.οnbefοreunlοad = function () {
- alert("===οnbefοreunlοad===");
- if (event.clientX > document.body.clientWidth && event.clientY < 0 || event.altKey) {
- alert("你关闭了浏览器");
- jessibuca.destroy();
- } else {
- alert("你正在刷新页面");
- replay();
- }
- }
- </script>
- </html>
|