12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124 |
- /*!
- \file args.c
-
- \brief Parse command
-
- (C) 2008, 2010-2011 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.
-
- \author Martin Landa <landa.martin gmail.com> (Google SoC 2008/2010)
- */
- #include <stdlib.h>
- #include <string.h>
- #include <grass/gis.h>
- #include <grass/glocale.h>
- #include "local_proto.h"
- static void print_error(int, int, int,
- const char *, const char *,
- const char *, const char *);
- static void args_surface(struct GParams *);
- static void args_vline(struct GParams *);
- static void args_vpoint(struct GParams *);
- static void args_viewpoint(struct GParams *);
- static void args_volume(struct GParams *);
- static void args_lighting(struct GParams *);
- static void args_fringe(struct GParams *);
- static void args_cplane(struct GParams *);
- static void args_arrow(struct GParams *);
- /*!
- \brief Parse command
-
- \param argc number of arguments
- \param argv arguments array
- \param params GRASS parameters
-
- \return 1
- */
- void parse_command(int argc, char *argv[], struct GParams *params)
- {
- params->mode_all = G_define_flag();
- params->mode_all->key = 'a';
- params->mode_all->description =
- _("Use draw mode for all loaded surfaces");
- params->mode_all->guisection = _("Surfaces");
-
- /*** surface attributes ***/
- args_surface(params);
- /*** vector lines ***/
- args_vline(params);
- /*** vector points ***/
- args_vpoint(params);
- /*** volumes ***/
- args_volume(params);
- /*** misc ***/
- /* background color */
- params->bgcolor = G_define_standard_option(G_OPT_C_BG);
- /*** viewpoint ***/
- args_viewpoint(params);
- /*** lighting ***/
- args_lighting(params);
- /*** fringe ***/
- args_fringe(params);
- /*** cutting plane ***/
- args_cplane(params);
- /*** north arrow ***/
- args_arrow(params);
-
- /*** output image ***/
- /* output */
- params->output = G_define_standard_option(G_OPT_F_OUTPUT);
- params->output->description =
- _("Name for output image file (without extension)");
- params->output->guisection = _("Image");
- /* format */
- params->format = G_define_option();
- params->format->key = "format";
- params->format->type = TYPE_STRING;
- #ifdef HAVE_TIFFIO_H
- params->format->options = "ppm,tif"; /* TODO: png */
- #else
- params->format->options = "ppm";
- #endif
- params->format->answer = "ppm";
- params->format->description = _("Graphics file format");
- params->format->required = YES;
- params->format->guisection = _("Image");
- /* size */
- params->size = G_define_option();
- params->size->key = "size";
- params->size->type = TYPE_INTEGER;
- params->size->key_desc = "width,height";
- params->size->answer = "640,480";
- params->size->description = _("Size (width, height) of output image");
- params->size->required = YES;
- params->size->guisection = _("Image");
- if (G_parser(argc, argv))
- exit(EXIT_FAILURE);
- return;
- }
- void args_surface(struct GParams *params)
- {
- /* topography */
- params->elev_map = G_define_standard_option(G_OPT_R_ELEV);
- params->elev_map->key = "elevation_map";
- params->elev_map->required = NO;
- params->elev_map->multiple = YES;
- params->elev_map->description = _("Name of raster map(s) for elevation");
- params->elev_map->guisection = _("Surfaces");
- params->elev_const = G_define_option();
- params->elev_const->key = "elevation_value";
- params->elev_const->key_desc = "value";
- params->elev_const->type = TYPE_INTEGER;
- params->elev_const->required = NO;
- params->elev_const->multiple = YES;
- params->elev_const->description = _("Elevation value(s)");
- params->elev_const->guisection = _("Surfaces");
- /* color */
- params->color_map = G_define_standard_option(G_OPT_R_MAP);
- params->color_map->multiple = YES;
- params->color_map->required = NO;
- params->color_map->description = _("Name of raster map(s) for color");
- params->color_map->guisection = _("Surfaces");
- params->color_map->key = "color_map";
- params->color_const = G_define_standard_option(G_OPT_C_FG);
- params->color_const->multiple = YES;
- params->color_const->label = _("Color value(s)");
- params->color_const->guisection = _("Surfaces");
- params->color_const->answer = NULL;
-
- /* mask */
- params->mask_map = G_define_standard_option(G_OPT_R_MAP);
- params->mask_map->multiple = YES;
- params->mask_map->required = NO;
- params->mask_map->description = _("Name of raster map(s) for mask");
- params->mask_map->guisection = _("Surfaces");
- params->mask_map->key = "mask_map";
- /* transparency */
- params->transp_map = G_define_standard_option(G_OPT_R_MAP);
- params->transp_map->multiple = YES;
- params->transp_map->required = NO;
- params->transp_map->description =
- _("Name of raster map(s) for transparency");
- params->transp_map->guisection = _("Surfaces");
- params->transp_map->key = "transparency_map";
- params->transp_const = G_define_option();
- params->transp_const->key = "transparency_value";
- params->transp_const->key_desc = "value";
- params->transp_const->type = TYPE_INTEGER;
- params->transp_const->required = NO;
- params->transp_const->multiple = YES;
- params->transp_const->description = _("Transparency value(s)");
- params->transp_const->guisection = _("Surfaces");
- params->transp_const->options = "0-255";
- /* shininess */
- params->shine_map = G_define_standard_option(G_OPT_R_MAP);
- params->shine_map->multiple = YES;
- params->shine_map->required = NO;
- params->shine_map->description = _("Name of raster map(s) for shininess");
- params->shine_map->guisection = _("Surfaces");
- params->shine_map->key = "shininess_map";
- params->shine_const = G_define_option();
- params->shine_const->key = "shininess_value";
- params->shine_const->key_desc = "value";
- params->shine_const->type = TYPE_INTEGER;
- params->shine_const->required = NO;
- params->shine_const->multiple = YES;
- params->shine_const->description = _("Shininess value(s)");
- params->shine_const->guisection = _("Surfaces");
- params->shine_const->options = "0-255";
- /* emission */
- params->emit_map = G_define_standard_option(G_OPT_R_MAP);
- params->emit_map->multiple = YES;
- params->emit_map->required = NO;
- params->emit_map->description = _("Name of raster map(s) for emission");
- params->emit_map->guisection = _("Surfaces");
- params->emit_map->key = "emission_map";
- params->emit_const = G_define_option();
- params->emit_const->key = "emission_value";
- params->emit_const->key_desc = "value";
- params->emit_const->type = TYPE_INTEGER;
- params->emit_const->required = NO;
- params->emit_const->multiple = YES;
- params->emit_const->description = _("Emission value(s)");
- params->emit_const->guisection = _("Surfaces");
- params->emit_const->options = "0-255";
- /*
- draw
- */
- /* mode */
- params->mode = G_define_option();
- params->mode->key = "mode";
- params->mode->key_desc = "string";
- params->mode->type = TYPE_STRING;
- params->mode->required = NO;
- params->mode->multiple = YES;
- params->mode->description = _("Draw mode");
- params->mode->options = "coarse,fine,both";
- params->mode->answer = "fine";
- params->mode->guisection = _("Draw");
- /* resolution fine */
- params->res_fine = G_define_option();
- params->res_fine->key = "resolution_fine";
- params->res_fine->key_desc = "value";
- params->res_fine->type = TYPE_INTEGER;
- params->res_fine->required = NO;
- params->res_fine->multiple = YES;
- params->res_fine->description = _("Fine resolution");
- params->res_fine->answer = "6";
- params->res_fine->guisection = _("Draw");
- /* resolution coarse */
- params->res_coarse = G_define_option();
- params->res_coarse->key = "resolution_coarse";
- params->res_coarse->key_desc = "value";
- params->res_coarse->type = TYPE_INTEGER;
- params->res_coarse->required = NO;
- params->res_coarse->multiple = YES;
- params->res_coarse->description = _("Coarse resolution");
- params->res_coarse->answer = "9";
- params->res_coarse->guisection = _("Draw");
- /* style */
- params->style = G_define_option();
- params->style->key = "style";
- params->style->key_desc = "string";
- params->style->type = TYPE_STRING;
- params->style->required = NO;
- params->style->multiple = YES;
- params->style->description = _("Draw style");
- params->style->options = "wire,surface";
- params->style->answer = "surface";
- params->style->guisection = _("Draw");
- /* shading */
- params->shade = G_define_option();
- params->shade->key = "shading";
- params->shade->key_desc = "string";
- params->shade->type = TYPE_STRING;
- params->shade->required = NO;
- params->shade->multiple = YES;
- params->shade->description = _("Shading");
- params->shade->options = "flat,gouraud";
- params->shade->answer = "gouraud";
- params->shade->guisection = _("Draw");
- /* wire color */
- params->wire_color = G_define_standard_option(G_OPT_C_FG);
- params->wire_color->multiple = YES;
- params->wire_color->required = NO;
- params->wire_color->label = _("Wire color");
- params->wire_color->key = "wire_color";
- params->wire_color->answer = "136:136:136";
- params->wire_color->guisection = _("Draw");
- /* position */
- params->surface_pos = G_define_option();
- params->surface_pos->key = "surface_position";
- params->surface_pos->key_desc = "x,y,z";
- params->surface_pos->type = TYPE_INTEGER;
- params->surface_pos->required = NO;
- params->surface_pos->multiple = YES;
- params->surface_pos->description = _("Surface position");
- params->surface_pos->guisection = _("Draw");
- params->surface_pos->answer = "0,0,0";
-
- return;
- }
- void args_vline(struct GParams *params)
- {
- params->vlines = G_define_standard_option(G_OPT_V_MAP);
- params->vlines->multiple = YES;
- params->vlines->required = NO;
- params->vlines->description = _("Name of line vector overlay map(s)");
- params->vlines->guisection = _("Vector lines");
- params->vlines->key = "vline";
- params->vline_layer = G_define_standard_option(G_OPT_V_FIELD);
- params->vline_layer->multiple = YES;
- params->vline_layer->required = NO;
- params->vline_layer->description = _("Layer number or name for thematic mapping");
- params->vline_layer->guisection = _("Vector lines");
- params->vline_layer->key = "vline_layer";
- params->vline_layer->answer = "1";
- /* line width */
- params->vline_width = G_define_option();
- params->vline_width->key = "vline_width";
- params->vline_width->key_desc = "value";
- params->vline_width->type = TYPE_INTEGER;
- params->vline_width->required = NO;
- params->vline_width->multiple = YES;
- params->vline_width->description = _("Vector line width");
- params->vline_width->guisection = _("Vector lines");
- params->vline_width->options = "1-100";
- params->vline_width->answer = "2";
- params->vline_width_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vline_width_column->multiple = YES;
- params->vline_width_column->required = NO;
- params->vline_width_column->label = _("Name of width definition column");
- params->vline_width_column->key = "vline_width_column";
- params->vline_width_column->guisection = _("Vector lines");
- /* line color */
- params->vline_color = G_define_standard_option(G_OPT_C_FG);
- params->vline_color->multiple = YES;
- params->vline_color->required = NO;
- params->vline_color->label = _("Vector line color");
- params->vline_color->key = "vline_color";
- params->vline_color->answer = "blue";
- params->vline_color->guisection = _("Vector lines");
- params->vline_color_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vline_color_column->multiple = YES;
- params->vline_color_column->required = NO;
- params->vline_color_column->label = _("Name of color definition column");
- params->vline_color_column->key = "vline_color_column";
- params->vline_color_column->guisection = _("Vector lines");
- /* line mode */
- params->vline_mode = G_define_option();
- params->vline_mode->key = "vline_mode";
- params->vline_mode->key_desc = "string";
- params->vline_mode->type = TYPE_STRING;
- params->vline_mode->required = NO;
- params->vline_mode->multiple = YES;
- params->vline_mode->description = _("Vector line display mode");
- params->vline_mode->options = "surface,flat";
- params->vline_mode->answer = "surface";
- params->vline_mode->guisection = _("Vector lines");
- /* line height */
- params->vline_height = G_define_option();
- params->vline_height->key = "vline_height";
- params->vline_height->key_desc = "value";
- params->vline_height->type = TYPE_INTEGER;
- params->vline_height->required = NO;
- params->vline_height->multiple = YES;
- params->vline_height->description = _("Vector line height");
- params->vline_height->guisection = _("Vector lines");
- params->vline_height->options = "0-1000";
- params->vline_height->answer = "0";
- /* position */
- params->vline_pos = G_define_option();
- params->vline_pos->key = "vline_position";
- params->vline_pos->key_desc = "x,y,z";
- params->vline_pos->type = TYPE_INTEGER;
- params->vline_pos->required = NO;
- params->vline_pos->multiple = YES;
- params->vline_pos->description = _("Vector lines position");
- params->vline_pos->guisection = _("Vector lines");
- params->vline_pos->answer = "0,0,0";
- return;
- }
- void args_vpoint(struct GParams *params)
- {
- params->vpoints = G_define_standard_option(G_OPT_V_MAP);
- params->vpoints->multiple = YES;
- params->vpoints->required = NO;
- params->vpoints->description = _("Name of point vector overlay map(s)");
- params->vpoints->guisection = _("Vector points");
- params->vpoints->key = "vpoint";
- params->vpoint_layer = G_define_standard_option(G_OPT_V_FIELD);
- params->vpoint_layer->multiple = YES;
- params->vpoint_layer->required = NO;
- params->vpoint_layer->description = _("Layer number or name for thematic mapping");
- params->vpoint_layer->guisection = _("Vector points");
- params->vpoint_layer->key = "vpoint_layer";
- params->vpoint_layer->answer = "1";
- /* point width */
- params->vpoint_size = G_define_option();
- params->vpoint_size->key = "vpoint_size";
- params->vpoint_size->key_desc = "value";
- params->vpoint_size->type = TYPE_INTEGER;
- params->vpoint_size->required = NO;
- params->vpoint_size->multiple = YES;
- params->vpoint_size->description = _("Icon size");
- params->vpoint_size->guisection = _("Vector points");
- params->vpoint_size->options = "1-1000";
- params->vpoint_size->answer = "100";
- params->vpoint_size_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vpoint_size_column->multiple = YES;
- params->vpoint_size_column->required = NO;
- params->vpoint_size_column->label = _("Name of size definition column");
- params->vpoint_size_column->key = "vpoint_size_column";
- params->vpoint_size_column->guisection = _("Vector points");
- /* point width */
- params->vpoint_width = G_define_option();
- params->vpoint_width->key = "vpoint_width";
- params->vpoint_width->key_desc = "value";
- params->vpoint_width->type = TYPE_INTEGER;
- params->vpoint_width->required = NO;
- params->vpoint_width->multiple = YES;
- params->vpoint_width->description = _("Icon width");
- params->vpoint_width->guisection = _("Vector points");
- params->vpoint_width->options = "1-1000";
- params->vpoint_width->answer = "2";
- params->vpoint_width_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vpoint_width_column->multiple = YES;
- params->vpoint_width_column->required = NO;
- params->vpoint_width_column->label = _("Name of width definition column");
- params->vpoint_width_column->key = "vpoint_width_column";
- params->vpoint_width_column->guisection = _("Vector points");
- /* point color */
- params->vpoint_color = G_define_standard_option(G_OPT_C_FG);
- params->vpoint_color->multiple = YES;
- params->vpoint_color->required = NO;
- params->vpoint_color->label = _("Icon color");
- params->vpoint_color->key = "vpoint_color";
- params->vpoint_color->answer = "blue";
- params->vpoint_color->guisection = _("Vector points");
- params->vpoint_color_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vpoint_color_column->multiple = YES;
- params->vpoint_color_column->required = NO;
- params->vpoint_color_column->label = _("Name of color definition column");
- params->vpoint_color_column->key = "vpoint_color_column";
- params->vpoint_color_column->guisection = _("Vector points");
- /* point mode */
- params->vpoint_marker = G_define_option();
- params->vpoint_marker->key = "vpoint_marker";
- params->vpoint_marker->key_desc = "string";
- params->vpoint_marker->type = TYPE_STRING;
- params->vpoint_marker->required = NO;
- params->vpoint_marker->multiple = YES;
- params->vpoint_marker->description = _("Icon marker");
- params->vpoint_marker->options =
- "x,box,sphere,cube,diamond,dec_tree,con_tree,aster,gyro,histogram";
- params->vpoint_marker->answer = "sphere";
- params->vpoint_marker->guisection = _("Vector points");
- params->vpoint_marker_column = G_define_standard_option(G_OPT_DB_COLUMN);
- params->vpoint_marker_column->multiple = YES;
- params->vpoint_marker_column->required = NO;
- params->vpoint_marker_column->label = _("Name of marker definition column");
- params->vpoint_marker_column->key = "vpoint_marker_column";
- params->vpoint_marker_column->guisection = _("Vector points");
- /* position */
- params->vpoint_pos = G_define_option();
- params->vpoint_pos->key = "vpoint_position";
- params->vpoint_pos->key_desc = "x,y,z";
- params->vpoint_pos->type = TYPE_INTEGER;
- params->vpoint_pos->required = NO;
- params->vpoint_pos->multiple = YES;
- params->vpoint_pos->description = _("Vector points position");
- params->vpoint_pos->guisection = _("Vector points");
- params->vpoint_pos->answer = "0,0,0";
-
- return;
- }
- void args_viewpoint(struct GParams *params)
- {
- /* position */
- params->pos = G_define_option();
- params->pos->key = "position";
- params->pos->key_desc = "x,y";
- params->pos->type = TYPE_DOUBLE;
- params->pos->required = NO;
- params->pos->multiple = NO;
- params->pos->description =
- _("Viewpoint position (x,y model coordinates)");
- params->pos->guisection = _("Viewpoint");
- params->pos->answer = "0.84,0.16";
- /* height */
- params->height = G_define_option();
- params->height->key = "height";
- params->height->key_desc = "value";
- params->height->type = TYPE_INTEGER;
- params->height->required = NO;
- params->height->multiple = NO;
- params->height->description = _("Viewpoint height (in map units)");
- params->height->guisection = _("Viewpoint");
- /* perspective */
- params->persp = G_define_option();
- params->persp->key = "perspective";
- params->persp->key_desc = "value";
- params->persp->type = TYPE_INTEGER;
- params->persp->required = NO;
- params->persp->multiple = NO;
- params->persp->description = _("Viewpoint field of view (in degrees)");
- params->persp->guisection = _("Viewpoint");
- params->persp->answer = "40";
- params->persp->options = "1-100";
- /* twist */
- params->twist = G_define_option();
- params->twist->key = "twist";
- params->twist->key_desc = "value";
- params->twist->type = TYPE_INTEGER;
- params->twist->required = NO;
- params->twist->multiple = NO;
- params->twist->description = _("Viewpoint twist angle (in degrees)");
- params->twist->guisection = _("Viewpoint");
- params->twist->answer = "0";
- params->twist->options = "-180-180";
- /* z-exag */
- params->exag = G_define_option();
- params->exag->key = "zexag";
- params->exag->key_desc = "value";
- params->exag->type = TYPE_DOUBLE;
- params->exag->required = NO;
- params->exag->multiple = NO;
- params->exag->description = _("Vertical exaggeration");
- /* focus */
- params->focus = G_define_option();
- params->focus->key = "focus";
- params->focus->key_desc = "x,y,z";
- params->focus->type = TYPE_DOUBLE;
- params->focus->required = NO;
- params->focus->multiple = NO;
- params->focus->description = _("Focus to point on surface (from SW corner in map units)");
- params->focus->guisection = _("Viewpoint");
-
- return;
- }
- void args_volume(struct GParams *params)
- {
- params->volume = G_define_standard_option(G_OPT_R3_MAPS);
- params->volume->required = NO;
- params->volume->guisection = _("Volumes");
- params->volume->key = "volume";
- /* mode */
- params->volume_mode = G_define_option();
- params->volume_mode->key = "volume_mode";
- params->volume_mode->key_desc = "string";
- params->volume_mode->type = TYPE_STRING;
- params->volume_mode->required = NO;
- params->volume_mode->multiple = YES;
- params->volume_mode->description = _("Volume draw mode");
- params->volume_mode->options = "isosurface,slice";
- params->volume_mode->answer = "isosurface";
- params->volume_mode->guisection = _("Draw");
- /* shading */
- params->volume_shade = G_define_option();
- params->volume_shade->key = "volume_shading";
- params->volume_shade->key_desc = "string";
- params->volume_shade->type = TYPE_STRING;
- params->volume_shade->required = NO;
- params->volume_shade->multiple = YES;
- params->volume_shade->description = _("Volume shading");
- params->volume_shade->options = "flat,gouraud";
- params->volume_shade->answer = "gouraud";
- params->volume_shade->guisection = _("Draw");
- /* position */
- params->volume_pos = G_define_option();
- params->volume_pos->key = "volume_position";
- params->volume_pos->key_desc = "x,y,z";
- params->volume_pos->type = TYPE_INTEGER;
- params->volume_pos->required = NO;
- params->volume_pos->multiple = YES;
- params->volume_pos->description = _("Volume position");
- params->volume_pos->guisection = _("Volumes");
- params->volume_pos->answer = "0,0,0";
-
- /* resolution */
- params->volume_res = G_define_option();
- params->volume_res->key = "volume_resolution";
- params->volume_res->key_desc = "value";
- params->volume_res->type = TYPE_INTEGER;
- params->volume_res->required = NO;
- params->volume_res->multiple = YES;
- params->volume_res->description = _("Volume resolution");
- params->volume_res->answer = "3";
- params->volume_res->guisection = _("Volumes");
- /* isosurface level */
- params->isosurf_level = G_define_option();
- params->isosurf_level->key = "isosurf_level";
- params->isosurf_level->key_desc = "volume:value";
- params->isosurf_level->type = TYPE_STRING;
- params->isosurf_level->required = NO;
- params->isosurf_level->multiple = YES;
- params->isosurf_level->description = _("Isosurface level");
- params->isosurf_level->guisection = _("Volumes");
-
- /* isosurface color map */
- params->isosurf_color_map = G_define_standard_option(G_OPT_R3_MAPS);
- params->isosurf_color_map->key = "isosurf_color_map";
- params->isosurf_color_map->required = NO;
- params->isosurf_color_map->multiple = YES;
- params->isosurf_color_map->description = _("Name of volume for isosurface color");
- params->isosurf_color_map->guisection = _("Volumes");
- /* isosurface color value */
- params->isosurf_color_const = G_define_standard_option(G_OPT_C_FG);
- params->isosurf_color_const->key = "isosurf_color_value";
- params->isosurf_color_const->required = NO;
- params->isosurf_color_const->multiple = YES;
- params->isosurf_color_const->label = _("Isosurface color");
- params->isosurf_color_const->guisection = _("Volumes");
- params->isosurf_color_const->answer = NULL;
- /* isosurface transparency */
- params->isosurf_transp_map = G_define_standard_option(G_OPT_R3_MAP);
- params->isosurf_transp_map->multiple = YES;
- params->isosurf_transp_map->required = NO;
- params->isosurf_transp_map->description =
- _("Name of 3D raster map(s) for isosurface transparency");
- params->isosurf_transp_map->guisection = _("Volumes");
- params->isosurf_transp_map->key = "isosurf_transparency_map";
- params->isosurf_transp_const = G_define_option();
- params->isosurf_transp_const->key = "isosurf_transparency_value";
- params->isosurf_transp_const->key_desc = "value";
- params->isosurf_transp_const->type = TYPE_INTEGER;
- params->isosurf_transp_const->required = NO;
- params->isosurf_transp_const->multiple = YES;
- params->isosurf_transp_const->description = _("Transparency value(s)for isosurfaces");
- params->isosurf_transp_const->guisection = _("Volumes");
- params->isosurf_transp_const->options = "0-255";
-
- /* isosurface shininess */
- params->isosurf_shine_map = G_define_standard_option(G_OPT_R3_MAP);
- params->isosurf_shine_map->multiple = YES;
- params->isosurf_shine_map->required = NO;
- params->isosurf_shine_map->description = _("Name of 3D raster map(s) for shininess");
- params->isosurf_shine_map->guisection = _("Volumes");
- params->isosurf_shine_map->key = "isosurf_shininess_map";
- params->isosurf_shine_const = G_define_option();
- params->isosurf_shine_const->key = "isosurf_shininess_value";
- params->isosurf_shine_const->key_desc = "value";
- params->isosurf_shine_const->type = TYPE_INTEGER;
- params->isosurf_shine_const->required = NO;
- params->isosurf_shine_const->multiple = YES;
- params->isosurf_shine_const->description = _("Shininess value(s) for isosurfaces");
- params->isosurf_shine_const->guisection = _("Volumes");
- params->isosurf_shine_const->options = "0-255";
-
- /* slices */
- /* slice axis */
- params->slice = G_define_option();
- params->slice->key = "slice";
- params->slice->key_desc = "volume:axis";
- params->slice->type = TYPE_STRING;
- params->slice->required = NO;
- params->slice->multiple = YES;
- params->slice->description = _("Volume slice parallel to given axis (x, y, z)");
- params->slice->guisection = _("Volumes");
- /* slice position */
- params->slice_pos = G_define_option();
- params->slice_pos->key = "slice_position";
- params->slice_pos->key_desc = "x1,x2,y1,y2,z1,z2";
- params->slice_pos->type = TYPE_DOUBLE;
- params->slice_pos->required = NO;
- params->slice_pos->multiple = YES;
- params->slice_pos->description = _("Volume slice position");
- params->slice_pos->guisection = _("Volumes");
- params->slice_pos->answer = "0,1,0,1,0,1";
-
- /* slice transparency */
- params->slice_transp = G_define_option();
- params->slice_transp->key = "slice_transparency";
- params->slice_transp->key_desc = "value";
- params->slice_transp->type = TYPE_INTEGER;
- params->slice_transp->required = NO;
- params->slice_transp->multiple = YES;
- params->slice_transp->description = _("Volume slice transparency");
- params->slice_transp->guisection = _("Volumes");
- params->slice_transp->answer = "0";
- params->slice_transp->options = "0-255";
- return;
- }
- void args_lighting(struct GParams *params)
- {
- params->light_pos = G_define_option();
- params->light_pos->key = "light_position";
- params->light_pos->key_desc = "x,y,z";
- params->light_pos->type = TYPE_DOUBLE;
- params->light_pos->required = NO;
- params->light_pos->multiple = NO;
- params->light_pos->description =
- _("Light position (x,y,z model coordinates)");
- params->light_pos->guisection = _("Lighting");
- params->light_pos->answer = "0.68,-0.68,0.80";
- params->light_color = G_define_standard_option(G_OPT_C_FG);
- params->light_color->key = "light_color";
- params->light_color->label = _("Light color");
- params->light_color->guisection = _("Lighting");
- params->light_color->answer = "white";
-
- params->light_bright = G_define_option();
- params->light_bright->key = "light_brightness";
- params->light_bright->type = TYPE_INTEGER;
- params->light_bright->required = NO;
- params->light_bright->multiple = NO;
- params->light_bright->description = _("Light brightness");
- params->light_bright->guisection = _("Lighting");
- params->light_bright->answer = "80";
- params->light_bright->options="0-100";
- params->light_ambient = G_define_option();
- params->light_ambient->key = "light_ambient";
- params->light_ambient->type = TYPE_INTEGER;
- params->light_ambient->required = NO;
- params->light_ambient->multiple = NO;
- params->light_ambient->description = _("Light ambient");
- params->light_ambient->guisection = _("Lighting");
- params->light_ambient->answer = "20";
- params->light_ambient->options="0-100";
- }
- void args_cplane(struct GParams *params)
- {
- params->cplane = G_define_option();
- params->cplane->key = "cplane";
- params->cplane->key_desc = "value";
- params->cplane->type = TYPE_INTEGER;
- params->cplane->required = NO;
- params->cplane->multiple = YES;
- params->cplane->description = _("Cutting plane index (0-5)");
- params->cplane->guisection = _("Cutting planes");
-
- params->cplane_pos = G_define_option();
- params->cplane_pos->key = "cplane_position";
- params->cplane_pos->key_desc = "x,y,z";
- params->cplane_pos->type = TYPE_DOUBLE;
- params->cplane_pos->required = NO;
- params->cplane_pos->multiple = YES;
- params->cplane_pos->description = _("Cutting plane x,y,z coordinates");
- params->cplane_pos->guisection = _("Cutting planes");
- params->cplane_pos->answer = "0,0,0";
-
- params->cplane_rot = G_define_option();
- params->cplane_rot->key = "cplane_rotation";
- params->cplane_rot->key_desc = "value";
- params->cplane_rot->type = TYPE_DOUBLE;
- params->cplane_rot->multiple = YES;
- params->cplane_rot->required = NO;
- params->cplane_rot->guisection = _("Cutting planes");
- params->cplane_rot->description = _("Cutting plane rotation along the vertical axis");
- params->cplane_rot->answer = "0";
- params->cplane_rot->options="0-360";
-
- params->cplane_tilt = G_define_option();
- params->cplane_tilt->key = "cplane_tilt";
- params->cplane_tilt->key_desc = "value";
- params->cplane_tilt->type = TYPE_DOUBLE;
- params->cplane_tilt->multiple = YES;
- params->cplane_tilt->required = NO;
- params->cplane_tilt->guisection = _("Cutting planes");
- params->cplane_tilt->description = _("Cutting plane tilt");
- params->cplane_tilt->answer = "0";
- params->cplane_tilt->options="0-360";
-
- params->cplane_shading = G_define_option();
- params->cplane_shading->key = "cplane_shading";
- params->cplane_shading->key_desc = "string";
- params->cplane_shading->type = TYPE_STRING;
- params->cplane_shading->multiple = NO;
- params->cplane_shading->required = NO;
- params->cplane_shading->guisection = _("Cutting planes");
- params->cplane_shading->description = _("Cutting plane color (between two surfaces)");
- params->cplane_shading->answer = "clear";
- params->cplane_shading->options= "clear,top,bottom,blend,shaded";
- }
- void args_fringe(struct GParams *params)
- {
- char *desc;
-
- params->fringe = G_define_option();
- params->fringe->key = "fringe";
- params->fringe->type = TYPE_STRING;
- params->fringe->options = "nw,ne,sw,se";
- desc = NULL;
- G_asprintf(&desc,
- "nw;%s;ne;%s;sw;%s;se;%s",
- _("North-West edge"),
- _("North-East edge"),
- _("South-West edge"),
- _("South-East edge"));
- params->fringe->descriptions = desc;
- params->fringe->description = _("Fringe edges");
- params->fringe->guisection = _("Fringe");
- params->fringe->multiple = YES;
-
- params->fringe_color = G_define_standard_option(G_OPT_C_FG);
- params->fringe_color->key = "fringe_color";
- params->fringe_color->label = _("Fringe color");
- params->fringe_color->guisection = _("Fringe");
- params->fringe_color->answer = "grey";
-
- params->fringe_elev = G_define_option();
- params->fringe_elev->key = "fringe_elevation";
- params->fringe_elev->type = TYPE_INTEGER;
- params->fringe_elev->required = NO;
- params->fringe_elev->multiple = NO;
- params->fringe_elev->description = _("Fringe elevation");
- params->fringe_elev->guisection = _("Fringe");
- params->fringe_elev->answer = "55";
- }
- void args_arrow(struct GParams *params)
- {
- params->north_arrow = G_define_option();
- params->north_arrow->key = "arrow_position";
- params->north_arrow->key_desc = "x,y";
- params->north_arrow->type = TYPE_INTEGER;
- params->north_arrow->required = NO;
- params->north_arrow->multiple = NO;
- params->north_arrow->description = _("Place north arrow at given position \
- (in screen coordinates from bottom left corner)");
- params->north_arrow->guisection = _("Decoration");
-
- params->north_arrow_size = G_define_option();
- params->north_arrow_size->key = "arrow_size";
- params->north_arrow_size->key_desc = "value";
- params->north_arrow_size->type = TYPE_DOUBLE;
- params->north_arrow_size->required = NO;
- params->north_arrow_size->multiple = NO;
- params->north_arrow_size->description = _("North arrow size (in map units)");
- params->north_arrow_size->guisection = _("Decoration");
-
- params->north_arrow_color = G_define_standard_option(G_OPT_C_FG);
- params->north_arrow_color->key = "arrow_color";
- params->north_arrow_color->required = NO;
- params->north_arrow_color->multiple = NO;
- params->north_arrow_color->label = _("North arrow color");
- params->north_arrow_color->guisection = _("Decoration");
- params->north_arrow_color->answer = "black";
- }
- /*!
- \brief Get number of answers of given option
- \param pointer to option
- \return number of arguments
- */
- int opt_get_num_answers(const struct Option *opt)
- {
- int i;
- i = 0;
- if (opt->answer) {
- while (opt->answers[i]) {
- i++;
- }
- }
- G_debug(3, "opt_get_num_answers(): opt=%s num=%d", opt->key, i);
-
- return i;
- }
- /*!
- \brief Check parameters consistency
-
- \param params module parameters
- */
- void check_parameters(const struct GParams *params)
- {
- int nelev_map, nelev_const, nelevs;
- int nmaps, nconsts, ncoords, ncplanes;
- int nvlines;
- int nvpoints;
-
- int nvolumes, nisosurf, nslices;
- /* topography */
- nelev_map = opt_get_num_answers(params->elev_map);
- nelev_const = opt_get_num_answers(params->elev_const);
- nelevs = nelev_map + nelev_const;
- if (nelevs < 1)
- G_fatal_error(_("At least one <%s> or <%s> required"),
- params->elev_map->key, params->elev_const->key);
- /* color */
- nmaps = opt_get_num_answers(params->color_map);
- nconsts = opt_get_num_answers(params->color_const);
- print_error(nmaps, nconsts, nelevs,
- params->elev_map->key, params->elev_const->key,
- params->color_map->key, params->color_const->key);
- /* mask */
- nmaps = opt_get_num_answers(params->mask_map);
- if (nmaps > 0 && nelevs != nmaps)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key, nelevs,
- params->mask_map->key, nmaps);
- /* transparency */
- nmaps = opt_get_num_answers(params->transp_map);
- nconsts = opt_get_num_answers(params->transp_const);
- print_error(nmaps, nconsts, nelevs,
- params->elev_map->key, params->elev_const->key,
- params->transp_map->key, params->transp_const->key);
- /* shininess */
- nmaps = opt_get_num_answers(params->shine_map);
- nconsts = opt_get_num_answers(params->shine_const);
- print_error(nmaps, nconsts, nelevs,
- params->elev_map->key, params->elev_const->key,
- params->shine_map->key, params->shine_const->key);
- /* emit */
- nmaps = opt_get_num_answers(params->emit_map);
- nconsts = opt_get_num_answers(params->emit_const);
- print_error(nmaps, nconsts, nelevs,
- params->elev_map->key, params->elev_const->key,
- params->emit_map->key, params->emit_const->key);
- /* draw mode */
- if (!params->mode_all->answer) { /* use one mode for all surfaces */
- nconsts = opt_get_num_answers(params->mode);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->mode->key, nconsts);
- nconsts = opt_get_num_answers(params->res_fine);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->res_fine->key, nconsts);
- nconsts = opt_get_num_answers(params->res_coarse);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->res_coarse->key, nconsts);
- nconsts = opt_get_num_answers(params->style);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->style->key, nconsts);
- nconsts = opt_get_num_answers(params->shade);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->shade->key, nconsts);
- nconsts = opt_get_num_answers(params->wire_color);
- if (nconsts > 0 && nconsts != nelevs)
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
- params->elev_map->key, params->elev_const->key,
- nelevs, params->wire_color->key, nconsts);
- }
-
- /*
- * Cutting planes
- */
- ncplanes = opt_get_num_answers(params->cplane);
- ncoords = opt_get_num_answers(params->cplane_pos);
- if (ncplanes > 0 && ncplanes * 3 != ncoords)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d x 3)"),
- params->cplane->key, ncplanes, params->cplane_pos->key, ncoords/3);
-
- nconsts = opt_get_num_answers(params->cplane_rot);
- if (ncplanes > 0 && ncplanes != nconsts)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->cplane->key, ncplanes, params->cplane_rot->key, nconsts);
-
- nconsts = opt_get_num_answers(params->cplane_tilt);
- if (ncplanes > 0 && ncplanes != nconsts)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->cplane->key, ncplanes, params->cplane_tilt->key, nconsts);
- /*
- * vector lines
- */
- nvlines = opt_get_num_answers(params->vlines);
- /* width */
- nconsts = opt_get_num_answers(params->vline_width);
- if (nvlines > 0 && nconsts != nvlines)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->vlines->key, nvlines, params->vline_width->key,
- nconsts);
- /* color */
- nconsts = opt_get_num_answers(params->vline_color);
- if (nvlines > 0 && nconsts != nvlines)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->vlines->key, nvlines, params->vline_color->key,
- nconsts);
- /* mode */
- nconsts = opt_get_num_answers(params->vline_mode);
- if (nvlines > 0 && nconsts != nvlines)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->vlines->key, nvlines, params->vline_mode->key,
- nconsts);
- /* height */
- nconsts = opt_get_num_answers(params->vline_height);
- if (nvlines > 0 && nconsts != nvlines)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->vlines->key, nvlines, params->vline_height->key,
- nconsts);
-
- /* position */
- nconsts = opt_get_num_answers(params->vline_pos);
- if (nvlines > 0 && nconsts != 3 * nvlines)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->vlines->key, nvlines, params->vline_pos->key,
- nconsts);
- /*
- * vector points
- */
- nvpoints = opt_get_num_answers(params->vpoints);
- /* TODO */
-
- /*
- * volumes
- */
- nvolumes = opt_get_num_answers(params->volume);
- nisosurf = opt_get_num_answers(params->isosurf_level);
- nslices = opt_get_num_answers(params->slice);
- /* isosurface transparency */
- nmaps = opt_get_num_answers(params->isosurf_transp_map);
- nconsts = opt_get_num_answers(params->isosurf_transp_const);
- if ((nmaps + nconsts > 0) && (nisosurf != nmaps + nconsts))
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d, <%s> %d)"),
- params->isosurf_level->key, nisosurf, params->isosurf_transp_map->key, nmaps,
- params->isosurf_transp_const->key, nconsts);
- /* isosurface shininess */
- nmaps = opt_get_num_answers(params->isosurf_shine_map);
- nconsts = opt_get_num_answers(params->isosurf_shine_const);
- if ((nmaps + nconsts > 0) && (nisosurf != nmaps + nconsts))
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d, <%s> %d)"),
- params->isosurf_level->key, nisosurf, params->isosurf_shine_map->key, nmaps,
- params->isosurf_shine_const->key, nconsts);
- /* slice transparency */
- nconsts = opt_get_num_answers(params->slice_transp);
- if (nslices > 0 && nslices != nconsts)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
- params->slice->key, nslices, params->slice_transp->key, nconsts);
- /* slice position */
- ncoords = opt_get_num_answers(params->slice_pos);
- if (nslices > 0 && ncoords != 6 * nslices)
- G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d x 6)"),
- params->slice->key, nslices, params->slice_pos->key, ncoords/6);
- return;
- }
- void print_error(int nmaps, int nconsts, int nelevs,
- const char *elev_map, const char *elev_const,
- const char *map_name, const char *const_name)
- {
- if ((nmaps + nconsts > 0) && (nelevs != nmaps + nconsts))
- G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d, <%s> %d)"),
- elev_map, elev_const, nelevs, map_name, nmaps,
- const_name, nconsts);
- return;
- }
|