Openlayers瓷砖没有加载PhoneGap应用程序 - jQuery Mobile冲突?

时间:2012-06-15 21:41:53

标签: jquery-mobile cordova openlayers

作为我的第一个PhoneGap应用程序的一部分,我需要加载一个OpenLayers地图(最终使用我自己的本地自定义磁贴,但目前,我只是在线测试,修改标准的OpenLayers示例)。

但是当我尝试在iOS模拟器中初始化地图时,瓷砖不想使用OpenStreetMap或替代方案加载。地图初始化就像放置控件和版权声明一样,但我不断获得蓝色问号框而不是实时图块。在浏览器中独立测试地图加载代码,如果我删除jQuery Mobile引用它似乎正常运行,但是如果我在Xcode中调整文件似乎不起作用,除此之外,它会搞砸我想要的外观和行为。这是一个已知的冲突吗?有没有人知道解决方法呢?

提前致谢!

贾尔斯

<!DOCTYPE html> 
<html> 
<head> 
<title>My Page</title> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <link rel="stylesheet" href="jquery.mobilecus-1.1.0.min.css"/>
    <script src="js/jquery-1.7.2.js"></script>
    <script src="js/jquery.mobile-1.1.0.min.js"></script>
    <script src="js/sessionstorage.1.4.js"></script>
    <script src="js/OpenLayers.js"></script>

<script type="text/javascript" charset="utf-8">

    $(function() { //ready
    // JQuery stuff trimmed out
    }); //end ready

    var map
    function init() {
       map = new OpenLayers.Map("mapview");
       map.addLayer(new OpenLayers.Layer.OSM());
       var lonLat = new OpenLayers.LonLat( 0.0 ,51.0).transform(
            new OpenLayers.Projection("EPSG:4326"), // transform from WGS 1984
            map.getProjectionObject() // to Spherical Mercator Projection);
       var zoom=10;
       map.setCenter (lonLat, zoom);
       }
</script>
</head>

<body onload="init();"> 

<div data-role="page" id="page1" class="page">
     //html for first page (no map)
</div><!-- /page -->

<div data-role="page" id="page2" class="page">
    <div data-role="header" data-id="fixedheader" data-position="fixed" >   
    <h1>Fixed header</h1>
        </div><!-- /header -->

    <div data-role="content">
            <div id="leftbar">
            <img src="images/leftbar.png">
        </div><!-- /leftbar -->
        <div id="mapview">
            //map appears here
        </div><!-- /mapview -->
        </div><!-- /content -->

    <div data-role="footer"data-id="fixedfooter" data-position="fixed">
        <a id="ForwardButton">Forward</a><a id = "BackButton" href="#page2">Back</a>
    </div><!--/footer -->

</div><!-- /page -->

</body>
</html>

1 个答案:

答案 0 :(得分:0)

对不起 - 忘了我发言了!刚刚发现我需要将地图服务器域的引用添加到Cordova.plist中的“ExternalHosts”。现在这些图像好像装好了。