umorna/source/engine.c

213 lines
7.2 KiB
C

#include "engine.h"
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <png.h>
int camera_x = 0;
int camera_y = 0;
void view_unit (int race, int unit, int x, int y) {
int u, v, width, height;
u = 0;
v = (unit - race * 18) * BASE_SIZE;
width = BASE_SIZE;
height = BASE_SIZE;
switch (race) {
case orc: render_sprite (orcs, x, y, u, v, width, height); break;
case human: render_sprite (humans, x, y, u, v, width, height); break;
case elf: render_sprite (elves, x, y, u, v, width, height); break;
default: break;
}
}
void view_menu (int menu, int align, int x, int y) {
int item, width, height, aligned_x, aligned_y, u, v;
if (menu_show [menu] == 0) {
return;
}
width = (int) strlen (menu_text [menu] [0]);
height = menu_items [menu];
aligned_x = (align == 0) ? x : ((render_width () - ICON_SIZE * width) / 2);
aligned_y = (align == 0) ? y : ((render_height () - ICON_SIZE * height) / 2);
for (item = 0; item < menu_items [menu]; ++item) {
u = (menu_icon [menu] [item] / 10) * ICON_SIZE;
v = (menu_icon [menu] [item] % 10) * ICON_SIZE;
render_sprite (ui, aligned_x, aligned_y + item * ICON_SIZE, u, v, ICON_SIZE, ICON_SIZE);
render_string (menu_text [menu] [item], aligned_x + ICON_SIZE, aligned_y + item * ICON_SIZE);
}
}
void view_hud (int alpha, int width, int height, int x, int y) {
int i, j, u, v;
u = width % ICON_SIZE;
v = height % ICON_SIZE;
width /= ICON_SIZE;
height /= ICON_SIZE;
if (alpha == 0) {
for (i = 0; i < width - 1; ++i) {
for (j = 0; j < height - 1; ++j) {
render_sprite (neonui, x + i * ICON_SIZE + ICON_SIZE / 2, y + j * ICON_SIZE + ICON_SIZE / 2, 0, 0, ICON_SIZE, ICON_SIZE);
}
render_sprite (neonui, x + i * ICON_SIZE + ICON_SIZE / 2, y + height * ICON_SIZE + ICON_SIZE / 2, 0, 0, u, ICON_SIZE);
}
render_sprite (neonui, x + width * ICON_SIZE + ICON_SIZE / 2, y + height * ICON_SIZE + ICON_SIZE / 2, 0, 0, ICON_SIZE, v);
}
for (i = 1; i < width; ++i) {
render_sprite (neonui, x + i * ICON_SIZE, y, 560, 0, ICON_SIZE, ICON_SIZE);
render_sprite (neonui, x + i * ICON_SIZE, y + ICON_SIZE * (height - 1) + v, 560, 0, ICON_SIZE, ICON_SIZE);
}
for (i = 1; i < height - 1; ++i) {
render_sprite (neonui, x, y + i * ICON_SIZE, 256, 128, ICON_SIZE, ICON_SIZE);
render_sprite (neonui, x + ICON_SIZE * (width - 1) + u, y + i * ICON_SIZE + v, 256, 128, ICON_SIZE, ICON_SIZE);
}
render_sprite (neonui, x, y, 288, 0, 3 * ICON_SIZE, 3 * ICON_SIZE);
render_sprite (neonui, x + ICON_SIZE * (width - 3) + u, y, 384, 0, 3 * ICON_SIZE, 3 * ICON_SIZE);
render_sprite (neonui, x, y + ICON_SIZE * (height - 3) + v, 288, 96, 3 * ICON_SIZE, 3 * ICON_SIZE);
render_sprite (neonui, x + ICON_SIZE * (width - 3) + u, y + ICON_SIZE * (height - 3) + v, 384, 96, 3 * ICON_SIZE, 3 * ICON_SIZE);
}
void view_neon_menu (int menu, int align, int x, int y) {
int item, aligned_x, aligned_y, i, j;
if (menu_show [menu] == 0) {
return;
}
i = (int) strlen (menu_text [menu] [0]) + 4;
j = menu_items [menu] + 4;
aligned_x = (align == 0) ? x : ((render_width () - ICON_SIZE * i) / 2);
aligned_y = (align == 0) ? y : ((render_height () - ICON_SIZE * j) / 2);
view_hud (menu_alpha [menu], i * ICON_SIZE, j * ICON_SIZE, aligned_x, aligned_y);
aligned_x += 2 * ICON_SIZE;
aligned_y += 2 * ICON_SIZE;
for (item = 0; item < menu_items [menu]; ++item) {
i = (menu_icon [menu] [item] / 10) * ICON_SIZE;
j = (menu_icon [menu] [item] % 10) * ICON_SIZE;
render_sprite (ui, aligned_x, aligned_y + item * ICON_SIZE, i, j, ICON_SIZE, ICON_SIZE);
render_string (menu_text [menu] [item], aligned_x + ICON_SIZE, aligned_y + item * ICON_SIZE);
}
}
void view_map (int offset_x, int offset_y) {
int x, y, index;
for (x = 0; (x < (render_width () - SIDE_SIZE) / (BASE_SIZE * render_zoom)) && (x < CHAD_WORLD_WIDTH); ++x) {
for (y = 0; (y < render_height () / (BASE_SIZE * render_zoom)) && (y < CHAD_WORLD_HEIGHT); ++y) {
render_sprite (ashlands, (int) (x * BASE_SIZE * render_zoom), (int) (y * BASE_SIZE * render_zoom), 0,
chad_world [0] [(offset_x + x) * CHAD_WORLD_HEIGHT + offset_y + y] * BASE_SIZE, BASE_SIZE, BASE_SIZE);
}
}
for (index = 0; index < CHAD_WORLD_MODEL; ++index) {
if (chad_world_model_x [0] [index] < offset_x) continue;
if (chad_world_model_y [0] [index] < offset_y) continue;
if (chad_world_model_x [0] [index] > (render_width () - SIDE_SIZE) / (BASE_SIZE * render_zoom)) continue;
if (chad_world_model_y [0] [index] > render_height () / (BASE_SIZE * render_zoom)) continue;
x = (int) ((chad_world_model_x [0] [index] - offset_x) * BASE_SIZE * render_zoom);
y = (int) ((chad_world_model_y [0] [index] - offset_y) * BASE_SIZE * render_zoom);
render_sprite (model_1_1, x, y, 0, chad_world_model [0] [index] * BASE_SIZE, BASE_SIZE, BASE_SIZE);
}
}
void view_base_1 (int index, int x, int y) {
render_sprite (base_1, x, y, 0, index * 7 * BASE_SIZE, 10 * BASE_SIZE, 7 * BASE_SIZE);
}
void view_base_2 (int index, int x, int y) {
render_sprite (base_2, x, y, 0, index * 10 * BASE_SIZE, 15 * BASE_SIZE, 10 * BASE_SIZE);
}
void view_side_hud (void) {
return;
}
/*static void dump_block (unsigned int * * * pixels, unsigned int * source, int index, int x, int y) {
int i, j;
for (i = 0; i < BASE_SIZE; ++i) {
for (j = 0; j < BASE_SIZE; ++j) {
pixels [x] [y] [i * BASE_SIZE + j] = source [index * BASE_SIZE * BASE_SIZE + i * BASE_SIZE + j];
}
}
}
static void dump_world_screenshot (void) {
unsigned int * * * screenshot;
unsigned int * a;
unsigned int map [28 * BASE_SIZE * 12 * BASE_SIZE];
int i, j, k;
png_image input = { 0 };
png_image output = { 0 };
input.version = PNG_IMAGE_VERSION;
png_image_begin_read_from_file (& input, "sprite/ashlands.png");
input.format = PNG_FORMAT_RGBA;
png_image_finish_read (& input, NULL, map, 0, NULL);
png_image_free (& input);
a = calloc (CHAD_WORLD_SIZE * CHAD_WORLD_SIZE * BASE_SIZE * BASE_SIZE, sizeof (* a));
screenshot = calloc (CHAD_WORLD_SIZE, sizeof (* screenshot));
for (i = 0; i < CHAD_WORLD_SIZE; ++i) {
screenshot [i] = calloc (CHAD_WORLD_SIZE, sizeof (* * screenshot));
for (j = 0; j < CHAD_WORLD_SIZE; ++j) {
screenshot [i] [j] = calloc (BASE_SIZE * BASE_SIZE, sizeof (* * * screenshot));
}
}
for (i = 0; i < CHAD_WORLD_SIZE; ++i) {
for (j = 0; j < CHAD_WORLD_SIZE; ++j) {
dump_block (screenshot, map, chad_world [0] [i] [j], i, j);
}
}
for (i = 0; i < CHAD_WORLD_SIZE; ++i) {
for (j = 0; j < CHAD_WORLD_SIZE; ++j) {
for (k = 0; k < BASE_SIZE * BASE_SIZE; ++k) {
a [(i * CHAD_WORLD_SIZE + j) * BASE_SIZE * BASE_SIZE + k] = screenshot [i] [j] [k];
}
}
}
output.version = PNG_IMAGE_VERSION;
output.format = PNG_FORMAT_RGBA;
output.width = (unsigned int) (CHAD_WORLD_SIZE * BASE_SIZE);
output.height = (unsigned int) (CHAD_WORLD_SIZE * BASE_SIZE);
if (png_image_write_to_file (& output, "a.png", 0, a, 0, NULL) == 0) write (1, "\033[1;31mFailed to export render as PNG image!\033[0m\n", 49);
png_image_free (& output);
free (screenshot);
free (a);
}*/