Revision 2915
Added by harris almost 19 years ago
src/spatial/cpp/metacat_shapefile.cpp | ||
---|---|---|
56 | 56 |
* |
57 | 57 |
* @param the number of lines in the coordinates arrays |
58 | 58 |
************************************************************************/ |
59 |
static void WritePointsArray(int nSHPType, |
|
60 |
const char *pszFilename, |
|
61 |
float min_pntx[40000][100], |
|
62 |
float max_pntx[40000][100], |
|
63 |
float min_pnty[40000][100], |
|
64 |
float max_pnty[40000][100], |
|
65 |
float pointz[40000][100], |
|
66 |
vector < string > urlvec, |
|
67 |
vector < string > docidvec, |
|
68 |
int number_data_lines) |
|
69 |
{ |
|
59 |
// |
|
60 |
// 2/19/06 R Reeves modified array declarations for WritePointsArray funciton. |
|
61 |
// |
|
62 |
const int number_data_lines = 100; |
|
63 |
static void WritePointsArray ( int nSHPType, |
|
64 |
const char * pszFilename, |
|
65 |
float min_pntx[][100], |
|
66 |
float max_pntx[][100], |
|
67 |
float min_pnty[][100], |
|
68 |
float max_pnty[][100], |
|
69 |
float pointz[][100], |
|
70 |
vector<string> urlvec, |
|
71 |
vector<string> docidvec, |
|
72 |
int number_data_lines_x |
|
73 |
) |
|
74 |
{ |
|
75 |
SHPHandle hSHPHandle; |
|
76 |
SHPObject * psShape; |
|
77 |
double x, y, z, m, j, dx[number_data_lines], dy[number_data_lines], dz[number_data_lines]; |
|
78 |
int ii, iRecord, i; |
|
79 |
char buf[20]; |
|
80 |
char intString; |
|
81 |
//for the dbf file |
|
82 |
DBFHandle hDBF; |
|
70 | 83 |
|
71 |
SHPHandle hSHPHandle; |
|
72 |
SHPObject *psShape; |
|
73 |
double x, y, z, m, j, dx[number_data_lines], dy[number_data_lines], |
|
74 |
dz[number_data_lines]; |
|
75 |
int ii, iRecord, i; |
|
76 |
char buf[20]; |
|
77 |
char intString; |
|
78 |
//for the dbf file |
|
79 |
DBFHandle hDBF; |
|
84 |
//create the dbf file |
|
85 |
hDBF = DBFCreate( pszFilename ); |
|
86 |
if ( hDBF == NULL ) |
|
87 |
{ |
|
88 |
printf( "DBFCreate(%s) failed.\n" ); |
|
89 |
exit( 2 ); |
|
90 |
} |
|
80 | 91 |
|
81 |
//create the dbf file |
|
82 |
hDBF = DBFCreate(pszFilename); |
|
83 |
if (hDBF == NULL) { |
|
84 |
printf("DBFCreate(%s) failed.\n"); |
|
85 |
exit(2); |
|
86 |
} |
|
87 |
//add to the dbf file attributes for ID, pval(elevation), url |
|
88 |
if (DBFAddField(hDBF, "ID", FTInteger, 10, 0) == -1) { |
|
89 |
printf("DBFAddField(%s,FTInteger,%d,0) failed.\n"); |
|
90 |
} |
|
91 |
if (DBFAddField(hDBF, "area_coef", FTDouble, 10, 4) == -1) { |
|
92 |
printf("DBFAddField(%s,FTDouble,%d,0) failed.\n"); |
|
93 |
} |
|
94 |
if (DBFAddField(hDBF, "url", FTString, 220, 0) == -1) { |
|
95 |
printf("DBFAddField(%s,FTString,%d,0) failed.\n"); |
|
96 |
} |
|
97 |
if (DBFAddField(hDBF, "docid", FTString, 220, 0) == -1) { |
|
98 |
printf("DBFAddField(%s,FTString,%d,0) failed.\n"); |
|
99 |
} |
|
92 |
//add to the dbf file attributes for ID, pval(elevation), url |
|
93 |
if ( DBFAddField( hDBF, "ID", FTInteger, 10, 0 ) == -1 ) |
|
94 |
{ |
|
95 |
printf( "DBFAddField(%s,FTInteger,%d,0) failed.\n" ); |
|
96 |
} |
|
97 |
if ( DBFAddField( hDBF, "area_coef", FTDouble, 10, 4 ) == -1 ) |
|
98 |
{ |
|
99 |
printf( "DBFAddField(%s,FTDouble,%d,0) failed.\n" ); |
|
100 |
} |
|
101 |
if ( DBFAddField( hDBF, "url", FTString, 220, 0 ) == -1 ) |
|
102 |
{ |
|
103 |
printf( "DBFAddField(%s,FTString,%d,0) failed.\n" ); |
|
104 |
} |
|
105 |
if ( DBFAddField( hDBF, "docid", FTString, 220, 0 ) == -1 ) |
|
106 |
{ |
|
107 |
printf( "DBFAddField(%s,FTString,%d,0) failed.\n" ); |
|
108 |
} |
|
100 | 109 |
|
101 |
//cout<<" DBF Record Count --> "<<iRecord<<endl; |
|
102 |
int id_field = DBFGetFieldIndex(hDBF, "ID"); |
|
103 |
int url_field = DBFGetFieldIndex(hDBF, "url"); |
|
104 |
int docid_field = DBFGetFieldIndex(hDBF, "docid"); |
|
105 |
int area_field = DBFGetFieldIndex(hDBF, "area_coef"); |
|
106 | 110 |
|
107 |
hSHPHandle = SHPCreate(pszFilename, nSHPType); |
|
111 |
//cout<<" DBF Record Count --> "<<iRecord<<endl; |
|
112 |
int id_field = DBFGetFieldIndex( hDBF, "ID" ); |
|
113 |
int url_field = DBFGetFieldIndex( hDBF, "url" ); |
|
114 |
int docid_field = DBFGetFieldIndex( hDBF, "docid" ); |
|
115 |
int area_field = DBFGetFieldIndex( hDBF, "area_coef" ); |
|
108 | 116 |
|
109 |
ii = 0; |
|
110 |
for (ii = 0; ii < number_data_lines; ii++) { |
|
111 |
double area_coef = |
|
112 |
sqrt(pow((max_pntx[2][ii] - min_pntx[2][ii]), 2) + |
|
113 |
pow((max_pnty[2][ii] - min_pnty[2][ii]), 2)); |
|
114 |
double ave_x = ((min_pntx[2][ii] + max_pntx[2][ii]) / 2); |
|
115 |
double ave_y = ((min_pnty[2][ii] + max_pnty[2][ii]) / 2); |
|
116 |
double ave_z = (pointz[2][ii]); |
|
117 |
hSHPHandle = SHPCreate( pszFilename, nSHPType ); |
|
117 | 118 |
|
118 |
if (ave_x < 180 && ave_x > -180 && ave_y < 90 && ave_y > -90) { |
|
119 |
ii = 0; |
|
120 |
for ( ii = 0; ii < number_data_lines; ii++ ) |
|
121 |
{ |
|
122 |
double area_coef = sqrt( pow((max_pntx[2][ii]-min_pntx[2][ii]),2) + pow((max_pnty[2][ii]-min_pnty[2][ii]),2) ); |
|
123 |
double ave_x = ( (min_pntx[2][ii]+max_pntx[2][ii])/2 ); |
|
124 |
double ave_y = ( (min_pnty[2][ii]+max_pnty[2][ii])/2 ); |
|
125 |
double ave_z = ( pointz[2][ii] ); |
|
119 | 126 |
|
120 |
psShape = |
|
121 |
SHPCreateObject(SHPT_POINT, ii, 0, NULL, NULL, 1, &ave_x, &ave_y, |
|
122 |
&ave_z, NULL); |
|
127 |
if (ave_x < 180 && ave_x > -180 && ave_y < 90 && ave_y >-90 ) { |
|
123 | 128 |
|
124 |
SHPWriteObject(hSHPHandle, -1, psShape); |
|
125 |
SHPDestroyObject(psShape); |
|
126 |
//do the update to the dbf file too |
|
127 |
iRecord = DBFGetRecordCount(hDBF); |
|
129 |
psShape = SHPCreateObject( SHPT_POINT, ii, 0, NULL, NULL, 1, &ave_x, &ave_y, &ave_z, NULL ); |
|
128 | 130 |
|
129 |
DBFWriteStringAttribute(hDBF, iRecord, url_field, |
|
130 |
urlvec[ii].c_str()); |
|
131 |
DBFWriteStringAttribute(hDBF, iRecord, docid_field, |
|
132 |
docidvec[ii].c_str()); |
|
133 |
DBFWriteIntegerAttribute(hDBF, iRecord, id_field, int (ii)); |
|
134 |
DBFWriteDoubleAttribute(hDBF, iRecord, area_field, area_coef); |
|
135 |
} |
|
136 |
} |
|
137 |
//recompute the extents |
|
138 |
//SHPComputeExtents( psShape ); |
|
139 |
//cout << "xmin: " << psShape->dfXMin << " xmax: " << psShape->dfXMax << endl; |
|
140 |
//cout << "ymin: " << psShape->dfYMin << " ymax: " << psShape->dfYMax << endl; |
|
141 |
DBFClose(hDBF); |
|
142 |
SHPClose(hSHPHandle); |
|
131 |
SHPWriteObject( hSHPHandle, -1, psShape ); |
|
132 |
SHPDestroyObject( psShape ); |
|
133 |
//do the update to the dbf file too |
|
134 |
iRecord = DBFGetRecordCount( hDBF ); |
|
135 |
|
|
136 |
DBFWriteStringAttribute(hDBF, iRecord, url_field, urlvec[ii].c_str() ); |
|
137 |
DBFWriteStringAttribute(hDBF, iRecord, docid_field, docidvec[ii].c_str() ); |
|
138 |
DBFWriteIntegerAttribute(hDBF, iRecord, id_field, int(ii) ); |
|
139 |
DBFWriteDoubleAttribute(hDBF, iRecord, area_field, area_coef ); |
|
140 |
} |
|
141 |
} |
|
142 |
//recompute the extents |
|
143 |
//SHPComputeExtents( psShape ); |
|
144 |
//cout << "xmin: " << psShape->dfXMin << " xmax: " << psShape->dfXMax << endl; |
|
145 |
//cout << "ymin: " << psShape->dfYMin << " ymax: " << psShape->dfYMax << endl; |
|
146 |
DBFClose( hDBF ); |
|
147 |
SHPClose( hSHPHandle ); |
|
143 | 148 |
} |
144 | 149 |
|
145 | 150 |
|
146 | 151 |
/** getUsage -- function that prints to stdout the usage for this driver */ |
147 | 152 |
static void getUsage() |
148 | 153 |
{ |
149 |
std::cout << "usage: metacat2shape metacat_export.txt test.shp\n\n"; |
|
150 |
std::cout << " where:\n\n"; |
|
151 |
std:: |
|
152 |
cout << |
|
153 |
" input -- is an input ASCII file, that contains the following cols:\n"; |
|
154 |
std::cout << " -> docid -- the document id\n"; |
|
155 |
std::cout << " -> x -- the xlocation\n"; |
|
156 |
std::cout << " -> y -- the y location\n"; |
|
157 |
std::cout << " -> url -- the url to the document\n"; |
|
154 |
cout<<"usage: metacat2shape metacat_export.txt test.shp\n\n"; |
|
155 |
cout<<" where:\n\n"; |
|
156 |
cout<<" input -- is an input ASCII file, that contains the following cols:\n"; |
|
157 |
cout<<" -> docid -- the document id\n"; |
|
158 |
cout<<" -> x -- the xlocation\n"; |
|
159 |
cout<<" -> y -- the y location\n"; |
|
160 |
cout<<" -> url -- the url to the document\n"; |
|
158 | 161 |
|
159 |
std::cout << " shapefile -- {output} is a ESRI shapefile\n\n";
|
|
162 |
cout<<" shapefile -- {output} is a ESRI shapefile\n\n";
|
|
160 | 163 |
|
161 |
std::cout << " see:\n";
|
|
162 |
std::cout << " example: metacat2shape metacat_export.txt test.shp\n\n";
|
|
164 |
cout<<" see:\n";
|
|
165 |
cout<<" example: metacat2shape metacat_export.txt test.shp\n\n";
|
|
163 | 166 |
|
164 |
std::cout << " ##><><><><><><><><><><><><><><><><><><><><><><><><>##\n";
|
|
165 |
std::cout << " ## John Harris ##\n";
|
|
166 |
std::cout << " ## harris@nceas.ucsb.edu ##\n";
|
|
167 |
std::cout << " ## Copyright 1999-2003 ##\n";
|
|
168 |
std::cout << " ##><><><><><><><><><><><><><><><><><><><><><><><><>##\n";
|
|
167 |
cout<<" ##><><><><><><><><><><><><><><><><><><><><><><><><>##\n";
|
|
168 |
cout<<" ## John Harris ##\n";
|
|
169 |
cout<<" ## harris@nceas.ucsb.edu ##\n";
|
|
170 |
cout<<" ## Copyright 1999-2003 ##\n";
|
|
171 |
cout<<" ##><><><><><><><><><><><><><><><><><><><><><><><><>##\n";
|
|
169 | 172 |
|
170 |
std::cout << std::endl;
|
|
173 |
cout << endl;
|
|
171 | 174 |
|
172 | 175 |
} |
173 | 176 |
|
174 | 177 |
|
175 | 178 |
|
176 |
int main(int argc, char **argv)
|
|
179 |
int main( int argc, char * * argv )
|
|
177 | 180 |
{ |
178 | 181 |
//get the usage info if the inputs are not right |
179 |
if (argc != 3) { |
|
182 |
if ( argc != 3 ) |
|
183 |
{ |
|
180 | 184 |
getUsage(); |
181 |
exit(1);
|
|
185 |
exit( 1 );
|
|
182 | 186 |
} |
187 |
|
|
183 | 188 |
//these arrays are for the input x, y, z data |
184 |
float min_pntx[1000][100]; |
|
185 |
float min_pnty[1000][100]; |
|
186 |
float max_pntx[1000][100]; |
|
187 |
float max_pnty[1000][100]; |
|
189 |
float min_pntx[1000] [100];
|
|
190 |
float min_pnty[1000] [100];
|
|
191 |
float max_pntx[1000] [100];
|
|
192 |
float max_pnty[1000] [100];
|
|
188 | 193 |
|
189 |
float pointz[1000][100]; |
|
190 |
vector < string > docidvec;
|
|
191 |
vector < string > urlvec;
|
|
194 |
float pointz[1000] [100];
|
|
195 |
vector<string> docidvec;
|
|
196 |
vector<string> urlvec;
|
|
192 | 197 |
|
193 |
FILE *infile; |
|
198 |
FILE * infile;
|
|
194 | 199 |
char oneline[200]; |
195 |
char *value; |
|
200 |
char * value;
|
|
196 | 201 |
|
197 | 202 |
int cnt = 0; |
198 | 203 |
int number_lines = 0; |
... | ... | |
205 | 210 |
|
206 | 211 |
SHPHandle hSHP; |
207 | 212 |
int nShapeType, nEntities, i, iPart; |
208 |
const char *pszPlus; |
|
213 |
const char * pszPlus;
|
|
209 | 214 |
|
210 | 215 |
//test the reading of the file |
211 |
if ((infile = fopen(argv[1], "r")) == (FILE *) NULL) { |
|
212 |
fprintf(stderr, "Can't read the file: %s.\n", argv[1]); |
|
213 |
exit(2); |
|
216 |
if ( ( infile = fopen( argv[1], "r" ) ) == ( FILE * ) NULL ) |
|
217 |
{ |
|
218 |
fprintf( stderr, "Can't read the file: %s.\n", argv[1] ); |
|
219 |
exit( 2 ); |
|
214 | 220 |
} |
215 | 221 |
|
216 | 222 |
/* read the data into an array -- first the grid nodes |
... | ... | |
224 | 230 |
* 36.2083333333333 |
225 | 231 |
* http://metacat.nceas.ucsb.edu/knb/servlet/metacat?action=read&docid=nrs.239.1&qformat=knb |
226 | 232 |
*/ |
227 |
infile = fopen(argv[1], "r"); |
|
228 |
char const *out_shape = argv[2]; |
|
229 |
while (fgets(oneline, 199, infile)) { |
|
230 |
sscanf(oneline, "%s %s %s %s %s %s %s", buf_docid, buf_xmin, buf_xmax, |
|
231 |
buf_ymin, buf_ymax, buf_url); |
|
233 |
infile = fopen( argv[1], "r" ); |
|
234 |
char const * out_shape = argv[2]; |
|
235 |
while ( fgets( oneline, 199, infile ) ) { |
|
236 |
sscanf( oneline, "%s %s %s %s %s %s %s", buf_docid, buf_xmin, buf_xmax, buf_ymin, buf_ymax, buf_url); |
|
232 | 237 |
|
233 | 238 |
/**** cout<<" docid -> " << bufa |
234 | 239 |
<<"\n cnt -> " << cnt |
... | ... | |
237 | 242 |
<<"\n p -> " << buf2 |
238 | 243 |
<<endl; *******/ |
239 | 244 |
|
240 |
min_pntx[2][cnt] = atof(buf_xmin); |
|
241 |
max_pntx[2][cnt] = atof(buf_xmax); |
|
242 |
min_pnty[2][cnt] = atof(buf_ymin); |
|
243 |
max_pnty[2][cnt] = atof(buf_ymax); |
|
245 |
min_pntx[2] [cnt] = atof(buf_xmin);
|
|
246 |
max_pntx[2] [cnt] = atof(buf_xmax);
|
|
247 |
min_pnty[2] [cnt] = atof(buf_ymin);
|
|
248 |
max_pnty[2] [cnt] = atof(buf_ymax);
|
|
244 | 249 |
|
245 | 250 |
urlvec.push_back(buf_url); |
246 | 251 |
docidvec.push_back(buf_docid); |
... | ... | |
248 | 253 |
cnt++; |
249 | 254 |
number_lines = cnt; |
250 | 255 |
} |
251 |
fclose(infile);
|
|
256 |
fclose( infile );
|
|
252 | 257 |
|
253 |
cout << "creating a new shape file, with " << number_lines << " records " |
|
254 |
<< endl; |
|
255 |
WritePointsArray(SHPT_POINT, out_shape, min_pntx, max_pntx, min_pnty, |
|
256 |
max_pnty, pointz, urlvec, docidvec, number_lines); |
|
258 |
cout<<"creating a new shape file, with "<< number_lines <<" records "<<endl; |
|
259 |
WritePointsArray( SHPT_POINT, |
|
260 |
out_shape, |
|
261 |
min_pntx, |
|
262 |
max_pntx, |
|
263 |
min_pnty, |
|
264 |
max_pnty, |
|
265 |
pointz, |
|
266 |
urlvec, |
|
267 |
docidvec, |
|
268 |
number_lines ); |
|
257 | 269 |
|
258 | 270 |
#ifdef USE_DBMALLOC |
259 |
malloc_dump(2);
|
|
271 |
malloc_dump( 2 );
|
|
260 | 272 |
#endif |
261 |
exit(0);
|
|
273 |
exit( 0 );
|
|
262 | 274 |
} |
src/edu/ucsb/nceas/metacat/spatial/MetacatSpatialDataset.java | ||
---|---|---|
49 | 49 |
docs = new Vector(); |
50 | 50 |
} |
51 | 51 |
|
52 |
/** |
|
53 |
* Returns XML as a String -- the xml describes the dataset |
|
54 |
*/ |
|
55 |
public String toXML () { |
|
56 |
StringBuffer _sb = new StringBuffer(); |
|
52 | 57 |
|
58 |
_sb.append("<metacatspatialdataset>"); |
|
59 |
for (int i = 0; i < docs.size(); i++) { |
|
60 |
|
|
61 |
MetacatSpatialDocument _doc = (MetacatSpatialDocument)docs.elementAt(i); |
|
62 |
|
|
63 |
_sb.append("<metacatspatialdocument>\n"); |
|
64 |
|
|
65 |
_sb.append("<creator>"); |
|
66 |
_sb.append(" <individualName>"); |
|
67 |
_sb.append(" <givenName></givenName>"); |
|
68 |
_sb.append(" <surName></surName>"); |
|
69 |
_sb.append(" </individualName>"); |
|
70 |
_sb.append(" <organizationName></organizationName>"); |
|
71 |
_sb.append(" </creator>"); |
|
72 |
|
|
73 |
_sb.append("<title>"+_doc.getTitle()+"</title>"); |
|
74 |
_sb.append("<docid>"+_doc.getDocid()+"</docid>"); |
|
75 |
_sb.append(" <extents>"); |
|
76 |
_sb.append(" <ispoint>"+_doc.getIsPoint()+"</ispoint>"); |
|
77 |
_sb.append(" <xmin>"+_doc.getXMin()+"</xmin>"); |
|
78 |
_sb.append(" <ymin>"+_doc.getYMin()+"</ymin>"); |
|
79 |
_sb.append(" <xmax>"+_doc.getXMax()+"</xmax>"); |
|
80 |
_sb.append(" <ymax>"+_doc.getYMax()+"</ymax>"); |
|
81 |
_sb.append(" </extents>\n"); |
|
82 |
|
|
83 |
|
|
84 |
_sb.append("</metacatspatialdocument>"); |
|
85 |
|
|
86 |
} |
|
87 |
_sb.append("</metacatspatialdataset>"); |
|
88 |
|
|
89 |
return _sb.toString(); |
|
90 |
} |
|
91 |
|
|
92 |
|
|
53 | 93 |
/** |
54 | 94 |
* returns the document corresponding to the input index from this dataset |
55 | 95 |
*/ |
... | ... | |
79 | 119 |
* x y z segid |
80 | 120 |
* |
81 | 121 |
* the data are delimited by spaces and each line is terminated bt '\n' |
122 |
* out.println("#HEADER docid x y url"); |
|
82 | 123 |
*/ |
83 | 124 |
public StringBuffer getExtentsDataAsAscii() { |
84 | 125 |
StringBuffer _sb = new StringBuffer(); |
... | ... | |
86 | 127 |
MetacatSpatialDocument _doc = (MetacatSpatialDocument)docs.elementAt(i); |
87 | 128 |
try { |
88 | 129 |
if ( ! _doc.getIsPoint() ) { |
89 |
_sb.append( _doc.getXMin()+ " " + _doc.getYMin() + " 0 " + _doc.getDocid()+"\n");
|
|
90 |
_sb.append( _doc.getXMax()+ " " + _doc.getYMin() + " 0 " + _doc.getDocid()+"\n");
|
|
91 |
_sb.append( _doc.getXMax()+ " " + _doc.getYMax() + " 0 " + _doc.getDocid()+"\n");
|
|
92 |
_sb.append( _doc.getXMin()+ " " + _doc.getYMax() + " 0 " + _doc.getDocid()+"\n");
|
|
130 |
_sb.append( _doc.getDocid()+" "+ _doc.getXMin()+ " " + _doc.getYMin() + " http://www.cnn.com \n");
|
|
131 |
_sb.append( _doc.getDocid()+" "+ _doc.getXMax()+ " " + _doc.getYMin() + " http://www.cnn.com \n");
|
|
132 |
_sb.append( _doc.getDocid()+" "+ _doc.getXMax()+ " " + _doc.getYMax() + " http://www.cnn.com \n");
|
|
133 |
_sb.append( _doc.getDocid()+" "+ _doc.getXMin()+ " " + _doc.getYMax() + " http://www.cnn.com \n");
|
|
93 | 134 |
} |
94 | 135 |
} catch (NullPointerException npe) { |
95 | 136 |
log.fatal("ERROR: null pointer exception on a spatial document"); |
src/edu/ucsb/nceas/metacat/spatial/PersistentMetacatSpatialDataset.java | ||
---|---|---|
40 | 40 |
* Class for doing IO of spatial data from. IO can be with the FS in the |
41 | 41 |
* case of a shapefile, and or with a DB (as in the case of a PostGIS |
42 | 42 |
* entry or a Metacat Entry) |
43 |
* |
|
44 |
* usage: metacat2shape metacat_export.txt test.shp |
|
45 |
* |
|
46 |
* where: |
|
47 |
* |
|
48 |
* input -- is an input ASCII file, that contains the following cols: |
|
49 |
* -> docid -- the document id |
|
50 |
* -> x -- the xlocation |
|
51 |
* -> y -- the y location |
|
52 |
* -> url -- the url to the document |
|
53 |
* shapefile -- {output} is a ESRI shapefile |
|
54 |
* |
|
55 |
* see: |
|
56 |
* example: metacat2shape metacat_export.txt test.shp |
|
57 |
* |
|
58 |
* ##><><><><><><><><><><><><><><><><><><><><><><><><>## |
|
59 |
* ## John Harris ## |
|
60 |
* ## harris@nceas.ucsb.edu ## |
|
61 |
* ## Copyright 1999-2003 ## |
|
62 |
* ##><><><><><><><><><><><><><><><><><><><><><><><><>## |
|
63 |
* |
|
43 | 64 |
*/ |
44 | 65 |
public class PersistentMetacatSpatialDataset { |
45 | 66 |
|
46 | 67 |
private String textQueryAsciiFile = "/tmp/mso_metacat_textquery.ascii"; |
47 | 68 |
private String metacatSpatialCacheAsciiFile = "/tmp/mso_metacat_cache.ascii"; |
69 |
private String metacatSpatialCacheShapeFile = "/tmp/mso_metacat_cache.shp"; |
|
48 | 70 |
|
49 | 71 |
private static Logger log = Logger.getLogger(PersistentMetacatSpatialDataset.class.getName()); |
50 | 72 |
|
... | ... | |
56 | 78 |
try { |
57 | 79 |
PrintStream out = new PrintStream(new FileOutputStream( metacatSpatialCacheAsciiFile)); |
58 | 80 |
|
59 |
out.println("#HEADER x y z segid");
|
|
81 |
out.println("#HEADER docid x y url");
|
|
60 | 82 |
|
61 | 83 |
out.println( dataset.getExtentsDataAsAscii()); |
62 | 84 |
log.fatal("extents data: " + dataset.getExtentsDataAsAscii() +" done" ); |
63 | 85 |
|
64 | 86 |
out.close(); |
65 | 87 |
|
88 |
|
|
89 |
// make the shapefile |
|
90 |
String command = "metacat_shapefile "+metacatSpatialCacheAsciiFile+" "+metacatSpatialCacheShapeFile; |
|
91 |
try{ |
|
92 |
Process p = Runtime.getRuntime().exec(command); |
|
93 |
} |
|
94 |
catch(IOException ioe){} |
|
95 |
|
|
66 | 96 |
} catch (FileNotFoundException fnfe) { |
67 | 97 |
log.fatal("ERROR: could not find the file "); |
68 | 98 |
fnfe.printStackTrace(); |
src/edu/ucsb/nceas/metacat/spatial/SpatialQueryProcessor.java | ||
---|---|---|
147 | 147 |
float _docMinX = |
148 | 148 |
queryWestBoundingCoordinate((String) _docs.elementAt(i)); |
149 | 149 |
|
150 |
String _title = getTitle((String) _docs.elementAt(i)); |
|
151 |
|
|
150 | 152 |
// check if inside the bounding box |
151 | 153 |
if (_docMaxX <= _xmax && _docMinX >= _xmin && _docMaxY <= _ymax && _docMinY >= _ymin ) { |
152 | 154 |
MetacatSpatialDocument _doc = |
... | ... | |
212 | 214 |
return _docs; |
213 | 215 |
} |
214 | 216 |
|
217 |
/** |
|
218 |
* returns the north bounding coordinate -- this is a single point |
|
219 |
*/ |
|
220 |
private String getTitle(String docid) { |
|
221 |
String title = null; |
|
222 |
PreparedStatement pstmt = null; |
|
223 |
ResultSet rs = null; |
|
224 |
String query = "select docid, nodedata, nodeid from xml_nodes where " |
|
225 |
+ "nodeid =(select nodeid from xml_nodes where docid like '" |
|
226 |
+ docid.trim() + "' and nodename like 'title%');"; |
|
215 | 227 |
|
228 |
try { |
|
229 |
pstmt = dbconn.prepareStatement(query); |
|
230 |
pstmt.execute(); |
|
231 |
rs = pstmt.getResultSet(); |
|
232 |
if (rs.next()) |
|
233 |
title = rs.getString(2); |
|
234 |
rs.close(); |
|
235 |
pstmt.close(); |
|
236 |
} |
|
237 |
catch(Exception e) { |
|
238 |
log.error("Error getting docids from queryExtentsByDocid"); |
|
239 |
e.printStackTrace(); |
|
240 |
} |
|
241 |
return title; |
|
242 |
} |
|
243 |
|
|
216 | 244 |
/** |
217 | 245 |
* returns the north bounding coordinate -- this is a single point |
218 | 246 |
*/ |
src/edu/ucsb/nceas/metacat/spatial/MetacatSpatialDocument.java | ||
---|---|---|
35 | 35 |
|
36 | 36 |
private String docid; |
37 | 37 |
|
38 |
private String title; |
|
39 |
|
|
38 | 40 |
private MetacatSpatialExtents extents; |
39 | 41 |
|
40 | 42 |
public MetacatSpatialDocument(String docid) { |
41 | 43 |
setDocid(docid); |
42 | 44 |
} |
43 | 45 |
|
46 |
|
|
47 |
|
|
44 | 48 |
/** |
45 | 49 |
* function that registers the document with the Spatial system. This is |
46 | 50 |
* to be called when the document is inserted to the Metacat system. At |
... | ... | |
59 | 63 |
this.extents = _extents; |
60 | 64 |
} |
61 | 65 |
|
66 |
public String getTitle() { return this.title; } |
|
67 |
public void setTitle(String _title) {this.title = _title; } |
|
68 |
|
|
62 | 69 |
public float getXMin() { return extents.getXMin(); } |
63 | 70 |
public void setXMin(float x) { extents.setXMin(x); } |
64 | 71 |
|
src/edu/ucsb/nceas/metacat/MetaCatServlet.java | ||
---|---|---|
780 | 780 |
out = response.getWriter(); |
781 | 781 |
|
782 | 782 |
// switch -- html/xml print |
783 |
boolean printXML = false;
|
|
783 |
boolean printXML = true;
|
|
784 | 784 |
|
785 | 785 |
// get the spatial parameters |
786 | 786 |
logMetacat.warn("params: " + params); |
... | ... | |
802 | 802 |
// return the list of docs and point at the spatial theme |
803 | 803 |
if ( printXML) { |
804 | 804 |
response.setContentType("text/xml"); |
805 |
out.println("<?xml version=\"1.0\"?>"); |
|
806 |
out.println("<urllist>"); |
|
807 |
//for all data (print url approximations) |
|
808 |
for (int i = 0; i < _data.size(); i++) { |
|
809 |
out.println("<docid>"+(_data.getDocument(i)).getDocid()+"</docid>"); |
|
810 |
out.println("<url>"+request.getRequestURL()+(_data.getDocument(i)).getDocid()+"</url>"); |
|
811 |
} |
|
812 |
out.println("</urllist>"); |
|
805 |
out.println(_data.toXML() ); // write the data as xml |
|
813 | 806 |
out.close(); |
814 | 807 |
} else { |
815 | 808 |
response.setContentType("text/html"); |
Also available in: Unified diff
Integration of new shapefile writers (r. reeves code) with MSO.