2014-06-08 10:13:29 +04:00
|
|
|
/* This file is part of ToaruOS and is released under the terms
|
|
|
|
* of the NCSA / University of Illinois License - see LICENSE.md
|
|
|
|
* Copyright (C) 2013-2014 Kevin Lange
|
|
|
|
*/
|
2012-10-22 06:52:53 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <pixman.h>
|
|
|
|
|
2014-04-16 07:38:47 +04:00
|
|
|
#include "lib/yutani.h"
|
2012-10-22 06:52:53 +04:00
|
|
|
#include "lib/graphics.h"
|
|
|
|
|
2014-04-16 07:38:47 +04:00
|
|
|
static yutani_t * yctx;
|
|
|
|
static yutani_window_t * window;
|
|
|
|
static gfx_context_t * ctx;
|
|
|
|
|
2012-10-22 06:52:53 +04:00
|
|
|
int main(int argc, char * argv[]) {
|
|
|
|
|
|
|
|
#define WIDTH 400
|
|
|
|
#define HEIGHT 400
|
|
|
|
#define TILE_SIZE 25
|
|
|
|
|
2014-04-16 07:38:47 +04:00
|
|
|
yctx = yutani_init();
|
|
|
|
window = yutani_window_create(yctx,WIDTH,HEIGHT);
|
|
|
|
yutani_window_move(yctx, window, 100, 100);
|
|
|
|
ctx = init_graphics_yutani(window);
|
2012-10-22 06:52:53 +04:00
|
|
|
draw_fill(ctx, rgba(0,0,0,255));
|
|
|
|
|
|
|
|
pixman_image_t *checkerboard;
|
|
|
|
pixman_image_t *destination;
|
|
|
|
#define D2F(d) (pixman_double_to_fixed(d))
|
|
|
|
pixman_transform_t trans = { {
|
|
|
|
{ D2F (-1.96830), D2F (-1.82250), D2F (512.12250)},
|
|
|
|
{ D2F (0.00000), D2F (-7.29000), D2F (1458.00000)},
|
|
|
|
{ D2F (0.00000), D2F (-0.00911), D2F (0.59231)},
|
|
|
|
}};
|
|
|
|
int i, j;
|
|
|
|
|
|
|
|
checkerboard = pixman_image_create_bits (PIXMAN_a8r8g8b8,
|
|
|
|
WIDTH, HEIGHT,
|
|
|
|
NULL, 0);
|
|
|
|
|
|
|
|
destination = pixman_image_create_bits (PIXMAN_a8r8g8b8,
|
|
|
|
WIDTH, HEIGHT,
|
|
|
|
NULL, 0);
|
|
|
|
|
|
|
|
for (i = 0; i < HEIGHT / TILE_SIZE; ++i)
|
|
|
|
{
|
|
|
|
for (j = 0; j < WIDTH / TILE_SIZE; ++j)
|
|
|
|
{
|
|
|
|
double u = (double)(j + 1) / (WIDTH / TILE_SIZE);
|
|
|
|
double v = (double)(i + 1) / (HEIGHT / TILE_SIZE);
|
|
|
|
pixman_color_t black = { 0, 0, 0, 0xffff };
|
|
|
|
pixman_color_t white = {
|
|
|
|
v * 0xffff,
|
|
|
|
u * 0xffff,
|
|
|
|
(1 - (double)u) * 0xffff,
|
|
|
|
0xffff };
|
|
|
|
pixman_color_t *c;
|
|
|
|
pixman_image_t *fill;
|
|
|
|
|
|
|
|
if ((j & 1) != (i & 1))
|
|
|
|
c = &black;
|
|
|
|
else
|
|
|
|
c = &white;
|
|
|
|
|
|
|
|
fill = pixman_image_create_solid_fill (c);
|
|
|
|
|
|
|
|
pixman_image_composite (PIXMAN_OP_SRC, fill, NULL, checkerboard,
|
|
|
|
0, 0, 0, 0, j * TILE_SIZE, i * TILE_SIZE,
|
|
|
|
TILE_SIZE, TILE_SIZE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pixman_image_set_transform (checkerboard, &trans);
|
|
|
|
pixman_image_set_filter (checkerboard, PIXMAN_FILTER_BEST, NULL, 0);
|
|
|
|
pixman_image_set_repeat (checkerboard, PIXMAN_REPEAT_NONE);
|
|
|
|
|
|
|
|
pixman_image_composite (PIXMAN_OP_SRC,
|
|
|
|
checkerboard, NULL, destination,
|
|
|
|
0, 0, 0, 0, 0, 0,
|
|
|
|
WIDTH, HEIGHT);
|
|
|
|
|
|
|
|
printf("Going for native draw.\n");
|
|
|
|
|
|
|
|
uint32_t * buf = pixman_image_get_data(destination);
|
|
|
|
memcpy(ctx->buffer,buf,WIDTH*HEIGHT*4);
|
|
|
|
|
2014-04-16 07:38:47 +04:00
|
|
|
yutani_flip(yctx, window);
|
|
|
|
|
2012-10-22 06:52:53 +04:00
|
|
|
while (1) {
|
2014-04-16 07:38:47 +04:00
|
|
|
yutani_msg_t * m = yutani_poll(yctx);
|
|
|
|
if (m) {
|
|
|
|
switch (m->type) {
|
|
|
|
case YUTANI_MSG_KEY_EVENT:
|
|
|
|
{
|
|
|
|
struct yutani_msg_key_event * ke = (void*)m->data;
|
|
|
|
if (ke->event.action == KEY_ACTION_DOWN && ke->event.keycode == 'q') {
|
|
|
|
free(m);
|
|
|
|
goto done;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
2014-05-20 05:34:05 +04:00
|
|
|
case YUTANI_MSG_SESSION_END:
|
|
|
|
goto done;
|
2014-04-16 07:38:47 +04:00
|
|
|
default:
|
|
|
|
break;
|
2012-10-22 06:52:53 +04:00
|
|
|
}
|
|
|
|
}
|
2014-04-16 07:38:47 +04:00
|
|
|
free(m);
|
2012-10-22 06:52:53 +04:00
|
|
|
}
|
|
|
|
|
2014-04-16 07:38:47 +04:00
|
|
|
done:
|
|
|
|
yutani_close(yctx, window);
|
2012-10-22 06:52:53 +04:00
|
|
|
return 0;
|
|
|
|
}
|