Add VO control to retrieve hwaccel_context.
[vaapi:sewalliniusms-mplayer.git] / libvo / video_out.h
1 /*
2  * Copyright (C) Aaron Holtzman - Aug 1999
3  * Strongly modified, most parts rewritten: A'rpi/ESP-team - 2000-2001
4  * (C) MPlayer developers
5  *
6  * This file is part of MPlayer.
7  *
8  * MPlayer is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * MPlayer is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License along
19  * with MPlayer; if not, write to the Free Software Foundation, Inc.,
20  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
21  */
22
23 #ifndef MPLAYER_VIDEO_OUT_H
24 #define MPLAYER_VIDEO_OUT_H
25
26 #include <inttypes.h>
27 #include <stdarg.h>
28
29 //#include "sub/font_load.h"
30 #include "libmpcodecs/img_format.h"
31 //#include "vidix/vidix.h"
32
33 #define VO_EVENT_EXPOSE 1
34 #define VO_EVENT_RESIZE 2
35 #define VO_EVENT_KEYPRESS 4
36 #define VO_EVENT_REINIT 8
37 #define VO_EVENT_MOVE 16
38
39 /* Obsolete: VOCTRL_QUERY_VAA 1 */
40 /* does the device support the required format */
41 #define VOCTRL_QUERY_FORMAT 2
42 /* signal a device reset seek */
43 #define VOCTRL_RESET 3
44 /* true if vo driver can use GUI created windows */
45 #define VOCTRL_GUISUPPORT 4
46 #define VOCTRL_GUI_NOWINDOW 19
47 /* used to switch to fullscreen */
48 #define VOCTRL_FULLSCREEN 5
49 /* signal a device pause */
50 #define VOCTRL_PAUSE 7
51 /* start/resume playback */
52 #define VOCTRL_RESUME 8
53 /* libmpcodecs direct rendering: */
54 #define VOCTRL_GET_IMAGE 9
55 #define VOCTRL_DRAW_IMAGE 13
56 #define VOCTRL_SET_SPU_PALETTE 14
57 /* decoding ahead: */
58 #define VOCTRL_GET_NUM_FRAMES 10
59 #define VOCTRL_GET_FRAME_NUM  11
60 #define VOCTRL_SET_FRAME_NUM  12
61 #define VOCTRL_GET_PANSCAN 15
62 #define VOCTRL_SET_PANSCAN 16
63 /* equalizer controls */
64 #define VOCTRL_SET_EQUALIZER 17
65 #define VOCTRL_GET_EQUALIZER 18
66 //#define VOCTRL_GUI_NOWINDOW 19
67 /* Frame duplication */
68 #define VOCTRL_DUPLICATE_FRAME 20
69 // ... 21
70 #define VOCTRL_START_SLICE 21
71
72 #define VOCTRL_ONTOP 25
73 #define VOCTRL_ROOTWIN 26
74 #define VOCTRL_BORDER 27
75 #define VOCTRL_DRAW_EOSD 28
76 #define VOCTRL_GET_EOSD_RES 29
77
78 #define VOCTRL_SET_DEINTERLACE 30
79 #define VOCTRL_GET_DEINTERLACE 31
80
81 #define VOCTRL_UPDATE_SCREENINFO 32
82
83 // Return current HW acceleration context
84 // void *get_hwaccel_context(void);
85 #define VOCTRL_GET_HWACCEL_CONTEXT 33
86
87 // Vo can be used by xover
88 #define VOCTRL_XOVERLAY_SUPPORT 22
89
90 #define VOCTRL_XOVERLAY_SET_COLORKEY 24
91 typedef struct {
92   uint32_t x11; // The raw x11 color
93   uint16_t r,g,b;
94 } mp_colorkey_t;
95
96 #define VOCTRL_XOVERLAY_SET_WIN 23
97 typedef struct {
98   int x,y;
99   int w,h;
100 } mp_win_t;
101
102 #define VO_TRUE      1
103 #define VO_FALSE     0
104 #define VO_ERROR    -1
105 #define VO_NOTAVAIL -2
106 #define VO_NOTIMPL  -3
107
108 #define VOFLAG_FULLSCREEN         0x01
109 #define VOFLAG_MODESWITCHING      0x02
110 #define VOFLAG_SWSCALE            0x04
111 #define VOFLAG_FLIPPING           0x08
112 #define VOFLAG_HIDDEN             0x10  //< Use to create a hidden window
113 #define VOFLAG_STEREO             0x20  //< Use to create a stereo-capable window
114 #define VOFLAG_XOVERLAY_SUB_VO 0x10000
115
116 typedef struct vo_info_s
117 {
118     /* driver name ("Matrox Millennium G200/G400" */
119     const char *name;
120     /* short name (for config strings) ("mga") */
121     const char *short_name;
122     /* author ("Aaron Holtzman <aholtzma@ess.engr.uvic.ca>") */
123     const char *author;
124     /* any additional comments */
125     const char *comment;
126 } vo_info_t;
127
128 typedef struct vo_functions_s
129 {
130     const vo_info_t *info;
131     /*
132      * Preinitializes driver (real INITIALIZATION)
133      *   arg - currently it's vo_subdevice
134      *   returns: zero on successful initialization, non-zero on error.
135      */
136     int (*preinit)(const char *arg);
137     /*
138      * Initialize (means CONFIGURE) the display driver.
139      * params:
140      *   width,height: image source size
141      *   d_width,d_height: size of the requested window size, just a hint
142      *   fullscreen: flag, 0=windowd 1=fullscreen, just a hint
143      *   title: window title, if available
144      *   format: fourcc of pixel format
145      * returns : zero on successful initialization, non-zero on error.
146      */
147     int (*config)(uint32_t width, uint32_t height, uint32_t d_width,
148                   uint32_t d_height, uint32_t fullscreen, char *title,
149                   uint32_t format);
150
151     /*
152      * Control interface
153      */
154     int (*control)(uint32_t request, void *data);
155
156     /*
157      * Display a new RGB/BGR frame of the video to the screen.
158      * params:
159      *   src[0] - pointer to the image
160      */
161     int (*draw_frame)(uint8_t *src[]);
162
163     /*
164      * Draw a planar YUV slice to the buffer:
165      * params:
166      *   src[3] = source image planes (Y,U,V)
167      *   stride[3] = source image planes line widths (in bytes)
168      *   w,h = width*height of area to be copied (in Y pixels)
169      *   x,y = position at the destination image (in Y pixels)
170      */
171     int (*draw_slice)(uint8_t *src[], int stride[], int w,int h, int x,int y);
172
173     /*
174      * Draws OSD to the screen buffer
175      */
176     void (*draw_osd)(void);
177
178     /*
179      * Blit/Flip buffer to the screen. Must be called after each frame!
180      */
181     void (*flip_page)(void);
182
183     /*
184      * This func is called after every frames to handle keyboard and
185      * other events. It's called in PAUSE mode too!
186      */
187     void (*check_events)(void);
188
189     /*
190      * Closes driver. Should restore the original state of the system.
191      */
192     void (*uninit)(void);
193 } vo_functions_t;
194
195 const vo_functions_t* init_best_video_out(char** vo_list);
196 int config_video_out(const vo_functions_t *vo, uint32_t width, uint32_t height,
197                      uint32_t d_width, uint32_t d_height, uint32_t flags,
198                      char *title, uint32_t format);
199 void list_video_out(void);
200
201 // NULL terminated array of all drivers
202 extern const vo_functions_t* const video_out_drivers[];
203
204 extern int vo_flags;
205
206 extern int vo_config_count;
207
208 extern int xinerama_screen;
209 extern int xinerama_x;
210 extern int xinerama_y;
211
212 // correct resolution/bpp on screen:  (should be autodetected by vo_init())
213 extern int vo_depthonscreen;
214 extern int vo_screenwidth;
215 extern int vo_screenheight;
216
217 // requested resolution/bpp:  (-x -y -bpp options)
218 extern int vo_dx;
219 extern int vo_dy;
220 extern int vo_dwidth;
221 extern int vo_dheight;
222 extern int vo_dbpp;
223
224 extern int vo_grabpointer;
225 extern int vo_doublebuffering;
226 extern int vo_directrendering;
227 extern int vo_vsync;
228 extern int vo_fs;
229 extern int vo_fsmode;
230 extern float vo_panscan;
231 extern int vo_adapter_num;
232 extern int vo_refresh_rate;
233 extern int vo_keepaspect;
234 extern int vo_rootwin;
235 extern int vo_ontop;
236 extern int vo_border;
237
238 extern int vo_gamma_gamma;
239 extern int vo_gamma_brightness;
240 extern int vo_gamma_saturation;
241 extern int vo_gamma_contrast;
242 extern int vo_gamma_hue;
243 extern int vo_gamma_red_intensity;
244 extern int vo_gamma_green_intensity;
245 extern int vo_gamma_blue_intensity;
246
247 extern int vo_nomouse_input;
248 extern int enable_mouse_movements;
249
250 extern int vo_pts;
251 extern float vo_fps;
252
253 extern char *vo_subdevice;
254
255 extern int vo_colorkey;
256
257 extern char *vo_winname;
258 extern char *vo_wintitle;
259
260 extern int64_t WinID;
261
262 typedef struct {
263         float min;
264         float max;
265         } range_t;
266
267 float range_max(range_t *r);
268 int in_range(range_t *r, float f);
269 range_t *str2range(char *s);
270 extern char *monitor_hfreq_str;
271 extern char *monitor_vfreq_str;
272 extern char *monitor_dotclock_str;
273
274 struct mp_keymap {
275   int from;
276   int to;
277 };
278 int lookup_keymap_table(const struct mp_keymap *map, int key);
279 struct vo_rect {
280   int left, right, top, bottom, width, height;
281 };
282 void calc_src_dst_rects(int src_width, int src_height, struct vo_rect *src, struct vo_rect *dst,
283                         struct vo_rect *borders, const struct vo_rect *crop);
284 void vo_mouse_movement(int posx, int posy);
285
286 static inline int aspect_scaling(void)
287 {
288   return vo_fs;
289 }
290
291 #endif /* MPLAYER_VIDEO_OUT_H */