103 lines
2.6 KiB
HTML
103 lines
2.6 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport"
|
|
content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
|
|
<title>play</title>
|
|
</head>
|
|
<style>
|
|
html {
|
|
margin: 0;
|
|
padding: 0;
|
|
overflow: hidden; /* 防止滚动条出现 */
|
|
}
|
|
body {
|
|
width: 100vw;
|
|
height: 100vh;
|
|
margin: 0;
|
|
padding: 0;
|
|
background-color: white;
|
|
overflow: hidden; /* 防止滚动条出现 */
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
#player {
|
|
object-fit:cover;
|
|
height: 56vh;
|
|
transform: rotate(-90deg);
|
|
}
|
|
</style>
|
|
<body>
|
|
|
|
<video autoplay muted poster="images/loader-thumb.jpg"
|
|
id="player">
|
|
</video>
|
|
<script src="jmuxer.min.js"></script>
|
|
<script>
|
|
|
|
if (typeof JMuxer === 'undefined') {
|
|
console.error("JMuxer is not defined. Check if jmuxer.min.js is loaded correctly.");
|
|
} else {
|
|
console.log("JMuxer loaded successfully.");
|
|
}
|
|
let jmuxer;
|
|
window.onload = function() {
|
|
try {
|
|
jmuxer = new JMuxer({
|
|
node: 'player',
|
|
mode: 'video',
|
|
debug: false,
|
|
webgl: true, // 启用WebGL加速
|
|
webglOptions: {
|
|
preserveDrawingBuffer: false,
|
|
antialias: false
|
|
},
|
|
flushingTime: 0, // 禁用自动刷新
|
|
clearBuffer: false, // 保留解码缓存
|
|
fps:20,
|
|
onReady: () => {
|
|
console.log('播放器初始化完成');
|
|
// 通知Flutter端准备就绪
|
|
window.Flutter.postMessage('ready');
|
|
}
|
|
});
|
|
jmuxer.reset();
|
|
console.log("JMuxer initialized.");
|
|
} catch (e) {
|
|
console.error("Error initializing JMuxer:", e);
|
|
}
|
|
};
|
|
|
|
|
|
|
|
|
|
// Feed data from Flutter
|
|
function feedDataFromFlutter(data) {
|
|
const buffer = new Uint8Array(data);
|
|
jmuxer.feed({
|
|
video: buffer,
|
|
|
|
});
|
|
}
|
|
|
|
|
|
// Optional: notify Flutter
|
|
function notifyFlutter(message) {
|
|
if (window.Flutter) {
|
|
window.Flutter.postMessage(message);
|
|
} else {
|
|
console.log("Flutter interface not found. Message: " + message);
|
|
}
|
|
}
|
|
|
|
// Function to return to Flutter page
|
|
function returnToFlutter() {
|
|
notifyFlutter("Returning to Flutter page");
|
|
}
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|