1 /*****************************************************************************
2 * vlc_vout_wrapper.h: definitions for vout wrappers (temporary)
3 *****************************************************************************
4 * Copyright (C) 2009 Laurent Aimar
7 * Authors: Laurent Aimar <fenrir _AT_ videolan _DOT_ org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 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 General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, 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>
28 #include <vlc_vout_opengl.h>
30 /* XXX DO NOT use it outside the vout module wrapper XXX */
33 * It retreives a picture pool from the display
35 static inline picture_pool_t
*vout_display_Pool(vout_display_t
*vd
, unsigned count
)
37 return vd
->pool(vd
, count
);
41 * It preparse a picture for display.
43 static inline void vout_display_Prepare(vout_display_t
*vd
, picture_t
*picture
)
46 vd
->prepare(vd
, picture
);
50 * It display a picture.
52 static inline void vout_display_Display(vout_display_t
*vd
, picture_t
*picture
)
54 vd
->display(vd
, picture
);
58 * It holds a state for a vout display.
61 vout_display_cfg_t cfg
;
68 } vout_display_state_t
;
71 * It creates a vout managed display.
73 VLC_EXPORT(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
));
75 * It destroy a vout managed display.
77 VLC_EXPORT(void, vout_DeleteDisplay
, (vout_display_t
*, vout_display_state_t
*));
79 VLC_EXPORT(bool, vout_IsDisplayFiltered
, (vout_display_t
*));
80 VLC_EXPORT(picture_t
*, vout_FilterDisplay
, (vout_display_t
*, picture_t
*));
81 VLC_EXPORT(bool, vout_AreDisplayPicturesInvalid
, (vout_display_t
*));
83 VLC_EXPORT(void, vout_ManageDisplay
, (vout_display_t
*, bool allow_reset_pictures
));
85 VLC_EXPORT(void, vout_SetDisplayFullscreen
, (vout_display_t
*, bool is_fullscreen
));
86 VLC_EXPORT(void, vout_SetDisplayFilled
, (vout_display_t
*, bool is_filled
));
87 VLC_EXPORT(void, vout_SetDisplayZoom
, (vout_display_t
*, int num
, int den
));
88 VLC_EXPORT(void, vout_SetWindowState
, (vout_display_t
*, unsigned state
));
89 VLC_EXPORT(void, vout_SetDisplayAspect
, (vout_display_t
*, unsigned sar_num
, unsigned sar_den
));
90 VLC_EXPORT(void, vout_SetDisplayCrop
, (vout_display_t
*, unsigned crop_num
, unsigned crop_den
, unsigned x
, unsigned y
, unsigned width
, unsigned height
));
91 VLC_EXPORT(vout_opengl_t
*, vout_GetDisplayOpengl
, (vout_display_t
*));
93 #endif /* VLC_VOUT_WRAPPER_H */