//TODO: Add zoom to extent as control //TODO: Try to leave everything in 4326 var reset_btn = $('#reset')[0]; var novafactory_btn = $('#nfDownload')[0]; var dataPanel = $('#dataPanel'); var br = document.createElement('br'); proj4.defs("EPSG:31467", "+proj=tmerc +lat_0=0 +lon_0=9 +k=1 +x_0=3500000 +y_0=0" + " +ellps=bessel +datum=potsdam +units=m +no_defs"); // http://spatialreference.org/ref/epsg/31467/proj4js/ var wgs84Sphere = new ol.Sphere(6378137); var osm_layer = new ol.layer.Tile({ source : new ol.source.OSM() }); var kml_source = new ol.source.KML({ projection : ol.proj.get('EPSG:3857'), url : 'data/citygml_hulls.kml', extractAttributes : false, extractStyles : false }) var kml_layer = new ol.layer.Vector({ source : kml_source, style : new ol.style.Style({ fill : new ol.style.Fill({ color : 'rgba(255, 255, 255, 0.2)' }), stroke : new ol.style.Stroke({ color : '#777777', width : 2, lineDash : [ 5, 10 ] }), }) }); var intersections = new ol.source.Vector(); var intersections_layer = new ol.layer.Vector({ source : intersections, style : new ol.style.Style({ fill : new ol.style.Fill({ color : 'rgba(255, 155, 51, 0.5)' }) }) }); var vectorSource = new ol.source.Vector({ features : [] }); vectorSource.addMarker = function(x, y, name) { this.addFeature(new ol.Feature({ geometry : new ol.geom.Point(ol.proj.transform([ x, y ], 'EPSG:31467', 'EPSG:3857')), name : name, })); } // vectorSource.addMarker(3536859.19, 5438902.94, "BRUSE"); // vectorSource.addMarker(3533399.8907172694, 5439126.050470325, "MyPoly"); var createTextStyle = function(feature, resolution) { var align = "Normal"; var baseline = "Middle"; var size = "12px"; var weight = "Normal"; var font = weight + ' ' + size + ' ' + "Arial"; var fillColor = '#aa3300'; var outlineColor = "#ffffff"; var outlineWidth = 3; return new ol.style.Text({ textAlign : align, textBaseline : baseline, font : font, text : feature.get('name'), fill : new ol.style.Fill({ color : fillColor }), stroke : new ol.style.Stroke({ color : outlineColor, width : outlineWidth }), }); }; var createPointStyleFunction = function() { return function(feature, resolution) { var style = new ol.style.Style({ image : new ol.style.Circle({ radius : 10, fill : new ol.style.Fill({ color : 'rgba(255, 0, 0, 0.1)' }), stroke : new ol.style.Stroke({ color : 'red', width : 1 }) }), text : createTextStyle(feature, resolution) }); return [ style ]; }; }; var labels = new ol.layer.Vector({ source : vectorSource, style : createPointStyleFunction() }); var map = new ol.Map({ target : 'map', layers : [ osm_layer, kml_layer, intersections_layer, labels ], interactions : ol.interaction.defaults({ keyboard : true }) }); var geoJSONformat = new ol.format.GeoJSON(); kml_layer.addEventListener("change", function(event) { map.getView().fitExtent(kml_source.getExtent(), (map.getSize())); }); function updateGMLPolygons() { kml_source.forEachFeature(function(feature) { feature["geoJSON"] = geoJSONformat.writeFeatureObject(feature); feature["area"] = feature.getGeometry().getArea(); var project = feature.get("project"); var name = feature.get("name"); feature["description"] = project + ">" + name; var citygmlHere; if (fromJavaFX) { citygmlHere = fxapp.checkIfCityGMLSAreAvailable(project, name); } feature["available"] = citygmlHere; }); } // The features are not added to a regular vector layer/source, // but to a feature overlay which holds a collection of features. // This collection is passed to the modify and also the draw // interaction, so that both can add or modify features. var featureOverlay = new ol.FeatureOverlay({ style : new ol.style.Style({ fill : new ol.style.Fill({ color : 'rgba(255, 155, 51, 0.5)' }), stroke : new ol.style.Stroke({ color : '#ffcc33', width : 4 }), image : new ol.style.Circle({ radius : 5, fill : new ol.style.Fill({ color : '#ffcc33' }) }) }) }); featureOverlay.setMap(map); var selected_features = featureOverlay.getFeatures(); selected_features.on('add', function(event) { var feature = event.element; feature.on("change", function(event) { displayInfo(); }); }); var modify = new ol.interaction.Modify({ features : featureOverlay.getFeatures(), // the SHIFT key must be pressed to delete vertices, so // that new vertices can be drawn at the same position // of existing vertices deleteCondition : function(event) { return ol.events.condition.shiftKeyOnly(event) && ol.events.condition.singleClick(event); } }); map.addInteraction(modify); draw = new ol.interaction.Draw({ features : featureOverlay.getFeatures(), type : 'Polygon' }); map.addInteraction(draw); var sketch; var fromJavaFX; draw.on('drawstart', function(evt) { fromJavaFX = (typeof fxapp !== 'undefined'); sketch = evt.feature; reset_btn.disabled = false; updateGMLPolygons(); }); var sourceProj = map.getView().getProjection(); function findIntersections() { var sketch_area = sketch.getGeometry().getArea(); var poly1 = geoJSONformat.writeFeatureObject(sketch); var intersection_found = false; intersections.clear(); var i = 0; kml_source.forEachFeature(function(feature) { try { var jsonIntersection = turf.intersect(poly1, feature["geoJSON"]); if (undefined != jsonIntersection) { if (!intersection_found) { dataPanel.append("Intersection found with :
\n"); intersection_found = true; } var intersection = geoJSONformat.readFeature(jsonIntersection); var intersectionArea = intersection.getGeometry().getArea(); var citygml_percentage = Math.round(intersectionArea / feature["area"] * 100); var sketch_percentage = Math.round(intersectionArea / sketch_area * 100); intersections.addFeature(intersection); var description; if (feature["available"]) { description = "" + feature["description"] + ""; } else { description = feature['description']; } dataPanel.append(description + " (" + citygml_percentage + "%"); if (sketch_percentage == 100) { dataPanel.append(", all inside"); } dataPanel.append(")
\n"); } } catch (err) { console.log(feature.get('description') + " - " + err); } i++; }) if (!intersection_found) { dataPanel.append("No intersection found with any CityGML
\n"); } } function downloadRegionFromCityGML(i) { // TODO: Disable all links // TODO: DRY $("html").addClass("wait"); var feature = kml_source.getFeatures()[i]; // Waiting 100ms in order to let the cursor change setTimeout(function() { // var start = new Date().getTime(); fxapp.downloadRegionFromCityGML(sketchAsWKT(), feature.get("project"), feature.get("name"), vectorSource); // var end = new Date().getTime(); // var time = end - start; // console.log('DL Execution time: ' + time); setTimeout(function() { $("html").removeClass("wait"); dataPanel.append("Done
\n"); }, 100); }, 100); } function displayInfo() { // var start = new Date().getTime(); dataPanel.empty(); var geom = /** @type {ol.geom.Polygon} */ (sketch.getGeometry().clone().transform(sourceProj, 'EPSG:4326')); var coordinates = geom.getLinearRing(0).getCoordinates(); var area = Math.abs(wgs84Sphere.geodesicArea(coordinates)); var coords = geom.getLinearRing(0).getCoordinates(); if (!fromJavaFX) { var gsk3_coords = ""; var wgs84_coords = ""; var n = coords.length; for (var i = 0; i < n; i++) { var wgs84_coord = coords[i]; // wgs84_coords += "regionPolygon.add(new Coord(" + wgs84_coord[1] + // "," + wgs84_coord[0] + "));
"; wgs84_coords += "(" + wgs84_coord[1] + "," + wgs84_coord[0] + ")
"; var gsk3_coord = ol.proj.transform(coords[i], ol.proj.get('EPSG:4326'), ol.proj.get('EPSG:31467')) gsk3_coords += "(" + gsk3_coord[0] + "," + gsk3_coord[1] + ")
"; } dataPanel.append("WGS84 Coordinates
"); dataPanel.append(wgs84_coords + "
\n"); dataPanel.append("GSK3 Coordinates
"); dataPanel.append(gsk3_coords + "
\n"); } dataPanel.append("Area" + "
\n"); dataPanel.append((Math.round(area / 1000) / 10).toString() + " ha

\n"); findIntersections(); // var end = new Date().getTime(); // var time = end - start; // console.log('Execution time: ' + time); } draw.on('drawend', function(e) { displayInfo(); if (fromJavaFX) { novafactory_btn.disabled = false; } draw.setActive(false); }); $('#reset').click(function() { try { draw.finishDrawing(); } finally { dataPanel.empty(); $("html").removeClass("wait"); draw.setActive(true); featureOverlay.getFeatures().clear(); intersections.clear(); reset_btn.disabled = true; novafactory_btn.disabled = true; focusOnMap(); } }); novafactory_btn.downloadFinished = function() { // FIXME: Weird
s are inserted between lines dataPanel.append("NovaFactory : DONE
\n"); this.disabled = false; // FIXME: Doesn't stop waiting cursor $("html").removeClass("wait"); } novafactory_btn.updateStatus = function(status) { dataPanel.append("NovaFactory : " + status + "
\n"); } novafactory_btn.selectSaveFile = function(zipFilename) { fxapp.doSomethingWithThisZIP(zipFilename); } $('#nfDownload').click(function() { $("html").addClass("wait"); novafactory_btn.disabled = true; // dataPanel.append("NovaFactory BEGIN
\n"); setTimeout(function() { fxapp.downloadRegion(sketchAsWKT('4326'), novafactory_btn); }, 100); }); function sketchAsWKT(epsgId) { var epsgId = (typeof epsgId === 'undefined') ? '31467' : epsgId; var wktFormat = new ol.format.WKT(); return wktFormat.writeFeature(sketch, { dataProjection : ol.proj.get('EPSG:' + epsgId), featureProjection : ol.proj.get('EPSG:3857') }) } function focusOnMap() { $('#map').focus(); // $('#map').scrollIntoView(); } focusOnMap();