52 lines
1.2 KiB
JavaScript
52 lines
1.2 KiB
JavaScript
|
|
import { useCallback, useEffect, useRef, useState } from "react";
|
||
|
|
import { apiBaiduTTS } from "../apis";
|
||
|
|
|
||
|
|
/**
|
||
|
|
* 声音播放hook
|
||
|
|
* @param {*} src
|
||
|
|
* @returns
|
||
|
|
*/
|
||
|
|
export function useAudio(src) {
|
||
|
|
// const audioRef = useRef(new Audio(src));
|
||
|
|
const audioRef = useRef(null);
|
||
|
|
const [error, setError] = useState(null);
|
||
|
|
const [ready, setReady] = useState(false);
|
||
|
|
const [playing, setPlaying] = useState(false);
|
||
|
|
|
||
|
|
const play = useCallback(() => {
|
||
|
|
audioRef.current?.play();
|
||
|
|
}, []);
|
||
|
|
|
||
|
|
useEffect(() => {
|
||
|
|
if (!src) {
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
const audio = new Audio(src);
|
||
|
|
audio.addEventListener("error", (err) => setError(err));
|
||
|
|
audio.addEventListener("canplaythrough", () => setReady(true));
|
||
|
|
audio.addEventListener("play", () => setPlaying(true));
|
||
|
|
audio.addEventListener("ended", () => setPlaying(false));
|
||
|
|
audioRef.current = audio;
|
||
|
|
}, [src]);
|
||
|
|
|
||
|
|
return {
|
||
|
|
error,
|
||
|
|
ready,
|
||
|
|
playing,
|
||
|
|
play,
|
||
|
|
};
|
||
|
|
}
|
||
|
|
|
||
|
|
export function useTextAudio(text, lan = "uk", spd = 3) {
|
||
|
|
const [src, setSrc] = useState("");
|
||
|
|
|
||
|
|
useEffect(() => {
|
||
|
|
(async () => {
|
||
|
|
const res = await apiBaiduTTS(text, lan, spd);
|
||
|
|
setSrc(res);
|
||
|
|
})();
|
||
|
|
}, [text, lan, spd]);
|
||
|
|
|
||
|
|
return useAudio(src);
|
||
|
|
}
|