使用图形管理器覆盖自定义叠加图像 [英] Using Drawing Manager over custom overlay image

查看:108
本文介绍了使用图形管理器覆盖自定义叠加图像的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我希望在叠加图片的顶部使用图片管理器,我只能通过切换div顺序来使用图片管理器,但是我希望所有的功能都放在同一张地图上,如果可能的话,我们将为您提供任何帮助。



这是我的代码:

 <!DOCTYPE html> 
< html>
< head>
< meta name =viewportcontent =initial-scale = 1.0,user-scalable = no>
< meta charset =utf-8>
< meta name =descriptioncontent =CentroEstratégicode VigilanciaAéreayMarítimaHonduras>
< meta name =authorcontent =1RDS-PAMT>
< title> AIR MAP HND< / title>
< link rel =快捷图标href =../ images / cevamicon.ico>

< style>
html,body,#map-canvas,#map {
height:99.9%;
margin:0px;
padding:0px;
}

#panel {
position:absolute;
top:5px;
剩下:50%;
margin-left:-180px;
font-family:Arial,sans-serif;
z-index:5;
background-color:#fff;
padding:5px;
border:1px solid#999;
}

#drawPanel {
position:absolute;
width:200px;
font-family:Arial,sans-serif;
font-size:13px;
float:left;
margin-top:5px;
margin-left:200px;
z-index:5;
}

#color-palette {
clear:both;
}

.color-button {
width:20px;
height:20px;
font-size:0;
margin:2px;
float:left;
光标:指针;
}

#delete-button {
margin-top:0px;
margin-left:22px;
}
< / style>
< script type =text / javascriptsrc =https://maps.googleapis.com/maps/api/js?libraries=drawing>< / script>
< script>

//这增加了一个UI控件,允许用户从地图上移除地面覆盖层。
//并构建调色板并删除选定的形状和标记。

var airOverlay;
var mapp;
var drawingManager;
var selectedShape;
var colors = ['#1E90FF','#FF0000','#32CD32','#FFA500','#000000','#FFFF00'];
var selectedColor;
var colorButtons = {};

function clearSelection(){
if(selectedShape){
if(selectedShape.type!=='marker'){
selectedShape.setEditable(false);
}

selectedShape = null;



function setSelection(shape){
if(shape.type!=='marker'){
clearSelection();
shape.setEditable(true);
selectColor(shape.get('fillColor')|| shape.get('strokeColor'));
}

selectedShape = shape;


函数deleteSelectedShape(){
if(selectedShape){
selectedShape.setMap(null);
}
}

函数selectColor(color){
selectedColor = color;
for(var i = 0; i< colors.length; ++ i){
var currColor = colors [i];
colorButtons [currColor] .style.border = currColor == color? '2px solid#789':'2px solid #fff';
}

//从绘图管理器中检索当前选项,并根据需要替换
//笔划或填充颜色。
var polylineOptions = drawingManager.get('polylineOptions');
polylineOptions.strokeColor = color;
drawingManager.set('polylineOptions',polylineOptions);

var rectangleOptions = drawingManager.get('rectangleOptions');
rectangleOptions.fillColor = color;
drawingManager.set('rectangleOptions',rectangleOptions);

var circleOptions = drawingManager.get('circleOptions');
circleOptions.fillColor = color;
drawingManager.set('circleOptions',circleOptions);

var polygonOptions = drawingManager.get('polygonOptions');
polygonOptions.fillColor = color;
drawingManager.set('polygonOptions',polygonOptions);


函数setSelectedShapeColor(color){
if(selectedShape){
if(selectedShape.type == google.maps.drawing.OverlayType.POLYLINE){
selectedShape.set('strokeColor',color);
} else {
selectedShape.set('fillColor',color);




函数makeColorButton(color){
var button = document.createElement('span');
button.className ='color-button';
button.style.backgroundColor = color;
google.maps.event.addDomListener(button,'click',function(){
selectColor(color);
setSelectedShapeColor(color);
});

返回按钮;
}

函数buildColorPalette(){
var colorPalette = document.getElementById('color-palette');
for(var i = 0; i< colors.length; ++ i){
var currColor = colors [i];
var colorButton = makeColorButton(currColor);
colorPalette.appendChild(colorButton);
colorButtons [currColor] = colorButton;
}
selectColor(colors [0]);


函数初始化(){

var洪都拉斯=新google.maps.LatLng(14.888522,-87.150924);
var imageBounds = new google.maps.LatLngBounds(
new google.maps.LatLng(12.850803,-89.547900),
new google.maps.LatLng(16.668892,-83.002123));
$ b $ var mapOptions = {
zoom:8,
center:洪都拉斯,
disableDefaultUI:true,
mapTypeControl:true,
zoomControl:真
};

mapp = new google.maps.Map(document.getElementById('map-canvas'),
mapOptions);

airOverlay = new google.maps.GroundOverlay('../ overlayImg / airmap.png',imageBounds);

addOverlay();

var map = new google.maps.Map(document.getElementById('map'),
mapOptions);

var polyOptions = {
strokeWeight:0,
fillOpacity:0.45,
editable:true,
draggable:true
};

//创建附加到地图上的绘图管理器,允许用户绘制
//标记,线条和形状。
drawingManager = new google.maps.drawing.DrawingManager({
drawingMode:google.maps.drawing.OverlayType.POLYGON,
markerOptions:{
draggable:true,
$,

polylineOptions:{
editable:true,
draggable:true
},

rectangleOptions:polyOptions,
circleOptions:polyOptions,
polygonOptions:polyOptions,
map:map
});

google.maps.event.addListener(drawingManager,'overlaycomplete',function(e){
var newShape = e.overlay;

newShape.type = e.type;

if(e.type!== google.maps.drawing.OverlayType.MARKER){
//绘制形状后切换回非绘图模式
drawingManager.setDrawingMode(null);

//添加一个事件侦听器,用于在用户
//将鼠标拖拽到其上时选择新绘制的形状
google .maps.event.addListener(newShape,'click',function(e){
if(e.vertex!== undefined){
if(newShape.type === google.maps.drawing .OverlayType.POLYGON){
var path = newShape.getPaths()。getAt(e.path);
path.removeAt(e.vertex);
如果(path.length < 3){
newShape.setMap(null);


if(newShape.type === google.maps.drawing.OverlayType.POLYLINE){
var path = newShape.getPath();
path.removeAt(e.vertex);
if(path.length< 2){
newShape.setMap(null);
}
}
}
setSelection(newShape);
});
setSelection(newShape);
} else {
google.maps.event.addListener(newShape,'click',function(e){
setSelection(newShape);
});
setSelection(newShape);
}
});

//当绘图模式改变或单击
//地图时清除当前选择。
google.maps.event.addListener(drawingManager,'drawingmode_changed',clearSelection);
google.maps.event.addListener(地图,'click',clearSelection);
google.maps.event.addDomListener(document.getElementById('delete-button'),'click',deleteSelectedShape);

buildColorPalette();



function addOverlay(){
airOverlay.setMap(mapp);
}

// [START region_removal]
function removeOverlay(){
airOverlay.setMap(null);

// [END region_removal]

函数setOpacity(){
var opacityStr = document.getElementById('opacity')。value;
var opacity = parseFloat(opacityStr);
airOverlay.setOpacity(opacity);
}

google.maps.event.addDomListener(window,'load',initialize);

< / script>

< / head>

< body>

< div id =drawPanel>
< div id =color-palette>< / div>
< div>
< button id =delete-button> BorrarSelección< / button>
< / div>
< / div>
< div id =panel>
< input onclick =removeOverlay(); type = button value =去除覆盖>
< input onclick =addOverlay(); type = button value =Restaurar overlay>
< input type =textid =opacityvalue =0.5>< / input>
< input type =buttonvalue =Transparenciaonclick =setOpacity();>< / input>
< / div>
< div id =map-canvas>< / div>
< div id =map>< / div>
< / body>

< / html>


解决方案

您需要删除第二张地图,和绘图管理器到相同的地图。



证明概念小提琴



工作代码片段:

// This add一个UI控件,允许用户从地图上删除地面覆盖层.//并构建调色板并删除选定的形状和标记。var airPlayer; var mapp; var drawingManager; var selectedShape; var colors = ['#1E90FF',' FF0000','#32CD32','#FFA500','#000000','#FFFF00']; var selectedColor; var colorButtons = {}; function clearSelection(){if(selectedShape){if(selectedShape.type!= ='marker'){selectedShape.setEditable(false); } selectedShape = null; }} function setSelection(shape){if(shape.type!=='marker'){clearSelection(); shape.setEditable(真); selectColor(shape.get('fillColor')|| shape.get('strokeColor')); } selectedShape = shape;} function deleteSelectedShape(){if(selectedShape){selectedShape.setMap(null); }} function selectColor(color){selectedColor = color; for(var i = 0; i< colors.length; ++ i){var currColor = colors [i]; colorButtons [currColor] .style.border = currColor == color? '2px solid#789':'2px solid #fff'; } //从绘图管理器中检索当前选项并根据需要替换//笔划或填充颜色。 var polylineOptions = drawingManager.get('polylineOptions'); polylineOptions.strokeColor = color; drawingManager.set('polylineOptions',polylineOptions); var rectangleOptions = drawingManager.get('rectangleOptions'); rectangleOptions.fillColor = color; drawingManager.set('rectangleOptions',rectangleOptions); var circleOptions = drawingManager.get('circleOptions'); circleOptions.fillColor = color; drawingManager.set('circleOptions',circleOptions); var polygonOptions = drawingManager.get('polygonOptions'); polygonOptions.fillColor = color; drawingManager.set('polygonOptions',polygonOptions);} function setSelectedShapeColor(color){if(selectedShape){if(selectedShape.type == google.maps.drawing.OverlayType.POLYLINE){selectedShape.set('strokeColor',color ); } else {selectedShape.set('fillColor',color); }}}函数makeColorButton(color){var button = document.createElement('span'); button.className ='color-button'; button.style.backgroundColor = color; google.maps.event.addDomListener(button,'click',function(){selectColor(color); setSelectedShapeColor(color);});返回按钮;}函数buildColorPalette(){var colorPalette = document.getElementById('color-palette'); for(var i = 0; i< colors.length; ++ i){var currColor = colors [i]; var colorButton = makeColorButton(currColor); colorPalette.appendChild(colorButton); colorButtons [currColor] = colorButton; } selectColor(colors [0]);} function initialize(){var newark = new google.maps.LatLng(40.740,-74.18);} var imageBounds = new google.maps.LatLngBounds(new google.maps.LatLng(40.712216,-74.22655),new google.maps.LatLng(40.773941,-74.12544)); var mapOptions = {zoom:13,center:newark}; airOverlay = new google.maps.GroundOverlay('https://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg',imageBounds); // historicalOverlay.setMap(map); / * var洪都拉斯=新google.maps.LatLng(14.888522,-87.150924); var imageBounds = new google.maps.LatLngBounds(new google.maps.LatLng(12.850803,-89.547900),new google.maps.LatLng(16.668892,-83.002123)); var mapOptions = {zoom:8,center:honduras,disableDefaultUI:true,mapTypeControl:true,zoomControl:true}; mapp = new google.maps.Map(document.getElementById('map-canvas'),mapOptions); airOverlay = new google.maps.GroundOverlay('../ overlayImg / airmap.png',imageBounds); * / mapp = new google.maps.Map(document.getElementById('map-canvas'),mapOptions); addOverlay(); var polyOptions = {strokeWeight:0,fillOpacity:0.45,editable:true,draggable:true}; //创建一个附加到地图的绘图管理器,允许用户绘制标记,线条和形状。 drawingManager = new google.maps.drawing.DrawingManager({drawingMode:google.maps.drawing.OverlayType.POLYGON,markerOptions:{draggable:true},polylineOptions:{editable:true,dragggable:true},rectangleOptions:polyOptions,circleOptions: polyOptions,polygonOptions:polyOptions,map:mapp}); google.maps.event.addListener(drawingManager,'overlaycomplete',function(e){var newShape = e.overlay; newShape.type = e.type; if(e.type!== google.maps.drawing.OverlayType。 MARKER){//绘制形状后,切换回非绘图模式drawingManager.setDrawingMode(null); //添加一个事件监听器,当用户将鼠标移动到其上时,选择新绘制的形状google.maps .event.addListener(newShape,'click',function(e){if(e.vertex!== undefined){if(newShape.type === google.maps.drawing.OverlayType.POLYGON){var path = newShape .getPaths()。getAt(e.path); path.removeAt(e.vertex); if(path.length< 3){newShape.setMap(null);}} if(newShape.type === google。 maps.drawing.OverlayType.POLYLINE) {var path = newShape.getPath(); path.removeAt(e.vertex); if(path.length< 2){newShape.setMap(null); }}} setSelection(newShape); });为setSelection(newShape); } else {google.maps.event.addListener(newShape,'click',function(e){setSelection(newShape);});为setSelection(newShape); }}); //当绘图模式改变或者单击//地图时清除当前选择。 google.maps.event.addListener(drawingManager,'drawingmode_changed',clearSelection); google.maps.event.addListener(mapp,'click',clearSelection); google.maps.event.addDomListener(document.getElementById('delete-button'),'click',deleteSelectedShape); ()函数addOverlay(){airOverlay.setMap(mapp);} // [START region_removal] function removeOverlay(){airOverlay.setMap(null);} // [END region_removal] function setOpacity(){var opacityStr = document.getElementById('opacity')。value; var opacity = parseFloat(opacityStr); airOverlay.setOpacity(opacity);} google.maps.event.addDomListener(window,'load',initialize);

  html,body,#map-canvas,#map {height:99.9%; margin:0px; padding:0px; } #panel {position:absolute; top:5px;剩下:50%; margin-left:-180px; font-family:Arial,sans-serif; z-index:5; background-color:#fff;填充:5px;边界:1px固体#999; } #drawPanel {position:absolute;宽度:200px; font-family:Arial,sans-serif; font-size:13px;向左飘浮; margin-top:5px; margin-left:200px; z-index:5; }#color-palette {clear:both; } .color-button {width:20px; height:20px; font-size:0; margin:2px;向左飘浮;光标:指针; }#delete-button {margin-top:0px; margin-left:22px; }  

< script src =https:// maps .googleapis.com / maps / api / js?libraries = geometry,drawing& ext = .js>< / script>< div id =drawPanel> < div id =color-palette>< / div> < DIV> < button id =delete-button> BorrarSelección< / button> < / div>< / div>< div id =panel> < input onclick =removeOverlay(); type = button value =去除覆盖> < input onclick =addOverlay(); type = button value =Restaurar overlay> < input type =textid =opacityvalue =0.5>< / input> < input type =buttonvalue =Transparenciaonclick =setOpacity();>< / input>< / div>< div id =map-canvas>< / div> < div id =map>< / div>

I would like use Drawing Manager on top of an overlay image so far I can use only one by switching the div order but I want all functions in one map, if possible, any help will be appreciated.

here is my code:

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no">
    <meta charset="utf-8">
    <meta name="description" content="Centro Estratégico de Vigilancia Aérea y Marítima Honduras">
    <meta name="author" content="1RDS-PAMT">
    <title>AIR MAP HND</title>
    <link rel="shortcut icon" href="../images/cevamicon.ico">

    <style>
      html, body, #map-canvas, #map {   
        height: 99.9%;
        margin: 0px;
        padding: 0px;
      }

      #panel {
        position: absolute;
        top: 5px;
        left: 50%;
        margin-left: -180px;
        font-family: Arial, sans-serif;
        z-index: 5;
        background-color: #fff;
        padding: 5px;
        border: 1px solid #999;
      }

     #drawPanel {
        position: absolute;
        width: 200px;
        font-family: Arial, sans-serif;
        font-size: 13px;
        float: left;
        margin-top: 5px;
        margin-left: 200px;
        z-index: 5;
     }

     #color-palette {
        clear: both;
     }

     .color-button {
        width: 20px;
        height: 20px;
        font-size: 0;
        margin: 2px;
        float: left;
        cursor: pointer;
     }

     #delete-button {
        margin-top: 0px;
        margin-left: 22px;
     }
    </style>
    <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?libraries=drawing"></script>
    <script>

// This adds a UI control allowing users to remove the ground overlay from the map.
// and build color palette and delete selected shapes and markers.

        var airOverlay;
        var mapp;
        var drawingManager;
        var selectedShape;
        var colors = ['#1E90FF', '#FF0000', '#32CD32', '#FFA500', '#000000', '#FFFF00'];
        var selectedColor;
        var colorButtons = {};

        function clearSelection () {
            if (selectedShape) {
                if (selectedShape.type !== 'marker') {
                    selectedShape.setEditable(false);
                }

                selectedShape = null;
            }
        }

        function setSelection (shape) {
            if (shape.type !== 'marker') {
                clearSelection();
                shape.setEditable(true);
                selectColor(shape.get('fillColor') || shape.get('strokeColor'));
            }

            selectedShape = shape;
        }

        function deleteSelectedShape () {
            if (selectedShape) {
                selectedShape.setMap(null);
            }
        }

        function selectColor (color) {
            selectedColor = color;
            for (var i = 0; i < colors.length; ++i) {
                var currColor = colors[i];
                colorButtons[currColor].style.border = currColor == color ? '2px solid #789' : '2px solid #fff';
            }

        // Retrieves the current options from the drawing manager and replaces the
        // stroke or fill color as appropriate.
            var polylineOptions = drawingManager.get('polylineOptions');
            polylineOptions.strokeColor = color;
            drawingManager.set('polylineOptions', polylineOptions);

            var rectangleOptions = drawingManager.get('rectangleOptions');
            rectangleOptions.fillColor = color;
            drawingManager.set('rectangleOptions', rectangleOptions);

            var circleOptions = drawingManager.get('circleOptions');
            circleOptions.fillColor = color;
            drawingManager.set('circleOptions', circleOptions);

            var polygonOptions = drawingManager.get('polygonOptions');
            polygonOptions.fillColor = color;
            drawingManager.set('polygonOptions', polygonOptions);
        }

        function setSelectedShapeColor (color) {
            if (selectedShape) {
                if (selectedShape.type == google.maps.drawing.OverlayType.POLYLINE) {
                    selectedShape.set('strokeColor', color);
                } else {
                    selectedShape.set('fillColor', color);
                }
            }
        }

        function makeColorButton (color) {
            var button = document.createElement('span');
            button.className = 'color-button';
            button.style.backgroundColor = color;
            google.maps.event.addDomListener(button, 'click', function () {
                selectColor(color);
                setSelectedShapeColor(color);
            });

            return button;
        }

        function buildColorPalette () {
            var colorPalette = document.getElementById('color-palette');
            for (var i = 0; i < colors.length; ++i) {
                var currColor = colors[i];
                var colorButton = makeColorButton(currColor);
                colorPalette.appendChild(colorButton);
                colorButtons[currColor] = colorButton;
            }
            selectColor(colors[0]);
        }

        function initialize() {

            var honduras = new google.maps.LatLng(14.888522, -87.150924);
            var imageBounds = new google.maps.LatLngBounds(
                new google.maps.LatLng(12.850803, -89.547900),
                new google.maps.LatLng(16.668892, -83.002123));

            var mapOptions = {
                zoom: 8,
                center: honduras,
                disableDefaultUI: true,
                mapTypeControl: true,
                zoomControl: true
            };

            mapp = new google.maps.Map(document.getElementById('map-canvas'), 
                mapOptions);

            airOverlay = new google.maps.GroundOverlay('../overlayImg/airmap.png', imageBounds);

            addOverlay();

            var map = new google.maps.Map(document.getElementById('map'),
                mapOptions);

            var polyOptions = {
                strokeWeight: 0,
                fillOpacity: 0.45,
                editable: true,
                draggable: true
            };

        // Creates a drawing manager attached to the map that allows the user to draw
        // markers, lines, and shapes.
            drawingManager = new google.maps.drawing.DrawingManager({
                drawingMode: google.maps.drawing.OverlayType.POLYGON,
                markerOptions: {
                    draggable: true,
                },

                polylineOptions: {
                    editable: true,
                    draggable: true
                },

                rectangleOptions: polyOptions,
                circleOptions: polyOptions,
                polygonOptions: polyOptions,
                map: map
            });

            google.maps.event.addListener(drawingManager, 'overlaycomplete', function (e) {
                var newShape = e.overlay;

                newShape.type = e.type;

                if (e.type !== google.maps.drawing.OverlayType.MARKER) {
                    // Switch back to non-drawing mode after drawing a shape.
                    drawingManager.setDrawingMode(null);

                    // Add an event listener that selects the newly-drawn shape when the user
                    // mouses down on it.
                    google.maps.event.addListener(newShape, 'click', function (e) {
                        if (e.vertex !== undefined) {
                            if (newShape.type === google.maps.drawing.OverlayType.POLYGON) {
                                var path = newShape.getPaths().getAt(e.path);
                                path.removeAt(e.vertex);
                                if (path.length < 3) {
                                    newShape.setMap(null);
                                }
                            }
                            if (newShape.type === google.maps.drawing.OverlayType.POLYLINE) {
                                var path = newShape.getPath();
                                path.removeAt(e.vertex);
                                if (path.length < 2) {
                                    newShape.setMap(null);
                                }
                            }
                        }
                        setSelection(newShape);
                    });
                        setSelection(newShape);
                } else {
                    google.maps.event.addListener(newShape, 'click', function (e) {
                        setSelection(newShape);
                    });
                    setSelection(newShape);
                }
            });

            // Clear the current selection when the drawing mode is changed, or when the
            // map is clicked.
            google.maps.event.addListener(drawingManager, 'drawingmode_changed', clearSelection);
            google.maps.event.addListener(map, 'click', clearSelection);
            google.maps.event.addDomListener(document.getElementById('delete-button'), 'click', deleteSelectedShape);

            buildColorPalette();

        }

        function addOverlay() {
            airOverlay.setMap(mapp);
        }

        // [START region_removal]
        function removeOverlay() {
            airOverlay.setMap(null);
        }
        // [END region_removal]

        function setOpacity() {
            var opacityStr = document.getElementById('opacity').value;
            var opacity = parseFloat(opacityStr);
            airOverlay.setOpacity(opacity);
        }

        google.maps.event.addDomListener(window, 'load', initialize);

    </script>

</head>

<body>

    <div id="drawPanel">
            <div id="color-palette"></div>
            <div>
                <button id="delete-button">Borrar Selección</button>
            </div>
        </div>
        <div id="panel">
            <input onclick="removeOverlay();" type=button value="Remover overlay">
            <input onclick="addOverlay();" type=button value="Restaurar overlay">
            <input type="text" id="opacity" value="0.5"></input>
            <input type="button" value="Transparencia" onclick="setOpacity();"></input>
        </div>
        <div id="map-canvas"></div>
        <div id="map"></div>
    </body>

</html>

解决方案

You need to remove the second map, add the overlay and the drawing manager to the same map.

proof of concept fiddle

working code snippet:

// This adds a UI control allowing users to remove the ground overlay from the map.
// and build color palette and delete selected shapes and markers.

var airOverlay;
var mapp;
var drawingManager;
var selectedShape;
var colors = ['#1E90FF', '#FF0000', '#32CD32', '#FFA500', '#000000', '#FFFF00'];
var selectedColor;
var colorButtons = {};

function clearSelection() {
    if (selectedShape) {
        if (selectedShape.type !== 'marker') {
            selectedShape.setEditable(false);
        }

        selectedShape = null;
    }
}

function setSelection(shape) {
    if (shape.type !== 'marker') {
        clearSelection();
        shape.setEditable(true);
        selectColor(shape.get('fillColor') || shape.get('strokeColor'));
    }

    selectedShape = shape;
}

function deleteSelectedShape() {
    if (selectedShape) {
        selectedShape.setMap(null);
    }
}

function selectColor(color) {
    selectedColor = color;
    for (var i = 0; i < colors.length; ++i) {
        var currColor = colors[i];
        colorButtons[currColor].style.border = currColor == color ? '2px solid #789' : '2px solid #fff';
    }

    // Retrieves the current options from the drawing manager and replaces the
    // stroke or fill color as appropriate.
    var polylineOptions = drawingManager.get('polylineOptions');
    polylineOptions.strokeColor = color;
    drawingManager.set('polylineOptions', polylineOptions);

    var rectangleOptions = drawingManager.get('rectangleOptions');
    rectangleOptions.fillColor = color;
    drawingManager.set('rectangleOptions', rectangleOptions);

    var circleOptions = drawingManager.get('circleOptions');
    circleOptions.fillColor = color;
    drawingManager.set('circleOptions', circleOptions);

    var polygonOptions = drawingManager.get('polygonOptions');
    polygonOptions.fillColor = color;
    drawingManager.set('polygonOptions', polygonOptions);
}

function setSelectedShapeColor(color) {
    if (selectedShape) {
        if (selectedShape.type == google.maps.drawing.OverlayType.POLYLINE) {
            selectedShape.set('strokeColor', color);
        } else {
            selectedShape.set('fillColor', color);
        }
    }
}

function makeColorButton(color) {
    var button = document.createElement('span');
    button.className = 'color-button';
    button.style.backgroundColor = color;
    google.maps.event.addDomListener(button, 'click', function () {
        selectColor(color);
        setSelectedShapeColor(color);
    });

    return button;
}

function buildColorPalette() {
    var colorPalette = document.getElementById('color-palette');
    for (var i = 0; i < colors.length; ++i) {
        var currColor = colors[i];
        var colorButton = makeColorButton(currColor);
        colorPalette.appendChild(colorButton);
        colorButtons[currColor] = colorButton;
    }
    selectColor(colors[0]);
}

function initialize() {
    var newark = new google.maps.LatLng(40.740, -74.18);
    var imageBounds = new google.maps.LatLngBounds(
    new google.maps.LatLng(40.712216, -74.22655),
    new google.maps.LatLng(40.773941, -74.12544));

    var mapOptions = {
        zoom: 13,
        center: newark
    };

    airOverlay = new google.maps.GroundOverlay(
        'https://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg',
    imageBounds);
    // historicalOverlay.setMap(map);
    /*
            var honduras = new google.maps.LatLng(14.888522, -87.150924);
            var imageBounds = new google.maps.LatLngBounds(
                new google.maps.LatLng(12.850803, -89.547900),
                new google.maps.LatLng(16.668892, -83.002123));

            var mapOptions = {
                zoom: 8,
                center: honduras,
                disableDefaultUI: true,
                mapTypeControl: true,
                zoomControl: true
            };

            mapp = new google.maps.Map(document.getElementById('map-canvas'), 
                mapOptions);

            airOverlay = new google.maps.GroundOverlay('../overlayImg/airmap.png', imageBounds);
*/

    mapp = new google.maps.Map(document.getElementById('map-canvas'),
    mapOptions);
    
    addOverlay();
    
    var polyOptions = {
        strokeWeight: 0,
        fillOpacity: 0.45,
        editable: true,
        draggable: true
    };

    // Creates a drawing manager attached to the map that allows the user to draw
    // markers, lines, and shapes.
    drawingManager = new google.maps.drawing.DrawingManager({
        drawingMode: google.maps.drawing.OverlayType.POLYGON,
        markerOptions: {
            draggable: true
        },

        polylineOptions: {
            editable: true,
            draggable: true
        },

        rectangleOptions: polyOptions,
        circleOptions: polyOptions,
        polygonOptions: polyOptions,
        map: mapp
    });

    google.maps.event.addListener(drawingManager, 'overlaycomplete', function (e) {
        var newShape = e.overlay;

        newShape.type = e.type;

        if (e.type !== google.maps.drawing.OverlayType.MARKER) {
            // Switch back to non-drawing mode after drawing a shape.
            drawingManager.setDrawingMode(null);

            // Add an event listener that selects the newly-drawn shape when the user
            // mouses down on it.
            google.maps.event.addListener(newShape, 'click', function (e) {
                if (e.vertex !== undefined) {
                    if (newShape.type === google.maps.drawing.OverlayType.POLYGON) {
                        var path = newShape.getPaths().getAt(e.path);
                        path.removeAt(e.vertex);
                        if (path.length < 3) {
                            newShape.setMap(null);
                        }
                    }
                    if (newShape.type === google.maps.drawing.OverlayType.POLYLINE) {
                        var path = newShape.getPath();
                        path.removeAt(e.vertex);
                        if (path.length < 2) {
                            newShape.setMap(null);
                        }
                    }
                }
                setSelection(newShape);
            });
            setSelection(newShape);
        } else {
            google.maps.event.addListener(newShape, 'click', function (e) {
                setSelection(newShape);
            });
            setSelection(newShape);
        }
    });

    // Clear the current selection when the drawing mode is changed, or when the
    // map is clicked.
    google.maps.event.addListener(drawingManager, 'drawingmode_changed', clearSelection);
    google.maps.event.addListener(mapp, 'click', clearSelection);
    google.maps.event.addDomListener(document.getElementById('delete-button'), 'click', deleteSelectedShape);

    buildColorPalette();

}

function addOverlay() {
    airOverlay.setMap(mapp);
}

// [START region_removal]
function removeOverlay() {
    airOverlay.setMap(null);
}
// [END region_removal]

function setOpacity() {
    var opacityStr = document.getElementById('opacity').value;
    var opacity = parseFloat(opacityStr);
    airOverlay.setOpacity(opacity);
}

google.maps.event.addDomListener(window, 'load', initialize);

html, body, #map-canvas, #map {
          height: 99.9%;
          margin: 0px;
          padding: 0px;
      }
      #panel {
          position: absolute;
          top: 5px;
          left: 50%;
          margin-left: -180px;
          font-family: Arial, sans-serif;
          z-index: 5;
          background-color: #fff;
          padding: 5px;
          border: 1px solid #999;
      }
      #drawPanel {
          position: absolute;
          width: 200px;
          font-family: Arial, sans-serif;
          font-size: 13px;
          float: left;
          margin-top: 5px;
          margin-left: 200px;
          z-index: 5;
      }
      #color-palette {
          clear: both;
      }
      .color-button {
          width: 20px;
          height: 20px;
          font-size: 0;
          margin: 2px;
          float: left;
          cursor: pointer;
      }
      #delete-button {
          margin-top: 0px;
          margin-left: 22px;
      }

<script src="https://maps.googleapis.com/maps/api/js?libraries=geometry,drawing&ext=.js"></script>
<div id="drawPanel">
    <div id="color-palette"></div>
    <div>
        <button id="delete-button">Borrar Selección</button>
    </div>
</div>
<div id="panel">
    <input onclick="removeOverlay();" type=button value="Remover overlay">
    <input onclick="addOverlay();" type=button value="Restaurar overlay">
    <input type="text" id="opacity" value="0.5"></input>
    <input type="button" value="Transparencia" onclick="setOpacity();"></input>
</div>
<div id="map-canvas"></div>
<div id="map"></div>

这篇关于使用图形管理器覆盖自定义叠加图像的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆