[GRASS-SVN] r50989 - grass/branches/develbranch_6/imagery/i.modis.qc
svn_grass at osgeo.org
svn_grass at osgeo.org
Sun Mar 4 07:26:40 EST 2012
Author: martinl
Date: 2012-03-04 04:26:40 -0800 (Sun, 04 Mar 2012)
New Revision: 50989
Modified:
grass/branches/develbranch_6/imagery/i.modis.qc/main.c
Log:
i.modis.qc: fix broken module's UI
Modified: grass/branches/develbranch_6/imagery/i.modis.qc/main.c
===================================================================
--- grass/branches/develbranch_6/imagery/i.modis.qc/main.c 2012-03-04 12:11:00 UTC (rev 50988)
+++ grass/branches/develbranch_6/imagery/i.modis.qc/main.c 2012-03-04 12:26:40 UTC (rev 50989)
@@ -67,7 +67,7 @@
int row, col;
char *qcflag; /*Switch for particular index */
struct GModule *module;
- struct Option *input, *input1, *input2, *input_band, *output;
+ struct Option *productname, *qcname, *input, *input_band, *output;
struct History history; /*metadata */
struct Colors colors; /*Color rules */
@@ -89,65 +89,72 @@
module = G_define_module();
module->keywords = _("QC, Quality Control, surface reflectance, Modis");
module->description =
- _("Extract quality control parameters from Modis QC layers");
+ _("Extracts quality control parameters from Modis QC layers.");
/* Define the different options */
- input = G_define_option();
- input->key = "productname";
- input->type = TYPE_STRING;
- input->required = YES;
- input->description = _("Name of MODIS product type");
- input->descriptions =_("mod09Q1;surf. refl. 250m 8-days;"
- "mod09A1;surf. refl. 500m 8-days;"
- "mod09A1s;surf. refl. 500m 8-days, State QA;"
- "mod11A1;LST 1Km daily (Day/Night);"
- "mod11A2;LST 1Km 8-days (Day/Night);");
- input->answer = "mod09Q1";
- input1 = G_define_option();
- input1->key = "qcname";
- input1->type = TYPE_STRING;
- input1->required = YES;
- input1->description = _("Name of QC type to extract:"
- "adjcorr;mod09: Adjacency Correction;"
- "atcorr;mod09: Atmospheric Correction;"
- "cloud;mod09: Cloud State;"
- "data_quality;mod09: Band-Wise Data Quality Flag;"
- "diff_orbit_from_500m;mod09: 250m Band is at Different Orbit than 500m;"
- "modland_qa_bits;mod09: MODIS Land General Quality Assessment;"
- "mandatory_qa_11A1;mod11A1: MODIS Land General Quality Assessment;"
- "data_quality_flag_11A1;mod11A1: Detailed Quality Indications;"
- "emis_error_11A1;mod11A1: Average Emissivity Error Classes;"
- "lst_error_11A1;mod11A1: Average LST Error Classes;"
- "data_quality_flag_11A2;mod11A2: Detailed Quality Indications;"
- "emis_error_11A2;mod11A2: Average Emissivity Error Classes;"
- "mandatory_qa_11A2;mod11A2: MODIS Land General Quality Assessment;"
- "lst_error_11A2;mod11A2: Average LST Error Classes;"
- "aerosol_quantity;mod09A1s: StateQA Internal Snow Mask"
- "brdf_correction_performed;mod09A1s: StateQA Internal Snow Mask"
- "cirrus_detected;mod09A1s: StateQA Internal Snow Mask"
- "cloud_shadow;mod09A1s: StateQA Internal Snow Mask"
- "cloud_state;mod09A1s: StateQA Internal Snow Mask"
- "internal_cloud_algorithm;mod09A1s: StateQA Internal Snow Mask"
- "internal_fire_algorithm;mod09A1s: StateQA Internal Snow Mask"
- "internal_snow_mask;mod09A1s: StateQA Internal Snow Mask"
- "land_water;mod09A1s: StateQA Internal Snow Mask"
- "mod35_snow_ice;mod09A1s: StateQA Internal Snow Mask"
- "pixel_adjacent_to_cloud;mod09A1s: StateQA Internal Snow Mask"
-);
- input1->answer = "modland_qa_bits";
+ input = G_define_standard_option(G_OPT_R_INPUT);
+ input->description =
+ _("Name of input surface reflectance QC layer [bit array]");
- input2 = G_define_standard_option(G_OPT_R_INPUT);
- input2->description =
- _("Name of the surface reflectance QC layer [bit array]");
+ output = G_define_standard_option(G_OPT_R_OUTPUT);
+ output->key = "output";
+ output->description =
+ _("Name for output QC type classification layer");
+ productname = G_define_option();
+ productname->key = "productname";
+ productname->type = TYPE_STRING;
+ productname->required = YES;
+ productname->description = _("Name of MODIS product type");
+ productname->descriptions =_("mod09Q1;surf. refl. 250m 8-days;"
+ "mod09A1;surf. refl. 500m 8-days;"
+ "mod09A1s;surf. refl. 500m 8-days, State QA;"
+ "mod11A1;LST 1Km daily (Day/Night);"
+ "mod11A2;LST 1Km 8-days (Day/Night);");
+ productname->options = "mod09Q1,mod09A1,mod09A1s,mod11A1,mod11A2";
+ productname->answer = "mod09Q1";
+
+ qcname = G_define_option();
+ qcname->key = "qcname";
+ qcname->type = TYPE_STRING;
+ qcname->required = YES;
+ qcname->description = _("Name of QC type to extract");
+ qcname->descriptions = _("adjcorr;mod09: Adjacency Correction;"
+ "atcorr;mod09: Atmospheric Correction;"
+ "cloud;mod09: Cloud State;"
+ "data_quality;mod09: Band-Wise Data Quality Flag;"
+ "diff_orbit_from_500m;mod09: 250m Band is at Different Orbit than 500m;"
+ "modland_qa_bits;mod09: MODIS Land General Quality Assessment;"
+ "mandatory_qa_11A1;mod11A1: MODIS Land General Quality Assessment;"
+ "data_quality_flag_11A1;mod11A1: Detailed Quality Indications;"
+ "emis_error_11A1;mod11A1: Average Emissivity Error Classes;"
+ "lst_error_11A1;mod11A1: Average LST Error Classes;"
+ "data_quality_flag_11A2;mod11A2: Detailed Quality Indications;"
+ "emis_error_11A2;mod11A2: Average Emissivity Error Classes;"
+ "mandatory_qa_11A2;mod11A2: MODIS Land General Quality Assessment;"
+ "lst_error_11A2;mod11A2: Average LST Error Classes;"
+ "aerosol_quantity;mod09A1s: StateQA Internal Snow Mask;"
+ "brdf_correction_performed;mod09A1s: StateQA Internal Snow Mask;"
+ "cirrus_detected;mod09A1s: StateQA Internal Snow Mask;"
+ "cloud_shadow;mod09A1s: StateQA Internal Snow Mask;"
+ "cloud_state;mod09A1s: StateQA Internal Snow Mask;"
+ "internal_clou_algorithm;mod09A1s: StateQA Internal Snow Mask;"
+ "internal_fire_algorithm;mod09A1s: StateQA Internal Snow Mask;"
+ "internal_snow_mask;mod09A1s: StateQA Internal Snow Mask;"
+ "land_water;mod09A1s: StateQA Internal Snow Mask;"
+ "mod35_snow_ice;mod09A1s: StateQA Internal Snow Mask;"
+ "pixel_adjacent_to_cloud;mod09A1s: StateQA Internal Snow Mask;"
+ );
+ qcname->options = "adjcorr,atcorr,cloud,data_quality,diff_orbit_from_500m,modland_qa_bits,mandatory_qa_11A1,data_quality_flag_11A1,emis_error_11A1,lst_error_11A1,data_quality_flag_11A2,emis_error_11A2,mandatory_qa_11A2,lst_error_11A2,aerosol_quantity,brdf_correction_performed,cirrus_detected,cloud_shadow,cloud_state,internal_clou_algorithm,internal_fire_algorithm,internal_snow_mask,land_water,mod35_snow_ice,pixel_adjacent_to_cloud";
+ qcname->answer = "modland_qa_bits";
+
input_band = G_define_option();
input_band->key = "band";
- input_band->type = TYPE_INTEGER;
+ input_band->type = TYPE_STRING;
input_band->required = NO;
- input_band->gisprompt = "old,value";
input_band->description =
- _("Band number of Modis product mod09Q1=[1,2],mod09A1=[1-7]");
+ _("Band number of Modis product (mod09Q1=[1,2],mod09A1=[1-7])");
input_band->descriptions =_("1;mod09Q1/A1 Band 1: Red;"
"2;mod09Q1/A1 Band 2: NIR;"
"3;mod09A1 Band 3: Blue;"
@@ -155,20 +162,15 @@
"5;mod09A1 Band 5: SWIR 1;"
"6;mod09A1 Band 6: SWIR 2;"
"7;mod09A1 Band 7: SWIR 3;");
-
- output = G_define_standard_option(G_OPT_R_OUTPUT);
- output->key = "output";
- output->description =
- _("Name of the output QC type classification layer");
- output->answer = "qc";
-
+ input_band->options = "1,2,3,4,5,6,7";
+
/********************/
if (G_parser(argc, argv))
exit(EXIT_FAILURE);
- product = input->answer;
- qcflag = input1->answer;
- qcchan = input2->answer;
+ product = productname->answer;
+ qcflag = qcname->answer;
+ qcchan = input->answer;
if (input_band->answer)
bandno = atoi(input_band->answer);
More information about the grass-commit
mailing list