1
0
mirror of https://github.com/KubaPro010/fm-dx-webserver.git synced 2026-02-27 06:23:53 +01:00

hotfix for ffmpeg

This commit is contained in:
NoobishSVK
2024-03-22 22:15:27 +01:00
parent 39f0db35c2
commit 72953a2529
2 changed files with 12 additions and 28 deletions

View File

@@ -260,14 +260,14 @@ function handleData(ws, receivedData) {
for (const receivedLine of receivedLines) { for (const receivedLine of receivedLines) {
switch (true) { switch (true) {
case receivedLine.startsWith('P'): case receivedLine.startsWith('P'): // PI Code
modifiedData = receivedLine.slice(1); modifiedData = receivedLine.slice(1);
legacyRdsPiBuffer = modifiedData; legacyRdsPiBuffer = modifiedData;
if (dataToSend.pi.length >= modifiedData.length || dataToSend.pi == '?') { if (dataToSend.pi.length >= modifiedData.length || dataToSend.pi == '?') {
dataToSend.pi = modifiedData; dataToSend.pi = modifiedData;
} }
break; break;
case receivedLine.startsWith('T'): case receivedLine.startsWith('T'): // Frequency
modifiedData = receivedLine.substring(1).split(",")[0]; modifiedData = receivedLine.substring(1).split(",")[0];
if((modifiedData / 1000).toFixed(3) == dataToSend.freq) { if((modifiedData / 1000).toFixed(3) == dataToSend.freq) {
@@ -285,11 +285,11 @@ function handleData(ws, receivedData) {
dataToSend.pi = '?'; dataToSend.pi = '?';
} }
break; break;
case receivedLine.startsWith('Z'): case receivedLine.startsWith('Z'): // Antenna
dataToSend.ant = receivedLine.substring(1); dataToSend.ant = receivedLine.substring(1);
initialData.ant = receivedLine.substring(1); initialData.ant = receivedLine.substring(1);
break; break;
case receivedLine.startsWith('G'): case receivedLine.startsWith('G'): // EQ / iMS (RF+/IF+)
const mapping = filterMappings[receivedLine]; const mapping = filterMappings[receivedLine];
if (mapping) { if (mapping) {
initialData.eq = mapping.eq; initialData.eq = mapping.eq;
@@ -298,7 +298,7 @@ function handleData(ws, receivedData) {
dataToSend.ims = mapping.ims; dataToSend.ims = mapping.ims;
} }
break; break;
case receivedLine.startsWith('W'): case receivedLine.startsWith('W'): // Bandwidth
console.log(receivedLine); console.log(receivedLine);
break; break;
case receivedLine.startsWith('Sm'): case receivedLine.startsWith('Sm'):
@@ -313,7 +313,7 @@ function handleData(ws, receivedData) {
case receivedLine.startsWith('SM'): case receivedLine.startsWith('SM'):
processSignal(receivedLine, false, true); processSignal(receivedLine, false, true);
break; break;
case receivedLine.startsWith('R'): case receivedLine.startsWith('R'): // RDS HEX
modifiedData = receivedLine.slice(1); modifiedData = receivedLine.slice(1);
dataToSend.rds = true; dataToSend.rds = true;
@@ -375,19 +375,6 @@ function showOnlineUsers(currentUsers) {
initialData.users = currentUsers; initialData.users = currentUsers;
} }
function convertSignal(dBFS, fullScaleVoltage = 1, inputImpedance = 300) {
// Convert dBFS to voltage
let voltage = Math.pow(10, dBFS / 20) * fullScaleVoltage;
// Convert voltage to microvolts
let uV = voltage * 1e6;
// Convert microvolts to dBuV
let dBf = 20 * Math.log10(uV / Math.sqrt(2) / Math.sqrt(inputImpedance));
return dBf.toFixed(2);
}
function processSignal(receivedData, st, stForced) { function processSignal(receivedData, st, stForced) {
const modifiedData = receivedData.substring(2); const modifiedData = receivedData.substring(2);
const parsedValue = parseFloat(modifiedData); const parsedValue = parseFloat(modifiedData);
@@ -397,13 +384,8 @@ function processSignal(receivedData, st, stForced) {
initialData.st_forced = stForced; initialData.st_forced = stForced;
if (!isNaN(parsedValue)) { if (!isNaN(parsedValue)) {
/*if (serverConfig.device && serverConfig.device === 'sdr') {
dataToSend.signal = convertSignal(parsedValue);
initialData.signal = convertSignal(parsedValue);
} else {*/
dataToSend.signal = parsedValue.toFixed(2); dataToSend.signal = parsedValue.toFixed(2);
initialData.signal = parsedValue.toFixed(2); initialData.signal = parsedValue.toFixed(2);
//}
if(dataToSend.signal > dataToSend.highestSignal) { if(dataToSend.signal > dataToSend.highestSignal) {
dataToSend.highestSignal = dataToSend.signal; dataToSend.highestSignal = dataToSend.signal;

View File

@@ -5,20 +5,22 @@ const { configName, serverConfig, configUpdate, configSave } = require('../serve
const { logDebug, logError, logInfo, logWarn, logFfmpeg } = require('../console'); const { logDebug, logError, logInfo, logWarn, logFfmpeg } = require('../console');
function enableAudioStream() { function enableAudioStream() {
var ffmpegParams;
var ffmpegCommand; var ffmpegCommand;
serverConfig.webserver.webserverPort = Number(serverConfig.webserver.webserverPort); serverConfig.webserver.webserverPort = Number(serverConfig.webserver.webserverPort);
const command = ffmpeg.replace(/\\/g, '\\\\');
const flags = `-fflags +nobuffer+flush_packets -flags low_delay -rtbufsize 6192 -probesize 32`; const flags = `-fflags +nobuffer+flush_packets -flags low_delay -rtbufsize 6192 -probesize 32`;
const codec = `-acodec pcm_s16le -ar 48000 -ac ${serverConfig.audio.audioChannels}`; const codec = `-acodec pcm_s16le -ar 48000 -ac ${serverConfig.audio.audioChannels}`;
const output = `-f s16le -fflags +nobuffer+flush_packets -packetsize 384 -flush_packets 1 -bufsize 960`; const output = `-f s16le -fflags +nobuffer+flush_packets -packetsize 384 -flush_packets 1 -bufsize 960`;
if (process.platform === 'win32') { if (process.platform === 'win32') {
// Windows // Windows
ffmpegCommand = `${flags} -f dshow -audio_buffer_size 50 -i audio="${serverConfig.audio.audioDevice}" ${codec} ${output} pipe:1 | node server/stream/3las.server.js -port ${serverConfig.webserver.webserverPort + 10} -samplerate 48000 -channels ${serverConfig.audio.audioChannels}`; ffmpegCommand = ffmpeg.replace(/\\/g, '\\\\');
ffmpegParams = `${flags} -f dshow -audio_buffer_size 50 -i audio="${serverConfig.audio.audioDevice}" ${codec} ${output} pipe:1 | node server/stream/3las.server.js -port ${serverConfig.webserver.webserverPort + 10} -samplerate 48000 -channels ${serverConfig.audio.audioChannels}`;
} else { } else {
// Linux // Linux
ffmpegCommand = `${flags} -f alsa -i "${serverConfig.audio.softwareMode && serverConfig.audio.softwareMode == true ? 'plug' : ''}${serverConfig.audio.audioDevice}" ${codec} ${output} pipe:1 | node server/stream/3las.server.js -port ${serverConfig.webserver.webserverPort + 10} -samplerate 48000 -channels ${serverConfig.audio.audioChannels}`; ffmpegCommand = 'ffmpeg';
ffmpegParams = `${flags} -f alsa -i "${serverConfig.audio.softwareMode && serverConfig.audio.softwareMode == true ? 'plug' : ''}${serverConfig.audio.audioDevice}" ${codec} ${output} pipe:1 | node server/stream/3las.server.js -port ${serverConfig.webserver.webserverPort + 10} -samplerate 48000 -channels ${serverConfig.audio.audioChannels}`;
} }
consoleCmd.logInfo("Using audio device: " + serverConfig.audio.audioDevice); consoleCmd.logInfo("Using audio device: " + serverConfig.audio.audioDevice);
@@ -26,7 +28,7 @@ function enableAudioStream() {
// If an audio device is configured, start the stream // If an audio device is configured, start the stream
if(serverConfig.audio.audioDevice.length > 2) { if(serverConfig.audio.audioDevice.length > 2) {
const childProcess = spawn(command, [ffmpegCommand], { shell: true }); const childProcess = spawn(ffmpegCommand, [ffmpegParams], { shell: true });
childProcess.stdout.on('data', (data) => { childProcess.stdout.on('data', (data) => {
logFfmpeg(`stdout: ${data}`); logFfmpeg(`stdout: ${data}`);