aboutsummaryrefslogtreecommitdiff
path: root/src/App.jsx
blob: 25fe8349099c7e22ed9ca67c2d83454495bd4376 (plain)
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import './style.scss'
import { Canvas, useFrame } from '@react-three/fiber';
import Notes from './components/notes';
import Player from './components/player';
import Ground from './components/ground';
import React, { Suspense, useContext, useEffect, useState } from 'react';
import { Physics } from '@react-three/rapier';

export const AppContext = React.createContext(null);

function KeyPressedClearer() {
    const { setKeysPressed } = useContext(AppContext);
    useFrame((_s, _d) => setKeysPressed([]));
    return <></>
}

function App() {
    const [keys, setKeys] = useState([]);
    const [keysPressed, setKeysPressed] = useState([]);
    const playerKeyDown = (event) => {
        setKeys(keys => {
            if(!keys.includes(event.code)) {
                setKeysPressed(keysPressed => [...keysPressed, event.code]);
            }
         return [...keys, event.code]
        });
    }
    const playerKeyUp = (event) => {
        setKeys(keys => keys.filter(k => k != event.code));
    }
    useEffect(() => {
        window.addEventListener('keydown', playerKeyDown);
        window.addEventListener('keyup', playerKeyUp);
        return () => {
            window.removeEventListener('keydown', playerKeyDown);
            window.removeEventListener('keyup', playerKeyUp);
        };
    }, []);
    return (
        <AppContext.Provider value={{ keys: keys, keysPressed: keysPressed, setKeysPressed: setKeysPressed }}>
            <Canvas shadows>
                <KeyPressedClearer />
                <Suspense>
                    <Physics timeStep={1/60}>
                        <directionalLight
                            castShadow
                            position={[100, 100, 100]}
                            lookAt={[0, 0, 0]}
                            intensity={Math.PI / 2}
                            shadow-mapSize-height={2048}
                            shadow-mapSize-width={2048}
                        />
                        <ambientLight intensity={Math.PI / 4} />
                        <Notes />
                        <Player />
                        <Ground />
                    </Physics>
                </Suspense>
            </Canvas>
        </AppContext.Provider>
    )
}

export default App;