349 lines
11 KiB
PHP
349 lines
11 KiB
PHP
<?php
|
|
// Pandora FMS - http://pandorafms.com
|
|
// ==================================================
|
|
// Copyright (c) 2005-2009 Artica Soluciones Tecnologicas
|
|
// Please see http://pandorafms.org for full contribution list
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License
|
|
// as published by the Free Software Foundation for version 2.
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
function printMap($idDiv, $iniZoom, $numLevelZooms, $latCenter, $lonCenter, $urlMap, $controls = null) {
|
|
$controls = (array)$controls;
|
|
|
|
//require_javascript_file('OpenLayers/OpenLayers');
|
|
?>
|
|
<script type="text/javascript" src="http://dev.openlayers.org/nightly/OpenLayers.js"></script>
|
|
<script type="text/javascript">
|
|
var map;
|
|
|
|
$(document).ready (
|
|
function () {
|
|
map = new OpenLayers.Map ("<?php echo $idDiv; ?>", {
|
|
<?php
|
|
echo "controls: [";
|
|
$first = true;
|
|
foreach ($controls as $control) {
|
|
if (!$first) echo ",";
|
|
$first = false;
|
|
|
|
switch ($control) {
|
|
case 'Navigation':
|
|
echo "new OpenLayers.Control.Navigation()";
|
|
break;
|
|
case 'PanZoomBar':
|
|
echo "new OpenLayers.Control.PanZoomBar()";
|
|
break;
|
|
case 'ScaleLine':
|
|
echo "new OpenLayers.Control.ScaleLine()";
|
|
break;
|
|
}
|
|
}
|
|
echo "],";
|
|
?>
|
|
maxExtent: new OpenLayers.Bounds(-20037508.34,-20037508.34,20037508.34,20037508.34),
|
|
maxResolution: 156543.0399,
|
|
numZoomLevels: <?php echo $numLevelZooms; ?>,
|
|
units: 'm', //metros
|
|
projection: new OpenLayers.Projection("EPSG:900913"),
|
|
displayProjection: new OpenLayers.Projection("EPSG:4326")
|
|
});
|
|
|
|
//Define the map layer
|
|
var baseLayer = new OpenLayers.Layer.OSM("BaseLayer OSM", "<?php echo $urlMap['OSM']; ?>", {numZoomLevels: <?php echo $numLevelZooms; ?>});
|
|
map.addLayer(baseLayer);
|
|
|
|
if( ! map.getCenter() ){
|
|
var lonLat = new OpenLayers.LonLat(<?php echo $lonCenter; ?>, <?php echo $latCenter; ?>)
|
|
.transform(map.displayProjection, map.getProjectionObject());
|
|
map.setCenter (lonLat, <?php echo $iniZoom; ?>);
|
|
}
|
|
}
|
|
);
|
|
|
|
function showHideLayer(name, action) {
|
|
var layer = map.getLayersByName(name);
|
|
|
|
layer[0].setVisibility(action);
|
|
}
|
|
|
|
function addPoint(layerName, pointName, lon, lat) {
|
|
var point = new OpenLayers.Geometry.Point(lon, lat)
|
|
.transform(map.displayProjection, map.getProjectionObject());
|
|
|
|
var layer = map.getLayersByName(layerName);
|
|
layer = layer[0];
|
|
|
|
layer.addFeatures(new OpenLayers.Feature.Vector(point,{nombre: pointName, estado: "ok"}));
|
|
}
|
|
|
|
function addPointExtent(layerName, pointName, lon, lat, icon, width, height) {
|
|
var point = new OpenLayers.Geometry.Point(lon, lat)
|
|
.transform(map.displayProjection, map.getProjectionObject());
|
|
|
|
var layer = map.getLayersByName(layerName);
|
|
layer = layer[0];
|
|
layer.addFeatures(new OpenLayers.Feature.Vector(point,{estado: "ok"}, {fontWeight: "bolder", fontColor: "#00014F", labelYOffset: -height, graphicHeight: width, graphicWidth: height, externalGraphic: icon, label: pointName}));
|
|
}
|
|
|
|
function addPointPath(layerName, lon, lat, color, manual, id) {
|
|
var point = new OpenLayers.Geometry.Point(lon, lat)
|
|
.transform(map.displayProjection, map.getProjectionObject());
|
|
|
|
var layer = map.getLayersByName(layerName);
|
|
layer = layer[0];
|
|
|
|
var pointRadiusNormal = 4;
|
|
var strokeWidth = 2;
|
|
var pointRadiusManual = pointRadiusNormal - (strokeWidth / 2);
|
|
|
|
if (manual) {
|
|
point = new OpenLayers.Feature.Vector(point,{estado: "ok", id: id,
|
|
lanlot: new OpenLayers.LonLat(lon, lat).transform(map.displayProjection, map.getProjectionObject())},
|
|
{fillColor: "#ffffff", pointRadius: pointRadiusManual, stroke: 1, strokeColor: color, strokeWidth: strokeWidth}
|
|
);
|
|
}
|
|
else {
|
|
point = new OpenLayers.Feature.Vector(point,{estado: "ok", id: id,
|
|
lanlot: new OpenLayers.LonLat(lon, lat).transform(map.displayProjection, map.getProjectionObject())},
|
|
{fillColor: color, pointRadius: pointRadiusNormal}
|
|
);
|
|
}
|
|
|
|
layer.addFeatures(point);
|
|
}
|
|
|
|
function addLineString(layerName, points, color) {
|
|
var mapPoints = new Array(points.length);
|
|
var layer = map.getLayersByName(layerName);
|
|
|
|
layer = layer[0];
|
|
|
|
for (var i = 0; i < points.length; i++) {
|
|
mapPoints[i] = points[i].transform(map.displayProjection, map.getProjectionObject());
|
|
}
|
|
|
|
var lineString = new OpenLayers.Feature.Vector(
|
|
new OpenLayers.Geometry.LineString(mapPoints),
|
|
null,
|
|
{ strokeWidth: 2, fillOpacity: 0.2, fillColor: color, strokeColor: color}
|
|
);
|
|
|
|
layer.addFeatures(lineString);
|
|
}
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
function makeLayer($name, $visible = true, $dot = null) {
|
|
if ($dot == null) {
|
|
$dot['url'] = 'images/dot_green.png';
|
|
$dot['width'] = 20; //11;
|
|
$dot['height'] = 20; //11;
|
|
}
|
|
$visible = (bool)$visible;
|
|
?>
|
|
<script type="text/javascript">
|
|
$(document).ready (
|
|
function () {
|
|
//Creamos el estilo
|
|
var style = new OpenLayers.StyleMap(
|
|
{fontColor: "#ff0000",
|
|
labelYOffset: -<?php echo $dot['height']; ?>,
|
|
graphicHeight: <?php echo $dot['height']; ?>,
|
|
graphicWidth: <?php echo $dot['width']; ?>,
|
|
externalGraphic: "<?php echo $dot['url']; ?>", label:"${nombre}"
|
|
}
|
|
);
|
|
|
|
//Creamos la capa de tipo vector
|
|
var layer = new OpenLayers.Layer.Vector(
|
|
'<?php echo $name; ?>', {styleMap: style}
|
|
);
|
|
|
|
layer.setVisibility(<?php echo $visible; ?>);
|
|
map.addLayer(layer);
|
|
|
|
var select = new OpenLayers.Control.SelectFeature(layer);
|
|
map.addControl(select);
|
|
select.activate();
|
|
|
|
layer.events.on({
|
|
"featureselected": function(e) {
|
|
if (e.feature.geometry.CLASS_NAME == "OpenLayers.Geometry.Point") {
|
|
|
|
var feature = e.feature;
|
|
var featureData = feature.data;
|
|
var lanlot = featureData.lanlot;
|
|
|
|
var popup;
|
|
|
|
popup = new OpenLayers.Popup.FramedCloud('cloud00',
|
|
lanlot,
|
|
null,
|
|
'<div class="cloudContent' + featureData.id + '" style="text-align: center;"><img src="images/spinner.gif" /></div>',
|
|
null,
|
|
true,
|
|
function () { popup.destroy(); });
|
|
feature.popup = popup;
|
|
map.addPopup(popup);
|
|
|
|
jQuery.ajax ({
|
|
data: "page=operation/gis_maps/ajax&opt=point_info&id=" + featureData.id,
|
|
type: "GET",
|
|
dataType: 'json',
|
|
url: "ajax.php",
|
|
timeout: 10000,
|
|
success: function (data) {
|
|
if (data.correct) {
|
|
$('.cloudContent' + featureData.id).css('text-align', 'left');
|
|
$('.cloudContent' + featureData.id).html(data.content);
|
|
popup.updateSize();
|
|
}
|
|
}
|
|
});
|
|
}
|
|
}
|
|
});
|
|
}
|
|
);
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
function addPoint($layerName, $pointName, $lat, $lon, $icon = null, $width = 20, $height = 20) {
|
|
?>
|
|
<script type="text/javascript">
|
|
$(document).ready (
|
|
function () {
|
|
<?php
|
|
if ($icon != null) {
|
|
?>
|
|
addPointExtent('<?php echo $layerName; ?>',
|
|
'<?php echo $pointName; ?>', <?php echo $lon; ?>,
|
|
<?php echo $lat; ?>, '<?php echo $icon; ?>', <?php echo $width; ?>, <?php echo $height?>);
|
|
<?php
|
|
}
|
|
else {
|
|
?>
|
|
addPoint('<?php echo $layerName; ?>',
|
|
'<?php echo $pointName; ?>', <?php echo $lon; ?>, <?php echo $lat; ?>);
|
|
<?php
|
|
}
|
|
?>
|
|
}
|
|
);
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
function addPointPath($layerName, $lat, $lon, $color, $manual = 1, $id) {
|
|
?>
|
|
<script type="text/javascript">
|
|
$(document).ready (
|
|
function () {
|
|
addPointPath('<?php echo $layerName; ?>', <?php echo $lon; ?>, <?php echo $lat; ?>, '<?php echo $color; ?>', <?php echo $manual; ?>, <?php echo $id; ?>);
|
|
}
|
|
);
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
function getMaps() {
|
|
return get_db_all_rows_in_table ('tgis_map', 'map_name');
|
|
}
|
|
|
|
function getMapConf($idMap) {
|
|
$confsEncode = get_db_all_rows_sql('SELECT * FROM tgis_map_connection WHERE tgis_map_id_tgis_map = ' . $idMap);
|
|
|
|
$confsDecode = array();
|
|
|
|
if ($confsEncode !== false) {
|
|
foreach ($confsEncode as $confEncode) {
|
|
$temp = json_decode($confEncode['conection_data'], true);
|
|
|
|
$confsDecode[$temp['type']][] = $temp['content'];
|
|
}
|
|
}
|
|
|
|
return $confsDecode;
|
|
}
|
|
|
|
function getLayers($idMap) {
|
|
$layers = get_db_all_rows_sql('SELECT * FROM tgis_map_layer WHERE tgis_map_id_tgis_map = ' . $idMap);
|
|
|
|
return $layers;
|
|
}
|
|
|
|
function get_agent_last_coords($idAgent) {
|
|
$coords = get_db_row_sql("SELECT last_latitude, last_longitude, last_altitude FROM tagente WHERE id_agente = " . $idAgent);
|
|
|
|
return $coords;
|
|
}
|
|
|
|
function get_agent_icon_map($idAgent, $state = false) {
|
|
$row = get_db_row_sql('SELECT id_grupo, icon_path FROM tagente WHERE id_agente = ' . $idAgent);
|
|
|
|
if ($row['icon_path'] === null) {
|
|
$iconGroup = "images/" . get_group_icon($row['id_grupo']) . ".png";
|
|
return $iconGroup;
|
|
}
|
|
else {
|
|
$icon = "images/gis_map/icons/" . $row['icon_path'];
|
|
if (!$state)
|
|
return $icon . ".png";
|
|
else
|
|
return $icon . "_" . $state . ".png";
|
|
}
|
|
}
|
|
|
|
function addPath($layerName, $idAgent) {
|
|
$listPoints = get_db_all_rows_sql('SELECT * FROM tgis_data WHERE tagente_id_agente = ' . $idAgent . ' ORDER BY end_timestamp ASC');
|
|
|
|
$listPoints = array(
|
|
array('id_tgis_data' => 0, 'longitude' => -3.709, 'latitude' => 40.422, 'altitude' => 0, 'manual_placemen' => 1),
|
|
array('id_tgis_data' => 1, 'longitude' => -3.710, 'latitude' => 40.420, 'altitude' => 0, 'manual_placemen' => 0),
|
|
array('id_tgis_data' => 2, 'longitude' => -3.711, 'latitude' => 40.420, 'altitude' => 0, 'manual_placemen' => 1),
|
|
array('id_tgis_data' => 3, 'longitude' => -3.712, 'latitude' => 40.422, 'altitude' => 0, 'manual_placemen' => 0),
|
|
array('id_tgis_data' => 4, 'longitude' => -3.708187, 'latitude' => 40.42056, 'altitude' => 0, 'manual_placemen' => 0)
|
|
);
|
|
|
|
$avaliableColors = array("#ff0000", "#00ff00", "#0000ff", "#000000");
|
|
|
|
$color = $avaliableColors[array_rand($avaliableColors)];
|
|
?>
|
|
<script type="text/javascript">
|
|
$(document).ready (
|
|
function () {
|
|
<?php
|
|
if ($listPoints != false) {
|
|
$listPoints = (array)$listPoints;
|
|
$first = true;
|
|
|
|
echo "var points = [";
|
|
foreach($listPoints as $point) {
|
|
if (!$first) echo ",";
|
|
$first =false;
|
|
echo "new OpenLayers.Geometry.Point(" . $point['longitude'] . ", " . $point['latitude'] . ")";
|
|
}
|
|
echo "];";
|
|
}
|
|
?>
|
|
|
|
addLineString('<?php echo $layerName; ?>', points, '<?php echo $color; ?>');
|
|
}
|
|
);
|
|
</script>
|
|
<?php
|
|
if ($listPoints != false) {
|
|
foreach($listPoints as $point) {
|
|
if (end($listPoints) != $point)
|
|
addPointPath($layerName, $point['latitude'], $point['longitude'], $color, (int)$point['manual_placemen'], $point['id_tgis_data']);
|
|
}
|
|
}
|
|
}
|
|
?>
|