2020-05-24 20:41:11 +04:00
|
|
|
#include <printf.h>
|
|
|
|
#include <syscall.h>
|
2020-05-27 21:04:48 +04:00
|
|
|
#include <input-event-codes.h>
|
2020-05-24 20:41:11 +04:00
|
|
|
|
|
|
|
struct Pixel {
|
|
|
|
unsigned char r;
|
|
|
|
unsigned char g;
|
|
|
|
unsigned char b;
|
|
|
|
unsigned char a;
|
|
|
|
};
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
#define cos(x) table_cos(x)
|
|
|
|
// #define cos(x) taylor_cos(x)
|
2020-05-24 21:34:54 +04:00
|
|
|
#define min(x, y) ((x < y) ? x : y)
|
|
|
|
#define max(x, y) ((x > y) ? x : y)
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
using u8 = unsigned char;
|
|
|
|
using i8 = signed char;
|
|
|
|
using u16 = unsigned short;
|
|
|
|
using i16 = signed short;
|
2020-05-24 20:41:11 +04:00
|
|
|
using u32 = unsigned int;
|
|
|
|
using i32 = signed int;
|
|
|
|
using u64 = unsigned long;
|
|
|
|
using i64 = signed long;
|
|
|
|
using f64 = double;
|
|
|
|
using f32 = float;
|
|
|
|
|
|
|
|
void fill_rect(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color);
|
2020-05-27 21:04:48 +04:00
|
|
|
void stroke_rect(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color, u32 size);
|
2020-05-24 20:41:11 +04:00
|
|
|
void set_pixel(Pixel *fb, u32 x, u32 y, Pixel &color);
|
|
|
|
void draw_cosine(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color);
|
2020-05-27 21:04:48 +04:00
|
|
|
void draw_circle(Pixel *fb, u32 x, u32 y, f64 r, Pixel &color);
|
2020-05-24 20:41:11 +04:00
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
const u64 noevt_slptm = 1000000;
|
|
|
|
const u64 evt_slptm = 100000;
|
2020-05-24 21:34:54 +04:00
|
|
|
|
|
|
|
struct Rect {
|
|
|
|
u32 x;
|
|
|
|
u32 y;
|
|
|
|
u32 width;
|
|
|
|
u32 height;
|
|
|
|
};
|
|
|
|
|
2020-05-24 20:41:11 +04:00
|
|
|
int main()
|
|
|
|
{
|
2020-05-27 21:04:48 +04:00
|
|
|
bool mouse_down = false;
|
2020-05-24 21:34:54 +04:00
|
|
|
int VERSION = -1;
|
2020-05-24 20:41:11 +04:00
|
|
|
printf("(%d): TESTING FRAMEBUFFER FROM USERSPACE\n", VERSION);
|
|
|
|
Pixel *fb = (Pixel *)syscall_get_fb(6);
|
|
|
|
Pixel blue_color = {0, 0, 255, 255};
|
2020-05-27 21:04:48 +04:00
|
|
|
Pixel red_color = {255, 0, 0, 255};
|
|
|
|
Pixel green_color = {0, 255, 0, 255};
|
2020-05-24 21:34:54 +04:00
|
|
|
Pixel white_color = {255, 255, 255, 255};
|
2020-05-27 21:04:48 +04:00
|
|
|
Pixel orange_color = {255, 150, 0, 255};
|
|
|
|
u32 x = 0;
|
|
|
|
u32 y = 0;
|
|
|
|
u32 width = 40;
|
|
|
|
u32 height = 50;
|
|
|
|
|
|
|
|
fill_rect(fb, 0, 0, 640, 480, white_color);
|
|
|
|
stroke_rect(fb, 10, 10, 20, 20, blue_color, 5);
|
|
|
|
stroke_rect(fb, 50, 50, 40, 40, green_color, 10);
|
|
|
|
stroke_rect(fb, 150, 150, 140, 140, red_color, 15);
|
|
|
|
draw_cosine(fb, 0, 400, 500, 50, red_color);
|
|
|
|
syscall_inv_rect(6, x, y, 640, 480);
|
2020-05-24 21:34:54 +04:00
|
|
|
do {
|
2020-05-27 21:04:48 +04:00
|
|
|
i64 key = syscall_get_key();
|
|
|
|
i64 abs = syscall_get_abs();
|
|
|
|
if (key == -1 && abs == -1) {
|
|
|
|
syscall_sleep(noevt_slptm);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (key != -1) {
|
|
|
|
short code = key >> 16;
|
|
|
|
bool pressed = (key & 1) ? true : false;
|
|
|
|
printf("%s key %d\n", pressed ? "pressed" : "released", code);
|
|
|
|
if (code == BTN_LEFT) { // left mouse button
|
|
|
|
mouse_down = pressed;
|
2020-05-24 21:34:54 +04:00
|
|
|
}
|
|
|
|
}
|
2020-05-27 21:04:48 +04:00
|
|
|
if (abs != -1 && mouse_down) {
|
|
|
|
u16 code = abs >> 16;
|
|
|
|
if (code == ABS_X) {
|
|
|
|
x = abs & 0xffff;
|
|
|
|
}
|
|
|
|
else if (code == ABS_Y) {
|
|
|
|
y = abs & 0xffff;
|
|
|
|
}
|
|
|
|
x %= 400;
|
|
|
|
y %= 400;
|
|
|
|
syscall_sleep(noevt_slptm);
|
|
|
|
printf("Draw %d, %d\n", x, y);
|
|
|
|
fill_rect(fb, x, y, 10, 10, orange_color);
|
|
|
|
syscall_inv_rect(6, x, y, 10, 10);
|
|
|
|
}
|
|
|
|
} while (true);
|
2020-05-24 20:41:11 +04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_pixel(Pixel *fb, u32 x, u32 y, Pixel &color) {
|
|
|
|
if (x < 640 && y < 480) {
|
|
|
|
fb[y * 640 + x] = color;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void fill_rect(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color) {
|
|
|
|
for (u32 row = y; row < (y+height);row++) {
|
|
|
|
for (u32 col = x; col < (x+width);col++) {
|
|
|
|
set_pixel(fb, col, row, color);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
void stroke_rect(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color, u32 size) {
|
|
|
|
// Essentially fill the four sides.
|
|
|
|
// Top
|
|
|
|
fill_rect(fb, x, y, width, size, color);
|
|
|
|
// Bottom
|
|
|
|
fill_rect(fb, x, y + height, width, size, color);
|
|
|
|
// Left
|
|
|
|
fill_rect(fb, x, y, size, height, color);
|
|
|
|
// Right
|
|
|
|
fill_rect(fb, x + width, y, size, height + size, color);
|
|
|
|
}
|
|
|
|
|
2020-05-24 20:41:11 +04:00
|
|
|
f64 table_cos(f64 angle_degrees) {
|
|
|
|
const f64 COS_TABLE[] = {
|
|
|
|
1.0,
|
|
|
|
0.9962,
|
|
|
|
0.9848,
|
|
|
|
0.9659,
|
|
|
|
0.9397,
|
|
|
|
0.9063,
|
|
|
|
0.8660,
|
|
|
|
0.8191,
|
|
|
|
0.7660,
|
|
|
|
0.7071,
|
|
|
|
0.6428,
|
|
|
|
0.5736,
|
|
|
|
0.5000,
|
|
|
|
0.4226,
|
|
|
|
0.3420,
|
|
|
|
0.2558,
|
|
|
|
0.1736,
|
|
|
|
0.0872,
|
|
|
|
0.0,
|
|
|
|
-0.0872,
|
|
|
|
-0.1736,
|
|
|
|
-0.2558,
|
|
|
|
-0.3420,
|
|
|
|
-0.4226,
|
|
|
|
-0.5000,
|
|
|
|
-0.5736,
|
|
|
|
-0.6428,
|
|
|
|
-0.7071,
|
|
|
|
-0.7660,
|
|
|
|
-0.8191,
|
|
|
|
-0.8660,
|
|
|
|
-0.9063,
|
|
|
|
-0.9397,
|
|
|
|
-0.9659,
|
|
|
|
-0.9848,
|
|
|
|
-0.9962,
|
|
|
|
-1.0,
|
|
|
|
-0.9962,
|
|
|
|
-0.9848,
|
|
|
|
-0.9659,
|
|
|
|
-0.9397,
|
|
|
|
-0.9063,
|
|
|
|
-0.8660,
|
|
|
|
-0.8191,
|
|
|
|
-0.7660,
|
|
|
|
-0.7071,
|
|
|
|
-0.6428,
|
|
|
|
-0.5736,
|
|
|
|
-0.5000,
|
|
|
|
-0.4226,
|
|
|
|
-0.3420,
|
|
|
|
-0.2558,
|
|
|
|
-0.1736,
|
|
|
|
-0.0872,
|
|
|
|
0.0,
|
|
|
|
0.0872,
|
|
|
|
0.1736,
|
|
|
|
0.2558,
|
|
|
|
0.3420,
|
|
|
|
0.4226,
|
|
|
|
0.5000,
|
|
|
|
0.5736,
|
|
|
|
0.6428,
|
|
|
|
0.7071,
|
|
|
|
0.7660,
|
|
|
|
0.8191,
|
|
|
|
0.8660,
|
|
|
|
0.9063,
|
|
|
|
0.9397,
|
|
|
|
0.9659,
|
|
|
|
0.9848,
|
|
|
|
0.9962,
|
|
|
|
1.0,
|
|
|
|
};
|
|
|
|
u32 lookup_ang = angle_degrees / 5;
|
|
|
|
return COS_TABLE[lookup_ang];
|
|
|
|
}
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
f64 taylor_cos(f64 angle_degrees) {
|
2020-05-24 20:41:11 +04:00
|
|
|
f64 x = 3.14159265359 * angle_degrees / 180.0;
|
|
|
|
f64 result = 1.0;
|
|
|
|
f64 inter = 1.0;
|
|
|
|
f64 num = x * x;
|
2020-05-27 21:04:48 +04:00
|
|
|
for (int i = 1;i <= 6;i++) {
|
|
|
|
u64 comp = 2 * i;
|
|
|
|
u64 den = comp * (comp - 1);
|
2020-05-24 20:41:11 +04:00
|
|
|
inter *= num / den;
|
2020-05-27 21:04:48 +04:00
|
|
|
if ((i & 1) == 0) {
|
2020-05-24 20:41:11 +04:00
|
|
|
result += inter;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
result -= inter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
f64 sin(f64 angle_degrees) {
|
|
|
|
return cos(90.0 - angle_degrees);
|
2020-05-24 20:41:11 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
void draw_cosine(Pixel *fb, u32 x, u32 y, u32 width, u32 height, Pixel &color) {
|
|
|
|
for (u32 i = 1; i <= width;i++) {
|
2020-05-27 21:04:48 +04:00
|
|
|
f64 fy = -cos(i % 360);
|
2020-05-24 21:34:54 +04:00
|
|
|
f64 yy = fy / 2.0 * height;
|
2020-05-24 20:41:11 +04:00
|
|
|
u32 nx = x + i;
|
|
|
|
u32 ny = yy + y;
|
|
|
|
// printf("Cos %u = %lf, x: %u, y: %u\n", (i % 360), fy, nx, ny);
|
|
|
|
fill_rect(fb, nx, ny, 2, 2, color);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-05-27 21:04:48 +04:00
|
|
|
|
|
|
|
|
|
|
|
void draw_circle(Pixel *fb, u32 x, u32 y, f64 r, Pixel &color)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|