-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfunkcijasKarlim.c
65 lines (56 loc) · 1.3 KB
/
funkcijasKarlim.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#include "map.h"
void init_map_params(MAP *p_map);
void print_map_params(MAP *p_map);
void create_map(MAP *map, int flag);
void init_map_params(MAP *p_map)
{
p_map->height = MAP_HEIGHT;
p_map->width = MAP_WIDTH;
p_map->starty = 0;
p_map->startx = 0;
p_map->border.top = '-';
p_map->border.side = '|';
}
void print_map_params(MAP *p_map)
{
#ifdef _DEBUG
mvprintw(25, 0, "%d %d %d %d", p_map->startx, p_map->starty,
p_map->width, p_map->height);
refresh();
#endif
}
void create_map(MAP *p_map, int flag)
{ int i, j;
int x, y, w, h;
x = p_map->startx;
y = p_map->starty;
w = p_map->width;
h = p_map->height;
if(flag == 1){
mvhline(y, x, p_map->border.top, w-1); // augša
mvhline(y + h, x, p_map->border.top, w-1); // apakša
mvvline(y+1, x, p_map->border.side, h-1); // kreisā puse
mvvline(y+1, x + w, p_map->border.side, h-1); // labā puse
}
else
for(j = y; j <= y + h; ++j)
for(i = x; i <= x + w; ++i)
mvaddch(j, i, ' ');
refresh();
}
void fill_map(int x, int y, int size, char mas[]){
int i, j=0;
int xx = x-1, yy = 1;
for (i = 1; i < size; i++){
j++;
if(j < xx){
mvaddch(yy, j, mas[i]);
}else{
j = 1;
if(yy < y){
yy++;
mvaddch(yy, j, mas[i]);
}
}
}
}