Video Audio Compressor

视频音量压缩器,防止耳聋,避免响度战争,懒得写UI了,直接改脚本文件里面的数值吧。

  1. // ==UserScript==
  2. // @name Video Audio Compressor
  3. // @namespace https://github.com/tjxwork
  4. // @version 0.0.1
  5. // @description 视频音量压缩器,防止耳聋,避免响度战争,懒得写UI了,直接改脚本文件里面的数值吧。
  6. // @author tjxwork
  7. // @license CC-BY-NC-SA
  8. // @icon 
  9. // @match https://*.bilibili.com/*
  10. // @match https://*.youtube.com/*
  11. // @grant GM_registerMenuCommand
  12. // @grant GM_setValue
  13. // @grant GM_getValue
  14. // ==/UserScript==
  15.  
  16. "use strict";
  17.  
  18. function AudioCompressor() {
  19. // 音频元素
  20. const audioElement = document.querySelector("video");
  21.  
  22. // 设置音频上下文
  23. let audioContext = new AudioContext();
  24.  
  25. // 创建 音频来源节点 MediaElementAudioSourceNode,将 音频元素 输入其中
  26. const source = new MediaElementAudioSourceNode(audioContext, {
  27. mediaElement: audioElement,
  28. });
  29.  
  30. // 创建压缩器节点
  31. const compressor = new DynamicsCompressorNode(audioContext, {
  32.  
  33. //----------修改数值处----------
  34.  
  35. // 阈值(dB)
  36. threshold: -24,
  37. // 拐点过渡(dB)
  38. knee: 5,
  39. // 压缩比例
  40. ratio: 18,
  41. // 启动时间(S)
  42. attack: 0,
  43. // 释放时间(S)
  44. release: 0.25,
  45.  
  46. //----------修改数值处----------
  47. });
  48.  
  49. // 音频来源节点 -x-> 音频目标
  50. //source.disconnect(audioContext.destination);
  51. // 音频来源节点 -> 压缩器节点 -> 音频目标
  52. source.connect(compressor);
  53. compressor.connect(audioContext.destination);
  54. }
  55.  
  56. // 页面加载完成后运行脚本
  57. window.addEventListener("load", AudioCompressor);