116 lines
2.8 KiB
TypeScript
116 lines
2.8 KiB
TypeScript
import Head from "next/head";
|
|
import { useEffect, useState } from "react";
|
|
|
|
import ThreeCanvas from "../components/ThreeCanvas";
|
|
import PromptPanel from "../components/PromptPanel";
|
|
import Settings from "../components/Settings";
|
|
import Pause from "../components/Pause";
|
|
|
|
import { InferenceResult, PromptInput } from "../types";
|
|
|
|
import * as Tone from "tone";
|
|
|
|
const defaultPromptInputs = [
|
|
{ prompt: "A jazz pianist playing a classical concerto", seed: 10 },
|
|
{ prompt: "Taylor Swift singing with a tropical beat", seed: 10 },
|
|
];
|
|
|
|
const defaultInferenceResults = [
|
|
{
|
|
input: {
|
|
alpha: 0.0,
|
|
start: defaultPromptInputs[0],
|
|
end: defaultPromptInputs[1],
|
|
},
|
|
image: "rap_sample.jpg",
|
|
audio: "rap_sample.mp3",
|
|
counter: 0,
|
|
},
|
|
];
|
|
|
|
const timeout = 5000;
|
|
const maxLength = 10;
|
|
|
|
export default function Home() {
|
|
const [paused, setPaused] = useState(false);
|
|
|
|
const [promptInputs, setPromptInputs] =
|
|
useState<PromptInput[]>(defaultPromptInputs);
|
|
|
|
const [inferenceResults, setInferenceResults] = useState<InferenceResult[]>(
|
|
defaultInferenceResults
|
|
);
|
|
|
|
// /////////////
|
|
|
|
const [tonePlayer, setTonePlayer] = useState(null);
|
|
|
|
useEffect(() => {
|
|
setTonePlayer(
|
|
new Tone.Player(defaultInferenceResults[0].audio).toDestination()
|
|
);
|
|
// play as soon as the buffer is loaded
|
|
// player.autostart = true;
|
|
}, [inferenceResults]);
|
|
|
|
useEffect(() => {
|
|
if (tonePlayer && tonePlayer.loaded) {
|
|
if (!paused) {
|
|
tonePlayer.start();
|
|
} else {
|
|
tonePlayer.stop();
|
|
}
|
|
}
|
|
}, [paused, tonePlayer]);
|
|
|
|
// /////////////
|
|
|
|
useEffect(() => {
|
|
setTimeout(() => {
|
|
const lastResult = inferenceResults[inferenceResults.length - 1];
|
|
const newResult = { ...lastResult, counter: lastResult.counter + 1 };
|
|
|
|
let results = [...inferenceResults, newResult];
|
|
|
|
if (results.length > maxLength) {
|
|
results = results.slice(1);
|
|
}
|
|
|
|
console.log("Adding to inference results");
|
|
console.log(results);
|
|
|
|
setInferenceResults(results);
|
|
}, timeout);
|
|
});
|
|
|
|
return (
|
|
<>
|
|
<Head>
|
|
<title>Riffusion</title>
|
|
<meta
|
|
name="description"
|
|
content="My name is Riffusion, and I write music."
|
|
/>
|
|
<link rel="icon" href="/favicon.ico" />
|
|
</Head>
|
|
|
|
<div className="bg-sky-900 flex flex-row min-h-screen text-white">
|
|
<div className="w-1/3 min-h-screen">
|
|
<ThreeCanvas paused={paused} inferenceResults={inferenceResults} />
|
|
</div>
|
|
|
|
<PromptPanel
|
|
prompts={promptInputs}
|
|
addPrompt={(prompt: string, seed: number) => {
|
|
setPromptInputs([...promptInputs, { prompt: prompt, seed: seed }]);
|
|
}}
|
|
/>
|
|
|
|
<Settings />
|
|
|
|
<Pause paused={paused} setPaused={setPaused} />
|
|
</div>
|
|
</>
|
|
);
|
|
}
|