谷歌地图上旋转标记

4
我使用了这个在谷歌地图上显示风向来旋转谷歌地图上的标记,但是角度设置为220度。现在我有一个输入文本框,用户在其中输入角度,当点击按钮时,在谷歌地图上显示旋转的标记。如何编辑此代码以从文本框中获取值?是否可以使用<canvas>
代码在此处:
<body onload="xz()" onunload="GUnload()">

<div id="map" style="width: 400px; height: 300px"></div> 

<script type="text/javascript"> 

function xz()
{

if (GBrowserIsCompatible()) {   
    var angleDegrees = document.getElementById('angle').value;
    var map = new GMap2(document.getElementById("map"));
    var arrowIcon = new Image();

    var marker = new ELabel( new GLatLng(55.50, 2.50), '<canvas id="arrowcanvas" width="32" height="32"><\/canvas>', null, new GSize(-16, 16));

    arrowIcon.src = "http://i49.tinypic.com/mafqee.png";

    map.addOverlay(marker);

    map.setCenter(new GLatLng(53.85, -1.80), 3);

    var canvas = document.getElementById("arrowcanvas").getContext('2d');
    var angleRadians = (angleDegrees / 180) * Math.PI;

    var cosa = Math.cos(angleRadians);
    var sina = Math.sin(angleRadians);

    canvas.clearRect(0, 0, 32, 32);
    canvas.save();
    canvas.rotate(angleRadians);
    canvas.translate(16 * sina + 16 * cosa, 16 * cosa - 16 * sina);
    canvas.drawImage(arrowIcon, -16, -16);
    canvas.restore();
}
}
</script>

<form> 
    <input type="text" size="13" id="angle" name="angle" value=""> </input>

    <input type="submit" id="button2" value="Prika?i" class="btnsearch" onsubmit="xz(); return false;">


</form> 
 </body>


请问您能否具体说明目前遇到了哪些错误或问题? - Nathan Taylor
当我启动这个程序并输入角度时,我只能得到加载的谷歌地图。当我在代码中将angleDegrees设置为某个值时,我会在谷歌地图上得到标记。我不知道问题出在哪里。 - Josip
1个回答

4
您可以复制他的代码并替换此行:
var angleDegrees = 220;

像这样:

var angleDegrees = document.getElementById('myTextbox').value;

其中'myTextbox'是分配给您的输入字段的ID。


@Josip,我最初将“angleDegrees”错拼为“angleDegress”,请确保您使用正确的拼写。如果这不起作用,请更新您正在使用的代码到您的问题中。 - Nathan Taylor

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接