enhancement exporting layers
This commit is contained in:
parent
9ecee3b2f6
commit
6523b98860
16
pom.xml
16
pom.xml
|
@ -110,6 +110,12 @@
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.gcube.spatial.data</groupId>
|
||||||
|
<artifactId>geo-utility</artifactId>
|
||||||
|
<version>[1.0.0,2.0.0-SNAPSHOT)</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- https://mvnrepository.com/artifact/com.itextpdf/itext7-core -->
|
<!-- https://mvnrepository.com/artifact/com.itextpdf/itext7-core -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.itextpdf</groupId>
|
<groupId>com.itextpdf</groupId>
|
||||||
|
@ -124,11 +130,11 @@
|
||||||
<!-- <version>[0.4, 0.5)</version> -->
|
<!-- <version>[0.4, 0.5)</version> -->
|
||||||
<!-- </dependency> -->
|
<!-- </dependency> -->
|
||||||
|
|
||||||
<dependency>
|
<!-- <dependency> -->
|
||||||
<groupId>org.imgscalr</groupId>
|
<!-- <groupId>org.imgscalr</groupId> -->
|
||||||
<artifactId>imgscalr-lib</artifactId>
|
<!-- <artifactId>imgscalr-lib</artifactId> -->
|
||||||
<version>4.2</version>
|
<!-- <version>4.2</version> -->
|
||||||
</dependency>
|
<!-- </dependency> -->
|
||||||
|
|
||||||
<!-- LOGGER -->
|
<!-- LOGGER -->
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
|
|
||||||
import java.awt.Color;
|
|
||||||
import java.awt.image.BufferedImage;
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -11,14 +9,13 @@ import java.nio.charset.StandardCharsets;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import javax.imageio.ImageIO;
|
|
||||||
|
|
||||||
import org.gcube.application.geoportal.common.model.document.Project;
|
import org.gcube.application.geoportal.common.model.document.Project;
|
||||||
import org.gcube.application.geoportalcommon.ConvertToDataValueObjectModel;
|
import org.gcube.application.geoportalcommon.ConvertToDataValueObjectModel;
|
||||||
import org.gcube.application.geoportalcommon.ProjectDVBuilder;
|
import org.gcube.application.geoportalcommon.ProjectDVBuilder;
|
||||||
|
@ -37,8 +34,12 @@ import org.gcube.application.geoportaldatamapper.Geoportal_JSON_Mapper;
|
||||||
import org.gcube.application.geoportaldatamapper.URLParserUtil;
|
import org.gcube.application.geoportaldatamapper.URLParserUtil;
|
||||||
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
||||||
import org.gcube.common.scope.api.ScopeProvider;
|
import org.gcube.common.scope.api.ScopeProvider;
|
||||||
import org.imgscalr.Scalr;
|
import org.gcube.spatial.data.geoutility.bean.WmsParameters;
|
||||||
import org.imgscalr.Scalr.Method;
|
import org.gcube.spatial.data.geoutility.shared.BBOX;
|
||||||
|
import org.gcube.spatial.data.geoutility.shared.wfs.WFSParameter;
|
||||||
|
import org.gcube.spatial.data.geoutility.wfs.WFSQueryBuilder;
|
||||||
|
//import org.imgscalr.Scalr;
|
||||||
|
//import org.imgscalr.Scalr.Method;
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
|
@ -72,6 +73,9 @@ import com.itextpdf.layout.element.Table;
|
||||||
import com.itextpdf.layout.element.Text;
|
import com.itextpdf.layout.element.Text;
|
||||||
import com.itextpdf.layout.properties.HorizontalAlignment;
|
import com.itextpdf.layout.properties.HorizontalAlignment;
|
||||||
import com.itextpdf.layout.properties.TextAlignment;
|
import com.itextpdf.layout.properties.TextAlignment;
|
||||||
|
import com.itextpdf.layout.renderer.CellRenderer;
|
||||||
|
import com.itextpdf.layout.renderer.DrawContext;
|
||||||
|
import com.itextpdf.layout.renderer.IRenderer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The Class Geoportal_Export_To_PDF_Tests.
|
* The Class Geoportal_Export_To_PDF_Tests.
|
||||||
|
@ -97,7 +101,10 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
// private static String PROFILE_ID = "concessioni-estere";
|
// private static String PROFILE_ID = "concessioni-estere";
|
||||||
private static String PROFILE_ID = "profiledConcessioni";
|
private static String PROFILE_ID = "profiledConcessioni";
|
||||||
private static String PROJECT_ID = "6388d9b3a1e60e66b7b5843a"; // "6384ae78308f5c28c5ee08aa"; //PRE
|
private static String PROJECT_ID = "646353c5d7fb4a4633022803"; // "6384ae78308f5c28c5ee08aa"; //PRE
|
||||||
|
//6388e4f8a1e60e66b7b584ac Ficocle-Cervia Vecchia
|
||||||
|
//6388d9b3a1e60e66b7b5843a
|
||||||
|
//646353c5d7fb4a4633022803 Villa Romana del Capo di Sorrento
|
||||||
|
|
||||||
// PROD
|
// PROD
|
||||||
// 63d011c4dcac4551b9a6b930
|
// 63d011c4dcac4551b9a6b930
|
||||||
|
@ -116,9 +123,11 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
private static String MAP_BOX_GEOJSON_PARAMETER = "geojson({\"type\":\"Point\",\"coordinates\":%s})";
|
private static String MAP_BOX_GEOJSON_PARAMETER = "geojson({\"type\":\"Point\",\"coordinates\":%s})";
|
||||||
|
|
||||||
private static String MAP_BOX_ACCESS_TOKEN = "access_token=%s";
|
// private static String MAP_BOX_ACCESS_TOKEN = "access_token=%s";
|
||||||
|
|
||||||
private static String accessToken = "{ADD_ACCESS_TOKEN}";
|
private static String mapBoxAccessToken = "";
|
||||||
|
|
||||||
|
private static String mapSize = "500x300";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read context settings.
|
* Read context settings.
|
||||||
|
@ -190,7 +199,7 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
Document document = new Document(pdf);
|
Document document = new Document(pdf);
|
||||||
|
|
||||||
// Adding logo D4GNA
|
// Adding logo D4GNA
|
||||||
Image image = toImageFromLink(logoD4GNA, 80, false);
|
Image image = toImageFromLink(logoD4GNA, 80);
|
||||||
// image.setMaxHeight(150);
|
// image.setMaxHeight(150);
|
||||||
image.setFixedPosition(document.getLeftMargin(),
|
image.setFixedPosition(document.getLeftMargin(),
|
||||||
pdf.getDefaultPageSize().getHeight() - image.getImageHeight() + 90);
|
pdf.getDefaultPageSize().getHeight() - image.getImageHeight() + 90);
|
||||||
|
@ -232,9 +241,9 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
// Adding centroid MAP
|
// Adding centroid MAP
|
||||||
String geoJSON = theProjectDV.getSpatialReference().getGeoJSON();
|
String geoJSON = theProjectDV.getSpatialReference().getGeoJSON();
|
||||||
String downMapBoxImg = getMapBoxStaticMap(geoJSON, 7, accessToken);
|
String downMapBoxImg = linkToMarkerURLViaMapBoxStaticMap(geoJSON, 7, mapSize, mapBoxAccessToken);
|
||||||
|
|
||||||
Image backgroundImage = toImageFromLink(downMapBoxImg, 250, false);
|
Image backgroundImage = toImageFromLink(downMapBoxImg, 250);
|
||||||
Table tableI = new Table(1);
|
Table tableI = new Table(1);
|
||||||
tableI.setTextAlignment(TextAlignment.CENTER);
|
tableI.setTextAlignment(TextAlignment.CENTER);
|
||||||
tableI.addCell(backgroundImage);
|
tableI.addCell(backgroundImage);
|
||||||
|
@ -272,7 +281,17 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String getMapBoxStaticMap(String geoJSON, int zoom, String accessTokenValue) {
|
/**
|
||||||
|
* Link to marker URL via map box static map.
|
||||||
|
*
|
||||||
|
* @param geoJSON the geo JSON
|
||||||
|
* @param zoom the zoom
|
||||||
|
* @param widthXheight the width xheight
|
||||||
|
* @param accessTokenValue the access token value
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
private static String linkToMarkerURLViaMapBoxStaticMap(String geoJSON, int zoom, String widthXheight,
|
||||||
|
String accessTokenValue) {
|
||||||
|
|
||||||
// String geoJSON = theProjectDV.getSpatialReference().getGeoJSON();
|
// String geoJSON = theProjectDV.getSpatialReference().getGeoJSON();
|
||||||
|
|
||||||
|
@ -288,13 +307,9 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
zoom = 7;
|
zoom = 7;
|
||||||
|
|
||||||
jsonArray.put(jsonArray.length() - 1, zoom);
|
jsonArray.put(jsonArray.length() - 1, zoom);
|
||||||
|
|
||||||
pointCoordinates = jsonArray.toString();
|
pointCoordinates = jsonArray.toString();
|
||||||
|
String downMapBoxImg = String.format("%s/%s/%s/%s?access_token=%s", MAP_BOX_STATIC_API_ENDPOINT, geojson,
|
||||||
String accessToken = String.format(MAP_BOX_ACCESS_TOKEN, accessTokenValue);
|
pointCoordinates.replaceAll("\\[", "").replaceAll("\\]", ""), widthXheight, accessTokenValue);
|
||||||
//
|
|
||||||
String downMapBoxImg = String.format("%s/%s/%s/500x300?%s", MAP_BOX_STATIC_API_ENDPOINT, geojson,
|
|
||||||
pointCoordinates.replaceAll("\\[", "").replaceAll("\\]", ""), accessToken);
|
|
||||||
|
|
||||||
System.out.println("DOWN IMAGE: " + downMapBoxImg);
|
System.out.println("DOWN IMAGE: " + downMapBoxImg);
|
||||||
|
|
||||||
|
@ -311,6 +326,41 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Link to map box static map.
|
||||||
|
*
|
||||||
|
* @param bbox the bbox
|
||||||
|
* @param widthXheight the width xheight
|
||||||
|
* @param accessTokenValue the access token value
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
private static String linkToMapBoxStaticMap(String bbox, String widthXheight, String accessTokenValue) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
String downMapBoxImg = String.format("%s/[%s]/%s?access_token=%s", MAP_BOX_STATIC_API_ENDPOINT, bbox,
|
||||||
|
widthXheight, accessTokenValue);
|
||||||
|
|
||||||
|
System.out.println("DOWN IMAGE: " + downMapBoxImg);
|
||||||
|
|
||||||
|
return downMapBoxImg;
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
// TODO Auto-generated catch block
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the credits.
|
||||||
|
*
|
||||||
|
* @param document the document
|
||||||
|
* @param logoD4GNA the logo D 4 GNA
|
||||||
|
* @param logoPoweredByD4Science the logo powered by D 4 science
|
||||||
|
* @return the credits
|
||||||
|
*/
|
||||||
private Table getCredits(Document document, String logoD4GNA, String logoPoweredByD4Science) {
|
private Table getCredits(Document document, String logoD4GNA, String logoPoweredByD4Science) {
|
||||||
|
|
||||||
Table tableCredits = toTableFixedLayout(document, 4, false);
|
Table tableCredits = toTableFixedLayout(document, 4, false);
|
||||||
|
@ -320,7 +370,7 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
tableCredits.setFixedPosition(document.getLeftMargin() + 30, 15,
|
tableCredits.setFixedPosition(document.getLeftMargin() + 30, 15,
|
||||||
document.getPdfDocument().getDefaultPageSize().getWidth() - 75);
|
document.getPdfDocument().getDefaultPageSize().getWidth() - 75);
|
||||||
// Adding logo D4GNA
|
// Adding logo D4GNA
|
||||||
Image imageLogo = toImageFromLink(logoD4GNA, 40, false);
|
Image imageLogo = toImageFromLink(logoD4GNA, 40);
|
||||||
Cell cell1 = new Cell();
|
Cell cell1 = new Cell();
|
||||||
cell1.setBorder(Border.NO_BORDER);
|
cell1.setBorder(Border.NO_BORDER);
|
||||||
cell1.add(imageLogo);
|
cell1.add(imageLogo);
|
||||||
|
@ -335,7 +385,7 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
tableCredits.addCell(cell2);
|
tableCredits.addCell(cell2);
|
||||||
|
|
||||||
// Adding logo Powered By D4Science
|
// Adding logo Powered By D4Science
|
||||||
Image poweredByLink = toImageFromLink(logoPoweredByD4Science, 80, false);
|
Image poweredByLink = toImageFromLink(logoPoweredByD4Science, 80);
|
||||||
Cell cell3 = new Cell();
|
Cell cell3 = new Cell();
|
||||||
cell3.setBorder(Border.NO_BORDER);
|
cell3.setBorder(Border.NO_BORDER);
|
||||||
cell3.add(poweredByLink);
|
cell3.add(poweredByLink);
|
||||||
|
@ -353,6 +403,14 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return tableCredits;
|
return tableCredits;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append sub document to PDF.
|
||||||
|
*
|
||||||
|
* @param document the document
|
||||||
|
* @param sectionView the section view
|
||||||
|
* @param subDocuments the sub documents
|
||||||
|
* @return the document
|
||||||
|
*/
|
||||||
private static Document appendSubDocumentToPDF(Document document, SectionView sectionView,
|
private static Document appendSubDocumentToPDF(Document document, SectionView sectionView,
|
||||||
List<SubDocumentView> subDocuments) {
|
List<SubDocumentView> subDocuments) {
|
||||||
try {
|
try {
|
||||||
|
@ -401,7 +459,7 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
if (files != null) {
|
if (files != null) {
|
||||||
for (FilesetDV fileset : files) {
|
for (FilesetDV fileset : files) {
|
||||||
// Paragraph paragraphInt = new Paragraph(fileset.getGcubeProfileFieldName());
|
// Paragraph paragraphInt = new Paragraph(fileset.getGcubeProfileFieldName());
|
||||||
List<Image> listLinks = toImages(fileset.getListPayload(), 250, false);
|
List<Image> listLinks = toImages(fileset.getListPayload(), 250);
|
||||||
for (Image image : listLinks) {
|
for (Image image : listLinks) {
|
||||||
image.setBorder(Border.NO_BORDER);
|
image.setBorder(Border.NO_BORDER);
|
||||||
tableI.addCell(image);
|
tableI.addCell(image);
|
||||||
|
@ -432,29 +490,61 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
Table tableMeta = new Table(2);
|
Table tableMeta = new Table(2);
|
||||||
tableMeta = jsonToTable(tableMeta, 1, "", jsonObject);
|
tableMeta = jsonToTable(tableMeta, 1, "", jsonObject);
|
||||||
List<GCubeSDIViewerLayerDV> layers = subDocumentView.getListLayers();
|
List<GCubeSDIViewerLayerDV> layers = subDocumentView.getListLayers();
|
||||||
Table tableI = new Table(1);
|
Table tableI = new Table(2);
|
||||||
if (layers != null) {
|
if (layers != null) {
|
||||||
for (GCubeSDIViewerLayerDV gCubeLayer : layers) {
|
for (GCubeSDIViewerLayerDV gCubeLayer : layers) {
|
||||||
tableI.setTextAlignment(TextAlignment.CENTER);
|
tableI.setTextAlignment(TextAlignment.CENTER);
|
||||||
String wmsLink = gCubeLayer.getWMSLink();
|
String wmsLink = gCubeLayer.getWMSLink();
|
||||||
System.out.println("wmsLink: " + wmsLink);
|
System.out.println("wmsLink(1): " + wmsLink);
|
||||||
wmsLink = URLParserUtil.setValueOfParameter("format", wmsLink, "image/jpeg", true);
|
wmsLink = URLParserUtil.setValueOfParameter("format", wmsLink, "image/png", true);
|
||||||
Image image = toImageFromLink(wmsLink, 250, false);
|
String bbox = URLParserUtil.extractValueOfParameterFromURL("bbox", wmsLink);
|
||||||
|
String wmsVersion = URLParserUtil.extractValueOfParameterFromURL("version", wmsLink);
|
||||||
|
|
||||||
/*
|
Integer expWidth = 600;
|
||||||
wmsLink = URLParserUtil.setValueOfParameter("format", wmsLink, "application/json", true);
|
Integer expHeight = 600;
|
||||||
String geoJSON = toStringFromLink(wmsLink);
|
wmsLink = URLParserUtil.setValueOfParameter("width", wmsLink, expWidth+"", true);
|
||||||
String downMapBoxImg = getMapBoxStaticMap(geoJSON, 7, accessToken);
|
wmsLink = URLParserUtil.setValueOfParameter("height", wmsLink, expHeight+"", true);
|
||||||
Image image = toImageFromLink(downMapBoxImg, 250, false);*/
|
|
||||||
|
|
||||||
tableI.setTextAlignment(TextAlignment.CENTER);
|
Image image = toImageFromLink(wmsLink, null);
|
||||||
tableI.setHorizontalAlignment(HorizontalAlignment.CENTER);
|
System.out.println("wmsLink cell 1: " + wmsLink);
|
||||||
|
|
||||||
// Cell cell = new Cell();
|
|
||||||
//// cell.add(backgroundImage);
|
|
||||||
// cell.add(image);
|
|
||||||
tableI.addCell(image);
|
tableI.addCell(image);
|
||||||
|
|
||||||
|
|
||||||
|
BBOX.COORDINATE_FORMAT bboxFormat = wmsVersion.contains("1.3") ? BBOX.COORDINATE_FORMAT.YX
|
||||||
|
: BBOX.COORDINATE_FORMAT.XY;
|
||||||
|
|
||||||
|
BBOX theBBOX = new BBOX(bbox, bboxFormat);
|
||||||
|
|
||||||
|
double tolerance = 0.003;
|
||||||
|
double lowerXR = theBBOX.getLowerLeftX() - tolerance;
|
||||||
|
double lowerYR = theBBOX.getLowerLeftY() - tolerance;
|
||||||
|
double upperXR = theBBOX.getUpperRightX() + tolerance;
|
||||||
|
double upperYR = theBBOX.getUpperRightY() + tolerance;
|
||||||
|
|
||||||
|
String parmBBOX = BBOX.toBBOXString(new BBOX(lowerXR, lowerYR, upperXR, upperYR, ""),
|
||||||
|
bboxFormat);
|
||||||
|
|
||||||
|
//Layer with background color
|
||||||
|
String wmsLinkTol = URLParserUtil.setValueOfParameter("bbox", wmsLink, parmBBOX, false);
|
||||||
|
wmsLinkTol+="&TRANSPARENT=TRUE";
|
||||||
|
System.out.println("wmsLink cell 2: " + wmsLink);
|
||||||
|
Image image2 = toImageFromLink(wmsLinkTol, null, null);
|
||||||
|
|
||||||
|
|
||||||
|
//MapBox static as background
|
||||||
|
String linkToMapBox = linkToMapBoxStaticMap(parmBBOX, expWidth+"x"+expHeight, mapBoxAccessToken);
|
||||||
|
System.out.println("linkToMapBox: " + linkToMapBox);
|
||||||
|
|
||||||
|
Image backImg = toImageFromLink(linkToMapBox, null, null);
|
||||||
|
|
||||||
|
Cell mapCell = new Cell();
|
||||||
|
mapCell.setNextRenderer(new ImageBackgroundCellRenderer(mapCell, backImg));
|
||||||
|
|
||||||
|
|
||||||
|
mapCell.add(image2);
|
||||||
|
|
||||||
|
tableI.addCell(mapCell);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -507,6 +597,84 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static class ImageBackgroundCellRenderer extends CellRenderer {
|
||||||
|
protected Image img;
|
||||||
|
|
||||||
|
public ImageBackgroundCellRenderer(Cell modelElement, Image img) {
|
||||||
|
super(modelElement);
|
||||||
|
this.img = img;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If a renderer overflows on the next area, iText uses #getNextRenderer() method to create a new renderer for the overflow part.
|
||||||
|
// If #getNextRenderer() isn't overridden, the default method will be used and thus the default rather than the custom
|
||||||
|
// renderer will be created
|
||||||
|
@Override
|
||||||
|
public IRenderer getNextRenderer() {
|
||||||
|
return new ImageBackgroundCellRenderer((Cell) modelElement, img);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void draw(DrawContext drawContext) {
|
||||||
|
img.scaleToFit(getOccupiedAreaBBox().getWidth(), getOccupiedAreaBBox().getHeight());
|
||||||
|
drawContext.getCanvas().addXObjectFittedIntoRectangle(img.getXObject(), getOccupiedAreaBBox());
|
||||||
|
super.draw(drawContext);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wms link to WFS request.
|
||||||
|
*
|
||||||
|
* @param wmsLink the wms link
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
private static String wmsLinkToWFSRequest(String wmsLink) {
|
||||||
|
|
||||||
|
String endpoint = wmsLink.substring(0, wmsLink.indexOf("?"));
|
||||||
|
|
||||||
|
WFSQueryBuilder builder = new WFSQueryBuilder();
|
||||||
|
HashMap<WFSParameter, String> defaultR = builder.getDefaultWFSGetFeatureRequest();
|
||||||
|
wmsLink = URLParserUtil.setValueOfParameter("format", wmsLink, "application/json", true);
|
||||||
|
|
||||||
|
defaultR.put(WFSParameter.TYPENAME,
|
||||||
|
URLParserUtil.extractValueOfParameterFromURL(WmsParameters.LAYERS.getParameter(), wmsLink));
|
||||||
|
|
||||||
|
String crs = URLParserUtil.extractValueOfParameterFromURL(WmsParameters.CRS.getParameter(), wmsLink);
|
||||||
|
if (crs != null && !crs.isEmpty())
|
||||||
|
defaultR.put(WFSParameter.CRS, crs);
|
||||||
|
|
||||||
|
String srs = URLParserUtil.extractValueOfParameterFromURL(WmsParameters.SRS.getParameter(), wmsLink);
|
||||||
|
if (srs != null && !srs.isEmpty())
|
||||||
|
defaultR.put(WFSParameter.SRSNAME, srs);
|
||||||
|
|
||||||
|
String version = URLParserUtil.extractValueOfParameterFromURL(WmsParameters.VERSION.getParameter(), wmsLink);
|
||||||
|
if (version != null && !version.isEmpty())
|
||||||
|
defaultR.put(WFSParameter.VERSION, version);
|
||||||
|
|
||||||
|
// String bbox = URLParserUtil.extractValueOfParameterFromURL(WmsParameters.BBOX.getParameter(), wmsLink);
|
||||||
|
// if(bbox!=null && !bbox.isEmpty())
|
||||||
|
defaultR.put(WFSParameter.BBOX, null); // all features of the layers
|
||||||
|
|
||||||
|
String cqlFilter = URLParserUtil.extractValueOfParameterFromURL(WmsParameters.CQL_FILTER.getParameter(),
|
||||||
|
wmsLink);
|
||||||
|
if (cqlFilter != null && !cqlFilter.isEmpty())
|
||||||
|
defaultR.put(WFSParameter.CQL_FILTER, cqlFilter);
|
||||||
|
|
||||||
|
defaultR.put(WFSParameter.OUTPUTFORMAT, "application/json");
|
||||||
|
|
||||||
|
String wfsURL = builder.buildWFSFeatureQuery(endpoint, defaultR);
|
||||||
|
System.out.println("wfsLink:" + wfsURL);
|
||||||
|
return wfsURL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* To table fixed layout.
|
||||||
|
*
|
||||||
|
* @param document the document
|
||||||
|
* @param column the column
|
||||||
|
* @param maxWidthToPageSize the max width to page size
|
||||||
|
* @return the table
|
||||||
|
*/
|
||||||
private static Table toTableFixedLayout(Document document, int column, boolean maxWidthToPageSize) {
|
private static Table toTableFixedLayout(Document document, int column, boolean maxWidthToPageSize) {
|
||||||
Table table = new Table(column);
|
Table table = new Table(column);
|
||||||
table.setFixedLayout();
|
table.setFixedLayout();
|
||||||
|
@ -515,13 +683,20 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return table;
|
return table;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static List<Image> toImages(List<PayloadDV> payloads, Integer maxWidth, boolean scaleImg)
|
/**
|
||||||
throws IOException {
|
* To images.
|
||||||
|
*
|
||||||
|
* @param payloads the payloads
|
||||||
|
* @param maxWidth the max width
|
||||||
|
* @return the list
|
||||||
|
* @throws IOException Signals that an I/O exception has occurred.
|
||||||
|
*/
|
||||||
|
private static List<Image> toImages(List<PayloadDV> payloads, Integer maxWidth) throws IOException {
|
||||||
|
|
||||||
List<Image> listImages = new ArrayList<Image>(payloads.size());
|
List<Image> listImages = new ArrayList<Image>(payloads.size());
|
||||||
for (PayloadDV payloadDV : payloads) {
|
for (PayloadDV payloadDV : payloads) {
|
||||||
|
|
||||||
Image img = toImageFromLink(payloadDV.getLink(), maxWidth, scaleImg);
|
Image img = toImageFromLink(payloadDV.getLink(), maxWidth);
|
||||||
if (img != null)
|
if (img != null)
|
||||||
listImages.add(img);
|
listImages.add(img);
|
||||||
|
|
||||||
|
@ -531,21 +706,19 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Image toImageFromLink(String link, Integer maxWidth, boolean scaleImg) {
|
/**
|
||||||
|
* To image from link.
|
||||||
|
*
|
||||||
|
* @param link the link
|
||||||
|
* @param maxWidth the max width
|
||||||
|
* @return the image
|
||||||
|
*/
|
||||||
|
private static Image toImageFromLink(String link, Integer maxWidth) {
|
||||||
Image img = null;
|
Image img = null;
|
||||||
try {
|
try {
|
||||||
|
|
||||||
ImageData data = null;
|
ImageData data = null;
|
||||||
if (scaleImg) {
|
|
||||||
final InputStream is = new URL(link).openStream();
|
|
||||||
BufferedImage inputImage = ImageIO.read(is);
|
|
||||||
BufferedImage out = simpleResizeImage(inputImage, maxWidth);
|
|
||||||
data = ImageDataFactory.create(out, Color.WHITE);
|
|
||||||
is.close();
|
|
||||||
} else {
|
|
||||||
data = ImageDataFactory.create(new URL(link));
|
data = ImageDataFactory.create(new URL(link));
|
||||||
}
|
|
||||||
|
|
||||||
img = new Image(data);
|
img = new Image(data);
|
||||||
|
|
||||||
if (maxWidth != null)
|
if (maxWidth != null)
|
||||||
|
@ -562,6 +735,67 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return img;
|
return img;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* To image from link.
|
||||||
|
*
|
||||||
|
* @param link the link
|
||||||
|
* @param maxWidth the max width
|
||||||
|
* @return the image
|
||||||
|
*/
|
||||||
|
private static Image toImageFromLink(String link, Integer width, Integer height) {
|
||||||
|
Image img = null;
|
||||||
|
try {
|
||||||
|
|
||||||
|
ImageData data = null;
|
||||||
|
data = ImageDataFactory.create(new URL(link));
|
||||||
|
img = new Image(data);
|
||||||
|
|
||||||
|
if (width != null && height!=null) {
|
||||||
|
img.setWidth(width);
|
||||||
|
img.setHeight(height);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
img.setAutoScaleWidth(true);
|
||||||
|
//img.setAutoScaleHeight(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
// silent
|
||||||
|
e.printStackTrace();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return img;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* private static Image toImageFromLink(String link, Integer maxWidth, boolean
|
||||||
|
* scaleImg) { Image img = null; try {
|
||||||
|
*
|
||||||
|
* ImageData data = null; if (scaleImg) { final InputStream is = new
|
||||||
|
* URL(link).openStream(); BufferedImage inputImage = ImageIO.read(is);
|
||||||
|
* BufferedImage out = simpleResizeImage(inputImage, maxWidth); data =
|
||||||
|
* ImageDataFactory.create(out, Color.WHITE); is.close(); } else { data =
|
||||||
|
* ImageDataFactory.create(new URL(link)); }
|
||||||
|
*
|
||||||
|
* img = new Image(data);
|
||||||
|
*
|
||||||
|
* if (maxWidth != null) img.setMaxWidth(maxWidth); else
|
||||||
|
* img.setAutoScaleWidth(true);
|
||||||
|
*
|
||||||
|
* } catch (Exception e) { // silent e.printStackTrace();
|
||||||
|
*
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* return img; }
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* To string from link.
|
||||||
|
*
|
||||||
|
* @param link the link
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
private static String toStringFromLink(String link) {
|
private static String toStringFromLink(String link) {
|
||||||
String text = null;
|
String text = null;
|
||||||
try {
|
try {
|
||||||
|
@ -582,13 +816,21 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static BufferedImage simpleResizeImage(BufferedImage originalImage, int targetWidth) throws Exception {
|
// private static BufferedImage simpleResizeImage(BufferedImage originalImage, int targetWidth) throws Exception {
|
||||||
if (targetWidth > 0) {
|
// if (targetWidth > 0) {
|
||||||
return Scalr.resize(originalImage, Method.QUALITY, targetWidth);
|
// return Scalr.resize(originalImage, Method.QUALITY, targetWidth);
|
||||||
}
|
// }
|
||||||
return originalImage;
|
// return originalImage;
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* To PDF links.
|
||||||
|
*
|
||||||
|
* @param payloads the payloads
|
||||||
|
* @param marginLeft the margin left
|
||||||
|
* @return the list
|
||||||
|
* @throws IOException Signals that an I/O exception has occurred.
|
||||||
|
*/
|
||||||
private static List<Link> toPDFLinks(List<PayloadDV> payloads, Integer marginLeft) throws IOException {
|
private static List<Link> toPDFLinks(List<PayloadDV> payloads, Integer marginLeft) throws IOException {
|
||||||
|
|
||||||
List<Link> listLinks = new ArrayList<Link>(payloads.size());
|
List<Link> listLinks = new ArrayList<Link>(payloads.size());
|
||||||
|
@ -603,6 +845,14 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the link from URL.
|
||||||
|
*
|
||||||
|
* @param linkTxt the link txt
|
||||||
|
* @param url the url
|
||||||
|
* @param marginLeft the margin left
|
||||||
|
* @return the link from URL
|
||||||
|
*/
|
||||||
private static Link getLinkFromURL(String linkTxt, String url, Integer marginLeft) {
|
private static Link getLinkFromURL(String linkTxt, String url, Integer marginLeft) {
|
||||||
|
|
||||||
Link theLink = new Link(linkTxt, PdfAction.createURI(url));
|
Link theLink = new Link(linkTxt, PdfAction.createURI(url));
|
||||||
|
@ -617,9 +867,12 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* convert json Data to structured Html text
|
* convert json Data to structured Html text.
|
||||||
*
|
*
|
||||||
* @param json
|
* @param table the table
|
||||||
|
* @param deep the deep
|
||||||
|
* @param key the key
|
||||||
|
* @param obj the obj
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
private static Table jsonToTable(Table table, int deep, String key, Object obj) {
|
private static Table jsonToTable(Table table, int deep, String key, Object obj) {
|
||||||
|
@ -674,6 +927,12 @@ public class Geoportal_Export_To_PDF_Tests {
|
||||||
return table;
|
return table;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates the content cell.
|
||||||
|
*
|
||||||
|
* @param paddingTop the padding top
|
||||||
|
* @return the cell
|
||||||
|
*/
|
||||||
private static Cell createContentCell(Integer paddingTop) {
|
private static Cell createContentCell(Integer paddingTop) {
|
||||||
Cell cell = new Cell();
|
Cell cell = new Cell();
|
||||||
cell.setBorder(Border.NO_BORDER);
|
cell.setBorder(Border.NO_BORDER);
|
||||||
|
|
Loading…
Reference in New Issue