diff options
author | wm4 <wm4@nowhere> | 2015-11-17 21:07:41 +0100 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2015-11-17 21:21:19 +0100 |
commit | 0ec35fa111391b8069640ba2f616746a1b5530a5 (patch) | |
tree | e5356e8ab396e1c370a7784843f3101d3195469f /video/out/opengl/hwdec.c | |
parent | 25fe9e89e7db1658acac84ec8ac0a292b2e86165 (diff) | |
download | mpv-0ec35fa111391b8069640ba2f616746a1b5530a5.tar.bz2 mpv-0ec35fa111391b8069640ba2f616746a1b5530a5.tar.xz |
videotoolbox: make decoder format customizable
Because apparently there's no ideal universally working format.
The weird OpenGL texture format for kCVPixelFormatType_32BGRA is from:
http://stackoverflow.com/questions/22077544/draw-an-iosurface-to-an-opengl-context
(Which apparently got it from the linked Apple example code.)
Diffstat (limited to 'video/out/opengl/hwdec.c')
-rw-r--r-- | video/out/opengl/hwdec.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/video/out/opengl/hwdec.c b/video/out/opengl/hwdec.c index 2a8c1eb14b..3c3a9785a6 100644 --- a/video/out/opengl/hwdec.c +++ b/video/out/opengl/hwdec.c @@ -55,6 +55,7 @@ static const struct gl_hwdec_driver *const mpgl_hwdec_drivers[] = { }; static struct gl_hwdec *load_hwdec_driver(struct mp_log *log, GL *gl, + struct mpv_global *global, const struct gl_hwdec_driver *drv, bool is_auto) { @@ -62,6 +63,7 @@ static struct gl_hwdec *load_hwdec_driver(struct mp_log *log, GL *gl, *hwdec = (struct gl_hwdec) { .driver = drv, .log = mp_log_new(hwdec, log, drv->api_name), + .global = global, .gl = gl, .gl_texture_target = GL_TEXTURE_2D, .probing = is_auto, @@ -76,13 +78,13 @@ static struct gl_hwdec *load_hwdec_driver(struct mp_log *log, GL *gl, } struct gl_hwdec *gl_hwdec_load_api(struct mp_log *log, GL *gl, - const char *api_name) + struct mpv_global *g, const char *api_name) { bool is_auto = api_name && strcmp(api_name, "auto") == 0; for (int n = 0; mpgl_hwdec_drivers[n]; n++) { const struct gl_hwdec_driver *drv = mpgl_hwdec_drivers[n]; if (is_auto || (api_name && strcmp(drv->api_name, api_name) == 0)) { - struct gl_hwdec *r = load_hwdec_driver(log, gl, drv, is_auto); + struct gl_hwdec *r = load_hwdec_driver(log, gl, g, drv, is_auto); if (r) return r; } @@ -91,9 +93,10 @@ struct gl_hwdec *gl_hwdec_load_api(struct mp_log *log, GL *gl, } // Like gl_hwdec_load_api(), but use HWDEC_... identifiers. -struct gl_hwdec *gl_hwdec_load_api_id(struct mp_log *log, GL *gl, int id) +struct gl_hwdec *gl_hwdec_load_api_id(struct mp_log *log, GL *gl, + struct mpv_global *g, int id) { - return gl_hwdec_load_api(log, gl, m_opt_choice_str(mp_hwdec_names, id)); + return gl_hwdec_load_api(log, gl, g, m_opt_choice_str(mp_hwdec_names, id)); } void gl_hwdec_uninit(struct gl_hwdec *hwdec) |