javascript - 使 KML/KMZ 层透明/不透明

标签 javascript html google-maps

我一直在寻找使用 Google Map API 版本 3 使 KML/KMZ 层透明/不透明的简单方法。那里有很多示例,但似乎没有一个简单的示例使 KML 层不透明。我在下面提供了一个示例,有人可以帮我解决这个问题吗???

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<title>Example 2</title>
<style type="text/css">
  html { height: 100% }
  body { height: 100%; margin: 0px; padding: 0px }
  #map_canvas { height: 100% }
</style>
<script type="text/javascript"
  src="http://maps.google.com/maps/api/js?sensor=false">
</script>
<script type="text/javascript">

// ***Initialize the Map Function ***
function initialize() {
var latlng = new google.maps.LatLng(0,0);
var myOptions = {
  zoom: 10,
  center: latlng,
  mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_canvas"),
    myOptions);

var polyLayerOptions = {
    supressInfoWindows: true,
    Opacity: 0.15
};
var polyLayer = new google.maps.KmlLayer
('http://gmaps-samples.googlecode.com/svn/trunk/ggeoxml/cta.kml', polyLayerOptions);
polyLayer.setMap(map);
}

</script>
</head>
<body onload="initialize()">
<div id="map_canvas" style="width:100%; height:100%"></div>
</body>
</html>

最佳答案

KML 选项中没有不透明度标志,但您可以将 KML 中对象的颜色设置为透明。 Google 使用 ABGR 形式的 32 位颜色,其中第一个字节是 alpha channel 或透明度,接下来的三个字节是常规颜色(尽管不是其他人使用的标准 RGB 顺序!)。例如,#80FF0000 的颜色将是 50% 透明的蓝色。似乎没有办法像在 Google 地球中那样在代码中动态修改透明度,您必须更新 KML 并将其重新发布到您的 map 。

关于javascript - 使 KML/KMZ 层透明/不透明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5446906/

相关文章:

javascript - 为什么更新的状态没有反射(reflect)在事件监听器中 : React Native, Hooks

javascript - 当通过 AJAX 呈现表单时,jQuery 代码不适用于表单

javascript - 如何在移动旋转时旋转 HTML5 页面

javascript - Google map v3 infoWindow addDomListener 用于 HTML 按钮

javascript - 按下按钮时调用js函数

javascript - 用于打开网页、编辑输入字段和提交表单的脚本

html - 2 列列表项之间的尴尬间距

php - 自定义单选按钮显示里面的值(value)

google-maps - Android Studio(无法找到 Google API 镜像)在虚拟设备配置中

javascript - 谷歌地图标签和监听器事件驱动的 CSS