File size: 1,014 Bytes
c2c8c8d | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | import { useEffect, useRef } from 'react';
import Hls from 'hls.js';
interface HLSVideoProps {
src: string;
className?: string;
}
export default function HLSVideo({ src, className = '' }: HLSVideoProps) {
const videoRef = useRef<HTMLVideoElement>(null);
useEffect(() => {
const video = videoRef.current;
if (!video) return;
if (Hls.isSupported()) {
const hls = new Hls({
enableWorker: true,
lowLatencyMode: false,
});
hls.loadSource(src);
hls.attachMedia(video);
hls.on(Hls.Events.MANIFEST_PARSED, () => {
video.play().catch(() => {});
});
return () => hls.destroy();
} else if (video.canPlayType('application/vnd.apple.mpegurl')) {
video.src = src;
video.addEventListener('loadedmetadata', () => {
video.play().catch(() => {});
});
}
}, [src]);
return (
<video
ref={videoRef}
className={className}
autoPlay
loop
muted
playsInline
/>
);
}
|