forked from flutter/engine
-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathfl_framebuffer.h
86 lines (73 loc) · 2.08 KB
/
fl_framebuffer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// Copyright 2013 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef FLUTTER_SHELL_PLATFORM_LINUX_FL_FRAMEBUFFER_H_
#define FLUTTER_SHELL_PLATFORM_LINUX_FL_FRAMEBUFFER_H_
#include <epoxy/gl.h>
#include <glib-object.h>
G_BEGIN_DECLS
G_DECLARE_FINAL_TYPE(FlFramebuffer, fl_framebuffer, FL, FRAMEBUFFER, GObject)
/**
* FlFramebuffer:
*
* #FlFramebuffer creates framebuffers and their backing textures
* for use by the Flutter compositor.
*/
/**
* fl_framebuffer_new:
* @format: format, e.g. GL_RGB, GL_BGR
* @width: width of texture.
* @height: height of texture.
*
* Creates a new frame buffer. Requires a valid OpenGL context to create.
*
* Returns: a new #FlFramebuffer.
*/
FlFramebuffer* fl_framebuffer_new(GLint format, size_t width, size_t height);
/**
* fl_framebuffer_get_id:
* @framebuffer: an #FlFramebuffer.
*
* Gets the ID for this framebuffer.
*
* Returns: OpenGL framebuffer id or 0 if creation failed.
*/
GLuint fl_framebuffer_get_id(FlFramebuffer* framebuffer);
/**
* fl_framebuffer_get_texture_id:
* @framebuffer: an #FlFramebuffer.
*
* Gets the ID of the texture associated with this framebuffer.
*
* Returns: OpenGL texture id or 0 if creation failed.
*/
GLuint fl_framebuffer_get_texture_id(FlFramebuffer* framebuffer);
/**
* fl_framebuffer_get_target:
* @framebuffer: an #FlFramebuffer.
*
* Gets target texture (example GL_TEXTURE_2D or GL_TEXTURE_RECTANGLE).
*
* Returns: target texture.
*/
GLenum fl_framebuffer_get_target(FlFramebuffer* framebuffer);
/**
* fl_framebuffer_get_width:
* @framebuffer: an #FlFramebuffer.
*
* Gets the width of the framebuffer in pixels.
*
* Returns: width in pixels.
*/
size_t fl_framebuffer_get_width(FlFramebuffer* framebuffer);
/**
* fl_framebuffer_get_height:
* @framebuffer: an #FlFramebuffer.
*
* Gets the height of the framebuffer in pixels.
*
* Returns: height in pixels.
*/
size_t fl_framebuffer_get_height(FlFramebuffer* framebuffer);
G_END_DECLS
#endif // FLUTTER_SHELL_PLATFORM_LINUX_FL_FRAMEBUFFER_H_