Hello Stack Overflow人!!
老实说,我不知道是否有办法做到这一点,但我希望有,因为替代方案更复杂,我不肯定如何实现它。目前,我已经在一个带有其他控件的页面上运行了一个Google Earth插件。该页面应该显示一个图表,其中包含调制解调器的延迟和信噪比数据,以及一个包含大量附加信息的网格,以帮助我的ISP在解决问题调制解调器方面做得更好。
我的问题是:JavaScript是否有办法修改Google地球地标的颜色而不会弄乱KML?
我知道你可以在KML中做这样的事情
<Style id="normalPlacemark">
<IconStyle>
<color>ffffff00</color>
<scale>5</scale>
<Icon>
<href>http://maps.google.com/mapfiles/kml/pushpin/wht-pushpin.png</href>
</Icon>
</IconStyle>
</Style>
但是我一直无法使用C#或JavaScript中的AddKMLFromString()(我真的不熟悉)将它附加到整个XML中的正确位置,以使页面识别它。
这是我在片刻使用的修改过的插件代码:
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="text/javascript">
var ge;
google.load("earth", "1");
//Create an instance of the Earth
function init() {
google.earth.createInstance('gmap', initCallback, failureCallback);
}
function initCallback(pluginInstance) {
ge = pluginInstance;
ge.getWindow().setVisibility(true);
//URL for KML file which is taken directly from Google
//The KML in question is Google's giant file for weather data
var href = 'aurlwherewetherdatalives.kml';
//Use Google's fetch KML method to get the weather KML file and add it to our plugin's instance
google.earth.fetchKml(ge, href, function (kmlObject) {
if (kmlObject) {
ge.getFeatures().appendChild(kmlObject);
}
if (kmlObject.getAbstractView() !== null)
ge.getView().setAbstractView(kmlObject.getAbstractView());
});
//Turn on Country Borders, States, and Cities
ge.getLayerRoot().enableLayerById(ge.LAYER_BORDERS, true);
//By default, remoteExists uses True where JavaScript wants true
var jsRemoteExists = <%= remoteExists.ToString().ToLower() %>;
//If the remote exists, create a placemark and camera at its location using the
//the latitude and longitude variables retreived in the c#
if (jsRemoteExists)
{
//Variables have been created
var lat = <%= CSHARPLat %>;
var lon = <%= CSHARPLong %>;
ge.getWindow().setVisibility(true);
// Create the placemark and add it to Earth.
var placemark = ge.createPlacemark('');
// Set the placemark's location.
var point = ge.createPoint('');
point.setLatitude(lat);
point.setLongitude(lon);
placemark.setGeometry(point);
// Add the placemark to Earth.
ge.getFeatures().appendChild(placemark);
var la = ge.createLookAt('');
la.setLatitude(lat);
la.setLongitude(lon);
la.setRange(150000);
ge.getView().setAbstractView(la);
}
}
function failureCallback(errorCode) {
}
function addKmlFromString(kmlString) {
var kmlObject = ge.parseKml(kmlString);
ge.getFeatures().appendChild(kmlObject);
}
window.onload = init();
</script>
找到将上面的KML添加到后面的C#代码中的字符串并找到正确添加样式的地方会更好吗?我一直在倾注谷歌的API,并试图在不同的地方添加它,大多数时候它只是打破,并没有显示天气数据或地标。最终目标是根据遥控器是标称,警报还是警告状态更改为地标的颜色。我在这里和谷歌上寻找答案,但似乎没有任何东西在JS中做到这一点我似乎无法以正确的方式追加KML来改变地标颜色。有人有什么想法吗?
答案 0 :(得分:0)
我最终自己想出了这个。希望任何寻找答案的人都能在这里找到答案。
我看到很多东西建议根据样式换出不同颜色的图像,但找不到描述如何操作的任何地方。原因是JavaScript隐藏在不知名的中间。谷歌的API有时候......用户不太友好。所以,可搜索的更好,对吧?我希望这会帮助别人。
在C#中,我有一个带有链接的switch语句(因为本地人不想工作的绝对路径)到我已经存储了图像并将其传递给JavaScript的地方:
var statusURL = '<%= CSHARPstatusURL %>';
稍后,您可能需要调整位置,以便您不会隐藏任何其他图层,因为我动态生成KML,您需要这些方便的小线:
// Define a custom icon.
var icon = ge.createIcon('');
icon.setHref(statusURL);
var style = ge.createStyle(''); //create a new style
style.getIconStyle().setIcon(icon); //apply the icon to the style
style.getIconStyle().setScale(1.5); //set the icon's size
placemark.setStyleSelector(style); //apply the style to the placemark
这将允许您创建一个图标样式,这是我希望这样做的原始方式。创建一些图像并修改GIMP中的颜色饱和度,你就可以了。干杯!