diff --git a/FUNDING.yml b/FUNDING.yml new file mode 100644 index 0000000..5becc97 --- /dev/null +++ b/FUNDING.yml @@ -0,0 +1 @@ +buy_me_a_coffee: tooast \ No newline at end of file diff --git a/README.md b/README.md index cb4ec4a..1f5f81c 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,27 @@ # toast's toast -it's simple: make the best toast and dont let it burn +It's simple: make the best toast and don't let it burn + +## Tech Stacks +- HTML5 +- CSS3 +- JavaScript +- Three.js + +## Assets + +- [Favicon](favicon.ico) by me +- [3D Toaster Model](model.glb) by me + +## Setup + +To run this project locally: + +1. Clone the repository +```bash +git clone https://github.com/lightly-toasted/lightly-toasted.github.io +``` + +2. Open `index.html` in your browser. ## TODO -- [ ] maybe add sounds? -- [ ] get toast.is-a.dev \ No newline at end of file +- [ ] Add sounds \ No newline at end of file diff --git a/index.html b/index.html index 33a2239..5126475 100644 --- a/index.html +++ b/index.html @@ -66,7 +66,12 @@ font-size: 128px; } } - @media (min-width: 1024px) { + @media (min-width: 1280px) { + #message { + font-size: 192px; + } + } + @media (min-width: 1440px) { #message { font-size: 256px; } diff --git a/main.js b/main.js index f7b2a7f..4d3ba15 100644 --- a/main.js +++ b/main.js @@ -30,6 +30,18 @@ window.addEventListener('resize', () => { renderer.setSize( window.innerWidth, window.innerHeight ); }); +let tiers = [ + { name: 'Eww!', color: 'darkgray', threshold: 200 }, + { name: 'Yucky', color: 'gray', threshold: 150 }, + { name: 'Meh.', color: 'darkseagreen', threshold: 100 }, + { name: 'Hmm...', color: 'darkolivegreen', threshold: 50 }, + { name: 'Good', color: 'limegreen', threshold: 25 }, + { name: 'Tasty!', color: 'greenyellow', threshold: 10 }, + { name: 'Awesome', color: 'crimson', threshold: 2 }, + { name: 'LEGENDARY', color: 'goldenrod', threshold: 1 }, + { name: 'PERFECT', color: 'gold', threshold: 0 } +] + document.body.appendChild( renderer.domElement ); renderer.setClearColor(0x000000, 0) @@ -42,9 +54,8 @@ camera.position.z = 5; var loader = new GLTFLoader(); -loader.load('model.glb', function ( gltf ) -{ - const toaster = gltf.scene; // sword 3D object is loaded +loader.load('model.glb', gltf => { + const toaster = gltf.scene; toaster.scale.set(3, 3, 3); toaster.position.y = -.5; toaster.rotation.set(0.4, 37, 0) @@ -65,50 +76,13 @@ loader.load('model.glb', function ( gltf ) let burntAt = 0 let holdInterval; - const tiers = [ - { - name: 'Eww!', - color: 'darkgray', - threshold: 200, - }, - { - name: 'Yucky', - color: 'gray', - threshold: 150, - }, - { - name: 'Meh.', - color: 'darkseagreen', - threshold: 100, - }, - { - name: 'Hmm...', - color: 'darkolivegreen', - threshold: 50, - }, - { - name: 'Tasty!', - color: 'lightblue', - threshold: 40, - }, - { - name: 'LEGENDARY', - color: 'goldenrod', - threshold: 2, - }, - { - name: 'PERFECT!', - color: 'gold', - threshold: 0, - } - ] - function onStart() { burntTexture.visible = false message.style.color = 'white' time = 0 burntAt = Math.round(Math.random() * 5) + 5 + clearInterval(holdInterval) holdInterval = setInterval(() => { time++ message.textContent = `${time / 100} / ${burntAt}` @@ -141,8 +115,10 @@ loader.load('model.glb', function ( gltf ) const clock = new THREE.Clock(); function animate() { requestAnimationFrame(animate); + const delta = clock.getDelta(); mixer.update(delta) + renderer.render(scene, camera); }