summaryrefslogtreecommitdiffstats
path: root/gtk/src/audiohandler.c
diff options
context:
space:
mode:
Diffstat (limited to 'gtk/src/audiohandler.c')
-rw-r--r--gtk/src/audiohandler.c418
1 files changed, 219 insertions, 199 deletions
diff --git a/gtk/src/audiohandler.c b/gtk/src/audiohandler.c
index 68a114d26..343d9da38 100644
--- a/gtk/src/audiohandler.c
+++ b/gtk/src/audiohandler.c
@@ -27,194 +27,9 @@ static void ghb_add_audio_to_ui(signal_user_data_t *ud, const GhbValue *settings
static GhbValue* audio_get_selected_settings(signal_user_data_t *ud, int *index);
static void ghb_clear_audio_list_settings(GhbValue *settings);
static void ghb_clear_audio_list_ui(GtkBuilder *builder);
-static void ghb_adjust_audio_rate_combos(signal_user_data_t *ud);
static gboolean block_updates = FALSE;
-static void enable_quality_widget(signal_user_data_t *ud, int acodec)
-{
- GtkWidget *widget1, *widget2;
-
- widget1 = GHB_WIDGET(ud->builder, "AudioTrackQualityEnable");
- widget2 = GHB_WIDGET(ud->builder, "AudioTrackBitrateEnable");
- if (hb_audio_quality_get_default(acodec) == HB_INVALID_AUDIO_QUALITY)
- {
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget2), TRUE);
- gtk_widget_set_sensitive(widget1, FALSE);
- }
- else
- {
- gtk_widget_set_sensitive(widget1, TRUE);
- }
-}
-
-static void audio_deps(signal_user_data_t *ud, GhbValue *asettings, GtkWidget *widget)
-{
- ghb_adjust_audio_rate_combos(ud);
- ghb_grey_combo_options(ud);
- if (widget != NULL)
- ghb_check_dependency(ud, widget, NULL);
-
- gint track = -1, codec = 0;
- hb_audio_config_t *aconfig = NULL;
- int title_id;
- gint titleindex;
- const hb_title_t *title;
-
- title_id = ghb_dict_get_int(ud->settings, "title");
- title = ghb_lookup_title(title_id, &titleindex);
-
- if (asettings != NULL)
- {
- track = ghb_dict_get_int(asettings, "Track");
- codec = ghb_settings_audio_encoder_codec(asettings, "Encoder");
- aconfig = ghb_get_audio_info(title, track);
- }
-
- gboolean is_passthru = (codec & HB_ACODEC_PASS_FLAG);
- gboolean enable_drc = TRUE;
- if (aconfig != NULL)
- {
- enable_drc = hb_audio_can_apply_drc(aconfig->in.codec,
- aconfig->in.codec_param, codec) &&
- !is_passthru;
- }
-
- widget = GHB_WIDGET(ud->builder, "AudioTrackDRCSlider");
- gtk_widget_set_sensitive(widget, enable_drc);
- widget = GHB_WIDGET(ud->builder, "AudioTrackDRCSliderLabel");
- gtk_widget_set_sensitive(widget, enable_drc);
- widget = GHB_WIDGET(ud->builder, "AudioTrackDRCValue");
- gtk_widget_set_sensitive(widget, enable_drc);
-
- enable_quality_widget(ud, codec);
-
- gboolean qe = ghb_dict_get_bool(ud->settings, "AudioTrackQualityEnable");
- widget = GHB_WIDGET(ud->builder, "AudioBitrate");
- gtk_widget_set_visible(widget, !qe);
- widget = GHB_WIDGET(ud->builder, "AudioTrackQualityBox");
- gtk_widget_set_visible(widget, qe);
-
- widget = GHB_WIDGET(ud->builder, "AudioBitrate");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioTrackQualityEnableBox");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioTrackQualityBox");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioMixdown");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioSamplerate");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioTrackGainSlider");
- gtk_widget_set_sensitive(widget, !is_passthru);
- widget = GHB_WIDGET(ud->builder, "AudioTrackGainValue");
- gtk_widget_set_sensitive(widget, !is_passthru);
-}
-
-gint
-ghb_select_audio_codec(gint mux, hb_audio_config_t *aconfig, gint acodec, gint fallback, gint copy_mask)
-{
- guint32 in_codec = aconfig != NULL ? aconfig->in.codec : 0;
-
- if (acodec == HB_ACODEC_AUTO_PASS)
- {
- return hb_autopassthru_get_encoder(in_codec, copy_mask, fallback, mux);
- }
-
- // Sanitize fallback
- const hb_encoder_t *enc;
- for (enc = hb_audio_encoder_get_next(NULL); enc != NULL;
- enc = hb_audio_encoder_get_next(enc))
- {
- if (enc->codec == fallback &&
- !(enc->muxers & mux))
- {
- if ( mux & HB_MUX_MASK_MKV )
- fallback = HB_ACODEC_LAME;
- else
- fallback = HB_ACODEC_FFAAC;
- break;
- }
- }
- if ((acodec & HB_ACODEC_PASS_FLAG) &&
- !(acodec & in_codec & HB_ACODEC_PASS_MASK))
- {
- return fallback;
- }
- for (enc = hb_audio_encoder_get_next(NULL); enc != NULL;
- enc = hb_audio_encoder_get_next(enc))
- {
- if (enc->codec == acodec &&
- !(enc->muxers & mux))
- {
- return fallback;
- }
- }
- return acodec;
-}
-
-int ghb_get_copy_mask(GhbValue *settings)
-{
- gint mask = 0;
-
- if (ghb_dict_get_bool(settings, "AudioAllowMP3Pass"))
- {
- mask |= HB_ACODEC_MP3_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowAACPass"))
- {
- mask |= HB_ACODEC_AAC_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowAC3Pass"))
- {
- mask |= HB_ACODEC_AC3_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowDTSPass"))
- {
- mask |= HB_ACODEC_DCA_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowDTSHDPass"))
- {
- mask |= HB_ACODEC_DCA_HD_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowEAC3Pass"))
- {
- mask |= HB_ACODEC_EAC3_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowFLACPass"))
- {
- mask |= HB_ACODEC_FLAC_PASS;
- }
- if (ghb_dict_get_bool(settings, "AudioAllowTRUEHDPass"))
- {
- mask |= HB_ACODEC_TRUEHD_PASS;
- }
- return mask;
-}
-
-int ghb_select_fallback(GhbValue *settings, int acodec)
-{
- gint fallback = 0;
-
- if (acodec & HB_ACODEC_PASS_FLAG)
- {
- fallback = hb_audio_encoder_get_fallback_for_passthru(acodec);
- if (fallback != 0)
- {
- return fallback;
- }
- }
- const char *mux_id;
- const hb_container_t *mux;
-
- mux_id = ghb_dict_get_string(settings, "FileFormat");
- mux = ghb_lookup_container_by_name(mux_id);
-
- fallback = ghb_settings_audio_encoder_codec(settings,
- "AudioEncoderFallback");
- return hb_autopassthru_get_encoder(acodec, 0, fallback, mux->format);
-}
-
static void
ghb_sanitize_audio_settings(GhbValue *settings, GhbValue *asettings)
{
@@ -356,12 +171,6 @@ static gdouble get_quality(int codec, gdouble quality)
return quality;
}
-static char * get_quality_string(int codec, gdouble quality)
-{
- char *s_quality = ghb_format_quality("", codec, quality);
- return s_quality;
-}
-
static gdouble get_ui_quality(GhbValue *settings)
{
int codec = ghb_settings_audio_encoder_codec(settings, "Encoder");
@@ -370,9 +179,8 @@ static gdouble get_ui_quality(GhbValue *settings)
}
static void
-ghb_adjust_audio_rate_combos(signal_user_data_t *ud)
+ghb_adjust_audio_rate_combos(signal_user_data_t *ud, GhbValue *asettings)
{
- GhbValue *asettings = audio_get_selected_settings(ud, NULL);
if (asettings != NULL)
{
ghb_sanitize_audio_settings(ud->settings, asettings);
@@ -417,6 +225,216 @@ ghb_adjust_audio_rate_combos(signal_user_data_t *ud)
}
}
+static void enable_quality_widgets(
+ signal_user_data_t *ud,
+ gboolean quality_enable,
+ int acodec,
+ int sr,
+ int mix)
+{
+ GtkWidget *widget;
+ gboolean quality_sensitive;
+ gboolean bitrate_sensitive;
+
+ widget = GHB_WIDGET(ud->builder, "AudioBitrate");
+ gtk_widget_set_visible(widget, !quality_enable);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackQualityBox");
+ gtk_widget_set_visible(widget, quality_enable);
+
+ if (hb_audio_quality_get_default(acodec) == HB_INVALID_AUDIO_QUALITY)
+ {
+ quality_sensitive = FALSE;
+ }
+ if (hb_audio_bitrate_get_default(acodec, sr, mix) == -1)
+ {
+ bitrate_sensitive = FALSE;
+ }
+
+ if (!quality_sensitive)
+ {
+ widget = GHB_WIDGET(ud->builder, "AudioTrackBitrateEnable");
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget),
+ !quality_sensitive);
+ }
+ widget = GHB_WIDGET(ud->builder, "AudioTrackQualityEnable");
+ gtk_widget_set_sensitive(widget, quality_sensitive);
+
+ widget = GHB_WIDGET(ud->builder, "AudioBitrate");
+ gtk_widget_set_sensitive(widget, bitrate_sensitive);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackQualityEnableBox");
+ gtk_widget_set_sensitive(widget, bitrate_sensitive || quality_sensitive);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackQualityBox");
+ gtk_widget_set_sensitive(widget, quality_sensitive);
+}
+
+static void
+audio_deps(signal_user_data_t *ud, GhbValue *asettings, GtkWidget *widget)
+{
+ ghb_adjust_audio_rate_combos(ud, asettings);
+ ghb_grey_combo_options(ud);
+ if (widget != NULL)
+ ghb_check_dependency(ud, widget, NULL);
+
+ int track = -1, title_id, mix = 0, acodec = 0, sr = 0;
+ hb_audio_config_t *aconfig = NULL;
+ const hb_title_t *title;
+ gboolean qe = FALSE;
+
+ title_id = ghb_dict_get_int(ud->settings, "title");
+ title = ghb_lookup_title(title_id, NULL);
+
+ if (asettings != NULL)
+ {
+ track = ghb_dict_get_int(asettings, "Track");
+ acodec = ghb_settings_audio_encoder_codec(asettings, "Encoder");
+ aconfig = ghb_get_audio_info(title, track);
+ mix = ghb_settings_mixdown_mix(asettings, "Mixdown");
+ sr = ghb_dict_get_int(asettings, "Samplerate");
+ qe = ghb_dict_get_bool(asettings, "QualityEnable");
+ if (sr == 0 && aconfig != NULL)
+ {
+ sr = aconfig->in.samplerate;
+ }
+ }
+
+ gboolean is_passthru = (acodec & HB_ACODEC_PASS_FLAG);
+ gboolean enable_drc = TRUE;
+ if (aconfig != NULL)
+ {
+ enable_drc = hb_audio_can_apply_drc(aconfig->in.codec,
+ aconfig->in.codec_param, acodec) &&
+ !is_passthru;
+ }
+
+ widget = GHB_WIDGET(ud->builder, "AudioTrackDRCSlider");
+ gtk_widget_set_sensitive(widget, enable_drc);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackDRCSliderLabel");
+ gtk_widget_set_sensitive(widget, enable_drc);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackDRCValue");
+ gtk_widget_set_sensitive(widget, enable_drc);
+
+ enable_quality_widgets(ud, qe, acodec, sr, mix);
+
+ widget = GHB_WIDGET(ud->builder, "AudioMixdown");
+ gtk_widget_set_sensitive(widget, !is_passthru);
+ widget = GHB_WIDGET(ud->builder, "AudioSamplerate");
+ gtk_widget_set_sensitive(widget, !is_passthru);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackGainSlider");
+ gtk_widget_set_sensitive(widget, !is_passthru);
+ widget = GHB_WIDGET(ud->builder, "AudioTrackGainValue");
+ gtk_widget_set_sensitive(widget, !is_passthru);
+}
+
+gint
+ghb_select_audio_codec(gint mux, hb_audio_config_t *aconfig, gint acodec, gint fallback, gint copy_mask)
+{
+ guint32 in_codec = aconfig != NULL ? aconfig->in.codec : 0;
+
+ if (acodec == HB_ACODEC_AUTO_PASS)
+ {
+ return hb_autopassthru_get_encoder(in_codec, copy_mask, fallback, mux);
+ }
+
+ // Sanitize fallback
+ const hb_encoder_t *enc;
+ for (enc = hb_audio_encoder_get_next(NULL); enc != NULL;
+ enc = hb_audio_encoder_get_next(enc))
+ {
+ if (enc->codec == fallback &&
+ !(enc->muxers & mux))
+ {
+ if ( mux & HB_MUX_MASK_MKV )
+ fallback = HB_ACODEC_LAME;
+ else
+ fallback = HB_ACODEC_FFAAC;
+ break;
+ }
+ }
+ if ((acodec & HB_ACODEC_PASS_FLAG) &&
+ !(acodec & in_codec & HB_ACODEC_PASS_MASK))
+ {
+ return fallback;
+ }
+ for (enc = hb_audio_encoder_get_next(NULL); enc != NULL;
+ enc = hb_audio_encoder_get_next(enc))
+ {
+ if (enc->codec == acodec &&
+ !(enc->muxers & mux))
+ {
+ return fallback;
+ }
+ }
+ return acodec;
+}
+
+int ghb_get_copy_mask(GhbValue *settings)
+{
+ gint mask = 0;
+
+ if (ghb_dict_get_bool(settings, "AudioAllowMP3Pass"))
+ {
+ mask |= HB_ACODEC_MP3_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowAACPass"))
+ {
+ mask |= HB_ACODEC_AAC_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowAC3Pass"))
+ {
+ mask |= HB_ACODEC_AC3_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowDTSPass"))
+ {
+ mask |= HB_ACODEC_DCA_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowDTSHDPass"))
+ {
+ mask |= HB_ACODEC_DCA_HD_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowEAC3Pass"))
+ {
+ mask |= HB_ACODEC_EAC3_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowFLACPass"))
+ {
+ mask |= HB_ACODEC_FLAC_PASS;
+ }
+ if (ghb_dict_get_bool(settings, "AudioAllowTRUEHDPass"))
+ {
+ mask |= HB_ACODEC_TRUEHD_PASS;
+ }
+ return mask;
+}
+
+int ghb_select_fallback(GhbValue *settings, int acodec)
+{
+ gint fallback = 0;
+
+ if (acodec & HB_ACODEC_PASS_FLAG)
+ {
+ fallback = hb_audio_encoder_get_fallback_for_passthru(acodec);
+ if (fallback != 0)
+ {
+ return fallback;
+ }
+ }
+ const char *mux_id;
+ const hb_container_t *mux;
+
+ mux_id = ghb_dict_get_string(settings, "FileFormat");
+ mux = ghb_lookup_container_by_name(mux_id);
+
+ fallback = ghb_settings_audio_encoder_codec(settings,
+ "AudioEncoderFallback");
+ return hb_autopassthru_get_encoder(acodec, 0, fallback, mux->format);
+}
+
+static char * get_quality_string(int codec, gdouble quality)
+{
+ char *s_quality = ghb_format_quality("", codec, quality);
+ return s_quality;
+}
+
void ghb_sanitize_audio_tracks(signal_user_data_t *ud)
{
int ii;
@@ -750,16 +768,18 @@ audio_refresh_list_row_ui(
int bitrate = ghb_dict_get_int(settings, "Bitrate");
if (bitrate > 0)
{
- s_br_quality = g_strdup_printf(_("Bitrate: %dkbps"), bitrate);
+ s_br_quality = g_strdup_printf(_("Bitrate: %dkbps\n"), bitrate);
}
else if (quality != HB_INVALID_AUDIO_QUALITY)
{
- s_br_quality = ghb_format_quality(_("Quality: "),
- encoder->codec, quality);
+ char *tmp = ghb_format_quality(_("Quality: "),
+ encoder->codec, quality);
+ s_br_quality = g_strdup_printf("%s\n", tmp);
+ g_free(tmp);
}
else
{
- s_br_quality = g_strdup_printf(_("N/A"));
+ s_br_quality = g_strdup("");
}
sr = ghb_dict_get_int(settings, "Samplerate");
@@ -802,12 +822,12 @@ audio_refresh_list_row_ui(
if (s_track_name && s_track_name[0])
{
info_dst_2 = g_strdup_printf(
- _("%s\nGain: %s\nDRC: %s\nTrack Name: %s"),
+ _("%sGain: %s\nDRC: %s\nTrack Name: %s"),
s_br_quality, s_gain, s_drc, s_track_name);
}
else
{
- info_dst_2 = g_strdup_printf(_("%s\nGain: %s\nDRC: %s"),
+ info_dst_2 = g_strdup_printf(_("%sGain: %s\nDRC: %s"),
s_br_quality, s_gain, s_drc);
}
}