1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- 'use strict';
- /**
- * controllers for GoogleMap
- * AngularJS Directive
- */
- app.controller('MapCoordinatesCtrl', ["$scope", "$compile", function ($scope, $compile) {
- var TILE_SIZE = 256;
- function bound(value, opt_min, opt_max) {
- if (opt_min != null)
- value = Math.max(value, opt_min);
- if (opt_max != null)
- value = Math.min(value, opt_max);
- return value;
- }
- function degreesToRadians(deg) {
- return deg * (Math.PI / 180);
- }
- function radiansToDegrees(rad) {
- return rad / (Math.PI / 180);
- }
- function MercatorProjection() {
- this.pixelOrigin_ = new google.maps.Point(TILE_SIZE / 2, TILE_SIZE / 2);
- this.pixelsPerLonDegree_ = TILE_SIZE / 360;
- this.pixelsPerLonRadian_ = TILE_SIZE / (2 * Math.PI);
- }
- MercatorProjection.prototype.fromLatLngToPoint = function (latLng, opt_point) {
- var me = this;
- var point = opt_point || new google.maps.Point(0, 0);
- var origin = me.pixelOrigin_;
- point.x = origin.x + latLng.lng() * me.pixelsPerLonDegree_;
- // Truncating to 0.9999 effectively limits latitude to 89.189. This is
- // about a third of a tile past the edge of the world tile.
- var siny = bound(Math.sin(degreesToRadians(latLng.lat())), -0.9999, 0.9999);
- point.y = origin.y + 0.5 * Math.log((1 + siny) / (1 - siny)) * -me.pixelsPerLonRadian_;
- return point;
- };
- MercatorProjection.prototype.fromPointToLatLng = function (point) {
- var me = this;
- var origin = me.pixelOrigin_;
- var lng = (point.x - origin.x) / me.pixelsPerLonDegree_;
- var latRadians = (point.y - origin.y) / -me.pixelsPerLonRadian_;
- var lat = radiansToDegrees(2 * Math.atan(Math.exp(latRadians)) - Math.PI / 2);
- return new google.maps.LatLng(lat, lng);
- };
- $scope.$on('mapInitialized', function (event, map) {
- var numTiles = 1 << map.getZoom();
- var projection = new MercatorProjection();
- $scope.chicago = map.getCenter();
- $scope.worldCoordinate = projection.fromLatLngToPoint($scope.chicago);
- $scope.pixelCoordinate = new google.maps.Point($scope.worldCoordinate.x * numTiles, $scope.worldCoordinate.y * numTiles);
- $scope.tileCoordinate = new google.maps.Point(Math.floor($scope.pixelCoordinate.x / TILE_SIZE), Math.floor($scope.pixelCoordinate.y / TILE_SIZE));
- });
- }]);
- app.controller('EventSimpleCtrl', ['$scope', '$timeout',
- function ($scope, $timeout) {
- var marker, map;
- $scope.$on('mapInitialized', function (evt, evtMap) {
- map = evtMap;
- marker = map.markers[0];
- });
- $scope.centerChanged = function (event) {
- $timeout(function () {
- map.panTo(marker.getPosition());
- }, 3000);
- }
- $scope.click = function (event) {
- map.setZoom(8);
- map.setCenter(marker.getPosition());
- }
- }]);
- app.controller('EventPropertiesCtrl', ["$scope", function ($scope) {
- $scope.$on('mapInitialized', function (evt, map) {
- var infoWindow = map.infoWindows[1];
- $scope.zoomChanged = function (e) {
- infoWindow.setContent('Zoom: ' + map.getZoom());
- map.setCenter(infoWindow.getPosition());
- }
- });
- }]);
- app.controller('ControlCustomStateCtrl', ["$scope", function ($scope) {
- $scope.home = new google.maps.LatLng(41.850033, -87.6500523);
- $scope.goHome = function () {
- $scope.map.setCenter($scope.home);
- }
- $scope.setHome = function () {
- $scope.home = $scope.map.getCenter();
- }
- }]);
|