Handle double redraw
This commit is contained in:
parent
de24ab9b0d
commit
a29051ec7f
1 changed files with 89 additions and 83 deletions
|
@ -38,15 +38,8 @@ grub_cmd_videotest (grub_command_t cmd __attribute__ ((unused)),
|
||||||
unsigned int width;
|
unsigned int width;
|
||||||
unsigned int height;
|
unsigned int height;
|
||||||
int i;
|
int i;
|
||||||
grub_font_t sansbig;
|
|
||||||
grub_font_t sans;
|
|
||||||
grub_font_t sanssmall;
|
|
||||||
grub_font_t fixed;
|
|
||||||
struct grub_font_glyph *glyph;
|
|
||||||
struct grub_video_render_target *text_layer;
|
struct grub_video_render_target *text_layer;
|
||||||
grub_video_color_t palette[16];
|
grub_video_color_t palette[16];
|
||||||
const char *str;
|
|
||||||
int texty;
|
|
||||||
|
|
||||||
err = grub_video_set_mode ("auto", GRUB_VIDEO_MODE_TYPE_PURE_TEXT, 0);
|
err = grub_video_set_mode ("auto", GRUB_VIDEO_MODE_TYPE_PURE_TEXT, 0);
|
||||||
if (err)
|
if (err)
|
||||||
|
@ -54,102 +47,115 @@ grub_cmd_videotest (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
|
||||||
grub_video_get_viewport (&x, &y, &width, &height);
|
grub_video_get_viewport (&x, &y, &width, &height);
|
||||||
|
|
||||||
grub_video_create_render_target (&text_layer, width, height,
|
{
|
||||||
GRUB_VIDEO_MODE_TYPE_RGB
|
const char *str;
|
||||||
| GRUB_VIDEO_MODE_TYPE_ALPHA);
|
int texty;
|
||||||
|
grub_font_t sansbig;
|
||||||
|
grub_font_t sans;
|
||||||
|
grub_font_t sanssmall;
|
||||||
|
grub_font_t fixed;
|
||||||
|
struct grub_font_glyph *glyph;
|
||||||
|
|
||||||
grub_video_set_active_render_target (GRUB_VIDEO_RENDER_TARGET_DISPLAY);
|
grub_video_create_render_target (&text_layer, width, height,
|
||||||
|
GRUB_VIDEO_MODE_TYPE_RGB
|
||||||
|
| GRUB_VIDEO_MODE_TYPE_ALPHA);
|
||||||
|
|
||||||
color = grub_video_map_rgb (0, 0, 0);
|
grub_video_set_active_render_target (text_layer);
|
||||||
grub_video_fill_rect (color, 0, 0, width, height);
|
|
||||||
|
|
||||||
color = grub_video_map_rgb (255, 0, 0);
|
color = grub_video_map_rgb (0, 255, 255);
|
||||||
grub_video_fill_rect (color, 0, 0, 100, 100);
|
sansbig = grub_font_get ("Unknown Regular 16");
|
||||||
|
sans = grub_font_get ("Unknown Regular 16");
|
||||||
|
sanssmall = grub_font_get ("Unknown Regular 16");
|
||||||
|
fixed = grub_font_get ("Fixed 20");
|
||||||
|
if (! sansbig || ! sans || ! sanssmall || ! fixed)
|
||||||
|
return grub_error (GRUB_ERR_BAD_FONT, "no font loaded");
|
||||||
|
|
||||||
color = grub_video_map_rgb (0, 255, 255);
|
glyph = grub_font_get_glyph (fixed, '*');
|
||||||
grub_video_fill_rect (color, 100, 100, 100, 100);
|
grub_font_draw_glyph (glyph, color, 200 ,0);
|
||||||
|
|
||||||
sansbig = grub_font_get ("Unknown Regular 16");
|
color = grub_video_map_rgb (255, 255, 255);
|
||||||
sans = grub_font_get ("Unknown Regular 16");
|
|
||||||
sanssmall = grub_font_get ("Unknown Regular 16");
|
|
||||||
fixed = grub_font_get ("Fixed 20");
|
|
||||||
if (! sansbig || ! sans || ! sanssmall || ! fixed)
|
|
||||||
return grub_error (GRUB_ERR_BAD_FONT, "no font loaded");
|
|
||||||
|
|
||||||
glyph = grub_font_get_glyph (fixed, '*');
|
texty = 32;
|
||||||
grub_font_draw_glyph (glyph, color, 200 ,0);
|
grub_font_draw_string ("The quick brown fox jumped over the lazy dog.",
|
||||||
|
sans, color, 16, texty);
|
||||||
|
texty += grub_font_get_descent (sans) + grub_font_get_leading (sans);
|
||||||
|
|
||||||
grub_video_set_viewport (x + 150, y + 150,
|
texty += grub_font_get_ascent (fixed);
|
||||||
width - 150 * 2, height - 150 * 2);
|
grub_font_draw_string ("The quick brown fox jumped over the lazy dog.",
|
||||||
color = grub_video_map_rgb (77, 33, 77);
|
fixed, color, 16, texty);
|
||||||
grub_video_fill_rect (color, 0, 0, width, height);
|
texty += grub_font_get_descent (fixed) + grub_font_get_leading (fixed);
|
||||||
|
|
||||||
grub_video_set_active_render_target (text_layer);
|
/* To convert Unicode characters into UTF-8 for this test, the following
|
||||||
|
command is useful:
|
||||||
color = grub_video_map_rgb (255, 255, 255);
|
|
||||||
|
|
||||||
texty = 32;
|
|
||||||
grub_font_draw_string ("The quick brown fox jumped over the lazy dog.",
|
|
||||||
sans, color, 16, texty);
|
|
||||||
texty += grub_font_get_descent (sans) + grub_font_get_leading (sans);
|
|
||||||
|
|
||||||
texty += grub_font_get_ascent (fixed);
|
|
||||||
grub_font_draw_string ("The quick brown fox jumped over the lazy dog.",
|
|
||||||
fixed, color, 16, texty);
|
|
||||||
texty += grub_font_get_descent (fixed) + grub_font_get_leading (fixed);
|
|
||||||
|
|
||||||
/* To convert Unicode characters into UTF-8 for this test, the following
|
|
||||||
command is useful:
|
|
||||||
echo -ne '\x00\x00\x26\x3A' | iconv -f UTF-32BE -t UTF-8 | od -t x1
|
echo -ne '\x00\x00\x26\x3A' | iconv -f UTF-32BE -t UTF-8 | od -t x1
|
||||||
This converts the Unicode character U+263A to UTF-8. */
|
This converts the Unicode character U+263A to UTF-8. */
|
||||||
|
|
||||||
/* Characters used:
|
/* Characters used:
|
||||||
Code point Description UTF-8 encoding
|
Code point Description UTF-8 encoding
|
||||||
----------- ------------------------------ --------------
|
----------- ------------------------------ --------------
|
||||||
U+263A unfilled smiley face E2 98 BA
|
U+263A unfilled smiley face E2 98 BA
|
||||||
U+00A1 inverted exclamation point C2 A1
|
U+00A1 inverted exclamation point C2 A1
|
||||||
U+00A3 British pound currency symbol C2 A3
|
U+00A3 British pound currency symbol C2 A3
|
||||||
U+03C4 Greek tau CF 84
|
U+03C4 Greek tau CF 84
|
||||||
U+00E4 lowercase letter a with umlaut C3 A4
|
U+00E4 lowercase letter a with umlaut C3 A4
|
||||||
U+2124 set 'Z' symbol (integers) E2 84 A4
|
U+2124 set 'Z' symbol (integers) E2 84 A4
|
||||||
U+2287 subset symbol E2 8A 87
|
U+2287 subset symbol E2 8A 87
|
||||||
U+211D set 'R' symbol (real numbers) E2 84 9D */
|
U+211D set 'R' symbol (real numbers) E2 84 9D */
|
||||||
|
|
||||||
str =
|
str =
|
||||||
"Unicode test: happy\xE2\x98\xBA \xC2\xA3 5.00"
|
"Unicode test: happy\xE2\x98\xBA \xC2\xA3 5.00"
|
||||||
" \xC2\xA1\xCF\x84\xC3\xA4u! "
|
" \xC2\xA1\xCF\x84\xC3\xA4u! "
|
||||||
" \xE2\x84\xA4\xE2\x8A\x87\xE2\x84\x9D";
|
" \xE2\x84\xA4\xE2\x8A\x87\xE2\x84\x9D";
|
||||||
color = grub_video_map_rgb (128, 128, 255);
|
color = grub_video_map_rgb (128, 128, 255);
|
||||||
|
|
||||||
/* All characters in the string exist in the 'Fixed 20' (10x20) font. */
|
/* All characters in the string exist in the 'Fixed 20' (10x20) font. */
|
||||||
texty += grub_font_get_ascent(fixed);
|
texty += grub_font_get_ascent(fixed);
|
||||||
grub_font_draw_string (str, fixed, color, 16, texty);
|
grub_font_draw_string (str, fixed, color, 16, texty);
|
||||||
texty += grub_font_get_descent (fixed) + grub_font_get_leading (fixed);
|
texty += grub_font_get_descent (fixed) + grub_font_get_leading (fixed);
|
||||||
|
|
||||||
texty += grub_font_get_ascent(sansbig);
|
texty += grub_font_get_ascent(sansbig);
|
||||||
grub_font_draw_string (str, sansbig, color, 16, texty);
|
grub_font_draw_string (str, sansbig, color, 16, texty);
|
||||||
texty += grub_font_get_descent (sansbig) + grub_font_get_leading (sansbig);
|
texty += grub_font_get_descent (sansbig) + grub_font_get_leading (sansbig);
|
||||||
|
|
||||||
texty += grub_font_get_ascent(sans);
|
texty += grub_font_get_ascent(sans);
|
||||||
grub_font_draw_string (str, sans, color, 16, texty);
|
grub_font_draw_string (str, sans, color, 16, texty);
|
||||||
texty += grub_font_get_descent (sans) + grub_font_get_leading (sans);
|
texty += grub_font_get_descent (sans) + grub_font_get_leading (sans);
|
||||||
|
|
||||||
texty += grub_font_get_ascent(sanssmall);
|
texty += grub_font_get_ascent(sanssmall);
|
||||||
grub_font_draw_string (str, sanssmall, color, 16, texty);
|
grub_font_draw_string (str, sanssmall, color, 16, texty);
|
||||||
texty += (grub_font_get_descent (sanssmall)
|
texty += (grub_font_get_descent (sanssmall)
|
||||||
+ grub_font_get_leading (sanssmall));
|
+ grub_font_get_leading (sanssmall));
|
||||||
|
|
||||||
glyph = grub_font_get_glyph (fixed, '*');
|
glyph = grub_font_get_glyph (fixed, '*');
|
||||||
|
|
||||||
for (i = 0; i < 16; i++)
|
for (i = 0; i < 16; i++)
|
||||||
{
|
{
|
||||||
color = grub_video_map_color (i);
|
color = grub_video_map_color (i);
|
||||||
palette[i] = color;
|
palette[i] = color;
|
||||||
grub_font_draw_glyph (glyph, color, 16 + i * 16, 220);
|
grub_font_draw_glyph (glyph, color, 16 + i * 16, 220);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
grub_video_set_active_render_target (GRUB_VIDEO_RENDER_TARGET_DISPLAY);
|
grub_video_set_active_render_target (GRUB_VIDEO_RENDER_TARGET_DISPLAY);
|
||||||
|
|
||||||
|
for (i = 0; i < 2; i++)
|
||||||
|
{
|
||||||
|
color = grub_video_map_rgb (0, 0, 0);
|
||||||
|
grub_video_fill_rect (color, 0, 0, width, height);
|
||||||
|
|
||||||
|
color = grub_video_map_rgb (255, 0, 0);
|
||||||
|
grub_video_fill_rect (color, 0, 0, 100, 100);
|
||||||
|
|
||||||
|
color = grub_video_map_rgb (0, 255, 255);
|
||||||
|
grub_video_fill_rect (color, 100, 100, 100, 100);
|
||||||
|
|
||||||
|
grub_video_set_viewport (x + 150, y + 150,
|
||||||
|
width - 150 * 2, height - 150 * 2);
|
||||||
|
color = grub_video_map_rgb (77, 33, 77);
|
||||||
|
grub_video_fill_rect (color, 0, 0, width, height);
|
||||||
|
grub_video_swap_buffers ();
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < 5; i++)
|
for (i = 0; i < 5; i++)
|
||||||
{
|
{
|
||||||
color = grub_video_map_rgb (i, 33, 77);
|
color = grub_video_map_rgb (i, 33, 77);
|
||||||
|
|
Loading…
Reference in a new issue