lib: deprecate the old track API
[vlc.git] / include / vlc_opengl.h
blob79e165e72b22ffc16b0909adda2887db8e8d1515
1 /*****************************************************************************
2 * vlc_opengl.h: VLC GL API
3 *****************************************************************************
4 * Copyright (C) 2009 Laurent Aimar
5 * Copyright (C) 2011 RĂ©mi Denis-Courmont
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_GL_H
25 #define VLC_GL_H 1
27 /**
28 * \file
29 * This file defines GL structures and functions.
32 struct vout_window_t;
33 struct vout_window_cfg_t;
34 struct vout_display_cfg;
36 /**
37 * A VLC GL context (and its underlying surface)
39 typedef struct vlc_gl_t vlc_gl_t;
41 struct vlc_gl_t
43 struct vlc_object_t obj;
45 struct vout_window_t *surface;
46 module_t *module;
47 void *sys;
49 int (*make_current)(vlc_gl_t *);
50 void (*release_current)(vlc_gl_t *);
51 void (*resize)(vlc_gl_t *, unsigned, unsigned);
52 void (*swap)(vlc_gl_t *);
53 void*(*get_proc_address)(vlc_gl_t *, const char *);
54 void (*destroy)(vlc_gl_t *);
56 enum {
57 VLC_GL_EXT_DEFAULT,
58 VLC_GL_EXT_EGL,
59 VLC_GL_EXT_WGL,
60 } ext;
62 union {
63 /* if ext == VLC_GL_EXT_EGL */
64 struct {
65 /* call eglQueryString() with current display */
66 const char *(*queryString)(vlc_gl_t *, int32_t name);
67 /* call eglCreateImageKHR() with current display and context, can
68 * be NULL */
69 void *(*createImageKHR)(vlc_gl_t *, unsigned target, void *buffer,
70 const int32_t *attrib_list);
71 /* call eglDestroyImageKHR() with current display, can be NULL */
72 bool (*destroyImageKHR)(vlc_gl_t *, void *image);
73 } egl;
74 /* if ext == VLC_GL_EXT_WGL */
75 struct
77 const char *(*getExtensionsString)(vlc_gl_t *);
78 } wgl;
82 enum {
83 VLC_OPENGL,
84 VLC_OPENGL_ES2,
87 /**
88 * Creates an OpenGL context (and its underlying surface).
90 * @note In most cases, you should vlc_gl_MakeCurrent() afterward.
92 * @param cfg initial configuration (including window to use as OpenGL surface)
93 * @param flags OpenGL context type
94 * @param name module name (or NULL for auto)
95 * @return a new context, or NULL on failure
97 VLC_API vlc_gl_t *vlc_gl_Create(const struct vout_display_cfg *cfg,
98 unsigned flags, const char *name) VLC_USED;
99 VLC_API void vlc_gl_Release(vlc_gl_t *);
100 VLC_API void vlc_gl_Hold(vlc_gl_t *);
102 static inline int vlc_gl_MakeCurrent(vlc_gl_t *gl)
104 return gl->make_current(gl);
107 static inline void vlc_gl_ReleaseCurrent(vlc_gl_t *gl)
109 gl->release_current(gl);
112 static inline void vlc_gl_Resize(vlc_gl_t *gl, unsigned w, unsigned h)
114 if (gl->resize != NULL)
115 gl->resize(gl, w, h);
118 static inline void vlc_gl_Swap(vlc_gl_t *gl)
120 gl->swap(gl);
123 static inline void *vlc_gl_GetProcAddress(vlc_gl_t *gl, const char *name)
125 return gl->get_proc_address(gl, name);
128 VLC_API vlc_gl_t *vlc_gl_surface_Create(vlc_object_t *,
129 const struct vout_window_cfg_t *,
130 struct vout_window_t **) VLC_USED;
131 VLC_API bool vlc_gl_surface_CheckSize(vlc_gl_t *, unsigned *w, unsigned *h);
132 VLC_API void vlc_gl_surface_Destroy(vlc_gl_t *);
134 static inline bool vlc_gl_StrHasToken(const char *apis, const char *api)
136 size_t apilen = strlen(api);
137 while (apis) {
138 while (*apis == ' ')
139 apis++;
140 if (!strncmp(apis, api, apilen) && memchr(" ", apis[apilen], 2))
141 return true;
142 apis = strchr(apis, ' ');
144 return false;
147 #endif /* VLC_GL_H */