Qt(Dialog provider): Add support for key accelerators
[vlc.git] / include / vlc_vout_wrapper.h
blob26d1d85c2ce519f373ceafdbd2311021173e549b
1 /*****************************************************************************
2 * vlc_vout_wrapper.h: definitions for vout wrappers (temporary)
3 *****************************************************************************
4 * Copyright (C) 2009 Laurent Aimar
5 * $Id$
7 * Authors: Laurent Aimar <fenrir _AT_ videolan _DOT_ org>
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU Lesser General Public License as published by
11 * the Free Software Foundation; either version 2.1 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public License
20 * along with this program; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22 *****************************************************************************/
24 #ifndef VLC_VOUT_WRAPPER_H
25 #define VLC_VOUT_WRAPPER_H 1
27 #include <vlc_vout_display.h>
29 /* XXX DO NOT use it outside the vout module wrapper XXX */
31 /**
32 * It retreives a picture pool from the display
34 static inline picture_pool_t *vout_display_Pool(vout_display_t *vd, unsigned count)
36 return vd->pool(vd, count);
39 /**
40 * It preparse a picture for display.
42 static inline void vout_display_Prepare(vout_display_t *vd,
43 picture_t *picture,
44 subpicture_t *subpicture)
46 if (vd->prepare )
47 vd->prepare(vd, picture, subpicture);
50 /**
51 * It display a picture.
53 static inline void vout_display_Display(vout_display_t *vd,
54 picture_t *picture,
55 subpicture_t *subpicture)
57 vd->display(vd, picture, subpicture);
60 /**
61 * It holds a state for a vout display.
63 typedef struct {
64 vout_display_cfg_t cfg;
65 unsigned wm_state;
66 struct {
67 int num;
68 int den;
69 } sar;
70 } vout_display_state_t;
72 /**
73 * It creates a vout managed display.
75 VLC_API vout_display_t * vout_NewDisplay( vout_thread_t *, const video_format_t *, const vout_display_state_t *, const char *psz_module, mtime_t i_double_click_timeout, mtime_t i_hide_timeout );
76 /**
77 * It destroy a vout managed display.
79 VLC_API void vout_DeleteDisplay(vout_display_t *, vout_display_state_t *);
81 VLC_API bool vout_IsDisplayFiltered(vout_display_t *);
82 VLC_API picture_t * vout_FilterDisplay(vout_display_t *, picture_t *);
83 VLC_API bool vout_AreDisplayPicturesInvalid(vout_display_t *);
85 VLC_API bool vout_ManageDisplay(vout_display_t *, bool allow_reset_pictures);
87 VLC_API void vout_SetDisplayFullscreen(vout_display_t *, bool is_fullscreen);
88 VLC_API void vout_SetDisplayFilled(vout_display_t *, bool is_filled);
89 VLC_API void vout_SetDisplayZoom(vout_display_t *, unsigned num, unsigned den);
90 VLC_API void vout_SetWindowState(vout_display_t *, unsigned state);
91 VLC_API void vout_SetDisplayAspect(vout_display_t *, unsigned dar_num, unsigned dar_den);
92 VLC_API void vout_SetDisplayCrop(vout_display_t *, unsigned crop_num, unsigned crop_den, unsigned left, unsigned top, int right, int bottom);
94 struct vlc_gl_t;
95 VLC_API struct vlc_gl_t * vout_GetDisplayOpengl(vout_display_t *);
97 #endif /* VLC_VOUT_WRAPPER_H */