带有可选标记颜色的 Google Maps Web API

如何解决带有可选标记颜色的 Google Maps Web API

我正在开发一个 Google Maps API 应用程序,该应用程序允许用户在地图上选择绘制多边形的颜色。

我还希望应用程序上的颜色选择器定义地图标记的颜色。基本上,如果用户选择蓝色,则在选择时绘制的任何多边形或放置的标记都将为蓝色。

最终结果将是能够在地图上使用不同颜色的标记和多边形。我不确定的是如何拉出选择的颜色并将其传递到标记上。

如果有人能帮助我,我将不胜感激。

var drawingManager;
var selectedShape;
var colors = ['yellow','blue','green','orange','purple','red','pink']; //these colors match what is available from Google regarding markers
var selectedColor;
var colorButtons = {};

// This clears the selected shape when another is selected
function clearSelection() {
  if (selectedShape) {
    if (selectedShape.type !== 'marker') {
      selectedShape.setEditable(false);
    }

    selectedShape = null;
  }
}

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

  selectedShape = shape;
}

// Select an object using a custom button
function selectObject() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.SELECT);
}

// Delete a plotted shape
function deleteSelectedShape() {
  if (selectedShape) {
    selectedShape.setMap(null);
  }
}

// Add custom marker buttons
function addMarker() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.MARKER);
}

// Draw a polygon using custom buttons
function drawPolygon() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.POLYGON);
}

// Draw a rectangle using custom button
function drawRectangle() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.RECTANGLE);
}

// Draw a circle using custom button
function drawCircle() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.CIRCLE);
}

// Draw a line using custom button
function drawLine() {
  drawingManager.setDrawingMode(google.maps.drawing.OverlayType.POLYLINE);
}


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

  // Retrieves the current options from the drawing manager and replaces the
  // set 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);
}

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

// Build the color buttons

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]);
}

// Initialise the map and set start up paramaters
function initialize(Color) {
  var map = new google.maps.Map(document.getElementById('map'),{
    zoom: 14,center: new google.maps.LatLng(56.44649,-2.89219),mapTypeId: google.maps.MapTypeId.SATELLITE,disableDefaultUI: true,zoomControl: true,});

  // Auto map location

  var infoWindow = new google.maps.InfoWindow({
    map: map
  });

  // Geolocation
  if (navigator.geolocation) {
    navigator.geolocation.getCurrentPosition(function(position) {
      var pos = {
        lat: position.coords.latitude,lng: position.coords.longitude
      };

      map.setCenter(pos);
    },function() {
      handleLocationError(true,infoWindow,map.getCenter());
    });
  } else {
    // Browser doesn't support Geolocation
    handleLocationError(false,map.getCenter());
  }

  function handleLocationError(browserHasGeolocation,pos) {
    infoWindow.setPosition(pos);
    infoWindow.setContent(browserHasGeolocation ?
      'Error: The Geolocation service failed.' :
      'Error: Your browser doesn\'t support geolocation.');
  }


  // Create the search box and link it to the UI element.
    const input = document.getElementById("pac-input");
    const searchBox = new google.maps.places.SearchBox(input);
    map.controls[google.maps.ControlPosition.TOP_LEFT].push(input);
    // Bias the SearchBox results towards current map's viewport.
    map.addListener("bounds_changed",() => {
      searchBox.setBounds(map.getBounds());
    });
    let markers = [];
    // Listen for the event fired when the user selects a prediction and retrieve
    // more details for that place.
    searchBox.addListener("places_changed",() => {
      const places = searchBox.getPlaces();

      if (places.length == 0) {
        return;
      }
      // Clear out the old markers.
      markers.forEach((marker) => {
        marker.setMap(null);
      });
      markers = [];
      // For each place,get the icon,name and location.
      const bounds = new google.maps.LatLngBounds();
      places.forEach((place) => {
        if (!place.geometry || !place.geometry.location) {
          console.log("Returned place contains no geometry");
          return;
        }
        const icon = {
          size: new google.maps.Size(71,71),origin: new google.maps.Point(0,0),anchor: new google.maps.Point(17,34),scaledSize: new google.maps.Size(25,25),};
        // Create a marker for each place.(this can be removed to stop marker when search has been done)
        markers.push(
          new google.maps.Marker({
            map,icon,title: place.name,position: place.geometry.location,})
        );

        if (place.geometry.viewport) {
          // Only geocodes have viewport.
          bounds.union(place.geometry.viewport);
        } else {
          bounds.extend(place.geometry.location);
        }
      });
      map.fitBounds(bounds);
    });




  //set the polygon charictoristics
  var polyOptions = {
    strokeWeight: 0,fillOpacity: 0.45,editable: true,draggable: true
  };

  var markerOptions = {
    icon: //custom icons can be added here
      "http://maps.google.com/mapfiles/ms/icons/" + "green" + "-dot.png",//pass the colour varible in where green is
    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({
    drawingControl: false,//hide google defalt drawing control
    drawingMode: google.maps.drawing.OverlayType.POLYGON,polylineOptions: {
      editable: true,draggable: true
    },markerOptions: markerOptions,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) {
      // revert 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,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,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,clearSelection);
  google.maps.event.addDomListener(document.getElementById('select-button'),selectObject);
  google.maps.event.addDomListener(document.getElementById('delete-button'),deleteSelectedShape);
  google.maps.event.addDomListener(document.getElementById('marker-button'),addMarker);
  google.maps.event.addDomListener(document.getElementById('polygon-button'),drawPolygon);
  google.maps.event.addDomListener(document.getElementById('rectangle-button'),drawRectangle);
  google.maps.event.addDomListener(document.getElementById('circle-button'),drawCircle);
  google.maps.event.addDomListener(document.getElementById('line-button'),drawLine);
  buildColorPalette();
}
google.maps.event.addDomListener(window,'load',initialize);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res