<property name="position">1</property>
</packing>
</child>
- <child>
- <object class="GtkCheckButton" id="x264_mbtree">
- <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="tooltip-text" translatable="yes">Using macroblock tree ratecontrol overall improves compression.</property>
- <property name="label" translatable="yes">Macroblock Tree Rate Control</property>
- <property name="active">True</property>
- <property name="draw_indicator">True</property>
- <signal handler="x264_widget_changed_cb" name="toggled"/>
- </object>
- <packing>
- <property name="position">2</property>
- </packing>
- </child>
<child>
<object class="GtkCheckButton" id="x264_no_fast_pskip">
<property name="visible">True</property>
<signal handler="x264_widget_changed_cb" name="toggled"/>
</object>
<packing>
- <property name="position">3</property>
+ <property name="position">2</property>
</packing>
</child>
<child>
<signal handler="x264_widget_changed_cb" name="toggled"/>
</object>
<packing>
- <property name="position">4</property>
+ <property name="position">3</property>
</packing>
</child>
<child>
<signal handler="x264_widget_changed_cb" name="toggled"/>
</object>
<packing>
- <property name="position">5</property>
+ <property name="position">4</property>
</packing>
</child>
<child>
</child>
</object>
<packing>
- <property name="position">6</property>
+ <property name="position">5</property>
</packing>
</child>
</object>
{"x264_subme", "x264_psy_trell", "<6", TRUE, FALSE},
{"x264_cabac", "x264_psy_trell", "TRUE", FALSE, FALSE},
{"x264_trellis", "x264_psy_trell", "0", TRUE, FALSE},
- {"x264_mbtree", "x264_bpyramid", "FALSE", FALSE, FALSE},
{"ChapterMarkers", "chapters_list", "TRUE", FALSE, FALSE},
{"use_source_name", "chapters_in_destination", "TRUE", FALSE, FALSE},
{"use_source_name", "title_no_in_destination", "TRUE", FALSE, FALSE},
{x264_decimate_syns, "x264_no_dct_decimate", "0", X264_OPT_BOOL},
{x264_cabac_syns, "x264_cabac", "1", X264_OPT_BOOL},
{x264_psy_syns, "x264_psy_rd", "1,0", X264_OPT_PSY},
- {x264_mbtree_syns, "x264_mbtree", "1", X264_OPT_BOOL},
+ {x264_mbtree_syns, "x264_mbtree", "1", X264_OPT_NONE},
{x264_psy_syns, "x264_psy_trell", "1,0", X264_OPT_PSY},
};
#define X264_OPT_MAP_SIZE (sizeof(x264_opt_map)/sizeof(struct x264_opt_map_s))
{
if (!x264_opt_map[jj].found)
{
- gchar *val;
-
- if (x264_opt_map[jj].opt_syns == x264_mbtree_syns)
- {
- int bframes = ghb_lookup_bframes(options);
- if (bframes > 0)
- val = strdup("1");
- else
- val = strdup("0");
- }
- else
- {
- val = strdup(x264_opt_map[jj].def_val);
- }
+ gchar *val = strdup(x264_opt_map[jj].def_val);
switch(x264_opt_map[jj].type)
{
case X264_OPT_INT:
return ret;
}
+gint
+ghb_lookup_mbtree(const gchar *options)
+{
+ gint ret = ghb_lookup_bframes(options) != 0;
+ gchar *result;
+ gchar **split;
+
+ if (options == NULL)
+ options = "";
+
+ split = g_strsplit(options, ":", -1);
+
+ result = x264_lookup_value(split, x264_mbtree_syns);
+ g_strfreev(split);
+ if (result != NULL)
+ {
+ ret = g_strtod(result, NULL);
+ g_free(result);
+ }
+ return ret;
+}
+
// Construct the x264 options string
// The result is allocated, so someone must free it at some point.
static gchar*
gint ii;
// Fix up option dependencies
- gboolean mbtree = ghb_settings_get_boolean(ud->settings, "x264_mbtree");
+ gboolean mbtree = ghb_lookup_mbtree(options);
if (mbtree)
{
x264_remove_opt(split, x264_bpyramid_syns);