[vlc-devel] [PATCH 1/5] video_output: add a wextern window which doesn't let the core resize it

Rémi Denis-Courmont remi at remlab.net
Mon May 27 18:21:16 CEST 2019


Le maanantaina 27. toukokuuta 2019, 14.06.46 EEST Steve Lhomme a écrit :
> Instead the display module can call vout_window_ReportSize() on its behalf.
> ---
>  modules/video_output/Makefile.am |  2 ++
>  modules/video_output/wextern.c   | 60 ++++++++++++++++++++++++++++++++
>  2 files changed, 62 insertions(+)
>  create mode 100644 modules/video_output/wextern.c
> 
> diff --git a/modules/video_output/Makefile.am
> b/modules/video_output/Makefile.am index d9a2488ad4..7983d3637b 100644
> --- a/modules/video_output/Makefile.am
> +++ b/modules/video_output/Makefile.am
> @@ -477,6 +477,7 @@ libvdummy_plugin_la_SOURCES = video_output/vdummy.c
>  libvideo_splitter_plugin_la_SOURCES = video_output/splitter.c
>  libvmem_plugin_la_SOURCES = video_output/vmem.c
>  libwdummy_plugin_la_SOURCES = video_output/wdummy.c
> +libwextern_plugin_la_SOURCES = video_output/wextern.c
>  libyuv_plugin_la_SOURCES = video_output/yuv.c
>  libvgl_plugin_la_SOURCES = video_output/vgl.c
> 
> @@ -486,5 +487,6 @@ vout_LTLIBRARIES += \
>  	libvideo_splitter_plugin.la \
>  	libvmem_plugin.la \
>  	libwdummy_plugin.la \
> +	libwextern_plugin.la \
>  	libvgl_plugin.la \
>  	libyuv_plugin.la
> diff --git a/modules/video_output/wextern.c b/modules/video_output/wextern.c
> new file mode 100644
> index 0000000000..da085f65f4
> --- /dev/null
> +++ b/modules/video_output/wextern.c
> @@ -0,0 +1,60 @@
> +/**
> + * @file wextern.c
> + * @brief Dummy video window provider where the size is handled externally
> + */
> +/**************************************************************************
> *** + * Copyright © 2019 VideoLabs, VideoLAN and VideoLAN Authors
> + *
> + * This program is free software; you can redistribute it and/or modify it
> + * under the terms of the GNU Lesser General Public License as published by
> + * the Free Software Foundation; either version 2.1 of the License, or + *
> (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU Lesser General Public License for more details.
> + *
> + * You should have received a copy of the GNU Lesser General Public License
> + * along with this program; if not, write to the Free Software Foundation,
> + * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. +
> ***************************************************************************
> **/ +
> +#ifdef HAVE_CONFIG_H
> +# include <config.h>
> +#endif
> +
> +#include <stdarg.h>
> +
> +#include <vlc_common.h>
> +#include <vlc_plugin.h>
> +#include <vlc_vout_window.h>
> +
> +static int Enable(vout_window_t *wnd, const vout_window_cfg_t *cfg)
> +{
> +    vout_window_ReportSize(wnd, cfg->width, cfg->height);

Does this not need to be removed too?

> +    return VLC_SUCCESS;
> +}
> +
> +static const struct vout_window_operations ops = {
> +    .enable = Enable,
> +    // .resize: don't let the core resize us on zoom/crop/ar changes
> +    //          the display module should do the ReportSize for us
> +};
> +
> +static int Open(vout_window_t *wnd)
> +{
> +    wnd->type = VOUT_WINDOW_TYPE_DUMMY;
> +    wnd->ops = &ops;
> +    return VLC_SUCCESS;
> +}
> +
> +vlc_module_begin()
> +    set_shortname(N_("Callback window"))
> +    set_description(N_("External callback window"))
> +    set_category(CAT_VIDEO)
> +    set_subcategory(SUBCAT_VIDEO_VOUT)
> +    set_capability("vout window", 0)
> +    set_callbacks(Open, NULL)
> +    add_shortcut("dummy")
> +vlc_module_end()


-- 
Rémi Denis-Courmont
http://www.remlab.net/





More information about the vlc-devel mailing list