Video Audio Compressor
// ==UserScript==
// @name Video Audio Compressor
// @namespace https://github.com/tjxwork
// @version 0.0.1
// @description 视频音量压缩器,防止耳聋,避免响度战争,懒得写UI了,直接改脚本文件里面的数值吧。
// @author tjxwork
// @license CC-BY-NC-SA
// @icon 
// @match https://*.bilibili.com/*
// @match https://*.youtube.com/*
// @grant GM_registerMenuCommand
// @grant GM_setValue
// @grant GM_getValue
// ==/UserScript==
"use strict";
function AudioCompressor() {
// 音频元素
const audioElement = document.querySelector("video");
// 设置音频上下文
let audioContext = new AudioContext();
// 创建 音频来源节点 MediaElementAudioSourceNode,将 音频元素 输入其中
const source = new MediaElementAudioSourceNode(audioContext, {
mediaElement: audioElement,
});
// 创建压缩器节点
const compressor = new DynamicsCompressorNode(audioContext, {
//----------修改数值处----------
// 阈值(dB)
threshold: -24,
// 拐点过渡(dB)
knee: 5,
// 压缩比例
ratio: 18,
// 启动时间(S)
attack: 0,
// 释放时间(S)
release: 0.25,
//----------修改数值处----------
});
// 音频来源节点 -x-> 音频目标
//source.disconnect(audioContext.destination);
// 音频来源节点 -> 压缩器节点 -> 音频目标
source.connect(compressor);
compressor.connect(audioContext.destination);
}
// 页面加载完成后运行脚本
window.addEventListener("load", AudioCompressor);