国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久

BIGEMPA Js API示例中心

框選范圍篩查點位.源代碼展示

代碼編輯區 運行 下載 還原
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>繪制</title>
    <script src="/Public/common/js/jquery.min.js"></script>
    <link href="http://ua.bigemap.com:30081/bmsdk/bigemap.js/v2.1.0/bigemap.css" rel="stylesheet"/>
    <script src="http://ua.bigemap.com:30081/bmsdk/bigemap.js/v2.1.0/bigemap.js"></script>
    <link href="https://cdn.bootcdn.net/ajax/libs/Buttons/2.0.0/css/buttons.min.css" rel="stylesheet">
    <!--
     以下CSS地址請在安裝軟件了替換成本地的地址
     CSS地址請使用:
     http://localhost:9000/bigemap.js/v2.1.0/bigemap.css
     JS地址請使用:
     http://localhost:9000/bigemap.js/v2.1.0/bigemap.js
     軟件下載地址 http://www.bt68f.cn/reader/download/detail201802017.html
    -->
    <!--<link href='http://www.bt68f.cn:9000/bigemap.js/v2.1.0/bigemap.css' rel='stylesheet' />-->
    <!--<script src='http://www.bt68f.cn:9000/bigemap.js/v2.1.0/bigemap.js'></script>-->
    <!--引入鼠標繪制的JS+CSS-->
    <!--對應下面的CSS+JS的下載地址 請直接訪問 http://bigemap.com/Public/mouse_draw/mouse_draw.zip 來下載-->
    <link rel="stylesheet" href="http://www.bt68f.cn/Public/mouse_draw/Bigemap.draw.css"/>
    <script src="http://www.bt68f.cn/Public/js/bm.draw.min.js"></script>

</head>
<style type="text/css">
    * {
        padding: 0;
        margin: 0;
    }

    html, body, #map {
        width: 100%;
        height: 100%;
    }

    .btnbox {
        position: absolute;
        z-index: 10;
        right: 20px;
        top: 20px;
        display: inline-block;
        display: flex;
        flex-direction: column;
    }

    .btnbox button {
        margin-top: 10px;
        height: 50px;
        width: 150px;
        font-size: 13px;
    }

    /*重寫默認的字體的屬性*/
    .my_tooltip {
        color: red;
        background: transparent;
        border: none;
        font-size: 18px;
    }

    .my_tooltip::before {
        display: none;
    }

    .kxtip {
        position: absolute;
        top: 30px;
        left: 50px;
        padding: 10px;
        background-color: white;
        color: black;
        z-index: 2
    }
</style>
<body>
<div class="btnbox">
    <button onclick="drawlayer('polygon')" class="button button-tiny button-rounded button-primary">多邊形框選范圍</button>
    <button onclick="drawlayer('circle')" class="button button-tiny button-rounded button-primary">圓形框選范圍</button>
</div>
<div id="map">

</div>
<div class="kxtip">
    <span>當前范圍內選中的點有:</span>
    <div class="xzdiv">

    </div>
</div>
<script>
    var originalInitTile = window.BM.GridLayer.prototype._initTile;
    window.BM.GridLayer.include({
        _initTile: function (tile) {
            originalInitTile.call(this, tile);
            var tileSize = this.getTileSize();
            tile.style.width = tileSize.x + 1 + 'px';
            tile.style.height = tileSize.y + 1 + 'px';
        }
    })
</script>
<script>

    BM.Config.HTTP_URL = "http://ua.bigemap.com:30081/bmsdk/"

    // 在ID為map的元素中實例化一個地圖,并設置地圖的ID號為 bigemap.zhongkexingtu,ID號程序自動生成,無需手動配置,并設置地圖的投影為百度地圖 ,中心點,默認的級別和顯示級別控件
    var map = BM.map('map', 'bigemap.dc-tian-w-satellite', {
        center: [39.905963, 116.390813],
        zoom: 8,
        zoomControl: true,
        attributionControl: false
    });
    let marker_arr = []
    let pass_layer = ''

    //生成假數據  數據應該又后端提供
    for (var i = 0; i < 200; i++) {
        var lat = 39.905963 + (Math.random() - Math.random()) * 3;
        var lng = 116.390813 + (Math.random() - Math.random()) * 3;

        let marker = BM.marker([lat, lng]).addTo(map)
        marker.id = i;
        marker.bindTooltip(i + '', {direction: 'bottom', permanent: true, className: 'my_tooltip'})
        marker_arr.push(marker)
    }

    //創建一個圖形覆蓋物的集合來保存點線面
    var drawnItems = new BM.FeatureGroup();
    //添加在地圖上
    map.addLayer(drawnItems);


    //監聽繪畫完成事件
    map.on(BM.Draw.Event.CREATED, function (e) {
        //判斷是否存在繪制的layer 刪除掉
        if (pass_layer != '') pass_layer.remove()
        var layer = e.layer;
        let layertype = e.layerType
        pass_layer = layer

        drawnItems.addLayer(layer);
        let in_arr = []
        //判斷是多邊形還是圓形
        if (layertype == 'polygon') {
            //判斷哪些點在多邊形里
            let polygonlatlng = layer.getLatLngs()

            //polygon的平面左邊數組
            let ps = polygonlatlng[0].map(v => {
                let arr = [v.lat, v.lng]
                return [map.project(arr).x, map.project(arr).y];
            });

            marker_arr.forEach(v => {
                let latlng = v.getLatLng()
                //點的平面坐標
                var point = map.project([latlng.lat, latlng.lng]);
                if (isIn([point.x, point.y], ps)) {
                    in_arr.push(v.id)
                }
            })

        } else if (layertype == 'circle') {
            //圓形
            //比較中心點
            let center = layer.getLatLng();
            let radius = layer.getRadius();

            marker_arr.forEach(v => {
                let latlngs = [v.getLatLng(), center]
                //計算距離
                let distance = map.distance(latlngs[0], latlngs[1]);
                if (distance <= radius) {
                    in_arr.push(v.id)
                }
            })
        }
        //提示在框選范圍的marker
        appendtip(in_arr)
        draw.disable()
        draw = ''
    });
    //設置一個變量來保存當前的繪制對象
    var draw;

    function drawlayer(type) {
        if (!draw) {
            switch (type) {
                case 'polygon':
                    draw = new BM.Draw.Polygon(map);
                    break;
                case 'circle':
                    draw = new BM.Draw.Circle(map);
                    break;
            }

        }
        draw.enable();
    }

    let xzdiv = document.getElementsByClassName('xzdiv')


    //展示tip
    function appendtip(arr) {
        console.log(xzdiv)
        let div2 = document.createElement('div')
        arr.forEach(v => {
            let span2 = document.createElement('span')
            span2.innerText = v + ','
            div2.append(span2)
        })
        console.log(div2)
        xzdiv[0].innerHTML = div2.innerHTML
    }

    //判斷函數
    function isIn(a, b, c) {
        var d = a[0];
        a = a[1];
        var e = !1, f, h, k, l, m = b.length, n = 0;
        for (l = m - 1; n < m; l = n,
            n += 1) {
            var p = !1;
            f = b[n][0];
            h = b[n][1];
            k = b[l][0];
            l = b[l][1];
            if (f === d && h === a || k === d && l === a)
                return c ? !0 : !1;
            if (h < a === l >= a) {
                f = (k - f) * (a - h) / (l - h) + f;
                if (d === f)
                    return c ? !0 : !1;
                p = d < f
            }
            p && (e = !e)
        }
        return e
    }

</script>
</body>
</html>                                                
国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久
<code id="kseui"><acronym id="kseui"></acronym></code>
  • <abbr id="kseui"><tbody id="kseui"></tbody></abbr>
  • <button id="kseui"></button>
  • 好吊色欧美一区二区三区四区| 5566中文字幕一区二区| 蜜桃视频在线观看成人| 亚洲深夜激情| 欧美人成在线| 亚洲v欧美v另类v综合v日韩v| 精品国产一区二区三区四区vr| 亚洲免费在线| 国产精品久久久一区二区| 欧美99在线视频观看| 亚洲 国产 日韩 综合一区| 久久综合狠狠综合久久综青草| 99r国产精品视频| 巨乳诱惑日韩免费av| 正在播放亚洲| 亚洲一区二区免费看| 国产精品久久国产三级国电话系列 | 国产精品hd| 欧美xxx在线观看| 中文字幕成人一区| 相泽南亚洲一区二区在线播放| 久久久久久久久一区| 久久精品二区| 日本一区二区精品视频| 视频一区二区综合| 神马影院一区二区三区| 亚洲欧美日韩另类精品一区二区三区 | 亚洲国产免费看| 一本色道精品久久一区二区三区 | 国产精品一区二| 精品在线不卡| 特级西西444www大精品视频| 日韩电影免费观看在| 欧美 日韩 国产 一区| 欧美日韩亚洲一区三区 | 一本色道久久综合亚洲精品婷婷| 亚洲v欧美v另类v综合v日韩v| 欧美国产激情| 99国产精品久久久久久久成人热| 国产三级精品在线不卡| 久久精品女人天堂| 精品国产乱码久久久久久久软件| 日韩一二三区不卡在线视频| 欧美在线亚洲| 一区二区冒白浆视频| 狂野欧美一区| 日本一区二区三区在线视频| 国产综合18久久久久久| 免费在线国产精品| 国产欧美韩日| 国产精品我不卡| 亚洲一区二区三区四区中文| 在线精品一区| 国产精品一区在线观看| 亚洲一区二区三区涩| 国产视频一区在线观看一区免费| 国产乱人伦精品一区二区| 亚洲电影一二三区| 国产精品一国产精品k频道56| 国产精品日韩欧美一区二区| 一本久道久久综合狠狠爱亚洲精品| 亚洲精品日韩精品| 激情五月综合色婷婷一区二区| 欧美黄色aaaa| 国产精品日韩一区二区| 亚洲五月婷婷| 精品视频一区二区三区四区| 亚洲天堂久久| 久久久久欧美| 国产欧美日韩一区二区三区在线| 久久偷看各类wc女厕嘘嘘偷窃| 欧美三级午夜理伦三级中文幕| 99精品国产高清在线观看| 午夜亚洲福利| 久久久久久久久久久久久久一区| 亚洲精品1区2区| 欧美亚洲爱爱另类综合| 亚洲欧美网站| 欧美视频导航| 免费试看一区| 免费日韩av片| 欧美日韩一区二| 欧美三级电影在线播放| 久久男女视频| 99视频一区| 午夜精彩国产免费不卡不顿大片| 国产欧美在线一区二区| 亚洲欧洲在线一区| 一区二区在线观看网站| 久久久久久99| 99爱精品视频| 亚洲综合日本| 最新国产乱人伦偷精品免费网站| 日韩三级在线播放| 国内视频一区| 91国产在线免费观看| 在线亚洲成人| 亚洲国产精品久久久久婷婷老年| 色爱区成人综合网| 另类欧美小说| 国产欧美精品一区二区三区| 久久精品在线| 国产欧美成人| av不卡在线| 在线精品一区| 亚洲午夜激情| 国产精品观看| 欧美系列一区| 欧美日韩视频| 国产精品v欧美精品v日韩 | 久久久国产精品一区二区中文| 亚洲精品一品区二品区三品区| 欧美精品观看| 国产精品va| 亚洲精品欧美精品| 国产日韩视频| 亚洲一区二区三区精品在线观看| 99综合精品| 国产日本精品| 亚洲综合激情| 91在线免费看片| 国产精品亚洲一区| 久久涩涩网站| 欧美日韩中文国产一区发布| 日本黄网免费一区二区精品| 日本高清不卡一区二区三| 国产精品久久亚洲7777| 国产精品毛片va一区二区三区| 成人自拍爱视频| 精品伦理一区二区三区| 蜜桃久久影院| 亚洲最新在线| 伊甸园精品99久久久久久| 99综合精品| 99久久综合狠狠综合久久止 | 精品亚洲一区二区三区四区五区高| 精品国产一区二区三区四区精华 | 久久亚洲风情| 久草精品电影| 一区二区三区四区免费视频| 很黄很黄激情成人| 亚洲一区二区三区欧美| 久久综合图片| 欧美不卡在线一区二区三区| 中日韩在线视频| 99精品热视频只有精品10| 久久久噜噜噜久久狠狠50岁| 国产午夜精品在线| 亚洲免费不卡| 亚洲欧洲一区| 国产伦精品一区二区三区四区视频 | 手机成人在线| 一区国产精品| 成人欧美视频在线| 亚洲一区3d动漫同人无遮挡| 一本色道久久99精品综合| 超碰在线观看97| 杨幂一区欧美专区| 香蕉国产精品偷在线观看不卡| 久久天堂国产精品| 在线播放精品| 国产视频一区二区三区四区| 欧美精品国产一区| 91传媒免费看| 欧美精品亚洲精品| www.一区二区三区| 欧美日韩精品一本二本三本| 老司机午夜精品视频| 亚洲精品一区二区毛豆| 噜噜噜在线观看免费视频日韩| 日本婷婷久久久久久久久一区二区 | 欧美色欧美亚洲另类七区| 精品91在线| 欧美极品一区二区| 免费久久99精品国产自在现线| 欧洲精品久久| 久久亚洲国产精品一区二区| 欧美黄色大片网站| 精品999在线观看| 99热在线精品观看| 视频在线99| 国产另类自拍| 国产精品综合| 午夜免费电影一区在线观看| 激情小说综合网| 性欧美videos另类喷潮| 最新欧美日韩亚洲| 国产综合色一区二区三区| 国产欧美日韩一区| 欧美大片专区| 欧美下载看逼逼| 成人在线观看av| 正在播放亚洲| 在线不卡欧美| 欧美一区二区三区在线免费观看| 麻豆av一区| 国产伦精品一区二区三区四区视频| 亚洲免费成人| 欧美日韩一区在线视频| 亚洲永久激情精品|