/**************************************************************************** * * MODULE: r.buffer * * AUTHOR(S): Michael Shapiro - CERL * * PURPOSE: This program creates distance zones from non-zero * cells in a grid layer. Distances are specified in * meters (on the command-line). Window does not have to * have square cells. Works both for planimetric * (UTM, State Plane) and lat-long. * * COPYRIGHT: (C) 2005 by the GRASS Development Team * * This program is free software under the GNU General Public * License (>=v2). Read the file COPYING that comes with GRASS * for details. * ****************************************************************************/ #include #include "distance.h" #include #include /* write out result */ int write_output_map(char *output, int offset) { int fd_in = 0, fd_out; int row; register int col; register CELL *cell; register MAPTYPE *ptr; int k; fd_out = Rast_open_c_new(output); if (fd_out < 0) G_fatal_error(_("Unable to create raster map <%s>"), output); if (offset) { fd_in = Rast_open_old(output, G_mapset()); if (fd_in < 0) G_fatal_error(_("Unable to open raster map <%s>"), output); } cell = Rast_allocate_c_buf(); G_message(_("Writing output raster map <%s>..."), output); ptr = map; for (row = 0; row < window.rows; row++) { G_percent(row, window.rows, 2); col = window.cols; if (!offset) { while (col-- > 0) *cell++ = (CELL) * ptr++; } else { if (Rast_get_c_row_nomask(fd_in, cell, row) < 0) G_fatal_error(_("Unable to read raster map <%s> row %d"), output, row); while (col-- > 0) { if (*cell == 0 && *ptr != 0) *cell = (CELL) * ptr + offset; cell++; ptr++; } } cell -= window.cols; /* set 0 to NULL */ for (k = 0; k < window.cols; k++) if (cell[k] == 0) Rast_set_null_value(&cell[k], 1, CELL_TYPE); if (Rast_put_raster_row(fd_out, cell, CELL_TYPE) < 0) G_fatal_error(_("Failed writing raster map <%s> row %d"), output, row); } G_percent(row, window.rows, 2); G_free(cell); if (offset) Rast_close(fd_in); Rast_close(fd_out); return 0; }