-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
109 lines (100 loc) · 3.75 KB
/
index.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
103
104
105
106
107
108
109
const { Plugin } = require('powercord/entities')
module.exports = class AudioViz extends Plugin {
startPlugin () {
setTimeout(() => {
this.intervals = []
this.startVisualizer()
this.loadStylesheet('style.scss')
}, 0)
}
reload () {
this.stopVisualizer()
this.startVisualizer()
}
pluginWillUnload() {
this.stopVisualizer()
}
stopVisualizer () {
clearInterval(this.interval)
cancelAnimationFrame(this.frame)
const filter = document.getElementById('vp-audioviz-goo');
const viz = document.getElementById('vp-audioviz-visualizer');
filter.parentNode.removeChild(filter);
viz.parentNode.removeChild(viz);
}
startVisualizer () {
const { desktopCapturer } = require('electron')
desktopCapturer.getSources({ types: ['window', 'screen'] }).then(async () => {
const stream = await navigator.mediaDevices.getUserMedia({
audio: {
mandatory: {
chromeMediaSource: 'desktop'
}
},
video: {
mandatory: {
chromeMediaSource: 'desktop'
}
}
})
const audioCtx = new AudioContext()
const audio = audioCtx.createMediaStreamSource(stream)
const easeInOutCubic = t => t<.5 ? 4*t*t*t : (t-1)*(2*t-2)*(2*t-2)+1
const barCount = 20
const analyser = audioCtx.createAnalyser()
audio.connect(analyser)
analyser.fftSize = 1024
let accountContainer
let visualizer = document.createElement('div')
visualizer.classList.add('vp-audioviz-visualizer')
visualizer.id = 'vp-audioviz-visualizer'
for (let i = 0; i < barCount; i++) {
let bar = document.createElement('div')
bar.classList.add('vp-audioviz-bar')
bar.style.height = "1px";
visualizer.appendChild(bar)
}
const visualizerGoo = document.createElementNS('http://www.w3.org/2000/svg', 'svg')
visualizerGoo.setAttributeNS('http://www.w3.org/2000/xmlns/', 'xmlns', 'http://www.w3.org/2000/svg')
visualizerGoo.setAttributeNS('http://www.w3.org/2000/version/', 'version', '1.1')
visualizerGoo.classList.add('vp-audioviz-goo')
visualizerGoo.id = 'vp-audioviz-goo'
visualizerGoo.innerHTML = `
<filter id="vpVisualizerGoo">
<feGaussianBlur in="SourceGraphic" stdDeviation="8" result="blur"></feGaussianBlur>
<feColorMatrix in="blur" mode="matrix" values="1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 19 -9" result="vpVisualizerGoo"></feColorMatrix>
<feComposite in="SourceGraphic" in2="vpVisualizerGoo" operator="atop"></feComposite>
</filter>
`
const findElement = setInterval(() => {
if (accountContainer) {
visualizer = document.querySelector('.vp-audioviz-visualizer')
} else {
accountContainer = document.querySelector('.panels-j1Uci_ > .container-3baos1:last-child')
if (accountContainer) {
accountContainer.prepend(visualizer)
accountContainer.prepend(visualizerGoo)
}
}
}, 1000)
const func = () => {
if (!visualizer) return
const bufferLength = analyser.frequencyBinCount
const dataArray = new Uint8Array(bufferLength)
analyser.getByteFrequencyData(dataArray)
for (let i = 0; i < barCount; i++) {
const y = dataArray[i * 2]
const height = easeInOutCubic(Math.min(1, y / 255)) * 100
const bar = visualizer.children[i]
bar.style.transform = `scale(1, ${height})`;
}
requestAnimationFrame(func)
}
const style = requestAnimationFrame(func)
this.interval = findElement;
this.frame = style
}).catch(error => {
console.error('An error occurred getting media sources', error)
})
}
}