-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcustomized.js
103 lines (89 loc) · 2.62 KB
/
customized.js
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import {AudioVisualizer} from "../audiovisualizer.js";
/*
Generates visualizations using configuration examples.
*/
var av;
const muteButton = document.querySelector("#mute");
const unmuteButton = document.querySelector("#unmute");
const nextButton = document.querySelector("#next");
const goButton = document.querySelector("#go");
var i = 0;
var sources = [
"./frequencies.mp3",
"./alternating.mp3",
"./music.mp3"
];
goButton.addEventListener("click", () => {
var av = new AudioVisualizer({ // no src, uses the microphone
src: sources[i],
muted: false,
stopped: true,
analyser: {
fftSize: 4096
},
v: [
{
type: "waveform",
container: ".wave1",
lineWidth: 1,
background: "goldenrod",
strokeStyle: "black"
},
{
type: "waveform",
container: ".wave2",
lineWidth: 10,
background: "rgb(80,0,80)",
strokeStyle: "#E11EB2"
},
{
type: "waveform",
container: ".wave3",
lineWidth: 3,
background: "#000",
strokeStyle: "#ccc"
},
{
type: "spectrum",
container: ".spectrum1",
background: "#000",
rowsPerSec: 150,
colortheme: [ "rgb(0,0,0)", "rgb(255,255,255)"]
},
{
type: "spectrum",
container: ".spectrum2",
background: "#f00",
rowsPerSec: 90,
colortheme: [ "#f00", "#ff0", "#0f0"]
},
{
type: "spectrum",
container: ".spectrum3",
background: "#ccc",
rowsPerSec: 30,
colortheme: [ "#ccc", "#000", "#ffaa10", "#f00", "#00f", "#0ff"]
}
]
});
goButton.style.display = "none";
muteButton.style.display = "block";
nextButton.style.display = "block";
muteButton.addEventListener("click", () => {
av.mute();
muteButton.style.display = "none";
unmuteButton.style.display = "block";
});
unmuteButton.addEventListener("click", () => {
av.unmute();
muteButton.style.display = "block";
unmuteButton.style.display = "none";
});
nextButton.addEventListener("click", () => {
i++;
if(i > sources.length - 1) {
i = 0;
}
av.setSource(sources[i]);
});
});