the layer switcher has been implemented #21991

This commit is contained in:
Francesco Mangiacrapa 2021-10-12 16:02:37 +02:00
parent 79948ad6bd
commit decdb3258e
5 changed files with 88 additions and 44 deletions

View File

@ -4,6 +4,7 @@
package org.gcube.portlets.user.geoportaldataviewer.client; package org.gcube.portlets.user.geoportaldataviewer.client;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -121,11 +122,6 @@ public class LayerManager {
GWT.log("(" + selectDataInfo.getX1() + "," + selectDataInfo.getY1() + ")(" + selectDataInfo.getX2() GWT.log("(" + selectDataInfo.getX1() + "," + selectDataInfo.getY1() + ")(" + selectDataInfo.getX2()
+ "," + selectDataInfo.getY2() + ")"); + "," + selectDataInfo.getY2() + ")");
// for (LayerObject layerObj : layerObjects.values()) {
// // TODO
// isLayerVisible(layerObj.getLayerItem());
// }
BoundsMap mapBBOX = new BoundsMap(); BoundsMap mapBBOX = new BoundsMap();
double minX = queryEvent.getGeoQuery().getX1(); double minX = queryEvent.getGeoQuery().getX1();
double minY = queryEvent.getGeoQuery().getY1(); double minY = queryEvent.getGeoQuery().getY1();
@ -157,7 +153,19 @@ public class LayerManager {
// for querying detail layers only in this case // for querying detail layers only in this case
if (olMap.getCurrentResolution() < OLMapManager.LAYER_DETAIL_MAX_RESOLUTION) { if (olMap.getCurrentResolution() < OLMapManager.LAYER_DETAIL_MAX_RESOLUTION) {
listLO.addAll(mapDetailLayerObjects.values()); Collection<LayerObject> collLO = mapDetailLayerObjects.values();
listLO.addAll(collLO);
ArrayList<LayerObject> layerVisibility = new ArrayList<LayerObject>(collLO.size());
layerVisibility.addAll(collLO);
//Managing layer visibility
for (LayerObject layerObject : layerVisibility) {
boolean isLayerVisible = olMap.isLayerVisible(layerObject.getLayerItem().getName());
if(!isLayerVisible) {
GWT.log("From querying removing layername: "+layerObject.getLayerItem().getName() + ", it is not visible");
listLO.remove(layerObject);
}
}
} }
GeoportalDataViewerServiceAsync.Util.getInstance().getDataResult(listLO, olMap.getProjectionCode(), GeoportalDataViewerServiceAsync.Util.getInstance().getDataResult(listLO, olMap.getProjectionCode(),
@ -567,7 +575,9 @@ public class LayerManager {
Label layerLabel = new Label(); Label layerLabel = new Label();
layerLabel.setType(LabelType.INFO); layerLabel.setType(LabelType.INFO);
layerLabel.setText(layerSourceName); String layerName = StringUtil.fullNameToLayerName(layerSourceName, ":");
layerLabel.setText(layerName);
layerLabel.setTitle(layerSourceName);
layerLabel.getElement().getStyle().setMarginTop(10, Unit.PX); layerLabel.getElement().getStyle().setMarginTop(10, Unit.PX);
layerLabel.getElement().getStyle().setMarginBottom(5, Unit.PX); layerLabel.getElement().getStyle().setMarginBottom(5, Unit.PX);
flowPanel.add(layerLabel); flowPanel.add(layerLabel);

View File

@ -38,7 +38,7 @@ public class OLMapManager {
private ol.Extent dragEndExtent = null; private ol.Extent dragEndExtent = null;
public static final int QUERY_MIN_ZOOM_LEVEL = 13; public static final int QUERY_MIN_ZOOM_LEVEL = 13;
public static final Double LAYER_DETAIL_MIN_RESOLUTION = 0.01; public static final Double LAYER_DETAIL_MIN_RESOLUTION = 0.01;
public static final Double LAYER_DETAIL_MAX_RESOLUTION = 13.2; public static final Double LAYER_DETAIL_MAX_RESOLUTION = 18.5;
/** /**
@ -255,11 +255,4 @@ public class OLMapManager {
olMap.hidePopup(); olMap.hidePopup();
} }
// /**
// * Removes the detail layers.
// */
// public void removeDetailLayers() {
// olMap.removeAllDetailLayers();
// }
} }

View File

@ -344,7 +344,7 @@ public abstract class OpenLayerOSM {
String key = layerItem.getName(); String key = layerItem.getName();
Image layer = wmsLayerMap.get(key); Image layer = wmsLayerMap.get(layerItem.getName());
if (layer == null) { if (layer == null) {
ImageWmsParams imageWMSParams = OLFactory.createOptions(); ImageWmsParams imageWMSParams = OLFactory.createOptions();
imageWMSParams.setLayers(layerItem.getName()); imageWMSParams.setLayers(layerItem.getName());
@ -722,6 +722,27 @@ public abstract class OpenLayerOSM {
return wmsLayerMap; return wmsLayerMap;
} }
/**
* Checks if is layer visible.
*
* @param layerName the layer name
* @return true, if is layer visible
*/
public boolean isLayerVisible(String layerName) {
String key = layerName;
Image layer = wmsLayerMap.get(key);
if (layer != null)
return layer.getVisible();
layer = wmsDetailsLayerMap.get(key);
if (layer != null)
return layer.getVisible();
return false;
}
/** /**
* Sets the WMS detail layer visible. * Sets the WMS detail layer visible.
* *

View File

@ -2,11 +2,14 @@ package org.gcube.portlets.user.geoportaldataviewer.client.ui.dandd;
import org.gcube.portlets.user.geoportaldataviewer.client.events.DoActionOnDetailLayersEvent; import org.gcube.portlets.user.geoportaldataviewer.client.events.DoActionOnDetailLayersEvent;
import org.gcube.portlets.user.geoportaldataviewer.client.events.DoActionOnDetailLayersEvent.DO_LAYER_ACTION; import org.gcube.portlets.user.geoportaldataviewer.client.events.DoActionOnDetailLayersEvent.DO_LAYER_ACTION;
import org.gcube.portlets.user.geoportaldataviewer.client.util.StringUtil;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem; import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem;
import com.github.gwtbootstrap.client.ui.Button; import com.github.gwtbootstrap.client.ui.Button;
import com.github.gwtbootstrap.client.ui.CheckBox; import com.github.gwtbootstrap.client.ui.CheckBox;
import com.github.gwtbootstrap.client.ui.Label;
import com.github.gwtbootstrap.client.ui.constants.IconType; import com.github.gwtbootstrap.client.ui.constants.IconType;
import com.github.gwtbootstrap.client.ui.constants.LabelType;
import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.GWT;
import com.google.gwt.dom.client.Element; import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.Style.Unit; import com.google.gwt.dom.client.Style.Unit;
@ -23,7 +26,6 @@ import com.google.gwt.event.logical.shared.ValueChangeHandler;
import com.google.gwt.event.shared.HandlerManager; import com.google.gwt.event.shared.HandlerManager;
import com.google.gwt.user.client.ui.FlexTable; import com.google.gwt.user.client.ui.FlexTable;
import com.google.gwt.user.client.ui.FlowPanel; import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.SimplePanel; import com.google.gwt.user.client.ui.SimplePanel;
import com.google.gwt.user.client.ui.Widget; import com.google.gwt.user.client.ui.Widget;
@ -42,13 +44,11 @@ public class DragDropLayer extends FlowPanel {
this.applicationBus = applicationBus; this.applicationBus = applicationBus;
this.layerItem = layer; this.layerItem = layer;
int layerSep = layer.getName().lastIndexOf(":"); String layerName = StringUtil.fullNameToLayerName(layer.getName(), ":");
String layerName = layerSep > 0 && (layerSep + 1) < layer.getName().length()
? layer.getName().substring(layerSep + 1, layer.getName().length())
: layer.getName();
this.label = new Label(layerName); this.label = new Label(layerName);
this.label.setTitle(layer.getName()); this.label.setTitle(layer.getName());
this.label.setType(LabelType.INFO);
getElement().getStyle().setMarginTop(5, Unit.PX); getElement().getStyle().setMarginTop(5, Unit.PX);
getElement().getStyle().setMarginBottom(10, Unit.PX); getElement().getStyle().setMarginBottom(10, Unit.PX);
@ -72,7 +72,7 @@ public class DragDropLayer extends FlowPanel {
rs.setWidth("250px"); rs.setWidth("250px");
FlexTable ft = new FlexTable(); FlexTable ft = new FlexTable();
ft.setWidget(0, 0, draggableButton); ft.setWidget(0, 0, draggableButton);
draggableButton.setTitle("Drag me to change my position"); draggableButton.setTitle("Drag me up or down to change my position on the Map");
checkBoxVisibility.getElement().getStyle().setMarginLeft(10, Unit.PX); checkBoxVisibility.getElement().getStyle().setMarginLeft(10, Unit.PX);
checkBoxVisibility.setValue(true); checkBoxVisibility.setValue(true);

View File

@ -12,7 +12,7 @@ import com.google.gwt.i18n.client.DateTimeFormat;
* *
* @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it) * @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it)
* *
* Nov 16, 2020 * Nov 16, 2020
*/ */
public class StringUtil { public class StringUtil {
@ -21,42 +21,62 @@ public class StringUtil {
/** /**
* Ellipsize. * Ellipsize.
* *
* @param input the input string that may be subjected to shortening * @param input the input string that may be subjected to shortening
* @param maxCharacters the maximum characters that must be returned for the input string * @param maxCharacters the maximum characters that must be returned for the
* input string
* @return the string * @return the string
* @throws Exception the exception * @throws Exception the exception
*/ */
public static String ellipsize(String input, int maxCharacters) { public static String ellipsize(String input, int maxCharacters) {
if(input==null) if (input == null)
return ""; return "";
if (input.length() < maxCharacters) if (input.length() < maxCharacters)
return input; return input;
return input.substring(0, maxCharacters)+"..."; return input.substring(0, maxCharacters) + "...";
} }
public static String formatDate(String date) { public static String formatDate(String date) {
if(date==null) if (date == null)
return date; return date;
Date theDate = null; Date theDate = null;
try { try {
if(date.endsWith(NO_TIME)) { if (date.endsWith(NO_TIME)) {
date = date.replaceAll(NO_TIME, ""); date = date.replaceAll(NO_TIME, "");
theDate = DateTimeFormat.getFormat("yyyyMMdd").parse(date); theDate = DateTimeFormat.getFormat("yyyyMMdd").parse(date);
}else { } else {
theDate = DateTimeFormat.getFormat("yyyyMMdd_HH-mm-ss").parse(date); theDate = DateTimeFormat.getFormat("yyyyMMdd_HH-mm-ss").parse(date);
} }
}catch (Exception e) { } catch (Exception e) {
//Window.alert(e.toString()); // Window.alert(e.toString());
} }
if(theDate!=null) { if (theDate != null) {
return DateTimeFormat.getFormat("dd-MM-yyyy").format(theDate); return DateTimeFormat.getFormat("dd-MM-yyyy").format(theDate);
} }
return date; return date;
} }
/**
* Full name to layer name.
*
* @param layerFullName the layer full name
* @param splitChar the split char
* @return the string
*/
public static String fullNameToLayerName(String layerFullName, String splitChar) {
if (layerFullName == null || layerFullName.isEmpty())
return layerFullName;
int layerSep = layerFullName.lastIndexOf(splitChar);
return layerSep > 0 && (layerSep + 1) < layerFullName.length()
? layerFullName.substring(layerSep + 1, layerFullName.length())
: layerFullName;
}
} }