高德地图 JS API示例->其他LBS服务->公交信息查询->公交到达圈

高德地图 JS API示例->其他LBS服务->公交信息查询->公交到达圈

<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
    <title>点到达圈</title>
    <link rel="stylesheet" href="https://a.amap.com/jsapi_demos/static/demo-center/css/demo-center.css"/> 
    <style type="text/css">
       html,body,#container{
           height:100%;
       }
       .btn{
           margin-left: 0.5rem;
           width:4rem;
       }
    </style>
    <link rel="stylesheet" href="https://cache.amap.com/lbs/static/jquery.range.css"/>

</head>

<body>
<div id="container"></div>

<div class="input-card" style='width:25rem;'>
    <h4 style='color:grey'>公交到达圈查询</h4>
    <div class="input-item">
            <div class="input-item-prepend"><span class="input-item-text" >出发位置</span></div>
            <input id='lnglat' type="text" value = '116.397428, 39.90923' >       
    </div>
    <div class="input-item" style='margin-bottom:2rem;'>
        <label>时长(分钟)</label>
        <input type="hidden" id="t" class="single-slider" value="30" />
    </div>
    
    <div class="input-item">
            <div class="input-item-prepend">
                <label class="input-item-text">出行方式</label>
            </div>
            <select iname="v" id="v">
                <option selected value ="SUBWAY,BUS">地铁+公交</option>
                <option value ="SUBWAY">地铁</option>
                <option value ="BUS">公交</option>
            </select>
            <input id="search" type="button" class="btn" value="查询" />
            <input id="clear" type="button" class="btn" value="清除" />
    </div>
</div>

<script src="https://webapi.amap.com/maps?v=1.4.15&key=您申请的key值&plugin=AMap.ArrivalRange"></script>
<script src="https://cache.amap.com/lbs/static/jquery-1.9.1.js"></script>
<script src="https://cache.amap.com/lbs/static/jquery.range.js"></script>
<script>
    var map = new AMap.Map("container", {
        resizeEnable: true,
        zoomEnable: true,
        center: [116.397428, 39.90923],
        zoom: 10
    });
    
    function getLnglat(e) {
        var lnglat = e.lnglat;
        document.getElementById('lnglat').value = e.lnglat.toString()
        getArriveRange();
    }
    map.on( 'click', getLnglat);
    
    var centerMarker;
    function addCenterMarker(position){
        if(!centerMarker){
            centerMarker= new AMap.Marker({
                map: map,
                position: position
            });
        }else{
            centerMarker.setPosition(position)
        }
    }
    
    
    var arrivalRange,polygons=[];
    //添加多边形覆盖物
    function getArriveRange() {
        if(!arrivalRange){
            arrivalRange = new AMap.ArrivalRange()
        }
        var lnglat = $("#lnglat").val().split(',');
        var t = $("#t").val();
        var v = $("#v").val();
        
        addCenterMarker(lnglat);
        
        arrivalRange.search(lnglat, t, function(status,result){
            map.remove(polygons);
            polygons = [];
            if(result.bounds){
                for(var i=0;i<result.bounds.length;i++){
                   var polygon = new AMap.Polygon({
                        fillColor:"#3366FF",
                        fillOpacity:"0.4",
                        strokeColor:"#00FF00",
                        strokeOpacity:"0.5",
                        strokeWeight:1
                    });
                    polygon.setPath(result.bounds[i]);
                    polygons.push(polygon);
                }
                map.add(polygons);
                map.setFitView();
            }
        },{
            policy:v
        });
    }


    var isChanged=false;
    $(function(){
        $('.single-slider').jRange({
            onstatechange: getArriveRange,
            from: 1,
            to: 45,
            step: 1,
            scale: [1,15,30,45],
            format: '%s',
            width: 400,
            showLabels: true,
            showScale: true
        });
    });
    getArriveRange();
    
    $('#search').on('click', getArriveRange);
    $('#v').on('change', getArriveRange);
    $('#clear').on('click', function(){map.remove(polygons)});

</script>
</body>

</html>
0 0 投票数
文章评分
订阅评论
提醒
0 评论
最旧
最新 最多投票
内联反馈
查看所有评论
0
希望看到您的想法,请您发表评论x