OpenLayers3和AngularJS中的静态图像旋转

时间:2017-04-07 13:14:54

标签: angularjs openlayers openlayers-3 angular-openlayers

我正在使用angular-openlayers-directive来创建自定义地图。试图修改this example,在自定义图层中使用静态图片而不是地图。它出错了。

我正在寻找自定义图像旋转的解决方案作为地图。你能帮忙吗?

1 个答案:

答案 0 :(得分:2)

如果没有看到您的代码或知道错误消息,很难具体说明问题是什么,但是这里修改了旋转静态图像的示例:



<!DOCTYPE html>
<html ng-app="demoapp">

<head>
  <script src="https://tombatossals.github.io/angular-openlayers-directive/bower_components/openlayers3/build/ol.js"></script>
  <script src="https://tombatossals.github.io/angular-openlayers-directive/bower_components/angular/angular.js"></script>
  <script src="https://tombatossals.github.io/angular-openlayers-directive/bower_components/angular-sanitize/angular-sanitize.js"></script>
  <script src="https://tombatossals.github.io/angular-openlayers-directive/dist/angular-openlayers-directive.js"></script>
  <link rel="stylesheet" href="https://tombatossals.github.io/angular-openlayers-directive/bower_components/openlayers3/build/ol.css" />
  <script>
    var app = angular.module('demoapp', ['openlayers-directive']);
    app.controller('DemoController', ['$scope', '$http', 'olData', function($scope, $http, olData) {

      angular.extend($scope, {
        degrees: 0,
        center: {
          coord: [900, 600],
          zoom: 3
        },
        defaults: {
          view: {
            projection: 'pixel',
            extent: [0, 0, 1800, 1200],
            rotation: 0
          }
        },
        static: {
          source: {
            type: "ImageStatic",
            url: "http://blog.wallpops.com/wp-content/upLoads/2013/05/WPE0624.jpg",
            imageSize: [1800, 1200]
          }
        },
        view: {
          extent: [0, 0, 1800, 1200],
          rotation: 0
        }

      });

      $scope.degreesToRadians = function() {
        $scope.view.rotation = parseFloat($scope.degrees, 10).toFixed(2) * (Math.PI / 180);
      };

      $scope.$watch('view.rotation', function(value) {
        $scope.degrees = ($scope.view.rotation * 180 / Math.PI).toFixed(2);
      });
    }]);
  </script>
</head>

<body ng-controller="DemoController">
  <openlayers ol-center="center" ol-defaults="defaults" ol-view="view" custom-layers="true" height="400px">
    <ol-layer ol-layer-properties="static"></ol-layer>
  </openlayers>
  <h1>View rotation example</h1>
  <p>You can interact with the view rotation of your map.</p>

  <p>
    <input type="range" min="-180" max="180" ng-change="degreesToRadians()" ng-model="degrees" /> Degrees: {{ degrees }}</p>
  <pre ng-bind="view | json"></pre>
</body>

</html>
&#13;
&#13;
&#13;

Plunker中的相同示例:http://plnkr.co/edit/zw7QUyFfWXqnNE9rkdjZ?p=preview