commit 01dcf79ef07c66239a88457941ed4886b4c1ffeb
Author: root <root@hub.scroll.pub> Date: 2024-12-28 16:49:52 +0000 Subject: Initial commit diff --git a/body.html b/body.html new file mode 100644 index 0000000..0402e4d --- /dev/null +++ b/body.html @@ -0,0 +1,18 @@ +<main> + <div class="container"> + <canvas id="visualizer"></canvas> + <div class="controls"> + <button id="playBtn" aria-label="Play/Pause visualization"> + <span class="play-icon">▶</span> + </button> + <select id="visualStyle" aria-label="Select visualization style"> + <option value="bars">Bars</option> + <option value="waves">Waves</option> + <option value="spectrum">Spectrum</option> + </select> + </div> + </div> +</main> +<footer> + <p>A tribute to the classic Windows Media Player visualizations</p> +</footer> diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..68ff171 --- /dev/null +++ b/index.scroll @@ -0,0 +1,8 @@ +buildHtml +baseUrl https://vizplayer.scroll.pub +metaTags +editButton /edit.html +title Classic Media Visualizer +style.css +body.html +script.js diff --git a/prompt.json b/prompt.json new file mode 100644 index 0000000..2b86a56 --- /dev/null +++ b/prompt.json @@ -0,0 +1,20 @@ +{ + "id": "msg_01D4VmxJLYd4V3riTzWxDyQb", + "type": "message", + "role": "assistant", + "model": "claude-3-5-sonnet-20241022", + "content": [ + { + "type": "text", + "text": "Let me create a Windows Media Player visualizer simulation website.\n\n---domain---\nvizplayer.scroll.pub\n\n---index.scroll---\nbuildHtml\nbaseUrl https://vizplayer.scroll.pub\nmetaTags\neditButton /edit.html\ntitle Classic Media Visualizer\nstyle.css\nbody.html\nscript.js\n\n---body.html---\n<main>\n <div class=\"container\">\n <canvas id=\"visualizer\"></canvas>\n <div class=\"controls\">\n <button id=\"playBtn\" aria-label=\"Play/Pause visualization\">\n <span class=\"play-icon\">▶</span>\n </button>\n <select id=\"visualStyle\" aria-label=\"Select visualization style\">\n <option value=\"bars\">Bars</option>\n <option value=\"waves\">Waves</option>\n <option value=\"spectrum\">Spectrum</option>\n </select>\n </div>\n </div>\n</main>\n<footer>\n <p>A tribute to the classic Windows Media Player visualizations</p>\n</footer>\n\n---style.css---\n:root {\n --primary-color: #2c3e50;\n --accent-color: #3498db;\n --bg-color: #000;\n --text-color: #ecf0f1;\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n}\n\nbody {\n background: var(--bg-color);\n color: var(--text-color);\n font-family: system-ui, -apple-system, sans-serif;\n min-height: 100vh;\n display: flex;\n flex-direction: column;\n}\n\n.container {\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 2rem;\n}\n\ncanvas {\n background: linear-gradient(45deg, #000510, #001040);\n border-radius: 8px;\n box-shadow: 0 0 30px rgba(52, 152, 219, 0.2);\n max-width: 100%;\n aspect-ratio: 16/9;\n width: 800px;\n}\n\n.controls {\n margin-top: 2rem;\n display: flex;\n gap: 1rem;\n align-items: center;\n}\n\nbutton, select {\n background: var(--primary-color);\n color: var(--text-color);\n border: none;\n padding: 0.8rem 1.5rem;\n border-radius: 4px;\n cursor: pointer;\n transition: all 0.3s ease;\n}\n\nbutton:hover, select:hover {\n background: var(--accent-color);\n transform: translateY(-2px);\n}\n\nselect {\n outline: none;\n}\n\nfooter {\n text-align: center;\n padding: 1rem;\n background: rgba(44, 62, 80, 0.3);\n backdrop-filter: blur(10px);\n}\n\n@media (max-width: 768px) {\n .container {\n padding: 1rem;\n }\n \n canvas {\n width: 100%;\n }\n}\n\n---script.js---\nclass Visualizer {\n constructor() {\n this.canvas = document.getElementById('visualizer');\n this.ctx = this.canvas.getContext('2d');\n this.isPlaying = false;\n this.currentStyle = 'bars';\n this.bars = 60;\n this.setupCanvas();\n this.setupEventListeners();\n this.animate();\n }\n\n setupCanvas() {\n this.canvas.width = 800;\n this.canvas.height = 450;\n }\n\n setupEventListeners() {\n window.addEventListener('resize', () => this.setupCanvas());\n document.getElementById('playBtn').addEventListener('click', () => {\n this.isPlaying = !this.isPlaying;\n document.querySelector('.play-icon').textContent = this.isPlaying ? '⏸' : '▶';\n });\n document.getElementById('visualStyle').addEventListener('change', (e) => {\n this.currentStyle = e.target.value;\n });\n }\n\n drawBars() {\n const width = this.canvas.width / this.bars;\n for (let i = 0; i < this.bars; i++) {\n const height = this.isPlaying ? Math.random() * this.canvas.height * 0.8 : 5;\n const hue = (i / this.bars) * 360;\n this.ctx.fillStyle = `hsla(${hue}, 80%, 50%, 0.8)`;\n this.ctx.fillRect(\n i * width,\n this.canvas.height - height,\n width - 1,\n height\n );\n }\n }\n\n drawWaves() {\n this.ctx.beginPath();\n this.ctx.moveTo(0, this.canvas.height / 2);\n for (let i = 0; i < this.canvas.width; i++) {\n const amplitude = this.isPlaying ? Math.random() * 100 : 20;\n const y = this.canvas.height/2 + Math.sin(i * 0.02 + Date.now() * 0.002) * amplitude;\n this.ctx.lineTo(i, y);\n }\n this.ctx.strokeStyle = `hsl(${Date.now() * 0.05 % 360}, 80%, 50%)`;\n this.ctx.lineWidth = 2;\n this.ctx.stroke();\n }\n\n drawSpectrum() {\n const centerX = this.canvas.width / 2;\n const centerY = this.canvas.height / 2;\n const radius = Math.min(centerX, centerY) * 0.8;\n const particles = 200;\n \n for (let i = 0; i < particles; i++) {\n const angle = (i / particles) * Math.PI * 2;\n const amplitude = this.isPlaying ? 0.3 + Math.random() * 0.7 : 0.5;\n const x = centerX + Math.cos(angle) * radius * amplitude;\n const y = centerY + Math.sin(angle) * radius * amplitude;\n const hue = (i / particles) * 360;\n \n this.ctx.beginPath();\n this.ctx.arc(x, y, 2, 0, Math.PI * 2);\n this.ctx.fillStyle = `hsla(${hue}, 80%, 50%, 0.8)`;\n this.ctx.fill();\n }\n }\n\n animate() {\n this.ctx.fillStyle = 'rgba(0, 0, 0, 0.1)';\n this.ctx.fillRect(0, 0, this.canvas.width, this.canvas.height);\n\n switch(this.currentStyle) {\n case 'bars':\n this.drawBars();\n break;\n case 'waves':\n this.drawWaves();\n break;\n case 'spectrum':\n this.drawSpectrum();\n break;\n }\n\n requestAnimationFrame(() => this.animate());\n }\n}\n\ndocument.addEventListener('DOMContentLoaded', () => {\n new Visualizer();\n});\n\n---end---\n\nThis implementation creates a beautiful, interactive visualization that mimics the classic Windows Media Player visualizer with three different styles: bars, waves, and a spectrum view. It features:\n\n1. Smooth animations using Canvas\n2. Multiple visualization styles\n3. Play/pause functionality\n4. Responsive design\n5. Beautiful color transitions\n6. Clean, modern UI\n7. Accessibility features\n8. Smooth performance\n\nThe visualizations are created using mathematical functions and random values to simulate audio reactivity. The colors are generated using HSL color space for smooth transitions and beautiful gradients." + } + ], + "stop_reason": "end_turn", + "stop_sequence": null, + "usage": { + "input_tokens": 289, + "cache_creation_input_tokens": 0, + "cache_read_input_tokens": 0, + "output_tokens": 1990 + } +} \ No newline at end of file diff --git a/readme.scroll b/readme.scroll new file mode 100644 index 0000000..a6c285d --- /dev/null +++ b/readme.scroll @@ -0,0 +1,2 @@ +# vizplayer.scroll.pub +Website generated by Claude from prompt: A fax simile of the Windows Media Player sound visualizer. Pay attention to the graphics \ No newline at end of file diff --git a/script.js b/script.js new file mode 100644 index 0000000..0aefb3d --- /dev/null +++ b/script.js @@ -0,0 +1,99 @@ +class Visualizer { + constructor() { + this.canvas = document.getElementById('visualizer'); + this.ctx = this.canvas.getContext('2d'); + this.isPlaying = false; + this.currentStyle = 'bars'; + this.bars = 60; + this.setupCanvas(); + this.setupEventListeners(); + this.animate(); + } + + setupCanvas() { + this.canvas.width = 800; + this.canvas.height = 450; + } + + setupEventListeners() { + window.addEventListener('resize', () => this.setupCanvas()); + document.getElementById('playBtn').addEventListener('click', () => { + this.isPlaying = !this.isPlaying; + document.querySelector('.play-icon').textContent = this.isPlaying ? '⏸' : '▶'; + }); + document.getElementById('visualStyle').addEventListener('change', (e) => { + this.currentStyle = e.target.value; + }); + } + + drawBars() { + const width = this.canvas.width / this.bars; + for (let i = 0; i < this.bars; i++) { + const height = this.isPlaying ? Math.random() * this.canvas.height * 0.8 : 5; + const hue = (i / this.bars) * 360; + this.ctx.fillStyle = `hsla(${hue}, 80%, 50%, 0.8)`; + this.ctx.fillRect( + i * width, + this.canvas.height - height, + width - 1, + height + ); + } + } + + drawWaves() { + this.ctx.beginPath(); + this.ctx.moveTo(0, this.canvas.height / 2); + for (let i = 0; i < this.canvas.width; i++) { + const amplitude = this.isPlaying ? Math.random() * 100 : 20; + const y = this.canvas.height/2 + Math.sin(i * 0.02 + Date.now() * 0.002) * amplitude; + this.ctx.lineTo(i, y); + } + this.ctx.strokeStyle = `hsl(${Date.now() * 0.05 % 360}, 80%, 50%)`; + this.ctx.lineWidth = 2; + this.ctx.stroke(); + } + + drawSpectrum() { + const centerX = this.canvas.width / 2; + const centerY = this.canvas.height / 2; + const radius = Math.min(centerX, centerY) * 0.8; + const particles = 200; + + for (let i = 0; i < particles; i++) { + const angle = (i / particles) * Math.PI * 2; + const amplitude = this.isPlaying ? 0.3 + Math.random() * 0.7 : 0.5; + const x = centerX + Math.cos(angle) * radius * amplitude; + const y = centerY + Math.sin(angle) * radius * amplitude; + const hue = (i / particles) * 360; + + this.ctx.beginPath(); + this.ctx.arc(x, y, 2, 0, Math.PI * 2); + this.ctx.fillStyle = `hsla(${hue}, 80%, 50%, 0.8)`; + this.ctx.fill(); + } + } + + animate() { + this.ctx.fillStyle = 'rgba(0, 0, 0, 0.1)'; + this.ctx.fillRect(0, 0, this.canvas.width, this.canvas.height); + + switch(this.currentStyle) { + case 'bars': + this.drawBars(); + break; + case 'waves': + this.drawWaves(); + break; + case 'spectrum': + this.drawSpectrum(); + break; + } + + requestAnimationFrame(() => this.animate()); + } +} + +document.addEventListener('DOMContentLoaded', () => { + new Visualizer(); +}); diff --git a/style.css b/style.css new file mode 100644 index 0000000..83e42b5 --- /dev/null +++ b/style.css @@ -0,0 +1,82 @@ +:root { + --primary-color: #2c3e50; + --accent-color: #3498db; + --bg-color: #000; + --text-color: #ecf0f1; +} + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body { + background: var(--bg-color); + color: var(--text-color); + font-family: system-ui, -apple-system, sans-serif; + min-height: 100vh; + display: flex; + flex-direction: column; +} + +.container { + flex: 1; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + padding: 2rem; +} + +canvas { + background: linear-gradient(45deg, #000510, #001040); + border-radius: 8px; + box-shadow: 0 0 30px rgba(52, 152, 219, 0.2); + max-width: 100%; + aspect-ratio: 16/9; + width: 800px; +} + +.controls { + margin-top: 2rem; + display: flex; + gap: 1rem; + align-items: center; +} + +button, select { + background: var(--primary-color); + color: var(--text-color); + border: none; + padding: 0.8rem 1.5rem; + border-radius: 4px; + cursor: pointer; + transition: all 0.3s ease; +} + +button:hover, select:hover { + background: var(--accent-color); + transform: translateY(-2px); +} + +select { + outline: none; +} + +footer { + text-align: center; + padding: 1rem; + background: rgba(44, 62, 80, 0.3); + backdrop-filter: blur(10px); +} + +@media (max-width: 768px) { + .container { + padding: 1rem; + } + + canvas { + width: 100%; + } +}