adding new objects

This commit is contained in:
Francesco Mangiacrapa 2020-10-29 17:48:20 +01:00
parent 5aa24f6198
commit 7f56579113
6 changed files with 119 additions and 13 deletions

View File

@ -76,15 +76,19 @@ public class LayerManager {
*/ */
//THE FOLLOWING SHOULD BE NOT NEEDED BUT THE GETFEATURE WITH EPSG_3857 SEEMS NOT WORK IN OUR GEOSERVER //THE FOLLOWING SHOULD BE NOT NEEDED BUT THE GETFEATURE WITH EPSG_3857 SEEMS NOT WORK IN OUR GEOSERVER
double minX = olMap.getExtent().getLowerLeftX(); // double minX = olMap.getExtent().getLowerLeftX();
double minY = olMap.getExtent().getLowerLeftY(); // double minY = olMap.getExtent().getLowerLeftY();
double minX = queryEvent.getGeoQuery().getX1();
double minY = queryEvent.getGeoQuery().getY1();
Coordinate centerCoordinate = new Coordinate(minX, minY); Coordinate centerCoordinate = new Coordinate(minX, minY);
centerCoordinate = olMap.transform(centerCoordinate, GeoportalDataViewerConstants.EPSG_3857, GeoportalDataViewerConstants.EPSG_4326); centerCoordinate = olMap.transform(centerCoordinate, GeoportalDataViewerConstants.EPSG_3857, GeoportalDataViewerConstants.EPSG_4326);
mapBBOX.setLowerLeftX(centerCoordinate.getX()); mapBBOX.setLowerLeftX(centerCoordinate.getX());
mapBBOX.setLowerLeftY(centerCoordinate.getY()); mapBBOX.setLowerLeftY(centerCoordinate.getY());
double maxX = olMap.getExtent().getUpperRightX(); // double maxX = olMap.getExtent().getUpperRightX();
double maxY = olMap.getExtent().getUpperRightY(); // double maxY = olMap.getExtent().getUpperRightY();
double maxX = queryEvent.getGeoQuery().getX2();
double maxY = queryEvent.getGeoQuery().getY2();
centerCoordinate = new Coordinate(maxX,maxY); centerCoordinate = new Coordinate(maxX,maxY);
centerCoordinate = olMap.transform(centerCoordinate, GeoportalDataViewerConstants.EPSG_3857, GeoportalDataViewerConstants.EPSG_4326); centerCoordinate = olMap.transform(centerCoordinate, GeoportalDataViewerConstants.EPSG_3857, GeoportalDataViewerConstants.EPSG_4326);
mapBBOX.setUpperRightX(centerCoordinate.getX()); mapBBOX.setUpperRightX(centerCoordinate.getX());

View File

@ -155,7 +155,7 @@ public class OpenLayerOSM {
// ratio - mapPixelWeight : bboxWeight = 10px : geoRectangleWidth // ratio - mapPixelWeight : bboxWeight = 10px : geoRectangleWidth
// where 10px is the pixel diameter dimension of the clicked point // where 10px is the pixel diameter dimension of the clicked point
double bboxWidth = Math.abs(getExtent().getLowerLeftX() - getExtent().getUpperRightX()); double bboxWidth = Math.abs(getExtent().getLowerLeftX() - getExtent().getUpperRightX());
double geoWidth = bboxWidth / w * 10 / 2; double geoWidth = (bboxWidth / w) * (20 / 2);
double x1 = Math.min(lon+geoWidth, lon-geoWidth); double x1 = Math.min(lon+geoWidth, lon-geoWidth);
double x2 = Math.max(lon+geoWidth, lon-geoWidth); double x2 = Math.max(lon+geoWidth, lon-geoWidth);
double y1 = Math.min(lat+geoWidth, lat-geoWidth); double y1 = Math.min(lat+geoWidth, lat-geoWidth);

View File

@ -20,6 +20,7 @@ import org.gcube.portlets.user.geoportaldataviewer.server.util.URLParserUtil;
import org.gcube.portlets.user.geoportaldataviewer.shared.FeatureRow; import org.gcube.portlets.user.geoportaldataviewer.shared.FeatureRow;
import org.gcube.portlets.user.geoportaldataviewer.shared.GeoNaDataObject; import org.gcube.portlets.user.geoportaldataviewer.shared.GeoNaDataObject;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.BoundsMap; import org.gcube.portlets.user.geoportaldataviewer.shared.gis.BoundsMap;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.FeatureGeometry;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem; import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem;
import org.json.JSONArray; import org.json.JSONArray;
import org.json.JSONException; import org.json.JSONException;
@ -57,9 +58,15 @@ public class FeatureParser {
maxWFSFeature = GeoportalDataViewerConstants.MAX_WFS_FEATURES; maxWFSFeature = GeoportalDataViewerConstants.MAX_WFS_FEATURES;
} }
List<GeoNaDataObject> listGeonaDO = new ArrayList<GeoNaDataObject>();
//IF WFS IS AVAILABLE USE WFS REQUEST OTHERWHISE TRY TO USE WPS SERVICE //IF WFS IS AVAILABLE USE WFS REQUEST OTHERWHISE TRY TO USE WPS SERVICE
for (LayerItem layerItem : layerItems){ for (LayerItem layerItem : layerItems){
List<FeatureRow> rows = getWFSFeatureProperties(layerItem, mapSrsName, mapBBOX, maxWFSFeature); List<FeatureRow> rows = getWFSFeatureProperties(layerItem, mapSrsName, mapBBOX, maxWFSFeature);
GeoNaDataObject gdo = new GeoNaDataObject();
gdo.setLayerItem(layerItem);
for (FeatureRow featureRow : rows) {
}
} }
return null; return null;
} }
@ -115,6 +122,17 @@ public class FeatureParser {
final FeatureRow row = new FeatureRow(); final FeatureRow row = new FeatureRow();
JSONObject theFeature = ((JSONObject)features.get(i)); JSONObject theFeature = ((JSONObject)features.get(i));
LOG.debug("Building at index: "+i); LOG.debug("Building at index: "+i);
try {
JSONObject geometry = theFeature.getJSONObject("geometry");
String typeValue = geometry.getString("type");
JSONArray coordinates = geometry.getJSONArray("coordinates");
String toCoordinates = coordinates.toString();
row.setGeometry(new FeatureGeometry(typeValue, toCoordinates));
}catch (Exception e) {
LOG.debug("Unable to pase geometry at index: "+i);
}
// // iterate properties // // iterate properties
JSONObject properties = theFeature.getJSONObject("properties"); JSONObject properties = theFeature.getJSONObject("properties");
Map<String,List<String>> mapProperties = new HashMap<String,List<String>>(); Map<String,List<String>> mapProperties = new HashMap<String,List<String>>();

View File

@ -7,13 +7,14 @@ import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.FeatureGeometry;
/** /**
* The Class FeatureRow. * The Class FeatureRow.
* *
* @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it) * @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it)
* *
* Oct 29, 2020 * Oct 29, 2020
*/ */
public class FeatureRow implements Serializable { public class FeatureRow implements Serializable {
@ -24,30 +25,45 @@ public class FeatureRow implements Serializable {
private Map<String, List<String>> mapProperties; private Map<String, List<String>> mapProperties;
private FeatureGeometry geometry;
public FeatureRow() {
}
public FeatureRow(Map<String, List<String>> mapProperties, FeatureGeometry geometry) {
super();
this.mapProperties = mapProperties;
this.setGeometry(geometry);
}
public Map<String, List<String>> getMapProperties() { public Map<String, List<String>> getMapProperties() {
return mapProperties; return mapProperties;
} }
public void setMapProperties(Map<String, List<String>> mapProperties) { public void setMapProperties(Map<String, List<String>> mapProperties) {
this.mapProperties = mapProperties; this.mapProperties = mapProperties;
} }
public FeatureGeometry getGeometry() {
return geometry;
}
public void setGeometry(FeatureGeometry geometry) {
this.geometry = geometry;
}
/* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override @Override
public String toString() { public String toString() {
StringBuilder builder = new StringBuilder(); StringBuilder builder = new StringBuilder();
builder.append("FeatureRow [mapValues="); builder.append("FeatureRow [mapProperties=");
builder.append(mapProperties); builder.append(mapProperties);
builder.append(", geometry=");
builder.append(geometry);
builder.append("]"); builder.append("]");
return builder.toString(); return builder.toString();
} }
} }

View File

@ -4,6 +4,8 @@ import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem;
/** /**
* The Class GeoNaDataObject. * The Class GeoNaDataObject.
@ -21,6 +23,7 @@ public class GeoNaDataObject implements Serializable{
/** The form data entry fields. */ /** The form data entry fields. */
private Map<String, List<String>> dataEntryFields; private Map<String, List<String>> dataEntryFields;
private String geonaDataType; private String geonaDataType;
private LayerItem layerItem;
/** /**
* Instantiates a new geo na data object. * Instantiates a new geo na data object.
@ -55,6 +58,15 @@ public class GeoNaDataObject implements Serializable{
public String getGeonaDataType() { public String getGeonaDataType() {
return geonaDataType; return geonaDataType;
} }
public LayerItem getLayerItem() {
return layerItem;
}
public void setLayerItem(LayerItem layerItem) {
this.layerItem = layerItem;
}
/** /**
* Sets the geona data type. * Sets the geona data type.

View File

@ -0,0 +1,56 @@
package org.gcube.portlets.user.geoportaldataviewer.shared.gis;
import java.io.Serializable;
/**
* The Class FeatureGeoemtry.
*
* @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it)
*
* Oct 29, 2020
*/
public class FeatureGeometry implements Serializable{
String type;
String coordinates;
public FeatureGeometry() {
}
public FeatureGeometry(String type, String coordinates) {
super();
this.type = type;
this.coordinates = coordinates;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getCoordinates() {
return coordinates;
}
public void setCoordinates(String coordinates) {
this.coordinates = coordinates;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("FeatureGeometry [type=");
builder.append(type);
builder.append(", coordinates=");
builder.append(coordinates);
builder.append("]");
return builder.toString();
}
}