-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathfbl.h
298 lines (240 loc) · 7.92 KB
/
fbl.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
//
// fbl.h
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _fb2_h
#define _fb2_h
#include "bcm_host.h"
#include "GLES2/gl2.h"
#include "GLES2/gl2ext.h"
#include "EGL/egl.h"
#include "EGL/eglext.h"
// A wrapper that manages a single dispmanx layer and
// indexed frame buffer.
class FrameBufferLayer {
public:
FrameBufferLayer();
virtual ~FrameBufferLayer();
// Sets the layer for this frame buffer. Must be called before Allocate.
void SetLayer(int layer);
int GetLayer(void);
// Tells this fb to use a palette with transparency.
// Must be called before Allocate. If transparency is used, palette
// calls must use the 32 bit ARGB format. Otherwise, the RGB565 format
// is used.
void SetTransparency(bool transparency);
// pixel mode: 0=8-bit-indexed, 1=RGB565
// pitch represents bytes per line
int Allocate(int pixelmode, uint8_t **pixels,
int width, int height, int *pitch);
// Allocate again with the same parameters. pixels and
// pitch will remain the same. Used for turning the shader
// on/off.
int ReAllocate(bool shader_enable);
void Free();
void Clear();
// Get a pointer to raw pixel data for this frame buffer
void* GetPixels();
// Indicates raw pixel data has a complete frame. Upload to the
// offscreen resource unless to_offscreen is 0, in which case
// the currently visible resource is the destination.
void FrameReady(int to_offscreen);
// Show the framebuffer.
void Show();
// Hide the framebuffer.
void Hide();
// Set one color of the indexed palette. Can only be called when
// transparency is false.
void SetPalette(uint8_t index, uint16_t rgb565);
// Set one color of the indexed palette. Can only be called when
// transparency is true.
void SetPalette(uint8_t index, uint32_t rgba);
// Commit current palette to frame buffer
void UpdatePalette();
// Sets the region within the frame buffer to scale. Takes effect
// on the next call to Show()
void SetSrcRect(int x, int y, int w, int h);
// The amount to stretch to vertical and horizontal dimensions
// If hstretch is positive, the src region height is scaled up to the
// height of the frame buffer * vstretch, the width is then determined by
// frame buffer height * hstretch.
// Otherwise, the src region width is scaled up to the width of the
// frame buffer * vstretch, the height is determined by
// frame buffer width / hstretch.
void SetStretch(double hstretch, double vstretch, int hintstr, int vintstr, int use_hintstr, int use_vintstr);
void SetCenterOffset(int cx, int cy);
// alignment can be -1 = ALIGN TOP, 0 = CENTER, 1 = ALIGN BOTTOM
// padding applies to TOP or BOTTOM only.
void SetVerticalAlignment(int alignment, int padding);
// alignment can be -1 = ALIGN LEFT, 0 = CENTER, 1 = ALIGN RIGHT
// padding applies to LEFT or RIGHT only.
void SetHorizontalAlignment(int alignment, int padding);
// Takes some space away from the full screen when determining destination rect
// Used to force a fb into a smaller space (for things like PIP or side-by-side.
void SetPadding(double leftPadding, double rightPadding, double topPadding, double bottomPadding);
// Retrieve dimensions for this layer.
void GetDimensions(int *display_w, int *display_h,
int *fb_w, int *fb_h,
int *src_w, int *src_h,
int *dst_w, int *dst_h);
// initializes the bcm_host interface
static void Initialize();
static void OGLInit();
bool UsesShader();
bool Showing();
void SetUsesShader(bool enable);
// NOTE: This will implicitly Hide the layer since the shader must be
// destroyed and recompiled.
void SetShaderParams(
bool curvature,
float curvature_x,
float curvature_y,
int mask,
float mask_brightness,
bool gamma,
bool fake_gamma,
bool scanlines,
bool multisample,
float scanline_weight,
float scanline_gap_brightness,
float bloom_factor,
float input_gamma,
float output_gamma,
bool sharper,
bool bilinear_interpolation);
// make off screen resources for fb1 (and optionally fb2) visible
// then swap destination resources in prep for next frame
static void SwapResources(bool sync, FrameBufferLayer* fb1, FrameBufferLayer* fb2);
static void SetInterpolation(int enable);
private:
void FreeInternal(bool keepPixels);
void Swap(DISPMANX_UPDATE_HANDLE_T& dispman_update);
void SwapGL(bool sync);
void RenderGL();
void ShaderInit();
void ShaderDestroy();
void CreateTexture();
void ReCreateTexture();
void ShaderUpdate();
void EnableShader();
void DisableShader();
void ConcatShaderDefines(char *dst);
// Raw pixel data. Not VC memory.
uint8_t* pixels_;
static DISPMANX_DISPLAY_HANDLE_T dispman_display_;
DISPMANX_ELEMENT_HANDLE_T dispman_element_;
DISPMANX_RESOURCE_HANDLE_T dispman_resource_[2];
static EGLDisplay egl_display_;
static EGLContext egl_context_;
EGLConfig egl_config_;
EGLSurface egl_surface_;
EGL_DISPMANX_WINDOW_T egl_native_window_;
VC_RECT_T scale_dst_rect_;
VC_RECT_T copy_dst_rect_;
// Defines the region within the frame buffer we are scaling
VC_RECT_T src_rect_;
VC_DISPMANX_ALPHA_T alpha_;
static bool initialized_;
int fb_width_;
int fb_height_;
int fb_pitch_;
int layer_;
int transparency_;
double hstretch_;
double vstretch_;
int hintstr_;
int vintstr_;
int use_hintstr_;
int use_vintstr_;
// -1 = top, 0 = center, 1 = bottom
int valign_;
int vpadding_;
// -1 = left, 0 = center, 1 = right
int halign_;
int hpadding_;
int h_center_offset_;
int v_center_offset_;
// Represents the resource currently visible
int rnum_;
// Used to take away some available display area
// before deciding what the dest rect coords should be. Expressed
// as percentage of available area.
double leftPadding_;
double rightPadding_;
double topPadding_;
double bottomPadding_;
int display_width_;
int display_height_;
int src_x_;
int src_y_;
int src_w_;
int src_h_;
int dst_x_;
int dst_y_;
int dst_w_;
int dst_h_;
bool showing_;
bool allocated_;
VC_IMAGE_TYPE_T mode_;
int bytes_per_pixel_;
uint16_t pal_565_[256];
uint32_t pal_argb_[256];
bool uses_shader_;
bool shader_init_;
GLuint vshader_;
GLuint fshader_;
GLuint shader_program_;
GLuint vbo_;
GLuint attr_vertex_;
GLuint attr_texcoord_;
GLuint texture_sampler_;
GLuint palette_sampler_;
GLuint tex_;
GLuint pal_;
// Orthographic projection matrix
GLint mvp_;
// Shader parameters
GLuint input_size_;
GLuint output_size_;
GLuint texture_size_;
GLuint texel_size_;
// Curvature requires the texture to have only
// the visible pixels in it. We can't get away
// with texture coords to crop what we want out
// of the buffer. The shader could probably be
// updated to avoid this. This flag being true
// causes hundreds of memcpy's to crop the data.
bool need_cpu_crop_;
uint8_t* cropped_pixels_;
// Coordinates. One array is used for both vertex and
// texture coordinates. 0-7 = vertex, 8-15 = texture
GLfloat tex_coords_[16];
// Shader params
bool curvature_;
float curvature_x_;
float curvature_y_;
int mask_;
float mask_brightness_;
bool gamma_;
bool fake_gamma_;
bool scanlines_;
bool multisample_;
float scanline_weight_;
float scanline_gap_brightness_;
float bloom_factor_;
float input_gamma_;
float output_gamma_;
bool sharper_;
bool bilinear_interpolation_;
};
#endif