summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Stebbins <[email protected]>2015-10-01 14:35:50 -0700
committerJohn Stebbins <[email protected]>2015-10-01 14:35:50 -0700
commit8522e451c0e9c768f60d3a6cd92f61f4ce83c326 (patch)
tree518957913bc794fe7fda4c2d67fc2bfc692c29b0
parent74d6f3349fc8c3e1b99363fde967c2fccf6253de (diff)
LinGui: use libhb filter param lists
Populate combo boxes from libhb param lists instead of duplicating info in LinGui.
-rw-r--r--gtk/src/hb-backend.c370
1 files changed, 271 insertions, 99 deletions
diff --git a/gtk/src/hb-backend.c b/gtk/src/hb-backend.c
index db8dce0b4..dc0372c30 100644
--- a/gtk/src/hb-backend.c
+++ b/gtk/src/hb-backend.c
@@ -196,47 +196,6 @@ combo_opts_t vqual_granularity_opts =
d_vqual_granularity_opts
};
-static options_map_t d_detel_opts[] =
-{
- {N_("Off"), "off", 0, ""},
- {N_("Custom"), "custom", 1, ""},
- {N_("Default"),"default",2, NULL},
-};
-combo_opts_t detel_opts =
-{
- sizeof(d_detel_opts)/sizeof(options_map_t),
- d_detel_opts
-};
-
-static options_map_t d_decomb_opts[] =
-{
- {N_("Off"), "off", 0, ""},
- {N_("Custom"), "custom", 1, ""},
- {N_("Default"),"default",2, NULL},
- {N_("Fast"), "fast", 3, "7:2:6:9:1:80"},
- {N_("Bob"), "bob", 4, "455"},
-};
-combo_opts_t decomb_opts =
-{
- sizeof(d_decomb_opts)/sizeof(options_map_t),
- d_decomb_opts
-};
-
-static options_map_t d_deint_opts[] =
-{
- {N_("Off"), "off", 0, ""},
- {N_("Custom"), "custom", 1, ""},
- {N_("Fast"), "fast", 2, "0:-1:-1:0:1"},
- {N_("Slow"), "slow", 3, "1:-1:-1:0:1"},
- {N_("Slower"), "slower", 4, "3:-1:-1:0:1"},
- {N_("Bob"), "bob", 5, "15:-1:-1:0:1"},
-};
-combo_opts_t deint_opts =
-{
- sizeof(d_deint_opts)/sizeof(options_map_t),
- d_deint_opts
-};
-
static options_map_t d_denoise_opts[] =
{
{N_("Off"), "off", 0, ""},
@@ -249,34 +208,6 @@ combo_opts_t denoise_opts =
d_denoise_opts
};
-static options_map_t d_denoise_preset_opts[] =
-{
- {N_("Custom"), "custom", 1, ""},
- {N_("Ultralight"), "ultralight", 5, ""},
- {N_("Light"), "light", 2, ""},
- {N_("Medium"), "medium", 3, ""},
- {N_("Strong"), "strong", 4, ""},
-};
-combo_opts_t denoise_preset_opts =
-{
- sizeof(d_denoise_preset_opts)/sizeof(options_map_t),
- d_denoise_preset_opts
-};
-
-static options_map_t d_nlmeans_tune_opts[] =
-{
- {N_("None"), "none", 0, ""},
- {N_("Film"), "film", 1, ""},
- {N_("Grain"), "grain", 2, ""},
- {N_("High Motion"), "highmotion", 3, ""},
- {N_("Animation"), "animation", 4, ""},
-};
-combo_opts_t nlmeans_tune_opts =
-{
- sizeof(d_nlmeans_tune_opts)/sizeof(options_map_t),
- d_nlmeans_tune_opts
-};
-
static options_map_t d_direct_opts[] =
{
{N_("None"), "none", 0, "none"},
@@ -433,8 +364,31 @@ static void video_level_opts_set(signal_user_data_t *ud, const gchar *name,
combo_opts_t *opts, const void* data);
static void container_opts_set(signal_user_data_t *ud, const gchar *name,
combo_opts_t *opts, const void* data);
+static void deint_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data);
+static void decomb_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data);
+static void detel_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data);
+static void denoise_preset_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data);
+static void denoise_tune_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data);
+
static GhbValue * generic_opt_get(const char *name, const combo_opts_t *opts,
const GhbValue *gval, GhbType type);
+static GhbValue * deint_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type);
+static GhbValue * decomb_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type);
+static GhbValue * detel_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type);
+static GhbValue *
+denoise_preset_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type);
+static GhbValue *
+denoise_tune_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type);
combo_name_map_t combo_name_map[] =
{
@@ -506,21 +460,21 @@ combo_name_map_t combo_name_map[] =
},
{
"PictureDeinterlace",
- &deint_opts,
- small_opts_set,
- generic_opt_get
+ NULL,
+ deint_opts_set,
+ deint_opt_get
},
{
"PictureDecomb",
- &decomb_opts,
- small_opts_set,
- generic_opt_get
+ NULL,
+ decomb_opts_set,
+ decomb_opt_get
},
{
"PictureDetelecine",
- &detel_opts,
- small_opts_set,
- generic_opt_get
+ NULL,
+ detel_opts_set,
+ detel_opt_get
},
{
"PictureDenoiseFilter",
@@ -530,15 +484,15 @@ combo_name_map_t combo_name_map[] =
},
{
"PictureDenoisePreset",
- &denoise_preset_opts,
- small_opts_set,
- generic_opt_get
+ NULL,
+ denoise_preset_opts_set,
+ denoise_preset_opt_get
},
{
"PictureDenoiseTune",
- &nlmeans_tune_opts,
- small_opts_set,
- generic_opt_get
+ NULL,
+ denoise_tune_opts_set,
+ denoise_tune_opt_get
},
{
"x264_direct",
@@ -1064,7 +1018,7 @@ ghb_vquality_range(
}
gint
-find_combo_entry(const combo_opts_t *opts, const GhbValue *gval)
+find_opt_entry(const combo_opts_t *opts, const GhbValue *gval)
{
gint ii;
@@ -1077,41 +1031,68 @@ find_combo_entry(const combo_opts_t *opts, const GhbValue *gval)
str = ghb_value_get_string(gval);
for (ii = 0; ii < opts->count; ii++)
{
- if (strcmp(opts->map[ii].shortOpt, str) == 0)
+ if (strcmp(opts->map[ii].shortOpt, str) == 0 ||
+ strcmp(opts->map[ii].option, str) == 0)
{
break;
}
}
return ii;
}
- else if (ghb_value_type(gval) == GHB_DOUBLE)
+ else if (ghb_value_type(gval) == GHB_INT ||
+ ghb_value_type(gval) == GHB_DOUBLE ||
+ ghb_value_type(gval) == GHB_BOOL)
{
- gdouble val;
- val = ghb_value_get_double(gval);
+ gint64 val;
+ val = ghb_value_get_int(gval);
for (ii = 0; ii < opts->count; ii++)
{
- if (opts->map[ii].ivalue == val)
+ if ((gint64)opts->map[ii].ivalue == val)
{
break;
}
}
return ii;
}
+ return opts->count;
+}
+
+const hb_filter_param_t*
+find_param_entry(const hb_filter_param_t *param, const GhbValue *gval)
+{
+ gint ii;
+
+ if (param == NULL)
+ return NULL;
+
+ if (ghb_value_type(gval) == GHB_STRING)
+ {
+ const gchar *str;
+ str = ghb_value_get_string(gval);
+ for (ii = 0; param[ii].name != NULL; ii++)
+ {
+ if (strcmp(param[ii].short_name, str) == 0 ||
+ strcmp(param[ii].name, str) == 0)
+ {
+ return &param[ii];
+ }
+ }
+ }
else if (ghb_value_type(gval) == GHB_INT ||
+ ghb_value_type(gval) == GHB_DOUBLE ||
ghb_value_type(gval) == GHB_BOOL)
{
gint64 val;
val = ghb_value_get_int(gval);
- for (ii = 0; ii < opts->count; ii++)
+ for (ii = 0; param[ii].name != NULL; ii++)
{
- if ((gint64)opts->map[ii].ivalue == val)
+ if ((gint64)param[ii].index == val)
{
- break;
+ return &param[ii];
}
}
- return ii;
}
- return opts->count;
+ return NULL;
}
static gint
@@ -1123,7 +1104,7 @@ lookup_generic_int(const combo_opts_t *opts, const GhbValue *gval)
if (opts == NULL)
return 0;
- ii = find_combo_entry(opts, gval);
+ ii = find_opt_entry(opts, gval);
if (ii < opts->count)
{
result = opts->map[ii].ivalue;
@@ -1137,7 +1118,7 @@ lookup_generic_double(const combo_opts_t *opts, const GhbValue *gval)
gint ii;
gdouble result = -1;
- ii = find_combo_entry(opts, gval);
+ ii = find_opt_entry(opts, gval);
if (ii < opts->count)
{
result = opts->map[ii].ivalue;
@@ -1151,7 +1132,7 @@ lookup_generic_option(const combo_opts_t *opts, const GhbValue *gval)
gint ii;
const gchar *result = "";
- ii = find_combo_entry(opts, gval);
+ ii = find_opt_entry(opts, gval);
if (ii < opts->count)
{
result = opts->map[ii].option;
@@ -1159,6 +1140,37 @@ lookup_generic_option(const combo_opts_t *opts, const GhbValue *gval)
return result;
}
+static gint
+lookup_param_int(const hb_filter_param_t *param, const GhbValue *gval)
+{
+ gint result = -1;
+
+ if (param == NULL)
+ return result;
+
+ const hb_filter_param_t *entry;
+ entry = find_param_entry(param, gval);
+ if (entry != NULL)
+ {
+ result = entry->index;
+ }
+ return result;
+}
+
+static const gchar*
+lookup_param_option(const hb_filter_param_t *param, const GhbValue *gval)
+{
+ const gchar *result = "";
+
+ const hb_filter_param_t *entry;
+ entry = find_param_entry(param, gval);
+ if (entry != NULL)
+ {
+ result = entry->name;
+ }
+ return result;
+}
+
gint
ghb_find_closest_audio_samplerate(gint irate)
{
@@ -2665,6 +2677,90 @@ small_opts_set(signal_user_data_t *ud, const gchar *name,
}
}
+static void
+filter_opts_set(signal_user_data_t *ud, const gchar *name,
+ int filter_id, int preset)
+{
+ GtkTreeIter iter;
+ GtkListStore *store;
+ gint ii;
+ gchar *str;
+
+ if (name == NULL) return;
+ GtkComboBox *combo = GTK_COMBO_BOX(GHB_WIDGET(ud->builder, name));
+ store = GTK_LIST_STORE(gtk_combo_box_get_model (combo));
+ gtk_list_store_clear(store);
+ hb_filter_param_t * param;
+ if (preset)
+ {
+ param = hb_filter_param_get_presets(filter_id);
+ }
+ else
+ {
+ param = hb_filter_param_get_tunes(filter_id);
+ }
+ for (ii = 0; param != NULL && param[ii].name != NULL; ii++)
+ {
+ gtk_list_store_append(store, &iter);
+ str = g_strdup_printf("<small>%s</small>",
+ gettext(param[ii].name));
+ gtk_list_store_set(store, &iter,
+ 0, str,
+ 1, TRUE,
+ 2, param[ii].short_name,
+ 3, (double)param[ii].index,
+ 4, param[ii].settings != NULL ?
+ param[ii].settings : "",
+ -1);
+ g_free(str);
+ }
+}
+
+static void
+deint_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data)
+{
+ (void)opts; // Silence "unused variable" warning
+ (void)data; // Silence "unused variable" warning
+ filter_opts_set(ud, name, HB_FILTER_DEINTERLACE, 1);
+}
+
+static void
+decomb_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data)
+{
+ (void)opts; // Silence "unused variable" warning
+ (void)data; // Silence "unused variable" warning
+ filter_opts_set(ud, name, HB_FILTER_DECOMB, 1);
+}
+
+static void
+detel_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data)
+{
+ (void)opts; // Silence "unused variable" warning
+ (void)data; // Silence "unused variable" warning
+ filter_opts_set(ud, name, HB_FILTER_DETELECINE, 1);
+}
+
+static void
+denoise_preset_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data)
+{
+ (void)opts; // Silence "unused variable" warning
+ (void)data; // Silence "unused variable" warning
+ filter_opts_set(ud, name, HB_FILTER_NLMEANS, 1);
+}
+
+static void
+denoise_tune_opts_set(signal_user_data_t *ud, const gchar *name,
+ combo_opts_t *opts, const void* data)
+{
+ (void)opts; // Silence "unused variable" warning
+ (void)data; // Silence "unused variable" warning
+ filter_opts_set(ud, name, HB_FILTER_NLMEANS, 0);
+}
+
combo_name_map_t*
find_combo_map(const gchar *name)
{
@@ -2699,6 +2795,7 @@ generic_opt_get(const char *name, const combo_opts_t *opts,
switch (type)
{
case GHB_INT:
+ case GHB_BOOL:
{
int val;
val = lookup_generic_int(opts, gval);
@@ -2721,6 +2818,81 @@ generic_opt_get(const char *name, const combo_opts_t *opts,
}
static GhbValue *
+filter_opt_get(const char *name, const GhbValue *gval, GhbType type,
+ int filter_id, int preset)
+{
+ GhbValue *result = NULL;
+ hb_filter_param_t * param;
+
+ if (preset)
+ {
+ param = hb_filter_param_get_presets(filter_id);
+ }
+ else
+ {
+ param = hb_filter_param_get_tunes(filter_id);
+ }
+ switch (type)
+ {
+ case GHB_DOUBLE:
+ case GHB_BOOL:
+ case GHB_INT:
+ {
+ int val;
+ val = lookup_param_int(param, gval);
+ return ghb_int_value_new(val);
+ } break;
+ case GHB_STRING:
+ {
+ const char *val;
+ val = lookup_param_option(param, gval);
+ return ghb_string_value_new(val);
+ } break;
+ }
+ return result;
+}
+
+static GhbValue *
+deint_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type)
+{
+ (void)opts; // Silence "unused variable" warning
+ return filter_opt_get(name, gval, type, HB_FILTER_DEINTERLACE, 1);
+}
+
+static GhbValue *
+decomb_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type)
+{
+ (void)opts; // Silence "unused variable" warning
+ return filter_opt_get(name, gval, type, HB_FILTER_DECOMB, 1);
+}
+
+static GhbValue *
+detel_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type)
+{
+ (void)opts; // Silence "unused variable" warning
+ return filter_opt_get(name, gval, type, HB_FILTER_DETELECINE, 1);
+}
+
+static GhbValue *
+denoise_preset_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type)
+{
+ (void)opts; // Silence "unused variable" warning
+ return filter_opt_get(name, gval, type, HB_FILTER_NLMEANS, 1);
+}
+
+static GhbValue *
+denoise_tune_opt_get(const char *name, const combo_opts_t *opts,
+ const GhbValue *gval, GhbType type)
+{
+ (void)opts; // Silence "unused variable" warning
+ return filter_opt_get(name, gval, type, HB_FILTER_NLMEANS, 0);
+}
+
+static GhbValue *
lookup_combo_value(const gchar *name, const GhbValue *gval, GhbType type)
{
combo_name_map_t *entry = find_combo_map(name);
@@ -2769,7 +2941,7 @@ ghb_lookup_combo_option(const gchar *name, const GhbValue *gval)
{
if (gval == NULL)
return NULL;
- GhbValue *gresult = lookup_combo_value(name, gval, GHB_DOUBLE);
+ GhbValue *gresult = lookup_combo_value(name, gval, GHB_STRING);
const char *tmp = ghb_value_get_string(gresult);
char *result = NULL;
if (tmp != NULL)