1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-08 08:00:17 +00:00
mpv/video/out/libmpv.h
wm4 b93f142011 client API: add software rendering API
This can be used to make vo_libmpv render video to a memory buffer. It
only adds a new backend API that takes memory surfaces. All the render
API (such as frame rendering control and so on) is reused.

I'm not quite convinced of the usefulness of this, and until now I
always resisted providing something like this. It only seems to
facilitate inefficient implementation. But whatever.

Unfortunately, this duplicates the software rendering glue code yet
again (like it exists in vo_x11, vo_wlshm, vo_drm, and probably more).
But in theory, these could reuse this backend in the future, just like
vo_gpu could reuse the render_gl API.

Fixes: #7852
2020-07-08 22:42:05 +02:00

84 lines
3.9 KiB
C

#pragma once
#include <stdint.h>
#include <stdbool.h>
#include "libmpv/render.h"
#include "vo.h"
// Helper for finding a parameter value. It returns the direct pointer to the
// value, and if not present, just returns the def argument. In particular, if
// def is not NULL, this never returns NULL (unless a param value is defined
// as accepting NULL, or the libmpv API user is triggering UB).
void *get_mpv_render_param(mpv_render_param *params, mpv_render_param_type type,
void *def);
#define GET_MPV_RENDER_PARAM(params, type, ctype, def) \
(*(ctype *)get_mpv_render_param(params, type, &(ctype){(def)}))
typedef int (*mp_render_cb_control_fn)(struct vo *vo, void *cb_ctx, int *events,
uint32_t request, void *data);
void mp_render_context_set_control_callback(mpv_render_context *ctx,
mp_render_cb_control_fn callback,
void *callback_ctx);
bool mp_render_context_acquire(mpv_render_context *ctx);
struct render_backend {
struct mpv_global *global;
struct mp_log *log;
const struct render_backend_fns *fns;
// Set on init, immutable afterwards.
int driver_caps;
struct mp_hwdec_devices *hwdec_devs;
void *priv;
};
// Generic backend for rendering via libmpv. This corresponds to vo/vo_driver,
// except for rendering via the mpv_render_*() API. (As a consequence it's as
// generic as the VO API.) Like with VOs, one backend can support multiple
// underlying GPU APIs.
struct render_backend_fns {
// Returns libmpv error code. In particular, this function has to check for
// MPV_RENDER_PARAM_API_TYPE, and silently return MPV_ERROR_NOT_IMPLEMENTED
// if the API is not included in this backend.
// If this fails, ->destroy() will be called.
int (*init)(struct render_backend *ctx, mpv_render_param *params);
// Check if the passed IMGFMT_ is supported.
bool (*check_format)(struct render_backend *ctx, int imgfmt);
// Implementation of mpv_render_context_set_parameter(). Optional.
int (*set_parameter)(struct render_backend *ctx, mpv_render_param param);
// Like vo_driver.reconfig().
void (*reconfig)(struct render_backend *ctx, struct mp_image_params *params);
// Like VOCTRL_RESET.
void (*reset)(struct render_backend *ctx);
void (*screenshot)(struct render_backend *ctx, struct vo_frame *frame,
struct voctrl_screenshot *args);
void (*perfdata)(struct render_backend *ctx,
struct voctrl_performance_data *out);
// Like vo_driver.get_image().
struct mp_image *(*get_image)(struct render_backend *ctx, int imgfmt,
int w, int h, int stride_align);
// This has two purposes: 1. set queue attributes on VO, 2. update the
// renderer's OSD pointer. Keep in mind that as soon as the caller releases
// the renderer lock, the VO pointer can become invalid. The OSD pointer
// will technically remain valid (even though it's a vo field), until it's
// unset with this function.
// Will be called if vo changes, or if renderer options change.
void (*update_external)(struct render_backend *ctx, struct vo *vo);
// Update screen area.
void (*resize)(struct render_backend *ctx, struct mp_rect *src,
struct mp_rect *dst, struct mp_osd_res *osd);
// Get target surface size from mpv_render_context_render() arguments.
int (*get_target_size)(struct render_backend *ctx, mpv_render_param *params,
int *out_w, int *out_h);
// Implementation of mpv_render_context_render().
int (*render)(struct render_backend *ctx, mpv_render_param *params,
struct vo_frame *frame);
// Free all data in ctx->priv.
void (*destroy)(struct render_backend *ctx);
};
extern const struct render_backend_fns render_backend_gpu;
extern const struct render_backend_fns render_backend_sw;