diff options
author | jstebbins <[email protected]> | 2009-05-21 20:23:04 +0000 |
---|---|---|
committer | jstebbins <[email protected]> | 2009-05-21 20:23:04 +0000 |
commit | 1ff5eb09c5cae153eaff6df81659dbbed76bf1c5 (patch) | |
tree | 07ac24f9e6d323985d42d9ce81c9407b4e65c04f | |
parent | dc39beecfc4d7ed31bfe0d62e771d12b5775133f (diff) |
LinGui:
add 'enable' checkbox to subtitle list and show all subtitles
in the list after scanning. Thanks eddyg for the suggestions.
git-svn-id: svn://svn.handbrake.fr/HandBrake/trunk@2434 b64f7644-9d1e-0410-96f1-a4d463321fa5
-rw-r--r-- | gtk/src/ghb.ui | 13 | ||||
-rw-r--r-- | gtk/src/hb-backend.c | 82 | ||||
-rw-r--r-- | gtk/src/hb-backend.h | 2 | ||||
-rw-r--r-- | gtk/src/main.c | 26 | ||||
-rw-r--r-- | gtk/src/presets.c | 45 | ||||
-rw-r--r-- | gtk/src/subtitlehandler.c | 396 | ||||
-rw-r--r-- | gtk/src/subtitlehandler.h | 4 |
7 files changed, 350 insertions, 218 deletions
diff --git a/gtk/src/ghb.ui b/gtk/src/ghb.ui index f740a9054..581d2c497 100644 --- a/gtk/src/ghb.ui +++ b/gtk/src/ghb.ui @@ -2259,11 +2259,20 @@ </packing> </child> <child> - <object class="GtkTreeView" id="subtitle_list"> + <object class="GtkScrolledWindow" id="scrolledwindow4"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property> - <property name="headers_clickable">True</property> + <property name="hscrollbar_policy">GTK_POLICY_AUTOMATIC</property> + <property name="vscrollbar_policy">GTK_POLICY_AUTOMATIC</property> + <child> + <object class="GtkTreeView" id="subtitle_list"> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property> + <property name="headers_clickable">True</property> + </object> + </child> </object> <packing> <property name="position">1</property> diff --git a/gtk/src/hb-backend.c b/gtk/src/hb-backend.c index 0fbd6919f..5fa554917 100644 --- a/gtk/src/hb-backend.c +++ b/gtk/src/hb-backend.c @@ -1981,6 +1981,63 @@ ghb_find_audio_track( return track; } +void +ghb_add_all_subtitles(signal_user_data_t *ud, gint titleindex) +{ + hb_list_t * list; + hb_title_t * title; + hb_subtitle_t * subtitle; + gint ii; + gint count = 0; + GValue *subdict; + + g_debug("ghb_add_all_subtitles ()\n"); + if (h_scan == NULL) + return; + list = hb_get_titles( h_scan ); + title = (hb_title_t*)hb_list_item( list, titleindex ); + if (title == NULL) + return; + + // Add special auto selection track + subdict = ghb_dict_value_new(); + ghb_settings_set_boolean(subdict, "SubtitleEnabled", FALSE); + ghb_settings_set_int(subdict, "SubtitleTrack", -1); + ghb_settings_set_boolean(subdict, "SubtitleForced", FALSE); + ghb_settings_set_boolean(subdict, "SubtitleBurned", FALSE); + ghb_settings_set_string(subdict, "SubtitleLanguage", "auto"); + ghb_add_subtitle(ud, subdict, FALSE); + + count = hb_list_count( title->list_subtitle ); + for (ii = 0; ii < count; ii++) + { + subtitle = (hb_subtitle_t*)hb_list_item( title->list_subtitle, ii ); + subdict = ghb_dict_value_new(); + ghb_settings_set_boolean(subdict, "SubtitleEnabled", FALSE); + ghb_settings_set_int(subdict, "SubtitleTrack", ii); + ghb_settings_set_boolean(subdict, "SubtitleForced", FALSE); + ghb_settings_set_boolean(subdict, "SubtitleBurned", FALSE); + ghb_settings_set_string(subdict, "SubtitleLanguage", + subtitle->iso639_2); + ghb_add_subtitle(ud, subdict, FALSE); + } +} + +gint +ghb_find_pref_subtitle_track(const gchar *lang) +{ + gint ii, count; + count = subtitle_opts.count; + for (ii = 0; ii < count; ii++) + { + if (strcmp(lang, subtitle_opts.map[ii].svalue) == 0) + { + return subtitle_opts.map[ii].ivalue; + } + } + return -1; +} + gint ghb_find_subtitle_track( gint titleindex, @@ -1990,8 +2047,7 @@ ghb_find_subtitle_track( hb_list_t * list; hb_title_t * title; hb_subtitle_t * subtitle; - gint ii; - gint count = 0; + gint count, ii; gboolean *used; g_debug("find_subtitle_track ()\n"); @@ -2023,20 +2079,8 @@ ghb_find_subtitle_track( return ii; } } - return -1; - } - else - { - count = subtitle_opts.count; - for (ii = 0; ii < count; ii++) - { - if (strcmp(lang, subtitle_opts.map[ii].svalue) == 0) - { - return subtitle_opts.map[ii].ivalue; - } - } - return -1; } + return -1; } gint @@ -4016,12 +4060,18 @@ add_job(hb_handle_t *h, GValue *js, gint unique_id, gint titleindex) for (ii = 0; ii < count; ii++) { GValue *ssettings; - gboolean burned, one_burned = FALSE; + gboolean burned, enabled, one_burned = FALSE; ssettings = ghb_array_get_nth(subtitle_list, ii); + enabled = ghb_settings_get_boolean(ssettings, "SubtitleEnabled"); + + if (!enabled) + continue; + subtitle = ghb_settings_get_int(ssettings, "SubtitleTrack"); burned = ghb_settings_get_boolean(ssettings, "SubtitleBurned"); + if (subtitle == -1) { job->indepth_scan = 1; diff --git a/gtk/src/hb-backend.h b/gtk/src/hb-backend.h index 0d98a8425..4b5589734 100644 --- a/gtk/src/hb-backend.h +++ b/gtk/src/hb-backend.h @@ -139,6 +139,8 @@ void ghb_update_ui_combo_box( signal_user_data_t *ud, const gchar *name, gint user_data, gboolean all); gint ghb_find_audio_track( gint titleindex, const gchar *lang, gint acodec, GHashTable *track_indices); +void ghb_add_all_subtitles(signal_user_data_t *ud, gint titleindex); +gint ghb_find_pref_subtitle_track(const gchar *lang); gint ghb_find_subtitle_track( gint titleindex, const gchar *lang, GHashTable *track_indices); gint ghb_pick_subtitle_track(signal_user_data_t *ud); diff --git a/gtk/src/main.c b/gtk/src/main.c index 74f7bf83a..9e214447d 100644 --- a/gtk/src/main.c +++ b/gtk/src/main.c @@ -377,6 +377,7 @@ bind_audio_tree_model (signal_user_data_t *ud) } extern G_MODULE_EXPORT void subtitle_list_selection_changed_cb(void); +extern G_MODULE_EXPORT void subtitle_enable_toggled_cb(void); extern G_MODULE_EXPORT void subtitle_forced_toggled_cb(void); extern G_MODULE_EXPORT void subtitle_burned_toggled_cb(void); extern G_MODULE_EXPORT void subtitle_track_changed_cb(void); @@ -398,41 +399,44 @@ bind_subtitle_tree_model (signal_user_data_t *ud) selection = gtk_tree_view_get_selection (treeview); // 6 columns in model. 4 are visible, the other 2 is for storing // values that I need - treestore = gtk_list_store_new(8, - G_TYPE_STRING, + treestore = gtk_list_store_new(7, + G_TYPE_BOOLEAN, G_TYPE_STRING, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, - G_TYPE_STRING, G_TYPE_STRING, - G_TYPE_STRING, G_TYPE_INT, - G_TYPE_INT); + G_TYPE_STRING, G_TYPE_STRING, + G_TYPE_BOOLEAN); gtk_tree_view_set_model(treeview, GTK_TREE_MODEL(treestore)); + cell = gtk_cell_renderer_toggle_new(); + column = gtk_tree_view_column_new_with_attributes( + _("On"), cell, "active", 0, NULL); + gtk_tree_view_append_column(treeview, GTK_TREE_VIEW_COLUMN(column)); + g_signal_connect(cell, "toggled", subtitle_enable_toggled_cb, ud); + cell = gtk_cell_renderer_combo_new(); ghb_subtitle_track_model(ud, -1); g_object_set(G_OBJECT(cell), "model", ud->subtitle_track_model, "text-column", 0, "editable", TRUE, "width", 200, "has-entry", FALSE, NULL); column = gtk_tree_view_column_new_with_attributes( _("Track"), cell, - "text", 0, "foreground", 5, "weight", 6, "style", 7, NULL); + "text", 1, NULL); gtk_tree_view_append_column(treeview, GTK_TREE_VIEW_COLUMN(column)); g_signal_connect(cell, "changed", subtitle_track_changed_cb, ud); cell = gtk_cell_renderer_toggle_new(); column = gtk_tree_view_column_new_with_attributes( - _("Forced Only"), cell, "active", 1, NULL); - gtk_tree_view_column_set_max_width (column, 50); + _("Forced Only"), cell, "active", 2, NULL); gtk_tree_view_append_column(treeview, GTK_TREE_VIEW_COLUMN(column)); g_signal_connect(cell, "toggled", subtitle_forced_toggled_cb, ud); cell = gtk_cell_renderer_toggle_new(); gtk_cell_renderer_toggle_set_radio(GTK_CELL_RENDERER_TOGGLE(cell), TRUE); column = gtk_tree_view_column_new_with_attributes( - _("Burned In"), cell, "active", 2, "cell-background", 5, NULL); - gtk_tree_view_column_set_max_width (column, 50); + _("Burned In"), cell, "active", 3, NULL); gtk_tree_view_append_column(treeview, GTK_TREE_VIEW_COLUMN(column)); g_signal_connect(cell, "toggled", subtitle_burned_toggled_cb, ud); cell = gtk_cell_renderer_text_new(); column = gtk_tree_view_column_new_with_attributes( - _("Type"), cell, "text", 3, NULL); + _("Type"), cell, "text", 4, NULL); gtk_tree_view_append_column(treeview, GTK_TREE_VIEW_COLUMN(column)); diff --git a/gtk/src/presets.c b/gtk/src/presets.c index 35f7b9c4b..fafdd7fde 100644 --- a/gtk/src/presets.c +++ b/gtk/src/presets.c @@ -1133,14 +1133,14 @@ ghb_prefs_to_ui(signal_user_data_t *ud) // pointer will break strict-aliasing rules" while (g_hash_table_iter_next( &iter, (gpointer*)(void*)&key, (gpointer*)(void*)&gval)) - { + { const GValue *value = NULL; if (dict) value = ghb_dict_lookup(dict, key); if (value == NULL) value = gval; ghb_settings_set_value(ud->settings, key, value); - } + } internal = plist_get_dict(internalPlist, "Preferences"); ghb_dict_iter_init(&iter, internal); // middle (void*) cast prevents gcc warning "defreferencing type-punned @@ -1203,12 +1203,12 @@ ghb_prefs_save(GValue *settings) // pointer will break strict-aliasing rules" while (g_hash_table_iter_next( &iter, (gpointer*)(void*)&key, (gpointer*)(void*)&value)) - { - value = ghb_settings_get_value(settings, key); - if (value != NULL) - { + { + value = ghb_settings_get_value(settings, key); + if (value != NULL) + { ghb_dict_insert(pref_dict, g_strdup(key), ghb_value_dup(value)); - } + } } store_prefs(); prefs_modified = FALSE; @@ -1371,20 +1371,20 @@ ghb_prefs_load(signal_user_data_t *ud) prefsPlist = ghb_dict_value_new(); dict = plist_get_dict(prefsPlist, "Preferences"); internal = plist_get_dict(internalPlist, "Preferences"); - if (dict == NULL && internal) - { + if (dict == NULL && internal) + { dict = ghb_dict_value_new(); ghb_dict_insert(prefsPlist, g_strdup("Preferences"), dict); - // Get defaults from internal defaults + // Get defaults from internal defaults ghb_dict_iter_init(&iter, internal); // middle (void*) cast prevents gcc warning "defreferencing type-punned // pointer will break strict-aliasing rules" while (g_hash_table_iter_next( &iter, (gpointer*)(void*)&key, (gpointer*)(void*)&gval)) - { + { ghb_dict_insert(dict, g_strdup(key), ghb_value_dup(gval)); - } + } const gchar *dir = g_get_user_special_dir (G_USER_DIRECTORY_VIDEOS); if (dir == NULL) { @@ -1405,7 +1405,7 @@ ghb_prefs_load(signal_user_data_t *ud) g_free(source); #endif store_prefs(); - } + } // Read legacy default_preset preference and update accordingly path = ghb_dict_lookup(dict, "default_preset"); if (path) @@ -2618,7 +2618,7 @@ ghb_presets_reload(signal_user_data_t *ud) if (std_presets == NULL) return; remove_std_presets(ud); - indices = presets_find_default(presetsPlist, &len); + indices = presets_find_default(presetsPlist, &len); if (indices) { presets_clear_default(std_presets); @@ -2946,10 +2946,23 @@ static void update_subtitle_presets(signal_user_data_t *ud) { g_debug("update_subtitle_presets"); - const GValue *subtitle_list; + const GValue *subtitle_list, *subtitle; + GValue *slist, *dict; + gint count, ii; subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); - ghb_settings_set_value(ud->settings, "SubtitleList", subtitle_list); + slist = ghb_array_value_new(8); + count = ghb_array_len(subtitle_list); + for (ii = 0; ii < count; ii++) + { + subtitle = ghb_array_get_nth(subtitle_list, ii); + if (ghb_settings_get_boolean(subtitle, "SubtitleEnabled")) + { + dict = ghb_value_dup(subtitle); + ghb_array_append(slist, dict); + } + } + ghb_settings_set_value(ud->settings, "SubtitleList", slist); } void diff --git a/gtk/src/subtitlehandler.c b/gtk/src/subtitlehandler.c index 06ed0ec0b..b3b3a9bbf 100644 --- a/gtk/src/subtitlehandler.c +++ b/gtk/src/subtitlehandler.c @@ -20,7 +20,8 @@ #include "preview.h" #include "subtitlehandler.h" -static void add_to_subtitle_list(signal_user_data_t *ud, GValue *settings); +static void add_to_subtitle_list( + signal_user_data_t *ud, GValue *settings, gboolean can_delete); void free_subtitle_index_list(gpointer data) @@ -35,15 +36,13 @@ free_subtitle_key(gpointer data) g_free(data); } -static void -add_pref(signal_user_data_t *ud, GValue *settings) +void +ghb_add_subtitle(signal_user_data_t *ud, GValue *settings, gboolean can_delete) { // Add the current subtitle settings to the list. - GtkWidget *widget; - gint count; GValue *subtitle_list; - g_debug("add_pref ()"); + g_debug("ghb_add_subtitle ()"); // Only allow up to 8 subtitle entries subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); @@ -53,12 +52,35 @@ add_pref(signal_user_data_t *ud, GValue *settings) ghb_settings_set_value(ud->settings, "subtitle_list", subtitle_list); } ghb_array_append(subtitle_list, settings); - add_to_subtitle_list(ud, settings); - count = ghb_array_len(subtitle_list); - if (count >= 8) + add_to_subtitle_list(ud, settings, can_delete); +} + +static void +add_all_pref_subtitles(signal_user_data_t *ud) +{ + const GValue *pref_subtitle; + GValue *subtitle; + gint count, ii, track; + char *lang; + + pref_subtitle = ghb_settings_get_value(ud->settings, "SubtitleList"); + count = ghb_array_len(pref_subtitle); + for (ii = 0; ii < count; ii++) { - widget = GHB_WIDGET(ud->builder, "subtitle_add"); - gtk_widget_set_sensitive(widget, FALSE); + subtitle = ghb_value_dup(ghb_array_get_nth(pref_subtitle, ii)); + ghb_settings_set_boolean(subtitle, "SubtitleEnabled", TRUE); + lang = ghb_settings_get_string(subtitle, "SubtitleLanguage"); + // If there are multiple subtitles using the same language, then + // select sequential tracks for each. The hash keeps track + // of the tracks used for each language. + track = ghb_find_pref_subtitle_track(lang); + g_free(lang); + if (track >= 0) + { + // Add to subtitle list + ghb_settings_set_int(subtitle, "SubtitleTrack", track); + ghb_add_subtitle(ud, subtitle, TRUE); + } } } @@ -74,11 +96,17 @@ ghb_set_pref_subtitle(gint titleindex, signal_user_data_t *ud) GValue *subtitle; gint count, ii; - g_debug("ghb_set_pref_subtitle"); + g_debug("ghb_set_pref_subtitle %d", titleindex); track_indices = g_hash_table_new_full(g_str_hash, g_str_equal, NULL, free_subtitle_index_list); // Clear the subtitle list ghb_clear_subtitle_list(ud); + if (titleindex < 0) + { + add_all_pref_subtitles(ud); + return; + } + ghb_add_all_subtitles(ud, titleindex); // Find "best" subtitle based on subtitle preferences button = GHB_WIDGET (ud->builder, "subtitle_add"); @@ -87,7 +115,7 @@ ghb_set_pref_subtitle(gint titleindex, signal_user_data_t *ud) count = ghb_array_len(pref_subtitle); for (ii = 0; ii < count; ii++) { - subtitle = ghb_value_dup(ghb_array_get_nth(pref_subtitle, ii)); + subtitle = ghb_array_get_nth(pref_subtitle, ii); lang = ghb_settings_get_string(subtitle, "SubtitleLanguage"); // If there are multiple subtitles using the same language, then // select sequential tracks for each. The hash keeps track @@ -96,9 +124,8 @@ ghb_set_pref_subtitle(gint titleindex, signal_user_data_t *ud) g_free(lang); if (track >= 0) { - ghb_settings_set_int(subtitle, "SubtitleTrack", track); // Add to subtitle list - add_pref(ud, subtitle); + ghb_set_subtitle(ud, track, subtitle); } } g_hash_table_destroy(track_indices); @@ -183,8 +210,47 @@ ghb_selected_subtitle_settings(signal_user_data_t *ud) return settings; } +void +ghb_subtitle_exclusive_burn(signal_user_data_t *ud, gint track) +{ + GValue *subtitle_list; + GValue *settings; + gint ii, count, tt; + GtkTreeView *tv; + GtkTreeModel *tm; + GtkTreeIter ti; + gboolean burned; + + g_debug("ghb_subtitle_exclusive_burn"); + subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); + count = ghb_array_len(subtitle_list); + for (ii = 0; ii < count; ii++) + { + settings = ghb_array_get_nth(subtitle_list, ii); + tt = ghb_settings_combo_int(settings, "SubtitleTrack"); + burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); + + tv = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); + g_return_if_fail(tv != NULL); + tm = gtk_tree_view_get_model(tv); + gtk_tree_model_iter_nth_child(tm, &ti, NULL, ii); + if (burned && tt != track) + { + + ghb_settings_set_boolean(settings, "SubtitleBurned", FALSE); + burned = FALSE; + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 3, FALSE, -1); + } + if (!burned && mustBurn(ud, tt)) + { + ghb_settings_set_boolean(settings, "SubtitleEnabled", FALSE); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 0, FALSE, -1); + } + } +} + G_MODULE_EXPORT void -subtitle_forced_toggled_cb( +subtitle_enable_toggled_cb( GtkCellRendererToggle *cell, gchar *path, signal_user_data_t *ud) @@ -196,6 +262,8 @@ subtitle_forced_toggled_cb( gint row; GtkTreePath *tp; gint *indices; + GValue *subtitle_list, *settings; + gint track; g_debug("forced toggled"); tp = gtk_tree_path_new_from_string (path); @@ -204,81 +272,77 @@ subtitle_forced_toggled_cb( tm = gtk_tree_view_get_model(tv); g_return_if_fail(tm != NULL); gtk_tree_model_get_iter(tm, &ti, tp); - gtk_tree_model_get(tm, &ti, 1, &active, -1); + gtk_tree_model_get(tm, &ti, 0, &active, -1); active ^= 1; // Get the row number indices = gtk_tree_path_get_indices (tp); row = indices[0]; gtk_tree_path_free(tp); + subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); - if (row >= 0) - { - GValue *subtitle_list, *settings; - gint source, track; - - subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); - - settings = ghb_array_get_nth(subtitle_list, row); - track = ghb_settings_combo_int(settings, "SubtitleTrack"); - - source = ghb_subtitle_track_source(ud, track); - if (source != VOBSUB) - return; + if (row < 0 || row >= ghb_array_len(subtitle_list)) + return; - if (row < ghb_array_len(subtitle_list)) - { - GValue *settings; + settings = ghb_array_get_nth(subtitle_list, row); + track = ghb_settings_combo_int(settings, "SubtitleTrack"); - settings = ghb_array_get_nth(subtitle_list, row); - ghb_settings_set_boolean(settings, "SubtitleForced", active); - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 1, active, -1); - } + if (active && mustBurn(ud, track)) + { + ghb_settings_set_boolean(settings, "SubtitleBurned", TRUE); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 3, TRUE, -1); + ghb_subtitle_exclusive_burn(ud, track); } + + ghb_settings_set_boolean(settings, "SubtitleEnabled", active); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 0, active, -1); } -void -ghb_subtitle_exclusive_burn(signal_user_data_t *ud, gint track) +G_MODULE_EXPORT void +subtitle_forced_toggled_cb( + GtkCellRendererToggle *cell, + gchar *path, + signal_user_data_t *ud) { - GValue *subtitle_list; - GValue *settings; - gint ii, count, tt; GtkTreeView *tv; GtkTreeModel *tm; GtkTreeIter ti; - gboolean burned; + gboolean active; + gint row; + GtkTreePath *tp; + gint *indices; + GValue *subtitle_list, *settings; + gint source, track; + + g_debug("forced toggled"); + tp = gtk_tree_path_new_from_string (path); + tv = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); + g_return_if_fail(tv != NULL); + tm = gtk_tree_view_get_model(tv); + g_return_if_fail(tm != NULL); + gtk_tree_model_get_iter(tm, &ti, tp); + gtk_tree_model_get(tm, &ti, 2, &active, -1); + active ^= 1; + + // Get the row number + indices = gtk_tree_path_get_indices (tp); + row = indices[0]; + gtk_tree_path_free(tp); - g_debug("ghb_subtitle_exclusive_burn"); subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); - count = ghb_array_len(subtitle_list); - for (ii = 0; ii < count; ii++) - { - settings = ghb_array_get_nth(subtitle_list, ii); - tt = ghb_settings_combo_int(settings, "SubtitleTrack"); - burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); - tv = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); - g_return_if_fail(tv != NULL); - tm = gtk_tree_view_get_model(tv); - gtk_tree_model_iter_nth_child(tm, &ti, NULL, ii); - if (burned && tt != track) - { + if (row < 0 || row >= ghb_array_len(subtitle_list)) + return; - ghb_settings_set_boolean(settings, "SubtitleBurned", FALSE); - burned = FALSE; - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 2, FALSE, -1); - } - if (!burned && mustBurn(ud, tt)) - { - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, - 5, "red", 6, 800, 7, 2, -1); - } - else - { - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, - 5, NULL, 6, 400, 7, 0, -1); - } - } + settings = ghb_array_get_nth(subtitle_list, row); + track = ghb_settings_combo_int(settings, "SubtitleTrack"); + + source = ghb_subtitle_track_source(ud, track); + if (source != VOBSUB) + return; + + ghb_settings_set_boolean(settings, "SubtitleForced", active); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 2, active, -1); } G_MODULE_EXPORT void @@ -305,7 +369,7 @@ subtitle_burned_toggled_cb( tm = gtk_tree_view_get_model(tv); g_return_if_fail(tm != NULL); gtk_tree_model_get_iter(tm, &ti, tp); - gtk_tree_model_get(tm, &ti, 2, &active, -1); + gtk_tree_model_get(tm, &ti, 3, &active, -1); active ^= 1; // Get the row number @@ -330,7 +394,7 @@ subtitle_burned_toggled_cb( ghb_settings_set_boolean(settings, "SubtitleBurned", active); - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 2, active, -1); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 3, active, -1); // Unburn the rest ghb_subtitle_exclusive_burn(ud, track); } @@ -408,43 +472,25 @@ subtitle_track_changed_cb( } ghb_settings_set_string(settings, "SubtitleLanguage", lang); - const gchar *track, *source, *color; - gboolean forced, burned; + const gchar *track, *source; + gboolean burned; gchar *s_track; - gint i_track, weight, style; + gint i_track; track = ghb_settings_combo_option(settings, "SubtitleTrack"); - forced = ghb_settings_get_boolean(settings, "SubtitleForced"); burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); s_track = ghb_settings_get_string(settings, "SubtitleTrack"); i_track = ghb_settings_get_int(settings, "SubtitleTrack"); source = ghb_subtitle_track_source_name(ud, i_track); - if (!burned && mustBurn(ud, i_track)) - { - weight = 800; - style = 2; - color = "red"; - } - else - { - weight = 400; - style = 0; - color = NULL; - } - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, // These are displayed in list - 0, track, - 1, forced, - 2, burned, - 3, source, + 1, track, + 3, burned, + 4, source, // These are used to set combo values when a list item is selected - 4, s_track, - 5, color, - 6, weight, - 7, style, + 5, s_track, -1); g_free(s_track); ghb_live_reset(ud); @@ -460,8 +506,7 @@ ghb_subtitle_adjust_burn(signal_user_data_t *ud) GtkTreeView *tv; GtkTreeModel *tm; GtkTreeIter ti; - gboolean burned; - gint burned_count = 0; + gboolean burned, enabled, found; g_debug("ghb_subtitle_adjust_burn"); subtitle_list = ghb_settings_get_value(ud->settings, "subtitle_list"); @@ -469,39 +514,46 @@ ghb_subtitle_adjust_burn(signal_user_data_t *ud) for (ii = 0; ii < count; ii++) { settings = ghb_array_get_nth(subtitle_list, ii); - track = ghb_settings_combo_int(settings, "SubtitleTrack"); - if (mustBurn(ud, track)) + enabled = ghb_settings_get_boolean(settings, "SubtitleEnabled"); + burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); + if (enabled && burned) { - burned_count++; + found = TRUE; + break; } } for (ii = 0; ii < count; ii++) { settings = ghb_array_get_nth(subtitle_list, ii); track = ghb_settings_combo_int(settings, "SubtitleTrack"); + + if (!mustBurn(ud, track)) + continue; + + enabled = ghb_settings_get_boolean(settings, "SubtitleEnabled"); burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); tv = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); g_return_if_fail(tv != NULL); tm = gtk_tree_view_get_model(tv); gtk_tree_model_iter_nth_child(tm, &ti, NULL, ii); - if (!burned && mustBurn(ud, track)) + + if (!found) { - if (burned_count > 1) - { - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, - 5, "red", 6, 800, 7, 2, -1); - } - else + if (enabled && !burned) { ghb_settings_set_boolean(settings, "SubtitleBurned", TRUE); - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 2, TRUE, -1); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 3, TRUE, -1); + found = TRUE; } } else { - gtk_list_store_set(GTK_LIST_STORE(tm), &ti, - 5, NULL, 6, 400, 7, 0, -1); + if (enabled && !burned) + { + ghb_settings_set_boolean(settings, "SubtitleEnabled", FALSE); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, 0, FALSE, -1); + } } } } @@ -528,16 +580,19 @@ ghb_clear_subtitle_list(signal_user_data_t *ud) } static void -add_to_subtitle_list(signal_user_data_t *ud, GValue *settings) +add_to_subtitle_list( + signal_user_data_t *ud, + GValue *settings, + gboolean can_delete) { GtkTreeView *treeview; GtkTreeIter iter; GtkListStore *store; GtkTreeSelection *selection; - const gchar *track, *source, *color; - gboolean forced, burned; + const gchar *track, *source; + gboolean forced, burned, enabled; gchar *s_track; - gint i_track, weight, style; + gint i_track; g_debug("add_to_subtitle_list ()"); treeview = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); @@ -545,6 +600,7 @@ add_to_subtitle_list(signal_user_data_t *ud, GValue *settings) store = GTK_LIST_STORE(gtk_tree_view_get_model(treeview)); track = ghb_settings_combo_option(settings, "SubtitleTrack"); + enabled = ghb_settings_get_boolean(settings, "SubtitleEnabled"); forced = ghb_settings_get_boolean(settings, "SubtitleForced"); burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); @@ -552,31 +608,17 @@ add_to_subtitle_list(signal_user_data_t *ud, GValue *settings) i_track = ghb_settings_get_int(settings, "SubtitleTrack"); source = ghb_subtitle_track_source_name(ud, i_track); - if (!burned && mustBurn(ud, i_track)) - { - weight = 800; - style = 2; - color = "red"; - } - else - { - weight = 400; - style = 0; - color = NULL; - } - gtk_list_store_append(store, &iter); gtk_list_store_set(store, &iter, // These are displayed in list - 0, track, - 1, forced, - 2, burned, - 3, source, + 0, enabled, + 1, track, + 2, forced, + 3, burned, + 4, source, // These are used to set combo box values when a list item is selected - 4, s_track, - 5, color, - 6, weight, - 7, style, + 5, s_track, + 6, can_delete, -1); gtk_tree_selection_select_iter(selection, &iter); g_free(s_track); @@ -595,17 +637,21 @@ subtitle_list_selection_changed_cb(GtkTreeSelection *selection, signal_user_data if (gtk_tree_selection_get_selected(selection, &store, &iter)) { const gchar *track; + gboolean can_delete; - gtk_tree_model_get(store, &iter, 4, &track, -1); + gtk_tree_model_get(store, &iter, 5, &track, 6, &can_delete, -1); ghb_settings_set_string(ud->settings, "SubtitleTrack", track); - widget = GHB_WIDGET (ud->builder, "subtitle_remove"); - gtk_widget_set_sensitive(widget, TRUE); - } - else - { - widget = GHB_WIDGET (ud->builder, "subtitle_remove"); - gtk_widget_set_sensitive(widget, FALSE); + if (can_delete) + { + widget = GHB_WIDGET (ud->builder, "subtitle_remove"); + gtk_widget_set_sensitive(widget, TRUE); + } + else + { + widget = GHB_WIDGET (ud->builder, "subtitle_remove"); + gtk_widget_set_sensitive(widget, FALSE); + } } } @@ -631,6 +677,7 @@ subtitle_add_clicked_cb(GtkWidget *xwidget, signal_user_data_t *ud) settings = ghb_dict_value_new(); // Only allow up to 8 subtitle entries ghb_settings_set_int(settings, "SubtitleTrack", track); + ghb_settings_set_boolean(settings, "SubtitleEnabled", TRUE); ghb_settings_take_value(settings, "SubtitleForced", ghb_boolean_value_new(FALSE)); ghb_settings_take_value(settings, "SubtitleBurned", @@ -643,12 +690,8 @@ subtitle_add_clicked_cb(GtkWidget *xwidget, signal_user_data_t *ud) ghb_settings_set_value(ud->settings, "subtitle_list", subtitle_list); } ghb_array_append(subtitle_list, settings); - add_to_subtitle_list(ud, settings); + add_to_subtitle_list(ud, settings, TRUE); count = ghb_array_len(subtitle_list); - if (count >= 8) - { - gtk_widget_set_sensitive(xwidget, FALSE); - } } G_MODULE_EXPORT void @@ -702,36 +745,45 @@ subtitle_remove_clicked_cb(GtkWidget *widget, signal_user_data_t *ud) } void -ghb_set_subtitle(signal_user_data_t *ud, GValue *settings) +ghb_set_subtitle(signal_user_data_t *ud, gint track, GValue *settings) { - GtkWidget *button; - + GtkTreeView *tv; + GtkTreeModel *tm; + GtkTreeIter ti; GValue *slist; - GValue *track, *subtitle; - //GValue *forced, *burned; - gint count, ii, i_track; + GValue *subtitle; + gint count, ii, tt; + gboolean forced, burned; - g_debug("set_subtitle"); - // Clear the subtitle list - ghb_clear_subtitle_list(ud); - button = GHB_WIDGET (ud->builder, "subtitle_add"); - slist = ghb_settings_get_value(settings, "subtitle_list"); + g_debug("ghb_set_subtitle"); + slist = ghb_settings_get_value(ud->settings, "subtitle_list"); count = ghb_array_len(slist); for (ii = 0; ii < count; ii++) { subtitle = ghb_array_get_nth(slist, ii); - track = ghb_settings_get_value(subtitle, "SubtitleTrack"); - i_track = ghb_settings_get_int(subtitle, "SubtitleTrack"); - //forced = ghb_settings_get_value(subtitle, "SubtitleForced"); - //burned = ghb_settings_get_value(subtitle, "SubtitleBurned"); + tt = ghb_settings_get_int(subtitle, "SubtitleTrack"); + if (track != tt) + continue; + + forced = ghb_settings_get_boolean(settings, "SubtitleForced"); + burned = ghb_settings_get_boolean(settings, "SubtitleBurned"); - if (i_track != -2) - { - // Add to subtitle list - g_signal_emit_by_name(button, "clicked", ud); - ghb_ui_update(ud, "AudioTrack", track); - } + tv = GTK_TREE_VIEW(GHB_WIDGET(ud->builder, "subtitle_list")); + g_return_if_fail(tv != NULL); + tm = gtk_tree_view_get_model(tv); + gtk_tree_model_iter_nth_child(tm, &ti, NULL, ii); + + ghb_settings_set_boolean(subtitle, "SubtitleEnabled", TRUE); + ghb_settings_set_boolean(subtitle, "SubtitleForced", forced); + ghb_settings_set_boolean(subtitle, "SubtitleBurned", burned); + gtk_list_store_set(GTK_LIST_STORE(tm), &ti, + 0, TRUE, + 2, forced, + 3, burned, + 6, FALSE, + -1); + break; } } diff --git a/gtk/src/subtitlehandler.h b/gtk/src/subtitlehandler.h index 9b37e58aa..eb9ce78e9 100644 --- a/gtk/src/subtitlehandler.h +++ b/gtk/src/subtitlehandler.h @@ -29,9 +29,11 @@ void ghb_set_pref_subtitle(gint titleindex, signal_user_data_t *ud); void ghb_clear_subtitle_list(signal_user_data_t *ud); -void ghb_set_subtitle(signal_user_data_t *ud, GValue *settings); +void ghb_set_subtitle(signal_user_data_t *ud, gint track, GValue *settings); void ghb_subtitle_adjust_burn(signal_user_data_t *ud); GValue* ghb_selected_subtitle_settings(signal_user_data_t *ud); gint ghb_selected_subtitle_row(signal_user_data_t *ud); +void ghb_add_subtitle( + signal_user_data_t *ud, GValue *settings, gboolean can_delete); #endif // _SUBTITLEHANDLER_H_ |