2016-07-28 18:12:07 +02:00
|
|
|
#include "gintdemo.h"
|
|
|
|
#include <display.h>
|
|
|
|
#include <gray.h>
|
|
|
|
#include <keyboard.h>
|
|
|
|
|
|
|
|
#include <internals/bopti.h>
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
test_bopti()
|
|
|
|
Displays and moves many kinds of bitmaps. Here are the images used:
|
|
|
|
|
|
|
|
Name Size Color Alpha
|
|
|
|
---------------------------------------------------------
|
|
|
|
items.bmp 266 * 124 Gray -
|
|
|
|
sprites.bmp 66 * 33 Gray -
|
|
|
|
swords.bmp 88 * 16 Gray Full
|
|
|
|
---------------------------------------------------------
|
|
|
|
zelda.bmp 86 * 280 Mono -
|
|
|
|
isometric.bmp 37 * 27 Mono Full
|
|
|
|
Mono Greater
|
|
|
|
---------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
static void getwh(image_t *img, int *width, int *height)
|
2016-07-28 18:12:07 +02:00
|
|
|
{
|
2017-01-20 21:11:00 +01:00
|
|
|
const uint8_t *data;
|
2016-07-28 18:12:07 +02:00
|
|
|
|
|
|
|
if(!img)
|
|
|
|
{
|
|
|
|
*width = 0;
|
|
|
|
*height = 0;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
*width = img->width;
|
|
|
|
*height = img->height;
|
|
|
|
if(*width && *height) return;
|
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
data = (uint8_t *)img->data;
|
2016-07-28 18:12:07 +02:00
|
|
|
*width = (data[0] << 8) | data[1];
|
|
|
|
*height = (data[2] << 8) | data[3];
|
|
|
|
}
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
static void getxy(image_t *img, int *x, int *y)
|
2016-07-28 18:12:07 +02:00
|
|
|
{
|
|
|
|
int width, height;
|
|
|
|
|
|
|
|
getwh(img, &width, &height);
|
|
|
|
*x = 64 - (width >> 1);
|
|
|
|
*y = 28 - (height >> 1);
|
|
|
|
}
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
static image_t *select(image_t *current)
|
2016-07-28 18:12:07 +02:00
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
extern image_t res_bopti_thumbs;
|
|
|
|
extern image_t
|
2016-09-04 11:35:41 +02:00
|
|
|
res_items,
|
|
|
|
res_sprites,
|
|
|
|
res_swords,
|
|
|
|
res_zelda,
|
|
|
|
res_isometric;
|
2016-07-28 18:12:07 +02:00
|
|
|
|
|
|
|
struct {
|
2017-03-26 18:38:32 +02:00
|
|
|
image_t *img;
|
2016-07-28 18:12:07 +02:00
|
|
|
const char *name;
|
|
|
|
const char *info;
|
|
|
|
} images[] = {
|
2016-09-04 11:35:41 +02:00
|
|
|
{ &res_items, "Items", "Gray" },
|
|
|
|
{ &res_sprites, "Sprites", "Gray" },
|
|
|
|
{ &res_swords, "Swords", "Gray Alpha" },
|
|
|
|
{ &res_zelda, "Zelda", "Mono" },
|
|
|
|
{ &res_isometric, "Isometric", "Mono Alpha" },
|
2016-07-28 18:12:07 +02:00
|
|
|
{ NULL, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
image_t *thumbs = &res_bopti_thumbs;
|
2016-07-28 18:12:07 +02:00
|
|
|
int items = 0;
|
|
|
|
static int row = 0;
|
|
|
|
int leave = 1, i;
|
|
|
|
|
|
|
|
while(images[items].img) items++;
|
|
|
|
|
|
|
|
gray_start();
|
|
|
|
|
|
|
|
while(1)
|
|
|
|
{
|
|
|
|
gclear();
|
|
|
|
locate(1, 1, "Select an image:");
|
|
|
|
|
|
|
|
for(i = 0; i < items && i < 7; i++)
|
|
|
|
{
|
|
|
|
locate(2, 2 + i + (i > row), images[i].name);
|
|
|
|
gimage_part(100, 8 + 8 * (i + (i > row)), thumbs, 0,
|
|
|
|
8 * i, 7, 7);
|
|
|
|
if(i == row)
|
|
|
|
{
|
|
|
|
int width, height;
|
|
|
|
getwh(images[i].img, &width, &height);
|
|
|
|
print(2, 2 + i + 1, "%d\x04%d", width, height);
|
|
|
|
locate(10, 2 + i + 1, images[i].info);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
grect(0, 8 * row + 8, 128, 8 * row + 23, color_invert);
|
2016-07-28 18:12:07 +02:00
|
|
|
gupdate();
|
|
|
|
|
|
|
|
do
|
|
|
|
{
|
|
|
|
leave = 1;
|
|
|
|
|
|
|
|
switch(getkey())
|
|
|
|
{
|
|
|
|
case KEY_UP:
|
|
|
|
row = (row + items - 1) % items;
|
|
|
|
break;
|
|
|
|
case KEY_DOWN:
|
|
|
|
row = (row + 1) % items;
|
|
|
|
break;
|
|
|
|
case KEY_EXE:
|
|
|
|
return images[row].img;
|
|
|
|
case KEY_EXIT:
|
|
|
|
return current;
|
|
|
|
default:
|
|
|
|
leave = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
while(!leave);
|
|
|
|
}
|
|
|
|
|
|
|
|
gray_stop();
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_bopti(void)
|
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
extern image_t res_opt_bitmap;
|
|
|
|
image_t *img = NULL;
|
2016-07-28 18:12:07 +02:00
|
|
|
|
|
|
|
int leave = 1;
|
|
|
|
int black_bg = 0;
|
|
|
|
int x = 0, y = 0;
|
|
|
|
|
|
|
|
while(1)
|
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
if(img && (img->format & channel_light))
|
2016-07-28 18:12:07 +02:00
|
|
|
{
|
|
|
|
gray_start();
|
|
|
|
gclear();
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
if(black_bg) grect(0, 0, 127, 63, color_invert);
|
2016-07-28 18:12:07 +02:00
|
|
|
if(img) gimage(x, y, img);
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
grect(0, 55, 127, 63, color_white);
|
2016-09-04 11:35:41 +02:00
|
|
|
gimage(0, 56, &res_opt_bitmap);
|
2016-07-28 18:12:07 +02:00
|
|
|
gupdate();
|
|
|
|
}
|
|
|
|
else if(img)
|
|
|
|
{
|
|
|
|
gray_stop();
|
|
|
|
dclear();
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
if(black_bg) drect(0, 0, 127, 63, color_invert);
|
2016-07-28 18:12:07 +02:00
|
|
|
if(img) dimage(x, y, img);
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
drect(0, 55, 127, 63, color_white);
|
2016-09-04 11:35:41 +02:00
|
|
|
dimage(0, 56, &res_opt_bitmap);
|
2016-07-28 18:12:07 +02:00
|
|
|
dupdate();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
gray_stop();
|
|
|
|
|
|
|
|
dclear();
|
|
|
|
locate(3, 3, "No image selected");
|
|
|
|
|
2016-09-04 11:35:41 +02:00
|
|
|
dimage(0, 56, &res_opt_bitmap);
|
2016-07-28 18:12:07 +02:00
|
|
|
dupdate();
|
|
|
|
}
|
|
|
|
|
|
|
|
do
|
|
|
|
{
|
|
|
|
leave = 1;
|
|
|
|
|
|
|
|
switch(getkey())
|
|
|
|
{
|
|
|
|
case KEY_EXIT:
|
|
|
|
gray_stop();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case KEY_F1:
|
|
|
|
img = select(img);
|
|
|
|
getxy(img, &x, &y);
|
|
|
|
break;
|
|
|
|
case KEY_F5:
|
|
|
|
black_bg = !black_bg;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case KEY_UP:
|
|
|
|
y--;
|
|
|
|
break;
|
|
|
|
case KEY_DOWN:
|
|
|
|
y++;
|
|
|
|
break;
|
|
|
|
case KEY_LEFT:
|
|
|
|
x--;
|
|
|
|
break;
|
|
|
|
case KEY_RIGHT:
|
|
|
|
x++;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
leave = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
while(!leave);
|
|
|
|
}
|
|
|
|
|
|
|
|
gray_stop();
|
|
|
|
return;
|
|
|
|
}
|