2013-09-30 21:39:56 +02:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// LameXP - Audio Encoder Front-End
|
2014-01-01 17:05:52 +01:00
|
|
|
// Copyright (C) 2004-2014 LoRd_MuldeR <MuldeR2@GMX.de>
|
2013-09-30 21:39:56 +02:00
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation; either version 2 of the License, or
|
2013-10-23 20:56:57 +02:00
|
|
|
// (at your option) any later version, but always including the *additional*
|
|
|
|
// restrictions defined in the "License.txt" file.
|
2013-09-30 21:39:56 +02:00
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
//
|
|
|
|
// http://www.gnu.org/licenses/gpl-2.0.txt
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "Registry_Encoder.h"
|
|
|
|
|
2013-10-02 19:17:33 +02:00
|
|
|
#include "Global.h"
|
2013-09-30 21:39:56 +02:00
|
|
|
#include "Model_Settings.h"
|
|
|
|
#include "Encoder_AAC.h"
|
|
|
|
#include "Encoder_AAC_FHG.h"
|
|
|
|
#include "Encoder_AAC_QAAC.h"
|
|
|
|
#include "Encoder_AC3.h"
|
|
|
|
#include "Encoder_DCA.h"
|
|
|
|
#include "Encoder_FLAC.h"
|
|
|
|
#include "Encoder_MP3.h"
|
|
|
|
#include "Encoder_Vorbis.h"
|
|
|
|
#include "Encoder_Opus.h"
|
2013-12-04 22:36:19 +01:00
|
|
|
#include "Encoder_MAC.h"
|
2013-09-30 21:39:56 +02:00
|
|
|
#include "Encoder_Wave.h"
|
|
|
|
|
|
|
|
#define IS_VBR(RC_MODE) ((RC_MODE) == SettingsModel::VBRMode)
|
2013-10-03 15:56:10 +02:00
|
|
|
#define IS_ABR(RC_MODE) ((RC_MODE) == SettingsModel::ABRMode)
|
|
|
|
#define IS_CBR(RC_MODE) ((RC_MODE) == SettingsModel::CBRMode)
|
2013-09-30 21:39:56 +02:00
|
|
|
|
2013-10-02 16:39:26 +02:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Create encoder instance
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
2013-09-30 21:39:56 +02:00
|
|
|
AbstractEncoder *EncoderRegistry::createInstance(const int encoderId, const SettingsModel *settings, bool *nativeResampling)
|
|
|
|
{
|
|
|
|
int rcMode = -1;
|
|
|
|
AbstractEncoder *encoder = NULL;
|
|
|
|
*nativeResampling = false;
|
|
|
|
|
2013-10-03 17:01:37 +02:00
|
|
|
//Create new encoder instance and apply encoder-specific settings
|
2013-09-30 21:39:56 +02:00
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
/*-------- MP3Encoder /*--------*/
|
|
|
|
case SettingsModel::MP3Encoder:
|
|
|
|
{
|
|
|
|
MP3Encoder *mp3Encoder = new MP3Encoder();
|
|
|
|
mp3Encoder->setAlgoQuality(settings->lameAlgoQuality());
|
|
|
|
if(settings->bitrateManagementEnabled())
|
|
|
|
{
|
|
|
|
mp3Encoder->setBitrateLimits(settings->bitrateManagementMinRate(), settings->bitrateManagementMaxRate());
|
|
|
|
}
|
|
|
|
if(settings->samplingRate() > 0)
|
|
|
|
{
|
|
|
|
mp3Encoder->setSamplingRate(SettingsModel::samplingRates[settings->samplingRate()]);
|
|
|
|
*nativeResampling = true;
|
|
|
|
}
|
|
|
|
mp3Encoder->setChannelMode(settings->lameChannelMode());
|
|
|
|
encoder = mp3Encoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- VorbisEncoder /*--------*/
|
|
|
|
case SettingsModel::VorbisEncoder:
|
|
|
|
{
|
|
|
|
VorbisEncoder *vorbisEncoder = new VorbisEncoder();
|
|
|
|
if(settings->bitrateManagementEnabled())
|
|
|
|
{
|
|
|
|
vorbisEncoder->setBitrateLimits(settings->bitrateManagementMinRate(), settings->bitrateManagementMaxRate());
|
|
|
|
}
|
|
|
|
if(settings->samplingRate() > 0)
|
|
|
|
{
|
|
|
|
vorbisEncoder->setSamplingRate(SettingsModel::samplingRates[settings->samplingRate()]);
|
|
|
|
*nativeResampling = true;
|
|
|
|
}
|
|
|
|
encoder = vorbisEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- AACEncoder /*--------*/
|
|
|
|
case SettingsModel::AACEncoder:
|
|
|
|
{
|
2013-10-02 19:17:33 +02:00
|
|
|
switch(getAacEncoder())
|
2013-09-30 21:39:56 +02:00
|
|
|
{
|
|
|
|
case SettingsModel::AAC_ENCODER_QAAC:
|
|
|
|
{
|
|
|
|
QAACEncoder *aacEncoder = new QAACEncoder();
|
|
|
|
aacEncoder->setProfile(settings->aacEncProfile());
|
|
|
|
encoder = aacEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SettingsModel::AAC_ENCODER_FHG:
|
|
|
|
{
|
|
|
|
FHGAACEncoder *aacEncoder = new FHGAACEncoder();
|
|
|
|
aacEncoder->setProfile(settings->aacEncProfile());
|
|
|
|
encoder = aacEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SettingsModel::AAC_ENCODER_NERO:
|
|
|
|
{
|
|
|
|
AACEncoder *aacEncoder = new AACEncoder();
|
|
|
|
aacEncoder->setEnable2Pass(settings->neroAACEnable2Pass());
|
|
|
|
aacEncoder->setProfile(settings->aacEncProfile());
|
|
|
|
encoder = aacEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("makeEncoder(): Unknown AAC encoder specified!");
|
2013-09-30 21:39:56 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- AC3Encoder /*--------*/
|
|
|
|
case SettingsModel::AC3Encoder:
|
|
|
|
{
|
|
|
|
AC3Encoder *ac3Encoder = new AC3Encoder();
|
|
|
|
ac3Encoder->setAudioCodingMode(settings->aftenAudioCodingMode());
|
|
|
|
ac3Encoder->setDynamicRangeCompression(settings->aftenDynamicRangeCompression());
|
|
|
|
ac3Encoder->setExponentSearchSize(settings->aftenExponentSearchSize());
|
|
|
|
ac3Encoder->setFastBitAllocation(settings->aftenFastBitAllocation());
|
|
|
|
encoder = ac3Encoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- FLACEncoder /*--------*/
|
|
|
|
case SettingsModel::FLACEncoder:
|
|
|
|
{
|
|
|
|
FLACEncoder *flacEncoder = new FLACEncoder();
|
|
|
|
encoder = flacEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- OpusEncoder --------*/
|
|
|
|
case SettingsModel::OpusEncoder:
|
|
|
|
{
|
|
|
|
OpusEncoder *opusEncoder = new OpusEncoder();
|
|
|
|
opusEncoder->setOptimizeFor(settings->opusOptimizeFor());
|
|
|
|
opusEncoder->setEncodeComplexity(settings->opusComplexity());
|
|
|
|
opusEncoder->setFrameSize(settings->opusFramesize());
|
|
|
|
encoder = opusEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- DCAEncoder --------*/
|
|
|
|
case SettingsModel::DCAEncoder:
|
|
|
|
{
|
|
|
|
DCAEncoder *dcaEncoder = new DCAEncoder();
|
|
|
|
encoder = dcaEncoder;
|
|
|
|
}
|
|
|
|
break;
|
2013-12-04 22:36:19 +01:00
|
|
|
/*-------- MACEncoder --------*/
|
|
|
|
case SettingsModel::MACEncoder:
|
|
|
|
{
|
|
|
|
MACEncoder *macEncoder = new MACEncoder();
|
|
|
|
encoder = macEncoder;
|
|
|
|
}
|
|
|
|
break;
|
2013-09-30 21:39:56 +02:00
|
|
|
/*-------- PCMEncoder --------*/
|
|
|
|
case SettingsModel::PCMEncoder:
|
|
|
|
{
|
|
|
|
WaveEncoder *waveEncoder = new WaveEncoder();
|
|
|
|
encoder = waveEncoder;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
/*-------- default --------*/
|
|
|
|
default:
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("Unsupported encoder!");
|
2013-09-30 21:39:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Sanity checking
|
|
|
|
if(!encoder)
|
|
|
|
{
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("No encoder instance has been assigend!");
|
2013-09-30 21:39:56 +02:00
|
|
|
}
|
|
|
|
|
2013-10-03 17:01:37 +02:00
|
|
|
//Apply common settings
|
|
|
|
encoder->setRCMode(rcMode = loadEncoderMode(settings, encoderId));
|
|
|
|
encoder->setCustomParams(loadEncoderCustomParams(settings, encoderId));
|
|
|
|
encoder->setBitrate(loadEncoderValue(settings, encoderId, rcMode));
|
|
|
|
|
2013-09-30 21:39:56 +02:00
|
|
|
return encoder;
|
|
|
|
}
|
|
|
|
|
2013-10-02 16:39:26 +02:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Get encoder info
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
2013-09-30 21:39:56 +02:00
|
|
|
const AbstractEncoderInfo *EncoderRegistry::getEncoderInfo(const int encoderId)
|
|
|
|
{
|
|
|
|
const AbstractEncoderInfo *info = NULL;
|
|
|
|
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
2013-10-02 19:17:33 +02:00
|
|
|
case SettingsModel::MP3Encoder: info = MP3Encoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::VorbisEncoder: info = VorbisEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::AC3Encoder: info = AC3Encoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::FLACEncoder: info = FLACEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::OpusEncoder: info = OpusEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::DCAEncoder: info = DCAEncoder::getEncoderInfo(); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: info = MACEncoder::getEncoderInfo(); break;
|
2013-10-02 19:17:33 +02:00
|
|
|
case SettingsModel::PCMEncoder: info = WaveEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::AACEncoder:
|
|
|
|
switch(getAacEncoder())
|
2013-09-30 21:39:56 +02:00
|
|
|
{
|
2013-10-02 19:17:33 +02:00
|
|
|
case SettingsModel::AAC_ENCODER_QAAC: info = QAACEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::AAC_ENCODER_FHG: info = FHGAACEncoder::getEncoderInfo(); break;
|
|
|
|
case SettingsModel::AAC_ENCODER_NERO: info = AACEncoder::getEncoderInfo(); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unknown AAC encoder specified!");
|
2013-09-30 21:39:56 +02:00
|
|
|
}
|
2013-10-02 19:17:33 +02:00
|
|
|
break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-09-30 21:39:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Sanity checking
|
|
|
|
if(!info)
|
|
|
|
{
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("No encoder instance has been assigend!");
|
2013-09-30 21:39:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return info;
|
|
|
|
}
|
2013-10-02 16:39:26 +02:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Load/store encoder RC mode
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#define STORE_MODE(ENCODER_ID, RC_MODE) do \
|
|
|
|
{ \
|
|
|
|
settings->compressionRCMode##ENCODER_ID(RC_MODE); \
|
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
#define LOAD_MODE(RC_MODE, ENCODER_ID) do \
|
|
|
|
{ \
|
|
|
|
(RC_MODE) = settings->compressionRCMode##ENCODER_ID(); \
|
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
void EncoderRegistry::saveEncoderMode(SettingsModel *settings, const int encoderId, const int rcMode)
|
|
|
|
{
|
|
|
|
//Sanity checking
|
|
|
|
if((rcMode < SettingsModel::VBRMode) || (rcMode > SettingsModel::CBRMode))
|
|
|
|
{
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("Unknown rate-control mode!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Store the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: STORE_MODE(LAME, rcMode); break;
|
|
|
|
case SettingsModel::VorbisEncoder: STORE_MODE(OggEnc, rcMode); break;
|
|
|
|
case SettingsModel::AACEncoder: STORE_MODE(AacEnc, rcMode); break;
|
|
|
|
case SettingsModel::AC3Encoder: STORE_MODE(Aften, rcMode); break;
|
|
|
|
case SettingsModel::FLACEncoder: STORE_MODE(FLAC, rcMode); break;
|
|
|
|
case SettingsModel::OpusEncoder: STORE_MODE(OpusEnc, rcMode); break;
|
|
|
|
case SettingsModel::DCAEncoder: STORE_MODE(DcaEnc, rcMode); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: STORE_MODE(MacEnc, rcMode); break;
|
2013-10-02 16:39:26 +02:00
|
|
|
case SettingsModel::PCMEncoder: STORE_MODE(Wave, rcMode); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-03 17:01:37 +02:00
|
|
|
int EncoderRegistry::loadEncoderMode(const SettingsModel *settings, const int encoderId)
|
2013-10-02 16:39:26 +02:00
|
|
|
{
|
|
|
|
int rcMode = -1;
|
|
|
|
|
|
|
|
//Store the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: LOAD_MODE(rcMode, LAME); break;
|
|
|
|
case SettingsModel::VorbisEncoder: LOAD_MODE(rcMode, OggEnc); break;
|
|
|
|
case SettingsModel::AACEncoder: LOAD_MODE(rcMode, AacEnc); break;
|
|
|
|
case SettingsModel::AC3Encoder: LOAD_MODE(rcMode, Aften); break;
|
|
|
|
case SettingsModel::FLACEncoder: LOAD_MODE(rcMode, FLAC); break;
|
|
|
|
case SettingsModel::OpusEncoder: LOAD_MODE(rcMode, OpusEnc); break;
|
|
|
|
case SettingsModel::DCAEncoder: LOAD_MODE(rcMode, DcaEnc); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: LOAD_MODE(rcMode, MacEnc); break;
|
2013-10-02 16:39:26 +02:00
|
|
|
case SettingsModel::PCMEncoder: LOAD_MODE(rcMode, Wave); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return rcMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Load/store encoder bitrate/quality value
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#define STORE_VALUE(ENCODER_ID, RC_MODE, VALUE) do \
|
|
|
|
{ \
|
2013-10-03 15:56:10 +02:00
|
|
|
if(IS_VBR(RC_MODE)) settings->compressionVbrQuality##ENCODER_ID(VALUE); \
|
|
|
|
if(IS_ABR(RC_MODE)) settings->compressionAbrBitrate##ENCODER_ID(VALUE); \
|
|
|
|
if(IS_CBR(RC_MODE)) settings->compressionCbrBitrate##ENCODER_ID(VALUE); \
|
2013-10-02 16:39:26 +02:00
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
#define LOAD_VALUE(VALUE, ENCODER_ID, RC_MODE) do \
|
|
|
|
{ \
|
2013-10-03 15:56:10 +02:00
|
|
|
if(IS_VBR(RC_MODE)) (VALUE) = settings->compressionVbrQuality##ENCODER_ID(); \
|
|
|
|
if(IS_ABR(RC_MODE)) (VALUE) = settings->compressionAbrBitrate##ENCODER_ID(); \
|
|
|
|
if(IS_CBR(RC_MODE)) (VALUE) = settings->compressionCbrBitrate##ENCODER_ID(); \
|
2013-10-02 16:39:26 +02:00
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
void EncoderRegistry::saveEncoderValue(SettingsModel *settings, const int encoderId, const int rcMode, const int value)
|
|
|
|
{
|
|
|
|
//Sanity checking
|
|
|
|
if((rcMode < SettingsModel::VBRMode) || (rcMode > SettingsModel::CBRMode))
|
|
|
|
{
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("Unknown rate-control mode!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Store the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: STORE_VALUE(LAME, rcMode, value); break;
|
|
|
|
case SettingsModel::VorbisEncoder: STORE_VALUE(OggEnc, rcMode, value); break;
|
|
|
|
case SettingsModel::AACEncoder: STORE_VALUE(AacEnc, rcMode, value); break;
|
|
|
|
case SettingsModel::AC3Encoder: STORE_VALUE(Aften, rcMode, value); break;
|
|
|
|
case SettingsModel::FLACEncoder: STORE_VALUE(FLAC, rcMode, value); break;
|
|
|
|
case SettingsModel::OpusEncoder: STORE_VALUE(OpusEnc, rcMode, value); break;
|
|
|
|
case SettingsModel::DCAEncoder: STORE_VALUE(DcaEnc, rcMode, value); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: STORE_VALUE(MacEnc, rcMode, value); break;
|
2013-10-02 16:39:26 +02:00
|
|
|
case SettingsModel::PCMEncoder: STORE_VALUE(Wave, rcMode, value); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int EncoderRegistry::loadEncoderValue(const SettingsModel *settings, const int encoderId, const int rcMode)
|
|
|
|
{
|
|
|
|
int value = INT_MAX;
|
|
|
|
|
|
|
|
//Sanity checking
|
|
|
|
if((rcMode < SettingsModel::VBRMode) || (rcMode > SettingsModel::CBRMode))
|
|
|
|
{
|
2013-10-18 21:37:40 +02:00
|
|
|
THROW("Unknown rate-control mode!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//Load the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: LOAD_VALUE(value, LAME, rcMode); break;
|
|
|
|
case SettingsModel::VorbisEncoder: LOAD_VALUE(value, OggEnc, rcMode); break;
|
|
|
|
case SettingsModel::AACEncoder: LOAD_VALUE(value, AacEnc, rcMode); break;
|
|
|
|
case SettingsModel::AC3Encoder: LOAD_VALUE(value, Aften, rcMode); break;
|
|
|
|
case SettingsModel::FLACEncoder: LOAD_VALUE(value, FLAC, rcMode); break;
|
|
|
|
case SettingsModel::OpusEncoder: LOAD_VALUE(value, OpusEnc, rcMode); break;
|
|
|
|
case SettingsModel::DCAEncoder: LOAD_VALUE(value, DcaEnc, rcMode); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: LOAD_VALUE(value, MacEnc, rcMode); break;
|
2013-10-02 16:39:26 +02:00
|
|
|
case SettingsModel::PCMEncoder: LOAD_VALUE(value, Wave, rcMode); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-02 16:39:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
2013-10-02 19:17:33 +02:00
|
|
|
|
2013-10-03 17:01:37 +02:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Load/store encoder custom parameters
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#define STORE_PARAMS(ENCODER_ID, PARAMS) do \
|
|
|
|
{ \
|
|
|
|
settings->customParameters##ENCODER_ID(PARAMS); \
|
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
#define LOAD_PARAMS(PARAMS, ENCODER_ID) do \
|
|
|
|
{ \
|
|
|
|
(PARAMS) = settings->customParameters##ENCODER_ID(); \
|
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
void EncoderRegistry::saveEncoderCustomParams(SettingsModel *settings, const int encoderId, const QString params)
|
|
|
|
{
|
|
|
|
//Store the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: STORE_PARAMS(LAME, params.trimmed()); break;
|
|
|
|
case SettingsModel::VorbisEncoder: STORE_PARAMS(OggEnc, params.trimmed()); break;
|
|
|
|
case SettingsModel::AACEncoder: STORE_PARAMS(AacEnc, params.trimmed()); break;
|
|
|
|
case SettingsModel::AC3Encoder: STORE_PARAMS(Aften, params.trimmed()); break;
|
|
|
|
case SettingsModel::FLACEncoder: STORE_PARAMS(FLAC, params.trimmed()); break;
|
|
|
|
case SettingsModel::OpusEncoder: STORE_PARAMS(OpusEnc, params.trimmed()); break;
|
|
|
|
case SettingsModel::DCAEncoder: STORE_PARAMS(DcaEnc, params.trimmed()); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: STORE_PARAMS(MacEnc, params.trimmed()); break;
|
2013-10-03 17:01:37 +02:00
|
|
|
case SettingsModel::PCMEncoder: STORE_PARAMS(Wave, params.trimmed()); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-03 17:01:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QString EncoderRegistry::loadEncoderCustomParams(const SettingsModel *settings, const int encoderId)
|
|
|
|
{
|
|
|
|
QString params;
|
|
|
|
|
|
|
|
//Load the encoder bitrate/quality value
|
|
|
|
switch(encoderId)
|
|
|
|
{
|
|
|
|
case SettingsModel::MP3Encoder: LOAD_PARAMS(params, LAME); break;
|
|
|
|
case SettingsModel::VorbisEncoder: LOAD_PARAMS(params, OggEnc); break;
|
|
|
|
case SettingsModel::AACEncoder: LOAD_PARAMS(params, AacEnc); break;
|
|
|
|
case SettingsModel::AC3Encoder: LOAD_PARAMS(params, Aften); break;
|
|
|
|
case SettingsModel::FLACEncoder: LOAD_PARAMS(params, FLAC); break;
|
|
|
|
case SettingsModel::OpusEncoder: LOAD_PARAMS(params, OpusEnc); break;
|
|
|
|
case SettingsModel::DCAEncoder: LOAD_PARAMS(params, DcaEnc); break;
|
2013-12-04 22:36:19 +01:00
|
|
|
case SettingsModel::MACEncoder: LOAD_PARAMS(params, MacEnc); break;
|
2013-10-03 17:01:37 +02:00
|
|
|
case SettingsModel::PCMEncoder: LOAD_PARAMS(params, Wave); break;
|
2013-10-18 21:37:40 +02:00
|
|
|
default: THROW("Unsupported encoder!");
|
2013-10-03 17:01:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return params;
|
|
|
|
}
|
|
|
|
|
2013-10-03 15:56:10 +02:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Reset encoder settings
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#define RESET_SETTING(OBJ,NAME) do \
|
|
|
|
{ \
|
|
|
|
(OBJ)->NAME((OBJ)->NAME##Default()); \
|
|
|
|
} \
|
|
|
|
while(0)
|
|
|
|
|
|
|
|
void EncoderRegistry::resetAllEncoders(SettingsModel *settings)
|
|
|
|
{
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateAacEnc);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateAften);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateDcaEnc);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateFLAC);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateLAME);
|
2013-12-04 22:36:19 +01:00
|
|
|
RESET_SETTING(settings, compressionAbrBitrateMacEnc);
|
2013-10-03 15:56:10 +02:00
|
|
|
RESET_SETTING(settings, compressionAbrBitrateOggEnc);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateOpusEnc);
|
|
|
|
RESET_SETTING(settings, compressionAbrBitrateWave);
|
|
|
|
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateAacEnc);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateAften);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateDcaEnc);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateFLAC);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateLAME);
|
2013-12-04 22:36:19 +01:00
|
|
|
RESET_SETTING(settings, compressionCbrBitrateMacEnc);
|
2013-10-03 15:56:10 +02:00
|
|
|
RESET_SETTING(settings, compressionCbrBitrateOggEnc);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateOpusEnc);
|
|
|
|
RESET_SETTING(settings, compressionCbrBitrateWave);
|
|
|
|
|
|
|
|
RESET_SETTING(settings, compressionRCModeAacEnc);
|
|
|
|
RESET_SETTING(settings, compressionRCModeAften);
|
|
|
|
RESET_SETTING(settings, compressionRCModeDcaEnc);
|
|
|
|
RESET_SETTING(settings, compressionRCModeFLAC);
|
|
|
|
RESET_SETTING(settings, compressionRCModeLAME);
|
2013-12-04 22:36:19 +01:00
|
|
|
RESET_SETTING(settings, compressionRCModeMacEnc);
|
2013-10-03 15:56:10 +02:00
|
|
|
RESET_SETTING(settings, compressionRCModeOggEnc);
|
|
|
|
RESET_SETTING(settings, compressionRCModeOpusEnc);
|
|
|
|
RESET_SETTING(settings, compressionRCModeWave);
|
|
|
|
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityAacEnc);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityAften);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityDcaEnc);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityFLAC);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityLAME);
|
2013-12-04 22:36:19 +01:00
|
|
|
RESET_SETTING(settings, compressionVbrQualityMacEnc);
|
2013-10-03 15:56:10 +02:00
|
|
|
RESET_SETTING(settings, compressionVbrQualityOggEnc);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityOpusEnc);
|
|
|
|
RESET_SETTING(settings, compressionVbrQualityWave);
|
|
|
|
}
|
|
|
|
|
2013-10-02 19:17:33 +02:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Static Functions
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
int EncoderRegistry::getAacEncoder(void)
|
|
|
|
{
|
|
|
|
if(lamexp_check_tool("qaac.exe") && lamexp_check_tool("libsoxrate.dll"))
|
|
|
|
{
|
|
|
|
return SettingsModel::AAC_ENCODER_QAAC;
|
|
|
|
}
|
|
|
|
else if(lamexp_check_tool("fhgaacenc.exe") && lamexp_check_tool("enc_fhgaac.dll") && lamexp_check_tool("nsutil.dll") && lamexp_check_tool("libmp4v2.dll"))
|
|
|
|
{
|
|
|
|
return SettingsModel::AAC_ENCODER_FHG;
|
|
|
|
}
|
|
|
|
else if(lamexp_check_tool("neroAacEnc.exe") && lamexp_check_tool("neroAacDec.exe") && lamexp_check_tool("neroAacTag.exe"))
|
|
|
|
{
|
|
|
|
return SettingsModel::AAC_ENCODER_NERO;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return SettingsModel::AAC_ENCODER_NONE;
|
|
|
|
}
|
|
|
|
}
|