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 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 */
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
);
40 * It preparse a picture for display.
42 static inline void vout_display_Prepare(vout_display_t
*vd
,
44 subpicture_t
*subpicture
)
47 vd
->prepare(vd
, picture
, subpicture
);
51 * It display a picture.
53 static inline void vout_display_Display(vout_display_t
*vd
,
55 subpicture_t
*subpicture
)
57 vd
->display(vd
, picture
, subpicture
);
61 * It holds a state for a vout display.
64 vout_display_cfg_t cfg
;
70 } vout_display_state_t
;
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
);
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
*, int num
, int 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
);
95 VLC_API
struct vlc_gl_t
* vout_GetDisplayOpengl(vout_display_t
*);
97 #endif /* VLC_VOUT_WRAPPER_H */