summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDudemanguy <random342@airmail.cc>2023-08-08 17:24:28 -0500
committerDudemanguy <random342@airmail.cc>2023-08-09 13:51:28 +0000
commit1df0a42a8cb12005311f6a03f3a1c4329c798f8c (patch)
treea437d1a5782f2aeb8e17202bed151f1ba5e67dd4
parentefefe3a6dcfb969ab9f5800b7aecb3ba685ffdbe (diff)
downloadmpv-1df0a42a8cb12005311f6a03f3a1c4329c798f8c.tar.bz2
mpv-1df0a42a8cb12005311f6a03f3a1c4329c798f8c.tar.xz
m_option: change m_option_type_aspect to double
This specific option type is only used for the video aspect. The underlying type was a float to represent the inputted value, but it's actually not precise enough. When using something like 4:3, the values of the incorrect digits are actually significant enough to make av_d2q return a very funky numerator and denominator which is close to 4/3 but not quite. This leads to some "off by one pixel" errors. Weirdly, mpv's actual calculations for this were already being done as double, but then converted to floats for this specific type. Just drop the conversion step and leave it all as double which has the precision we need (i.e. AVRational is now 4/3 for the this case). Fixes #8190.
-rw-r--r--filters/f_decoder_wrapper.c2
-rw-r--r--options/m_option.c52
-rw-r--r--options/m_option.h2
3 files changed, 28 insertions, 28 deletions
diff --git a/filters/f_decoder_wrapper.c b/filters/f_decoder_wrapper.c
index b0c174955b..5553002821 100644
--- a/filters/f_decoder_wrapper.c
+++ b/filters/f_decoder_wrapper.c
@@ -93,7 +93,7 @@ static const struct m_sub_options adec_queue_conf = {
#define OPT_BASE_STRUCT struct dec_wrapper_opts
struct dec_wrapper_opts {
- float movie_aspect;
+ double movie_aspect;
int aspect_method;
double force_fps;
bool correct_pts;
diff --git a/options/m_option.c b/options/m_option.c
index eb83547356..7ba87232fa 100644
--- a/options/m_option.c
+++ b/options/m_option.c
@@ -1109,6 +1109,32 @@ const m_option_type_t m_option_type_double = {
.equal = double_equal,
};
+static int parse_double_aspect(struct mp_log *log, const m_option_t *opt,
+ struct bstr name, struct bstr param, void *dst)
+{
+ if (bstr_equals0(param, "no")) {
+ if (dst)
+ VAL(dst) = 0.0;
+ return 1;
+ }
+ return parse_double(log, opt, name, param, dst);
+}
+
+const m_option_type_t m_option_type_aspect = {
+ .name = "Aspect",
+ .size = sizeof(double),
+ .flags = M_OPT_TYPE_CHOICE | M_OPT_TYPE_USES_RANGE,
+ .parse = parse_double_aspect,
+ .print = print_double,
+ .pretty_print = print_double_f3,
+ .copy = copy_opt,
+ .add = add_double,
+ .multiply = multiply_double,
+ .set = double_set,
+ .get = double_get,
+ .equal = double_equal,
+};
+
#undef VAL
#define VAL(x) (*(float *)(x))
@@ -1185,32 +1211,6 @@ const m_option_type_t m_option_type_float = {
.equal = float_equal,
};
-static int parse_float_aspect(struct mp_log *log, const m_option_t *opt,
- struct bstr name, struct bstr param, void *dst)
-{
- if (bstr_equals0(param, "no")) {
- if (dst)
- VAL(dst) = 0.0f;
- return 1;
- }
- return parse_float(log, opt, name, param, dst);
-}
-
-const m_option_type_t m_option_type_aspect = {
- .name = "Aspect",
- .size = sizeof(float),
- .flags = M_OPT_TYPE_CHOICE | M_OPT_TYPE_USES_RANGE,
- .parse = parse_float_aspect,
- .print = print_float,
- .pretty_print = print_float_f3,
- .copy = copy_opt,
- .add = add_float,
- .multiply = multiply_float,
- .set = float_set,
- .get = float_get,
- .equal = float_equal,
-};
-
///////////// String
#undef VAL
diff --git a/options/m_option.h b/options/m_option.h
index bcdc1f9fcc..1adac938e4 100644
--- a/options/m_option.h
+++ b/options/m_option.h
@@ -661,7 +661,7 @@ extern const char m_option_path_separator;
OPT_TYPED_FIELD(m_option_type_msglevels, char **, field)
#define OPT_ASPECT(field) \
- OPT_TYPED_FIELD(m_option_type_aspect, float, field)
+ OPT_TYPED_FIELD(m_option_type_aspect, double, field)
#define OPT_IMAGEFORMAT(field) \
OPT_TYPED_FIELD(m_option_type_imgfmt, int, field)