|
1 | 1 | // thème clair/sombre |
2 | 2 | document.getElementById('theme-toggle').addEventListener('click', () => { |
3 | | - document.body.classList.toggle('light'); |
| 3 | +document.body.classList.toggle('light'); |
4 | 4 | }); |
5 | 5 |
|
6 | | -// animation bg particules |
7 | | -const canvas = document.getElementById('background'); |
8 | | -const ctx = canvas.getContext('2d'); |
9 | | -canvas.width = window.innerWidth; |
10 | | -canvas.height = window.innerHeight; |
11 | | - |
12 | | -let particles = []; |
13 | | -for (let i = 0; i < 100; i++) { |
14 | | - particles.push({ |
15 | | - x: Math.random() * canvas.width, |
16 | | - y: Math.random() * canvas.height, |
17 | | - r: Math.random() * 2 + 1, |
18 | | - dx: (Math.random() - 0.5) * 0.5, |
19 | | - dy: (Math.random() - 0.5) * 0.5 |
20 | | - }); |
21 | | -} |
22 | | - |
23 | | -function animate() { |
24 | | - ctx.clearRect(0, 0, canvas.width, canvas.height); |
25 | | - particles.forEach(p => { |
26 | | - ctx.beginPath(); |
27 | | - ctx.arc(p.x, p.y, p.r, 0, Math.PI * 2); |
28 | | - ctx.fillStyle = '#00f7ff'; |
29 | | - ctx.fill(); |
30 | | - p.x += p.dx; |
31 | | - p.y += p.dy; |
32 | | - |
33 | | - if (p.x < 0 || p.x > canvas.width) p.dx *= -1; |
34 | | - if (p.y < 0 || p.y > canvas.height) p.dy *= -1; |
35 | | - }); |
36 | | - requestAnimationFrame(animate); |
37 | | -} |
38 | | -animate(); |
39 | | - |
40 | 6 | // music bg saloon jazz vintage // |
41 | | -// |
42 | | - const audioBG = document.getElementById("jazz-bg"); |
43 | | - const btnBG = document.getElementById("playPauseBtn"); |
44 | | - let musicStarted = false; |
45 | | - document.getElementById("jazz-bg").volume = 0.1; |
46 | 7 |
|
47 | | - // Quand l’utilisateur clique quelque part sur la page |
48 | | - document.body.addEventListener("click", () => { |
49 | | - if (!musicStarted) { |
50 | | - audioBG.play(); |
51 | | - musicStarted = true; |
52 | | - btnBG.style.display = "block"; // montrer le bouton |
53 | | - btnBG.textContent = "⏸"; // mettre pause comme premier état |
54 | | - } |
55 | | - }); |
| 8 | +const audioBG = document.getElementById("jazz-bg"); |
| 9 | +const btnBG = document.getElementById("playPauseBtn"); |
| 10 | +let musicStarted = false; |
| 11 | +document.getElementById("jazz-bg").volume = 0.1; |
| 12 | + |
| 13 | +// Quand l’utilisateur clique quelque part sur la page |
| 14 | +document.body.addEventListener("click", () => { |
| 15 | + if (!musicStarted) { |
| 16 | + audioBG.play(); |
| 17 | + musicStarted = true; |
| 18 | + btnBG.style.display = "block"; // montrer le bouton |
| 19 | + btnBG.textContent = "⏸"; // mettre pause comme premier état |
| 20 | + } |
| 21 | +}); |
56 | 22 |
|
57 | | - // Gérer le Play/Pause |
58 | | - btnBG.addEventListener("click", (e) => { |
59 | | - e.stopPropagation();// éviter de relancer l’audio avec le clic body |
60 | | - if (audioBG.paused) { |
61 | | - audioBG.play(); |
62 | | - btnBG.textContent = "⏸ "; |
| 23 | +// Gérer le Play/Pause |
| 24 | +btnBG.addEventListener("click", (e) => { |
| 25 | + e.stopPropagation();// éviter de relancer l’audio avec le clic body |
| 26 | + if (audioBG.paused) { |
| 27 | + audioBG.play(); |
| 28 | + btnBG.textContent = "⏸ "; |
63 | 29 | } else { |
64 | | - audioBG.pause(); |
65 | | - btnBG.textContent = "▶"; |
| 30 | + audioBG.pause(); |
| 31 | + btnBG.textContent = "▶"; |
66 | 32 | } |
67 | 33 | }); |
68 | 34 |
|
69 | 35 | // Barre d’espace pour Play/Pause |
70 | 36 | document.addEventListener("keydown", (e) => { |
71 | | - if (e.code === "Space") { |
72 | | - e.preventDefault(); // évite le scroll |
73 | | - if (audioBG.paused) { |
74 | | - audioBG.play(); |
75 | | - btnBG.textContent = "⏸ "; |
76 | | - } else { |
77 | | - audioBG.pause(); |
78 | | - btnBG.textContent = "▶"; |
79 | | - } |
80 | | - } |
| 37 | + if (e.code === "Space") { |
| 38 | + e.preventDefault(); // évite le scroll |
| 39 | + if (audioBG.paused) { |
| 40 | + audioBG.play(); |
| 41 | + btnBG.textContent = "⏸ "; |
| 42 | + } else { |
| 43 | + audioBG.pause(); |
| 44 | + btnBG.textContent = "▶"; |
| 45 | + } |
| 46 | + } |
81 | 47 | }); |
82 | 48 |
|
83 | 49 | //Bloquer clic droit |
84 | 50 | document.addEventListener("contextmenu", (e) => { |
85 | | - e.preventDefault(); |
| 51 | + e.preventDefault(); |
86 | 52 | }); |
87 | 53 |
|
88 | 54 | // Bloquer copier, coller, couper |
89 | 55 | ["copy", "paste", "cut"].forEach(evt => { |
90 | | - document.addEventListener(evt, (e) => { |
91 | | - e.preventDefault(); |
| 56 | + document.addEventListener(evt, (e) => { |
| 57 | + e.preventDefault(); |
92 | 58 | }); |
93 | 59 | }); |
94 | 60 |
|
95 | 61 | // Bloquer raccourcis clavier (Ctrl+C, Ctrl+V, Ctrl+X) |
96 | 62 | document.addEventListener("keydown", (e) => { |
97 | | - if ((e.ctrlKey || e.metaKey) && ["c", "v", "x", "u"].includes(e.key.toLowerCase())) { |
98 | | - e.preventDefault(); |
99 | | - } |
| 63 | + if ((e.ctrlKey || e.metaKey) && ["c", "v", "x", "u"].includes(e.key.toLowerCase())) { |
| 64 | + e.preventDefault(); |
| 65 | + } |
100 | 66 | }); |
101 | 67 |
|
0 commit comments