2

こんにちは、proj4jsライブラリの使用に問題があります。これが私の情報源です:

<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
      <script type="text/javascript" src="lib/proj4js-combined.js"></script>
   </head>

   <script type="text/javascript">
    function go()
    {
        var lon = document.getElementById("xOrg").value;
        var lat = document.getElementById("yOrg").value;
        var reprojected = reproject(Number(lon),Number(lat));

        document.getElementById("xNew").value = reprojected.x;
        document.getElementById("yNew").value = reprojected.y;
    }

    function reproject(lon,lat)
        {
            var sourceSys = new Proj4js.Proj('WGS84');
            var destSys = new Proj4js.Proj('EPSG:32187');

            var pointSource = new Proj4js.Point(lon,lat);
            var pointDest = Proj4js.transform(sourceSys, destSys, pointSource);

            return pointDest;
        }
   </script>

   <body>
    <div>
    <input id="xOrg" type="text" value="-73.56"/>
    <input id="yOrg" type="text" value="45.49"/>
    </div>
    <div>
    <input id="xNew" type="text" value=""/>
    <input id="yNew" type="text" value=""/>
    </div>
    <div>
        <input type="button" value="go" onclick="go()"/>
    </div>
   </body>
</html>

ボタンを2回クリックしたときにのみ再投影が機能する理由がわかりません。最初にボタンをクリックすると、同じ値が返されます。ボタンを2回以上クリックした場合にのみ機能するようです。これがオンラインのこのページです: クリック

4

2 に答える 2

3
var sourceSys = new Proj4js.Proj('WGS84'); 
var destSys = new Proj4js.Proj('EPSG:32187'); 

ここまで:

...

<script type="text/javascript">  
    var sourceSys = new Proj4js.Proj('WGS84'); 
    var destSys = new Proj4js.Proj('EPSG:32187'); 

    function go()
{
...  

そして、何らかの理由でそれが機能するようになりました...

于 2010-10-28T14:01:18.387 に答える
0

ページを読み込めませんが、更新の問題ですか?つまり。xNewおよびyNew入力タグを、値が設定された直後に明示的に更新させることはできますか?

于 2010-10-27T19:49:40.453 に答える