GRASS GIS 8 Programmer's Manual
8.5.0dev(2025)-fbabf32052
main.c
Go to the documentation of this file.
1
/****************************************************************************
2
*
3
* MODULE: bitmap
4
* AUTHOR(S): David Gerdes (CERL) (original contributor)
5
* Markus Neteler <neteler itc.it>,
6
* Bernhard Reiter <bernhard intevation.de>,
7
* Brad Douglas <rez touchofmadness.com>,
8
* Glynn Clements <glynn gclements.plus.com>
9
* PURPOSE: provides basic support for the creation and manipulation of
10
* two dimensional bitmap arrays
11
* COPYRIGHT: (C) 1999-2006 by the GRASS Development Team
12
*
13
* This program is free software under the GNU General Public
14
* License (>=v2). Read the file COPYING that comes with GRASS
15
* for details.
16
*
17
*****************************************************************************/
18
19
#include <stdio.h>
20
#include <stdlib.h>
21
#include <
grass/bitmap.h
>
22
23
static
int
dump_map(
struct
BM
*map);
24
25
int
main
(
int
argc,
char
*argv[])
26
{
27
int
SIZE;
28
struct
BM
*map, *map2;
29
int
i,
x
, y;
30
int
dump;
31
FILE *fp;
32
33
if
(argc < 2)
34
SIZE = 11;
35
else
36
SIZE = atoi(argv[1]);
37
38
if
(
NULL
!= getenv(
"NODUMP"
))
39
dump = 0;
40
else
41
dump = 1;
42
43
map =
BM_create
(SIZE, SIZE);
44
45
/* turn on bits in X pattern */
46
for
(i = 0; i < SIZE; i++) {
47
BM_set
(map, i, i, 1);
48
BM_set
(map, (SIZE - 1) - i, i, 1);
49
}
50
51
if
(dump)
52
dump_map(map);
53
fprintf(stdout,
"Size = %d\n"
,
BM_get_map_size
(map));
54
55
fprintf(stdout,
"\n\n"
);
56
57
/* now invert it */
58
for
(y = 0; y < SIZE; y++)
59
for
(
x
= 0;
x
< SIZE;
x
++)
60
BM_set
(map,
x
, y, !
BM_get
(map,
x
, y));
61
62
if
(dump)
63
dump_map(map);
64
65
fprintf(stdout,
"Size = %d\n"
,
BM_get_map_size
(map));
66
67
{
68
fp = fopen(
"dumpfile"
,
"w"
);
69
BM_file_write
(fp, map);
70
fclose(fp);
71
72
fp = fopen(
"dumpfile"
,
"r"
);
73
map2 =
BM_file_read
(fp);
74
fclose(fp);
75
dump_map(map2);
76
}
77
78
BM_destroy
(map);
79
BM_destroy
(map2);
80
81
return
0;
82
}
83
84
static
int
dump_map(
struct
BM
*map)
85
{
86
int
x
, y;
87
88
for
(y = 0; y < map->
rows
; y++) {
89
for
(
x
= 0;
x
< map->
cols
;
x
++) {
90
fprintf(stdout,
"%c"
,
BM_get
(map,
x
, y) ?
'#'
:
'.'
);
91
}
92
fprintf(stdout,
"\n"
);
93
}
94
}
bitmap.h
NULL
#define NULL
Definition:
ccmath.h:32
BM_get
int BM_get(struct BM *, int, int)
Gets 'val' from the bitmap.
Definition:
bitmap.c:217
BM_file_write
int BM_file_write(FILE *, struct BM *)
Write bitmap out to file.
Definition:
bitmap.c:264
BM_destroy
int BM_destroy(struct BM *)
Destroy bitmap and free all associated memory.
Definition:
bitmap.c:89
BM_get_map_size
size_t BM_get_map_size(struct BM *)
Returns size in bytes that bitmap is taking up.
Definition:
bitmap.c:241
BM_set
int BM_set(struct BM *, int, int, int)
Sets bitmap value to 'val' at location 'x' 'y'.
Definition:
bitmap.c:185
BM_file_read
struct BM * BM_file_read(FILE *)
Create map structure and load it from file.
Definition:
bitmap.c:306
BM_create
struct BM * BM_create(int, int)
Create bitmap of dimension x/y and return structure token.
Definition:
bitmap.c:58
main
int main(int argc, char *argv[])
Definition:
main.c:25
BM
Definition:
bitmap.h:17
BM::rows
int rows
Definition:
bitmap.h:18
BM::cols
int cols
Definition:
bitmap.h:19
x
#define x
lib
bitmap
main.c
Generated on Wed Jan 22 2025 07:38:50 for GRASS GIS 8 Programmer's Manual by
1.9.1