javascript - 如何使用选择标签过滤 ui-gmap-markers

标签 javascript angularjs google-maps google-maps-markers angular-google-maps

到目前为止,我必须在网站上显示带有标记的 map ,这些标记取决于 JSON 文件中指定的不同对象的纬度和经度。这些标记可以通过选择标记进行过滤,该标记显示在这些 JSON 对象中找到的不同类别。

我一直在使用 ui-gmap-marker (ng-repeat),但在这里我发现我最好使用 ui-gmap-markers。问题是我一直在尝试实现它,但是我不可能应用在选择标签中获得的过滤器(模型中的过滤器=“”给出很多错误!)而且,infoWindows不显示信息我获取了 JSON 文件(之前通过 ng-repeat 获取)。

我一直在尝试从这里开始工作:http://embed.plnkr.co/f2gxG7DM1U8IlOXfRiuT/

ui-gmap-markers implemented

<div ng-controller="loadMapController">
    <select id="dropdown" ng-model="categoryOrder">
        <option value="0">All</option>
        <option ng-repeat="category in categories" value="{{category}}">{{category}}</option>
    </select>

    <ui-gmap-google-map center='map.center' zoom='map.zoom' aria-label="Google map" pan="true">

        <ui-gmap-markers models="map.markers" idKey="'id'" coords="'self'" events="map.markersEvents">
            <ui-gmap-window show="map.window.show" coords="map.window.model" ng-cloak>
                <div>
                    <p><img ng-src="{{image}}" alt="{{name}}" style="width: 200px; height: 150px; border-radius: 5px;"></p>
                    <p><strong>{{name}}</strong></p>
                    <p>{{address}}</p>
                    <p><a ng-href="{{website}}">Website</a></p>
                    <p><span class="glyphicon glyphicon-plus"> </span><a href="#/"> Profile</a></p>
                </div>
            </ui-gmap-window>
        </ui-gmap-markers>

    </ui-gmap-google-map>

    <ul>
        <li ng-repeat="location in locations | filter:categoryOrder" ng-class="{selected: location == map.window.model}" ng-click="map.window.model = location">
            <p>{{location.name}}</p>
        </li>
    </ul>   
</div>




.controller('loadMapController', ['$scope', '$http', function($scope, $http){

    $http.get ("json/map_data.json").success(function(data) {
        $scope.locations = data;

        var category = [];

        for (var i = 0; i < data.length; i++){
            category[i] = data[i].category;
        };

        var sorted_categories = category.sort();

        $scope.categories = [];

        for (var i = 0; i < category.length; i++){
            if (sorted_categories[i+1] != sorted_categories[i]){
                $scope.categories.push(sorted_categories[i]);
            }
        };

        $scope.map.markers = data;

        console.log($scope.map.markers);

    })

    $scope.map = { 
        center: { 
            latitude: 37.395400, 
            longitude: -5.984930 
        }, 
        zoom: 12, 
        window: {
            model: {},
            show: false,
            options:{
                pixelOffset: {width:-1,height:-20}
            }
        }, 
        markers: [],
        markersEvents: {
            click: function(marker, eventName, model, args) {
                $scope.map.window.model = model;
                $scope.map.window.show = true;      
            }
        }
    };
}]);

最佳答案

关于过滤标记,您可以考虑以下解决方案。

一旦类别通过 ngChange 更改,就会引入事件以根据所选类别过滤标记:

<select id="dropdown" ng-model="categoryOrder" ng-change="changeCategory(categoryOrder)">
    <option value="All">All</option>
    <option ng-repeat="category in categories" value="{{category}}">{{category}}</option>
</select>


$scope.changeCategory = function (selectedCat) {
        if (selectedCat == "All")
            $scope.map.markers = $scope.map.allMarkers;
        else
            $scope.map.markers = $scope.map.allMarkers.filter(function (item) {
                return item.category == selectedCat;
            });
    }

其中 allMarkers 包含所有可用标记

$scope.map.allMarkers = data;

示例

angular.module('app', ['uiGmapgoogle-maps'])
    .controller('loadMapController', ['$scope', '$http', function ($scope, $http, uiGmapGoogleMapApi) {

        $scope.changeCategory = function (selectedCat) {
            if (selectedCat == "All")
                $scope.map.markers = $scope.map.allMarkers;
            else
                $scope.map.markers = $scope.map.allMarkers.filter(function (item) {
                    return item.category == selectedCat;
                });
        }

        $http.get("https://rawgit.com/vgrem/b3a820dcdf3c7b14fba6e53614a951b4/raw/map_data.json").success(function (data) {
            $scope.locations = data;

            var category = [];

            for (var i = 0; i < data.length; i++) {
                category[i] = data[i].category;
            };

            var sorted_categories = category.sort();

            $scope.categories = [];

            for (var i = 0; i < category.length; i++) {
                if (sorted_categories[i + 1] != sorted_categories[i]) {
                    $scope.categories.push(sorted_categories[i]);
                }
            };

            $scope.map.markers = data;
            $scope.map.allMarkers = data;
        });

        $scope.map = {
            center: {
                latitude: 36.2509994,
                longitude: -113.6920185
            },
            zoom: 3,
            window: {
                model: {},
                show: false,
                options: {
                    pixelOffset: { width: -1, height: -20 }
                }
            },
            markers: [],
            markersEvents: {
                click: function (marker, eventName, model, args) {
                    $scope.map.window.model = model;
                    $scope.map.window.show = true;
                }
            }
        };
    }]);
.angular-google-map-container {
	height: 30em;
}
<script src="//cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular.min.js" charset="utf-8"></script>
  <script src="http://cdnjs.cloudflare.com/ajax/libs/lodash.js/3.5.0/lodash.js" charset="utf-8"></script>
  <script src="http://cdnjs.cloudflare.com/ajax/libs/angular-google-maps/2.1.0-X.5/angular-google-maps.js" charset="utf-8"></script>
  


  <div ng-app="app" ng-controller="loadMapController">
    <select id="dropdown" ng-model="categoryOrder" ng-change="changeCategory(categoryOrder)">
        <option value="All">All</option>
        <option ng-repeat="category in categories" value="{{category}}">{{category}}</option>
    </select>

    <ui-gmap-google-map center='map.center' zoom='map.zoom' aria-label="Google map" pan="true">

        <ui-gmap-markers models="map.markers" idKey="'id'" coords="'self'" events="map.markersEvents">
        </ui-gmap-markers>

        <ui-gmap-window show="map.window.show" coords="map.window.model" ng-cloak>
                <div>
                    <p><img ng-src="{{map.window.model.image}}" alt="{{map.window.model.name}}" style="width: 200px; height: 150px; border-radius: 5px;"></p>
                    <p><strong>{{map.window.model.name}}</strong></p>
                    <p>{{map.window.model.address}}</p>
                    <p><a ng-href="{{map.window.model.website}}">Website</a></p>
                    <p><span class="glyphicon glyphicon-plus"> </span><a href="#/"> Profile</a></p>
                </div>
        </ui-gmap-window>

    </ui-gmap-google-map>

    <ul>
        <li ng-repeat="location in locations | filter:categoryOrder" ng-class="{selected: location == map.window.model}" ng-click="map.window.model = location">
            <p>{{location.name}}</p>
        </li>
    </ul>   

   
</div>

Plunker

关于javascript - 如何使用选择标签过滤 ui-gmap-markers,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38555543/

相关文章:

c# - Asp.net 逐页发送信息表单

c# - AngularJs/webAPI : recieving null in the parameter of webAPI

java - MapFragment - Google map 内存不足错误

java - 每当我调用 getMap() 时,我都会收到 nullPointerException

ios - 在 iOS 上制作 MarkerinfoWindow 动画

javascript - 在package.json中执行precommit hook时如何获取文件路径?

javascript - jQuery 可以在 Safari 上工作,但不能在 iOS 上工作 - 我可以做什么来调试?

javascript - 如何在 Chrome 中调试 RequreJS 检索的脚本

javascript - Angularjs 自定义指令传递对象数据

javascript - 使用 Comet 进行 Angular 工作