mirror of
https://github.com/bradgrantham/apple2e.git
synced 2025-01-01 03:31:18 +00:00
use raw string literals
This commit is contained in:
parent
b76c734115
commit
0a9399d646
564
interface.cpp
564
interface.cpp
@ -172,122 +172,122 @@ tuple<float,bool> get_paddle(int num)
|
|||||||
|
|
||||||
const int raster_coords_attrib = 0;
|
const int raster_coords_attrib = 0;
|
||||||
|
|
||||||
static const char *hires_vertex_shader = "\n\
|
static const char *hires_vertex_shader = R"(
|
||||||
uniform mat3 to_screen;\n\
|
uniform mat3 to_screen;
|
||||||
in vec2 vertex_coords;\n\
|
in vec2 vertex_coords;
|
||||||
out vec2 raster_coords;\n\
|
out vec2 raster_coords;
|
||||||
uniform float x_offset;\n\
|
uniform float x_offset;
|
||||||
uniform float y_offset;\n\
|
uniform float y_offset;
|
||||||
\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
raster_coords = vertex_coords;\n\
|
|
||||||
vec3 screen_coords = to_screen * vec3(vertex_coords + vec2(x_offset, y_offset), 1);\n\
|
|
||||||
gl_Position = vec4(screen_coords.x, screen_coords.y, .5, 1);\n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *image_fragment_shader = "\n\
|
void main()
|
||||||
in vec2 raster_coords;\n\
|
{
|
||||||
uniform vec2 image_coord_scale;\n\
|
raster_coords = vertex_coords;
|
||||||
uniform sampler2D image;\n\
|
vec3 screen_coords = to_screen * vec3(vertex_coords + vec2(x_offset, y_offset), 1);
|
||||||
\n\
|
gl_Position = vec4(screen_coords.x, screen_coords.y, .5, 1);
|
||||||
out vec4 color;\n\
|
})";
|
||||||
\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
ivec2 tc = ivec2(raster_coords.x, raster_coords.y);\n\
|
|
||||||
float pixel = texture(image, raster_coords * image_coord_scale).x;\n\
|
|
||||||
color = vec4(pixel, pixel, pixel, 1);\n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *hires_fragment_shader = "\n\
|
static const char *image_fragment_shader = R"(
|
||||||
in vec2 raster_coords;\n\
|
in vec2 raster_coords;
|
||||||
uniform vec2 hires_texture_coord_scale;\n\
|
uniform vec2 image_coord_scale;
|
||||||
uniform sampler2D hires_texture;\n\
|
uniform sampler2D image;
|
||||||
\n\
|
|
||||||
out vec4 color;\n\
|
|
||||||
\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
int byte = int(raster_coords.x) / 7;\n\
|
|
||||||
int bit = int(raster_coords.x) % 7;\n\
|
|
||||||
int texturex = byte * 8 + bit;\n\
|
|
||||||
ivec2 tc = ivec2(texturex, raster_coords.y);\n\
|
|
||||||
float pixel = texture(hires_texture, (tc + vec2(.01f, .01f)) * hires_texture_coord_scale).x;\n\
|
|
||||||
color = vec4(pixel, pixel, pixel, 1);\n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *hirescolor_fragment_shader = "\n\
|
out vec4 color;
|
||||||
in vec2 raster_coords;\n\
|
|
||||||
uniform vec2 hires_texture_coord_scale;\n\
|
|
||||||
uniform sampler2D hires_texture;\n\
|
|
||||||
\n\
|
|
||||||
out vec4 color;\n\
|
|
||||||
\n\
|
|
||||||
vec2 raster_to_texture(int x, int y)\n\
|
|
||||||
{\n\
|
|
||||||
int byte = x / 7;\n\
|
|
||||||
int bit = x % 7;\n\
|
|
||||||
int texturex = byte * 8 + bit;\n\
|
|
||||||
return vec2(texturex + .01f, y + .01f) * hires_texture_coord_scale; \n\
|
|
||||||
}\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
int x = int(raster_coords.x); \n\
|
|
||||||
int y = int(raster_coords.y); \n\
|
|
||||||
\n\
|
|
||||||
uint left = (x < 1) ? 0u : uint(255 * texture(hires_texture, raster_to_texture(x - 1, y)).x);\n\
|
|
||||||
uint pixel = uint(255 * texture(hires_texture, raster_to_texture(x, y)).x);\n\
|
|
||||||
uint right = (x > 278) ? 0u : uint(255 * texture(hires_texture, raster_to_texture(x + 1, y)).x);\n\
|
|
||||||
\n\
|
|
||||||
if((pixel == 255u) && ((left == 255u) || (right == 255u))) { \n\
|
|
||||||
/* Okay, first of all, if this pixel's on and its left or right are on, it's white. */ \n\
|
|
||||||
color = vec4(1.0, 1.0, 1.0, 1.0);\n\
|
|
||||||
} else if((pixel == 0u) && (left == 0u) && (right == 0u)) { \n\
|
|
||||||
/* If none are on, it's black */ \n\
|
|
||||||
color = vec4(0.0, 0.0, 0.0, 1.0);\n\
|
|
||||||
} else { \n\
|
|
||||||
uint even = (x % 2 == 1) ? left : pixel; \n\
|
|
||||||
uint odd = (x % 2 == 1) ? pixel : right; \n\
|
|
||||||
uint palette = uint(texture(hires_texture, vec2((x / 7) * 8 + 7 + .01f, raster_coords.y + .01f) * hires_texture_coord_scale).x); \n\
|
|
||||||
\n\
|
|
||||||
if(palette == 0u) { \n\
|
|
||||||
if((even == 0u) && (odd == 255u)) { \n\
|
|
||||||
color = vec4(20.0/255.0, 245.0/255.0, 60.0/255.0, 1.0);\n\
|
|
||||||
/* green 20 245 60 */ \n\
|
|
||||||
} else if((even == 255u) && (odd == 0u)) { \n\
|
|
||||||
/* purple 255 68 253 */ \n\
|
|
||||||
color = vec4(255.0/255.0, 68.0/255.0, 253.0/255.0, 1.0);\n\
|
|
||||||
} else if((even == 0u) && (odd == 0u)) { \n\
|
|
||||||
color = vec4(0, 0, 0, 1);\n\
|
|
||||||
} /* handled 1,1 above */ \n\
|
|
||||||
} else { \n\
|
|
||||||
if((even == 0u) && (odd == 255u)) { \n\
|
|
||||||
/* orange 255 106 60 */ \n\
|
|
||||||
color = vec4(255.0/255.0, 106.0/255.0, 60.0/255.0, 1.0);\n\
|
|
||||||
} else if((even == 255u) && (odd == 0u)) { \n\
|
|
||||||
/* blue 20 207 253 */ \n\
|
|
||||||
color = vec4(20.0/255.0, 207.0/255.0, 253.0/255.0, 1.0);\n\
|
|
||||||
} else if((even == 0u) && (odd == 0u)) { \n\
|
|
||||||
color = vec4(0, 0, 0, 1);\n\
|
|
||||||
} /* handled 1,1 above */ \n\
|
|
||||||
} \n\
|
|
||||||
} \n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *text_vertex_shader = "\n\
|
void main()
|
||||||
uniform mat3 to_screen;\n\
|
{
|
||||||
in vec2 vertex_coords;\n\
|
ivec2 tc = ivec2(raster_coords.x, raster_coords.y);
|
||||||
uniform float x_offset;\n\
|
float pixel = texture(image, raster_coords * image_coord_scale).x;
|
||||||
uniform float y_offset;\n\
|
color = vec4(pixel, pixel, pixel, 1);
|
||||||
out vec2 raster_coords;\n\
|
})";
|
||||||
\n\
|
|
||||||
void main()\n\
|
static const char *hires_fragment_shader = R"(
|
||||||
{\n\
|
in vec2 raster_coords;
|
||||||
raster_coords = vertex_coords;\n\
|
uniform vec2 hires_texture_coord_scale;
|
||||||
vec3 screen_coords = to_screen * vec3(vertex_coords + vec2(x_offset, y_offset), 1);\n\
|
uniform sampler2D hires_texture;
|
||||||
gl_Position = vec4(screen_coords.x, screen_coords.y, .5, 1);\n\
|
|
||||||
}\n";
|
out vec4 color;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
int byte = int(raster_coords.x) / 7;
|
||||||
|
int bit = int(raster_coords.x) % 7;
|
||||||
|
int texturex = byte * 8 + bit;
|
||||||
|
ivec2 tc = ivec2(texturex, raster_coords.y);
|
||||||
|
float pixel = texture(hires_texture, (tc + vec2(.01f, .01f)) * hires_texture_coord_scale).x;
|
||||||
|
color = vec4(pixel, pixel, pixel, 1);
|
||||||
|
})";
|
||||||
|
|
||||||
|
static const char *hirescolor_fragment_shader = R"(
|
||||||
|
in vec2 raster_coords;
|
||||||
|
uniform vec2 hires_texture_coord_scale;
|
||||||
|
uniform sampler2D hires_texture;
|
||||||
|
|
||||||
|
out vec4 color;
|
||||||
|
|
||||||
|
vec2 raster_to_texture(int x, int y)
|
||||||
|
{
|
||||||
|
int byte = x / 7;
|
||||||
|
int bit = x % 7;
|
||||||
|
int texturex = byte * 8 + bit;
|
||||||
|
return vec2(texturex + .01f, y + .01f) * hires_texture_coord_scale;
|
||||||
|
}
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
int x = int(raster_coords.x);
|
||||||
|
int y = int(raster_coords.y);
|
||||||
|
|
||||||
|
uint left = (x < 1) ? 0u : uint(255 * texture(hires_texture, raster_to_texture(x - 1, y)).x);
|
||||||
|
uint pixel = uint(255 * texture(hires_texture, raster_to_texture(x, y)).x);
|
||||||
|
uint right = (x > 278) ? 0u : uint(255 * texture(hires_texture, raster_to_texture(x + 1, y)).x);
|
||||||
|
|
||||||
|
if((pixel == 255u) && ((left == 255u) || (right == 255u))) {
|
||||||
|
/* Okay, first of all, if this pixel's on and its left or right are on, it's white. */
|
||||||
|
color = vec4(1.0, 1.0, 1.0, 1.0);
|
||||||
|
} else if((pixel == 0u) && (left == 0u) && (right == 0u)) {
|
||||||
|
/* If none are on, it's black */
|
||||||
|
color = vec4(0.0, 0.0, 0.0, 1.0);
|
||||||
|
} else {
|
||||||
|
uint even = (x % 2 == 1) ? left : pixel;
|
||||||
|
uint odd = (x % 2 == 1) ? pixel : right;
|
||||||
|
uint palette = uint(texture(hires_texture, vec2((x / 7) * 8 + 7 + .01f, raster_coords.y + .01f) * hires_texture_coord_scale).x);
|
||||||
|
|
||||||
|
if(palette == 0u) {
|
||||||
|
if((even == 0u) && (odd == 255u)) {
|
||||||
|
color = vec4(20.0/255.0, 245.0/255.0, 60.0/255.0, 1.0);
|
||||||
|
/* green 20 245 60 */
|
||||||
|
} else if((even == 255u) && (odd == 0u)) {
|
||||||
|
/* purple 255 68 253 */
|
||||||
|
color = vec4(255.0/255.0, 68.0/255.0, 253.0/255.0, 1.0);
|
||||||
|
} else if((even == 0u) && (odd == 0u)) {
|
||||||
|
color = vec4(0, 0, 0, 1);
|
||||||
|
} /* handled 1,1 above */
|
||||||
|
} else {
|
||||||
|
if((even == 0u) && (odd == 255u)) {
|
||||||
|
/* orange 255 106 60 */
|
||||||
|
color = vec4(255.0/255.0, 106.0/255.0, 60.0/255.0, 1.0);
|
||||||
|
} else if((even == 255u) && (odd == 0u)) {
|
||||||
|
/* blue 20 207 253 */
|
||||||
|
color = vec4(20.0/255.0, 207.0/255.0, 253.0/255.0, 1.0);
|
||||||
|
} else if((even == 0u) && (odd == 0u)) {
|
||||||
|
color = vec4(0, 0, 0, 1);
|
||||||
|
} /* handled 1,1 above */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})";
|
||||||
|
|
||||||
|
static const char *text_vertex_shader = R"(
|
||||||
|
uniform mat3 to_screen;
|
||||||
|
in vec2 vertex_coords;
|
||||||
|
uniform float x_offset;
|
||||||
|
uniform float y_offset;
|
||||||
|
out vec2 raster_coords;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
raster_coords = vertex_coords;
|
||||||
|
vec3 screen_coords = to_screen * vec3(vertex_coords + vec2(x_offset, y_offset), 1);
|
||||||
|
gl_Position = vec4(screen_coords.x, screen_coords.y, .5, 1);
|
||||||
|
})";
|
||||||
|
|
||||||
// 0-31 is inverse 32-63
|
// 0-31 is inverse 32-63
|
||||||
// 32-63 is inverse 0-31
|
// 32-63 is inverse 0-31
|
||||||
@ -298,176 +298,176 @@ static const char *text_vertex_shader = "\n\
|
|||||||
// 192-223 is normal 32-63
|
// 192-223 is normal 32-63
|
||||||
// 224-255 is normal 64-95
|
// 224-255 is normal 64-95
|
||||||
|
|
||||||
static const char *text_fragment_shader = "\n\
|
static const char *text_fragment_shader = R"(
|
||||||
in vec2 raster_coords;\n\
|
in vec2 raster_coords;
|
||||||
uniform int blink;\n\
|
uniform int blink;
|
||||||
uniform vec4 foreground;\n\
|
uniform vec4 foreground;
|
||||||
uniform vec4 background;\n\
|
uniform vec4 background;
|
||||||
uniform vec2 font_texture_coord_scale;\n\
|
uniform vec2 font_texture_coord_scale;
|
||||||
uniform sampler2D font_texture;\n\
|
uniform sampler2D font_texture;
|
||||||
uniform vec2 textport_texture_coord_scale;\n\
|
uniform vec2 textport_texture_coord_scale;
|
||||||
uniform sampler2D textport_texture;\n\
|
uniform sampler2D textport_texture;
|
||||||
\n\
|
|
||||||
out vec4 color;\n\
|
|
||||||
\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
uint character;\n\
|
|
||||||
character = uint(texture(textport_texture, (uvec2(uint(raster_coords.x) / 7u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0); \n\
|
|
||||||
bool inverse = false;\n\
|
|
||||||
if(character >= 0u && character <= 31u) {\n\
|
|
||||||
character = character - 0u + 32u;\n\
|
|
||||||
inverse = true;\n\
|
|
||||||
} else if(character >= 32u && character <= 63u) {\n\
|
|
||||||
character = character - 32u + 0u;\n\
|
|
||||||
inverse = true;\n\
|
|
||||||
} else if(character >= 64u && character <= 95u) {\n\
|
|
||||||
character = character - 64u + 32u; // XXX BLINK \n\
|
|
||||||
inverse = blink == 1;\n\
|
|
||||||
} else if(character >= 96u && character <= 127u){\n\
|
|
||||||
character = character - 96u + 0u; // XXX BLINK \n\
|
|
||||||
inverse = blink == 1;\n\
|
|
||||||
} else if(character >= 128u && character <= 159u)\n\
|
|
||||||
character = character - 128u + 32u;\n\
|
|
||||||
else if(character >= 160u && character <= 191u)\n\
|
|
||||||
character = character - 160u + 0u;\n\
|
|
||||||
else if(character >= 192u && character <= 223u)\n\
|
|
||||||
character = character - 192u + 32u;\n\
|
|
||||||
else if(character >= 224u && character <= 255u)\n\
|
|
||||||
character = character - 224u + 64u;\n\
|
|
||||||
else \n\
|
|
||||||
character = 33u;\n\
|
|
||||||
uvec2 inglyph = uvec2(uint(raster_coords.x) % 7u, uint(raster_coords.y) % 8u);\n\
|
|
||||||
uvec2 infont = inglyph + uvec2(0, character * 8u);\n\
|
|
||||||
float pixel = texture(font_texture, (infont + vec2(.01f, 0.1f)) * font_texture_coord_scale).x;\n\
|
|
||||||
if(inverse)\n\
|
|
||||||
color = mix(background, foreground, 1.0 - pixel);\n\
|
|
||||||
else\n\
|
|
||||||
color = mix(background, foreground, pixel);\n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *text80_fragment_shader = "\n\
|
out vec4 color;
|
||||||
in vec2 raster_coords;\n\
|
|
||||||
uniform int blink;\n\
|
|
||||||
uniform vec4 foreground;\n\
|
|
||||||
uniform vec4 background;\n\
|
|
||||||
uniform vec2 font_texture_coord_scale;\n\
|
|
||||||
uniform sampler2D font_texture;\n\
|
|
||||||
uniform vec2 textport_texture_coord_scale;\n\
|
|
||||||
uniform sampler2D textport_texture;\n\
|
|
||||||
uniform sampler2D textport_aux_texture;\n\
|
|
||||||
\n\
|
|
||||||
out vec4 color;\n\
|
|
||||||
\n\
|
|
||||||
void main()\n\
|
|
||||||
{\n\
|
|
||||||
uint character;\n\
|
|
||||||
uint x = uint(raster_coords.x * 2) / 7u; \n\
|
|
||||||
if(x % 2u == 1u) \n\
|
|
||||||
character = uint(texture(textport_texture, (uvec2((x - 1u) / 2u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0); \n\
|
|
||||||
else \n\
|
|
||||||
character = uint(texture(textport_aux_texture, (uvec2(x / 2u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0); \n\
|
|
||||||
bool inverse = false;\n\
|
|
||||||
if(character >= 0u && character <= 31u) {\n\
|
|
||||||
character = character - 0u + 32u;\n\
|
|
||||||
inverse = true;\n\
|
|
||||||
} else if(character >= 32u && character <= 63u) {\n\
|
|
||||||
character = character - 32u + 0u;\n\
|
|
||||||
inverse = true;\n\
|
|
||||||
} else if(character >= 64u && character <= 95u) {\n\
|
|
||||||
character = character - 64u + 32u; // XXX BLINK \n\
|
|
||||||
inverse = blink == 1;\n\
|
|
||||||
} else if(character >= 96u && character <= 127u){\n\
|
|
||||||
character = character - 96u + 0u; // XXX BLINK \n\
|
|
||||||
inverse = blink == 1;\n\
|
|
||||||
} else if(character >= 128u && character <= 159u)\n\
|
|
||||||
character = character - 128u + 32u;\n\
|
|
||||||
else if(character >= 160u && character <= 191u)\n\
|
|
||||||
character = character - 160u + 0u;\n\
|
|
||||||
else if(character >= 192u && character <= 223u)\n\
|
|
||||||
character = character - 192u + 32u;\n\
|
|
||||||
else if(character >= 224u && character <= 255u)\n\
|
|
||||||
character = character - 224u + 64u;\n\
|
|
||||||
else \n\
|
|
||||||
character = 33u;\n\
|
|
||||||
uvec2 inglyph = uvec2(uint(raster_coords.x * 2) % 7u, uint(raster_coords.y) % 8u);\n\
|
|
||||||
uvec2 infont = inglyph + uvec2(0, character * 8u);\n\
|
|
||||||
float pixel = texture(font_texture, (infont + vec2(.01f, 0.1f)) * font_texture_coord_scale).x;\n\
|
|
||||||
float value;\n\
|
|
||||||
if(inverse)\n\
|
|
||||||
color = mix(background, foreground, 1.0 - pixel);\n\
|
|
||||||
else\n\
|
|
||||||
color = mix(background, foreground, pixel);\n\
|
|
||||||
}\n";
|
|
||||||
|
|
||||||
static const char *lores_fragment_shader = "\n\
|
void main()
|
||||||
in vec2 raster_coords;\n\
|
{
|
||||||
uniform vec2 lores_texture_coord_scale;\n\
|
uint character;
|
||||||
uniform sampler2D lores_texture;\n\
|
character = uint(texture(textport_texture, (uvec2(uint(raster_coords.x) / 7u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0);
|
||||||
\n\
|
bool inverse = false;
|
||||||
out vec4 color;\n\
|
if(character >= 0u && character <= 31u) {
|
||||||
\n\
|
character = character - 0u + 32u;
|
||||||
void main()\n\
|
inverse = true;
|
||||||
{\n\
|
} else if(character >= 32u && character <= 63u) {
|
||||||
uint byte;\n\
|
character = character - 32u + 0u;
|
||||||
byte = uint(texture(lores_texture, (uvec2(uint(raster_coords.x) / 7u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * lores_texture_coord_scale).x * 255.0); \n\
|
inverse = true;
|
||||||
uint inglyph_y = uint(raster_coords.y) % 8u;\n\
|
} else if(character >= 64u && character <= 95u) {
|
||||||
uint lorespixel;\n\
|
character = character - 64u + 32u; // XXX BLINK
|
||||||
if(inglyph_y < 4u)\n\
|
inverse = blink == 1;
|
||||||
lorespixel = byte % 16u;\n\
|
} else if(character >= 96u && character <= 127u){
|
||||||
else\n\
|
character = character - 96u + 0u; // XXX BLINK
|
||||||
lorespixel = byte / 16u;\n\
|
inverse = blink == 1;
|
||||||
switch(lorespixel) {\n\
|
} else if(character >= 128u && character <= 159u)
|
||||||
case 0u:\n\
|
character = character - 128u + 32u;
|
||||||
color = vec4(0, 0, 0, 1);\n\
|
else if(character >= 160u && character <= 191u)
|
||||||
break;\n\
|
character = character - 160u + 0u;
|
||||||
case 1u:\n\
|
else if(character >= 192u && character <= 223u)
|
||||||
color = vec4(227.0/255.0, 30.0/255.0, 96.0/255.0, 1);\n\
|
character = character - 192u + 32u;
|
||||||
break;\n\
|
else if(character >= 224u && character <= 255u)
|
||||||
case 2u:\n\
|
character = character - 224u + 64u;
|
||||||
color = vec4(96.0/255.0, 78.0/255.0, 189.0/255.0, 1);\n\
|
else
|
||||||
break;\n\
|
character = 33u;
|
||||||
case 3u:\n\
|
uvec2 inglyph = uvec2(uint(raster_coords.x) % 7u, uint(raster_coords.y) % 8u);
|
||||||
color = vec4(255.0/255.0, 68.0/255.0, 253.0/255.0, 1);\n\
|
uvec2 infont = inglyph + uvec2(0, character * 8u);
|
||||||
break;\n\
|
float pixel = texture(font_texture, (infont + vec2(.01f, 0.1f)) * font_texture_coord_scale).x;
|
||||||
case 4u:\n\
|
if(inverse)
|
||||||
color = vec4(9.0/255.0, 163.0/255.0, 96.0/255.0, 1);\n\
|
color = mix(background, foreground, 1.0 - pixel);
|
||||||
break;\n\
|
else
|
||||||
case 5u:\n\
|
color = mix(background, foreground, pixel);
|
||||||
color = vec4(156.0/255.0, 156.0/255.0, 156.0/255.0, 1);\n\
|
})";
|
||||||
break;\n\
|
|
||||||
case 6u:\n\
|
static const char *text80_fragment_shader = R"(
|
||||||
color = vec4(20.0/255.0, 207.0/255.0, 253.0/255.0, 1);\n\
|
in vec2 raster_coords;
|
||||||
break;\n\
|
uniform int blink;
|
||||||
case 7u:\n\
|
uniform vec4 foreground;
|
||||||
color = vec4(208.0/255.0, 195.0/255.0, 255.0/255.0, 1);\n\
|
uniform vec4 background;
|
||||||
break;\n\
|
uniform vec2 font_texture_coord_scale;
|
||||||
case 8u:\n\
|
uniform sampler2D font_texture;
|
||||||
color = vec4(96.0/255.0, 114.0/255.0, 3.0/255.0, 1);\n\
|
uniform vec2 textport_texture_coord_scale;
|
||||||
break;\n\
|
uniform sampler2D textport_texture;
|
||||||
case 9u:\n\
|
uniform sampler2D textport_aux_texture;
|
||||||
color = vec4(255.0/255.0, 106.0/255.0, 60.0/255.0, 1);\n\
|
|
||||||
break;\n\
|
out vec4 color;
|
||||||
case 10u:\n\
|
|
||||||
color = vec4(156.0/255.0, 156.0/255.0, 156.0/255.0, 1);\n\
|
void main()
|
||||||
break;\n\
|
{
|
||||||
case 11u:\n\
|
uint character;
|
||||||
color = vec4(255.0/255.0, 160.0/255.0, 208.0/255.0, 1);\n\
|
uint x = uint(raster_coords.x * 2) / 7u;
|
||||||
break;\n\
|
if(x % 2u == 1u)
|
||||||
case 12u:\n\
|
character = uint(texture(textport_texture, (uvec2((x - 1u) / 2u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0);
|
||||||
color = vec4(20.0/255.0, 245.0/255.0, 60.0/255.0, 1);\n\
|
else
|
||||||
break;\n\
|
character = uint(texture(textport_aux_texture, (uvec2(x / 2u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * textport_texture_coord_scale).x * 255.0);
|
||||||
case 13u:\n\
|
bool inverse = false;
|
||||||
color = vec4(208.0/255.0, 221.0/255.0, 141.0/255.0, 1);\n\
|
if(character >= 0u && character <= 31u) {
|
||||||
break;\n\
|
character = character - 0u + 32u;
|
||||||
case 14u:\n\
|
inverse = true;
|
||||||
color = vec4(114.0/255.0, 255.0/255.0, 208.0/255.0, 1);\n\
|
} else if(character >= 32u && character <= 63u) {
|
||||||
break;\n\
|
character = character - 32u + 0u;
|
||||||
case 15u:\n\
|
inverse = true;
|
||||||
color = vec4(255.0/255.0, 255.0/255.0, 255.0/255.0, 1);\n\
|
} else if(character >= 64u && character <= 95u) {
|
||||||
break;\n\
|
character = character - 64u + 32u; // XXX BLINK
|
||||||
}\n\
|
inverse = blink == 1;
|
||||||
}\n";
|
} else if(character >= 96u && character <= 127u){
|
||||||
|
character = character - 96u + 0u; // XXX BLINK
|
||||||
|
inverse = blink == 1;
|
||||||
|
} else if(character >= 128u && character <= 159u)
|
||||||
|
character = character - 128u + 32u;
|
||||||
|
else if(character >= 160u && character <= 191u)
|
||||||
|
character = character - 160u + 0u;
|
||||||
|
else if(character >= 192u && character <= 223u)
|
||||||
|
character = character - 192u + 32u;
|
||||||
|
else if(character >= 224u && character <= 255u)
|
||||||
|
character = character - 224u + 64u;
|
||||||
|
else
|
||||||
|
character = 33u;
|
||||||
|
uvec2 inglyph = uvec2(uint(raster_coords.x * 2) % 7u, uint(raster_coords.y) % 8u);
|
||||||
|
uvec2 infont = inglyph + uvec2(0, character * 8u);
|
||||||
|
float pixel = texture(font_texture, (infont + vec2(.01f, 0.1f)) * font_texture_coord_scale).x;
|
||||||
|
float value;
|
||||||
|
if(inverse)
|
||||||
|
color = mix(background, foreground, 1.0 - pixel);
|
||||||
|
else
|
||||||
|
color = mix(background, foreground, pixel);
|
||||||
|
})";
|
||||||
|
|
||||||
|
static const char *lores_fragment_shader = R"(
|
||||||
|
in vec2 raster_coords;
|
||||||
|
uniform vec2 lores_texture_coord_scale;
|
||||||
|
uniform sampler2D lores_texture;
|
||||||
|
|
||||||
|
out vec4 color;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
uint byte;
|
||||||
|
byte = uint(texture(lores_texture, (uvec2(uint(raster_coords.x) / 7u, uint(raster_coords.y) / 8u) + vec2(.01f, .01f)) * lores_texture_coord_scale).x * 255.0);
|
||||||
|
uint inglyph_y = uint(raster_coords.y) % 8u;
|
||||||
|
uint lorespixel;
|
||||||
|
if(inglyph_y < 4u)
|
||||||
|
lorespixel = byte % 16u;
|
||||||
|
else
|
||||||
|
lorespixel = byte / 16u;
|
||||||
|
switch(lorespixel) {
|
||||||
|
case 0u:
|
||||||
|
color = vec4(0, 0, 0, 1);
|
||||||
|
break;
|
||||||
|
case 1u:
|
||||||
|
color = vec4(227.0/255.0, 30.0/255.0, 96.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 2u:
|
||||||
|
color = vec4(96.0/255.0, 78.0/255.0, 189.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 3u:
|
||||||
|
color = vec4(255.0/255.0, 68.0/255.0, 253.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 4u:
|
||||||
|
color = vec4(9.0/255.0, 163.0/255.0, 96.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 5u:
|
||||||
|
color = vec4(156.0/255.0, 156.0/255.0, 156.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 6u:
|
||||||
|
color = vec4(20.0/255.0, 207.0/255.0, 253.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 7u:
|
||||||
|
color = vec4(208.0/255.0, 195.0/255.0, 255.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 8u:
|
||||||
|
color = vec4(96.0/255.0, 114.0/255.0, 3.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 9u:
|
||||||
|
color = vec4(255.0/255.0, 106.0/255.0, 60.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 10u:
|
||||||
|
color = vec4(156.0/255.0, 156.0/255.0, 156.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 11u:
|
||||||
|
color = vec4(255.0/255.0, 160.0/255.0, 208.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 12u:
|
||||||
|
color = vec4(20.0/255.0, 245.0/255.0, 60.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 13u:
|
||||||
|
color = vec4(208.0/255.0, 221.0/255.0, 141.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 14u:
|
||||||
|
color = vec4(114.0/255.0, 255.0/255.0, 208.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
case 15u:
|
||||||
|
color = vec4(255.0/255.0, 255.0/255.0, 255.0/255.0, 1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
})";
|
||||||
|
|
||||||
void set_image_shader(float to_screen[9], const opengl_texture& texture, float x, float y)
|
void set_image_shader(float to_screen[9], const opengl_texture& texture, float x, float y)
|
||||||
{
|
{
|
||||||
@ -1776,6 +1776,10 @@ void iterate(const ModeHistory& history, unsigned long long current_byte, float
|
|||||||
glfwSwapBuffers(my_window);
|
glfwSwapBuffers(my_window);
|
||||||
CheckOpenGL(__FILE__, __LINE__);
|
CheckOpenGL(__FILE__, __LINE__);
|
||||||
|
|
||||||
|
for(int i = 0; i < 16; i++)
|
||||||
|
if(glfwJoystickPresent(GLFW_JOYSTICK_1 + i))
|
||||||
|
printf("joy %d present\n", i);
|
||||||
|
|
||||||
if(glfwJoystickPresent(GLFW_JOYSTICK_1)) {
|
if(glfwJoystickPresent(GLFW_JOYSTICK_1)) {
|
||||||
if(false) printf("joystick 1 present\n");
|
if(false) printf("joystick 1 present\n");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user