import React, { useEffect, useState, useRef } from "react"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faPlay, faPause } from "@fortawesome/free-solid-svg-icons"; import { Toast } from "antd-mobile"; import BackgroundPlayer from "next-video/background-player"; import { toggleFullScreen } from "@/utils/tools/handleFuns"; import Slider from "rc-slider"; import "rc-slider/assets/index.css"; export default function VideoPlayer({ video }) { const [videoState, setVideoState] = useState({ play: true, currentTimePercentage: 0, }); const [showController, setShowController] = useState(false); const [screenState, setScreenState] = useState(false); const isSliding = useRef(null); const userAgent = navigator.userAgent; // const currentTime = useMemo(()=>{ // const videoPlayer = document.getElementById("videoPlayer"); // if (videoPlayer) { // return videoPlayer.currentTime; // } // return 0; // }) useEffect(() => { window.onresize = function () { if (document.fullscreenElement) { console.log("进入全屏"); } else { console.log("退出全屏"); const video = document.getElementById("videoContainer"); const controller = document.getElementById("controllerContainer"); if (!video || !controller) return; video.firstChild.style.transform = "none"; video.firstChild.style.width = "auto"; video.firstChild.style.height = "auto"; video.firstChild.style.transformOrigin = ""; controller.style.width = "100%"; controller.style.height = "100%"; controller.firstChild.style.marginLeft = "0"; setScreenState(false); } }; const videoPlayer = document.getElementById("videoPlayer"); const openVolum = () => { videoPlayer.muted = false; }; const pauseVideo = () => { setVideoState((old) => ({ ...old, play: false })); }; const updateTime = () => { // console.log((videoPlayer.currentTime / videoPlayer.duration) * 100); if (!isSliding.current) setVideoState((old) => ({ ...old, currentTimePercentage: (videoPlayer.currentTime / videoPlayer.duration) * 100, })); }; if (videoPlayer) { videoPlayer.addEventListener("loadedmetadata", openVolum); videoPlayer.addEventListener("ended", pauseVideo); videoPlayer.addEventListener("timeupdate", updateTime); } return () => { if (videoPlayer) { videoPlayer.removeEventListener("loadedmetadata", openVolum); videoPlayer.removeEventListener("ended", pauseVideo); videoPlayer.removeEventListener("timeupdate", updateTime); } }; }, []); const getCurrentTime = (value) => { const videoPlayer = document.getElementById("videoPlayer"); if (!videoPlayer) null; const totalTime = videoPlayer?.duration; let timeSec = 0; timeSec = (totalTime * (100 - value)) / 100; const hour = Math.floor(timeSec / (60 * 60)); const minute = Math.floor((timeSec - hour * (60 * 60)) / 60); const second = Math.floor(timeSec - hour * (60 * 60) - minute * 60); return { desc: `${hour > 9 ? hour : "0" + hour}:${ minute > 9 ? minute : "0" + minute }:${second > 9 ? second : "0" + second}`, timeSec: (totalTime * value) / 100, }; }; const toastValue = (value) => { isSliding.current = true; const videoPlayer = document.getElementById("videoPlayer"); if (!videoPlayer) return; videoPlayer.pause(); const currentTimeStr = getCurrentTime(value); console.log("currentTimeStr-----", currentTimeStr.desc); // if (!currentTimeStr) return; Toast.show({ content: currentTimeStr.desc, position: "top", maskStyle: { "--z-index": 999999 }, }); videoPlayer.currentTime = currentTimeStr.timeSec; // console.log("currentTimeStr", currentTimeStr); setVideoState((old) => ({ play: false, currentTimePercentage: value })); }; const handleStart = () => { const videoPlayer = document.getElementById("videoPlayer"); if (!videoPlayer) return; videoPlayer.play(); isSliding.current = false; setVideoState((old) => ({ ...old, play: true })); }; return ( <div className="relative bg-black" id="videoContainer"> <div style={{ maxHeight: "90vh" }} className="overflow-hidden" onClick={() => setShowController((old) => !old)} > <BackgroundPlayer src={video.mp4} id="videoPlayer" // controlsList="none" poster={video?.url.src} blurDataURL={video?.url.blurDataURL} autoPlay={videoState.play} // style={{ height: "calc(100vh)" }} /> </div> <div className={`pointer-events-none absolute h-full p-4 bottom-0 right-0 flex ${ screenState && video.w > video.h ? "flex-col-reverse items-start justify-evenly" : "w-full flex-row-reverse justify-between items-end gap-4 py-10" }`} style={{ display: showController ? "flex" : "none", }} id="controllerContainer" > {/* <Slider value={videoState.currentTimePercentage} onAfterChange={handleStart} onChange={toastValue} icon={<div></div>} style={{ "--fill-color": "#ff669e" }} /> */} <div className={`pointer-events-auto flex items-center justify-center h-full px-4 ${ !screenState ? "max-h-[60vh]" : "max-h-[80vh]" }`} > <Slider styles={{ rail: { background: `#ff669e40`, width: 8, }, track: { background: "#ff669e", width: 8, }, handle: { borderColor: "#ff669e", background: "#ff669e", border: "2px solid #ff669e", opacity: 1, boxShadow: "0 0 0 5px #ff669e80", height: 24, width: 24, marginLeft: -8, marginTop: 0, }, }} activeDotStyle={{ borderColor: "#ff669e", background: "#ff669e80", }} vertical reverse={true} min={0} value={videoState.currentTimePercentage} onChangeComplete={handleStart} // startPoint={0} // marks={marks} // step={null} onChange={toastValue} defaultValue={0} /> </div> <div className={`pointer-events-auto gap-4 px-4 ${ screenState && video.w > video.h ? "grid grid-rows-[83px,30px,30px] mb-4 w-max " : "flex" }`} > <div className={`w-[83px] text-center text-white bg-[#ffffff80] rounded-lg px-2 py-1 h-max origin-bottom-left ${ screenState && video.w > video.h ? "rotate-90 -translate-y-7 " : "" }`} > {getCurrentTime(videoState.currentTimePercentage).desc} </div> <div className={ screenState && video.w > video.h ? "rotate-90 -translate-y-7 origin-bottom-left" : "" } > {/Android/i.test(userAgent) && ( <div onClick={() => { toggleFullScreen( "videoContainer", "controllerContainer", setScreenState ); }} className="rounded-full bg-[#ffffff80] p-2 w-[30px] h-[30px]" > <svg t="1734698522866" className="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4039" width="100%" height="100%" > {screenState ? ( <path d="M597.333333 128a42.666667 42.666667 0 0 0-42.666666 42.666667v256a42.666667 42.666667 0 0 0 42.666666 42.666666h256a42.666667 42.666667 0 1 0 0-85.333333h-153.002666l183.168-183.168a42.666667 42.666667 0 1 0-60.330667-60.330667L640 323.669333V170.666667a42.666667 42.666667 0 0 0-42.666667-42.666667z m-170.666666 426.666667H170.666667a42.666667 42.666667 0 1 0 0 85.333333h153.002666l-183.168 183.168a42.666667 42.666667 0 1 0 60.330667 60.330667L384 700.330667V853.333333a42.666667 42.666667 0 1 0 85.333333 0v-256a42.666667 42.666667 0 0 0-42.666666-42.666666z" p-id="21020" fill="#ffffff" ></path> ) : ( <> <path d="M865.706667 719.36zM842.666667 719.36zM159.786667 520.746667a49.066667 49.066667 0 0 1-49.066667-49.066667V163.626667a49.066667 49.066667 0 0 1 49.066667-49.066667h299.52a49.066667 49.066667 0 0 1 0 98.133333H208.853333v258.986667a49.066667 49.066667 0 0 1-49.066666 49.066667z" fill="#ffffff" p-id="18397" ></path> <path d="M437.973333 496.213333c-12.8 0-25.386667-4.906667-34.986666-14.72L124.8 197.973333c-18.986667-19.413333-18.773333-50.346667 0.64-69.333333 19.413333-18.986667 50.346667-18.773333 69.333333 0.64l278.186667 283.52c18.986667 19.413333 18.773333 50.346667-0.64 69.333333-9.6 9.386667-21.973333 14.08-34.346667 14.08zM872.96 921.173333H573.226667a49.066667 49.066667 0 0 1 0-98.133333h250.666666V564.053333a49.066667 49.066667 0 0 1 98.133334 0v308.053334a49.066667 49.066667 0 0 1-49.066667 49.066666z" fill="#ffffff" p-id="18398" ></path> <path d="M872.96 921.173333c-12.8 0-25.386667-4.906667-34.986667-14.72L559.573333 622.933333c-18.986667-19.413333-18.773333-50.346667 0.64-69.333333 19.413333-18.986667 50.346667-18.773333 69.333334 0.64l278.4 283.52c18.986667 19.413333 18.773333 50.346667-0.64 69.333333-9.6 9.386667-21.973333 14.08-34.346667 14.08z" fill="#ffffff" p-id="18399" ></path> </> )} </svg> </div> )} </div> <div className={`rounded-full bg-[#ffffff80] p-2 w-[30px] h-[30px] flex justify-center items-center ${ screenState && video.w > video.h ? "rotate-90 -translate-y-7 origin-bottom-left" : "" }`} > <FontAwesomeIcon icon={videoState.play ? faPause : faPlay} color="#ffffff" // style={{ maxWidth: "32px" }} // size="lg" onClick={() => { const videoPlayer = document.getElementById("videoPlayer"); if (videoState.play) { setVideoState((old) => ({ ...old, play: false })); videoPlayer.pause(); } else { setVideoState((old) => ({ ...old, play: true })); videoPlayer.play(); } }} /> </div> </div> </div> </div> ); }