feat: audio filters support

This commit is contained in:
Snowflake107 2021-06-19 23:55:38 +05:45
parent 8902d06057
commit d38aded085
2 changed files with 35 additions and 4 deletions

View file

@ -2,11 +2,12 @@ import { Collection, Guild, StageChannel, VoiceChannel } from "discord.js";
import { Player } from "../Player"; import { Player } from "../Player";
import { StreamDispatcher } from "../VoiceInterface/BasicStreamDispatcher"; import { StreamDispatcher } from "../VoiceInterface/BasicStreamDispatcher";
import Track from "./Track"; import Track from "./Track";
import { PlayerOptions, PlayOptions, QueueRepeatMode } from "../types/types"; import { PlayerOptions, PlayOptions, QueueFilters, QueueRepeatMode } from "../types/types";
import ytdl from "discord-ytdl-core"; import ytdl from "discord-ytdl-core";
import { AudioResource, StreamType } from "@discordjs/voice"; import { AudioResource, StreamType } from "@discordjs/voice";
import { Util } from "../utils/Util"; import { Util } from "../utils/Util";
import YouTube from "youtube-sr"; import YouTube from "youtube-sr";
import AudioFilters from "../utils/AudioFilters";
class Queue<T = unknown> { class Queue<T = unknown> {
public readonly guild: Guild; public readonly guild: Guild;
@ -18,7 +19,9 @@ class Queue<T = unknown> {
public playing = false; public playing = false;
public metadata?: T = null; public metadata?: T = null;
public repeatMode: QueueRepeatMode = 0; public repeatMode: QueueRepeatMode = 0;
public _streamTime: number = 0;
public _cooldownsTimeout = new Collection<string, NodeJS.Timeout>(); public _cooldownsTimeout = new Collection<string, NodeJS.Timeout>();
private _activeFilters: any = {};
/** /**
* Queue constructor * Queue constructor
@ -200,6 +203,30 @@ class Queue<T = unknown> {
this.setVolume(amount); this.setVolume(amount);
} }
get streamTime() {
if (!this.connection) return 0;
return this._streamTime + this.connection.streamTime;
}
async setFilters(filters: QueueFilters) {
if (!Object.keys(filters).length) return;
const _filters: any[] = [];
for (const filter in filters) {
if (filters[filter as keyof QueueFilters] === true) _filters.push(filter);
}
const newFilters = AudioFilters.create(_filters);
return await this.play(this.current, {
immediate: true,
filtersUpdate: true,
seek: this.streamTime,
encoderArgs: ["-af", newFilters]
});
}
/** /**
* Plays previous track * Plays previous track
* @returns {Promise<void>} * @returns {Promise<void>}
@ -216,7 +243,7 @@ class Queue<T = unknown> {
async play(src?: Track, options: PlayOptions = {}): Promise<void> { async play(src?: Track, options: PlayOptions = {}): Promise<void> {
if (!this.connection || !this.connection.voiceConnection) throw new Error("Voice connection is not available, use <Queue>.connect()!"); if (!this.connection || !this.connection.voiceConnection) throw new Error("Voice connection is not available, use <Queue>.connect()!");
if (src && (this.playing || this.tracks.length) && !options.immediate) return this.addTrack(src); if (src && (this.playing || this.tracks.length) && !options.immediate) return this.addTrack(src);
const track = options.filtersUpdate && !options.immediate ? this.current : src ?? this.tracks.shift(); const track = options.filtersUpdate && !options.immediate ? src || this.current : src ?? this.tracks.shift();
if (!track) return; if (!track) return;
if (!options.filtersUpdate) { if (!options.filtersUpdate) {
@ -261,8 +288,10 @@ class Queue<T = unknown> {
data: track data: track
}); });
if (options.seek) this._streamTime = options.seek;
const dispatcher = await this.connection.playStream(resource); const dispatcher = await this.connection.playStream(resource);
dispatcher.setVolume(this.options.initialVolume); dispatcher.setVolume(options.encoderArgs && options.encoderArgs[1]?.includes("bass=g") ? this.options.initialVolume + 35 : this.options.initialVolume);
// need to use these events here // need to use these events here
dispatcher.once("start", () => { dispatcher.once("start", () => {
@ -274,6 +303,8 @@ class Queue<T = unknown> {
this.playing = false; this.playing = false;
if (options.filtersUpdate) return; if (options.filtersUpdate) return;
this._streamTime = 0;
if (!this.tracks.length && this.repeatMode === QueueRepeatMode.OFF) { if (!this.tracks.length && this.repeatMode === QueueRepeatMode.OFF) {
if (this.options.leaveOnEnd) this.destroy(); if (this.options.leaveOnEnd) this.destroy();
this.player.emit("queueEnd", this); this.player.emit("queueEnd", this);

View file

@ -160,7 +160,7 @@ class BasicStreamDispatcher extends EventEmitter<VoiceEvents> {
get streamTime() { get streamTime() {
if (!this.audioResource) return 0; if (!this.audioResource) return 0;
return this.audioResource.playbackDuration; return Math.floor(this.audioResource.playbackDuration / 1000);
} }
get paused() { get paused() {