2015-03-31 228 views
2

我试图在我的混合应用程序中包括谷歌地图,我遇到了一个问题,其中功能正在运行,但谷歌地图没有显示。谷歌地图不显示

search.html 这是哪里的地图是要显示,这里的共享位置的选择上来,但也共享后,它并没有显示在网页 enter image description here

<style> 
#map { 
    width: 100%; 
    height: 100%; 
} 

.scroll { 
    height: 100%; 
} 
</style> 
<ion-view title="Map"> 
    <ion-nav-buttons side="left"> 
    <button menu-toggle="left"class="button button-icon icon ion-navicon"></button> 
    </ion-nav-buttons> 
    <ion-content > 
     <div id="map" data-tap-disabled="true"></div> 
    </ion-content> 
<ion-view> 

的index.html

<html> 
    <head > 
    <meta charset="utf-8"> 
    <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width"> 
    <title></title> 

    <link href="lib/ionic/css/ionic.css" rel="stylesheet"> 
    <link rel="stylesheet" type="text/css" href="css/flaticon/flaticon.css"> 
    <link rel="stylesheet" href="css/style.css"> 
    <link rel="stylesheet" href="css/app.css"> 

    <!-- ionic/angularjs js --> 
    <script src="lib/ionic/js/ionic.bundle.js"></script> 

    <!-- cordova script (this will be a 404 during development) --> 
    <script src="cordova.js"></script> 
    <!-- your app's js --> 
    <script src="js/datepicker.js"></script> 
    <script src="//maps.googleapis.com/maps/api/js"></script> 
    <script src="js/app.js"></script> 
    <script src="js/controllers.js"></script> 


    </head> 

    <body ng-app="starter"> 
    <ion-nav-view></ion-nav-view> 
    </body> 
</html> 

app.js 这是那里的状态定义主要的js文件,我不认为我做了这里的任何错误

angular.module('starter', ['ionic', 'starter.controllers']) 
.config(function($stateProvider, $urlRouterProvider) { 
    $stateProvider 

    .state('app', { 
    url: "/app", 
    abstract: true, 
    templateUrl: "templates/menu.html", 
    controller: 'AppCtrl' 
    }) 

    .state('app.search', { 
    url: "/connect", 
    views: { 
     'menuContent': { 
     templateUrl: "templates/search.html", 
     controller: 'GpsCtrl' 
     } 
    } 
    }); 
$urlRouterProvider.otherwise('/app/main'); 
}); 

controllers.js 这里定义的控制器的一部分,GpsCtrl对于地图。该网页获得打开并要求在浏览器的地址权限,但随后它没有显示在地图

angular.module('starter.controllers', ['angular-datepicker']) 
.controller('MainCtrl', function($scope) { 

}) 
.controller('GpsCtrl', function($scope) { 

    ionic.Platform.ready(function() { 
     var myLatlng = new google.maps.LatLng(12.96,77.65); 

     var mapOptions = { 
      center: myLatlng, 
      zoom: 16, 
      mapTypeId: google.maps.MapTypeId.ROADMAP 
     }; 

     var map = new google.maps.Map(document.getElementById("map"), mapOptions); 

     navigator.geolocation.getCurrentPosition(function(pos) { 
      map.setCenter(new google.maps.LatLng(pos.coords.latitude, pos.coords.longitude)); 
      var myLocation = new google.maps.Marker({ 
       position: new google.maps.LatLng(pos.coords.latitude, pos.coords.longitude), 
       map: map, 
       title: "My Location" 
      }); 
     }); 

     $scope.map = map; 
    }); 

}); 

menu.html 这对sidemenu

<ion-side-menus enable-menu-with-back-views="false"> 
    <ion-side-menu-content> 
    <ion-nav-bar class="bar-stable"> 
     <ion-nav-back-button> 
     </ion-nav-back-button> 

     <ion-nav-buttons side="left"> 
     <button class="button button-icon button-clear ion-navicon" menu-toggle="left"> 
     </button> 
     </ion-nav-buttons> 
    </ion-nav-bar> 
    <ion-nav-view name="menuContent"></ion-nav-view> 
    </ion-side-menu-content> 

    <ion-side-menu side="left"> 
    <ion-header-bar class="bar-stable"> 
     <h1 class="title">Left</h1> 
    </ion-header-bar> 
    <ion-content> 
     <ion-list> 
     <ion-item nav-clear menu-close ng-click="login()"> 
      Login 
     </ion-item> 
     <ion-item nav-clear menu-close href="#/app/connect"> 
      Search 
     </ion-item> 
     <ion-item nav-clear menu-close href="#/app/registration"> 
      Browse 
     </ion-item> 
     <ion-item nav-clear menu-close href="#/app/main"> 
      Main 
     </ion-item> 
     <ion-item nav-clear menu-close href="#/app/resu"> 
      Result 
     </ion-item> 

     </ion-list> 
    </ion-content> 
    </ion-side-menu> 
</ion-side-menus> 
+1

在您的index.html你的谷歌地图的脚本是 添加http:在SRC。 – Banik 2015-03-31 18:51:24

+0

@Banik它仍然显示相同的问题 – 2015-04-01 11:06:38

+0

我能解决它,但它不显示在Android设备 – 2015-04-02 09:08:56

回答

3

你缺少的文件谷歌地图调用中的http://

这样称呼它:

<script src="http://maps.googleapis.com/maps/api/js"></script> 
+0

den也没有帮助 – 2015-04-02 12:23:24

+1

谢谢!,这对我来说就像一个魅力。 – maltray 2016-09-28 00:21:48

+0

谢谢帮助也.. – 2016-10-12 07:55:41

0

你检查的run方法在app.js.请确保您有starter.controllers如扶养说有..

angular.module('starter',['ionic','starter.controllers']) <== add controller here 
.run(function($ionicPlatform) {...................... 
0

VAR选项= {超时:10000,enableHighAccuracy:真正};

$cordovaGeolocation.getCurrentPosition(options).then(function (position) { 

    var latLng = new google.maps.LatLng(12.32719230000002, 76.73288185390626); 

    var mapOptions = { 
     center: latLng, 
     zoom: 10, 
     mapTypeId: google.maps.MapTypeId.ROADMAP 
    }; 

    $scope.map = new google.maps.Map(document.getElementById("map"), mapOptions); 
    google.maps.event.addListenerOnce($scope.map, 'idle', function() { 

     var marker = new google.maps.Marker({ 
      map: $scope.map, 
      animation: google.maps.Animation.DROP, 
      position: latLng 
     }); 

     var infoWindow = new google.maps.InfoWindow({ 
      content: "Here I am!" 
     }); 

     google.maps.event.addListener(marker, 'click', function() { 
      infoWindow.open($scope.map, marker); 
     }); 

    }); 
}, function (error) { 
    console.log("Could not get location"); 
}); 
+0

试试这个在你的控制器 – yousuf 2017-04-15 11:34:50

+0

请解释你的答案 – Mazz 2017-04-15 12:05:38