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

顯示源代碼
五彩線
 開發文檔
            <!DOCTYPE html>

<html>
<head>
    <meta charset='UTF-8'/>
    <meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no'/>
    <link  rel='stylesheet'/>
    <script src='http://ua.bigemap.com:30081/bmsdk/bigemap-gl.js/v1.1.0/bigemap-gl.js'></script>
    <style>
        body {
            margin: 0;
            padding: 0;
        }

        #container {
            position: absolute;
            top: 0;
            bottom: 0;
            width: 100%;
        }
        .bmgl-widget-credits{display:none}
    </style>
    <title>part_test</title>
</head>
<body>

<div id='container'></div>

<script>
    bmgl.Config.HTTP_URL = 'http://ua.bigemap.com:30081/bmsdk/';
    var viewer = new bmgl.Viewer('container', {mapId: 'bigemap.dc-tian-w-satellite',requestRenderMode:false,});
    var lat = 30.598026044;
    var lon = 114.302312702;
    viewer.scene.globe.depthTestAgainstTerrain = true;
    //取消雙擊事件
    viewer.BMWidget.screenSpaceEventHandler.removeInputAction(bmgl.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
    //設置homebutton的位置
    bmgl.Camera.DEFAULT_VIEW_RECTANGLE =
        bmgl.Rectangle.fromDegrees(lon - 1, lat - 1, lon + 1, lat + 1);
    //設置初始位置
    viewer.camera.setView({
        destination: bmgl.Cartesian3.fromDegrees(lon, lat, 300000)
    });


    /*
      流紋紋理線
      color 顏色
      duration 持續時間 毫秒
   */
    function PolylineTrailLinkMaterialProperty(color, duration) {
        this._definitionChanged = new bmgl.Event();
        this._color = undefined;
        this._colorSubscription = undefined;
        this.color = color;
        this.duration = duration;
        this._time = (new Date()).getTime();
    }

    bmgl.defineProperties(PolylineTrailLinkMaterialProperty.prototype, {
        isConstant: {
            get: function () {
                return false;
            }
        },
        definitionChanged: {
            get: function () {
                return this._definitionChanged;
            }
        },
        color: bmgl.createPropertyDescriptor('color')
    });
    PolylineTrailLinkMaterialProperty.prototype.getType = function (time) {
        return 'PolylineTrailLink';
    }
    PolylineTrailLinkMaterialProperty.prototype.getValue = function (time, result) {
        if (!bmgl.defined(result)) {
            result = {};
        }
        result.color = bmgl.Property.getValueOrClonedDefault(this._color, time, bmgl.Color.WHITE, result.color);
        result.image = bmgl.Material.PolylineTrailLinkImage;
        result.time = (((new Date()).getTime() - this._time) % this.duration) / this.duration;
        return result;
    }
    PolylineTrailLinkMaterialProperty.prototype.equals = function (other) {
        return this === other ||
            (other instanceof PolylineTrailLinkMaterialProperty &&
                bmgl.Property.equals(this._color, other._color))
    }
    bmgl.PolylineTrailLinkMaterialProperty = PolylineTrailLinkMaterialProperty;
    bmgl.Material.PolylineTrailLinkType = 'PolylineTrailLink';
    bmgl.Material.PolylineTrailLinkImage = "/bmgl/images/colors.png";
    bmgl.Material.PolylineTrailLinkSource = "czm_material czm_getMaterial(czm_materialInput materialInput)\n\
                                                      {\n\
                                                           czm_material material = czm_getDefaultMaterial(materialInput);\n\
                                                           vec2 st = materialInput.st;\n\
                                                           vec4 colorImage = texture2D(image, vec2(fract(st.s - time), st.t));\n\
                                                           material.alpha = colorImage.a * color.a;\n\
                                                           material.diffuse = (colorImage.rgb+color.rgb)/2.0;\n\
                                                           return material;\n\
                                                       }";
    bmgl.Material._materialCache.addMaterial(bmgl.Material.PolylineTrailLinkType, {
        fabric: {
            type: bmgl.Material.PolylineTrailLinkType,
            uniforms: {
                color: new bmgl.Color(1.0, 0.0, 0.0, 0.5),
                image: bmgl.Material.PolylineTrailLinkImage,
                time: 0
            },
            source: bmgl.Material.PolylineTrailLinkSource
        },
        translucent: function (material) {
            return true;
        }
    });

    function parabolaEquation(options, resultOut) {
        //方程 y=-(4h/L^2)*x^2+h h:頂點高度 L:橫縱間距較大者
        var h = options.height && options.height > 5000 ? options.height : 5000;
        var L = Math.abs(options.pt1.lon - options.pt2.lon) > Math.abs(options.pt1.lat - options.pt2.lat) ? Math.abs(options.pt1.lon - options.pt2.lon) : Math.abs(options.pt1.lat - options.pt2.lat);
        var num = options.num && options.num > 50 ? options.num : 50;
        var result = [];
        var dlt = L / num;
        if (Math.abs(options.pt1.lon - options.pt2.lon) > Math.abs(options.pt1.lat - options.pt2.lat)) {//以lon為基準
            var delLat = (options.pt2.lat - options.pt1.lat) / num;
            if (options.pt1.lon - options.pt2.lon > 0) {
                dlt = -dlt;
            }
            for (var i = 0; i < num; i++) {
                var tempH = h - Math.pow((-0.5 * L + Math.abs(dlt) * i), 2) * 4 * h / Math.pow(L, 2);
                var lon = options.pt1.lon + dlt * i;
                var lat = options.pt1.lat + delLat * i;
                result.push([lon, lat, tempH]);
            }
        } else {//以lat為基準
            var delLon = (options.pt2.lon - options.pt1.lon) / num;
            if (options.pt1.lat - options.pt2.lat > 0) {
                dlt = -dlt;
            }
            for (var i = 0; i < num; i++) {
                var tempH = h - Math.pow((-0.5 * L + Math.abs(dlt) * i), 2) * 4 * h / Math.pow(L, 2);
                var lon = options.pt1.lon + delLon * i;
                var lat = options.pt1.lat + dlt * i;
                result.push([lon, lat, tempH]);
            }
        }
        if (resultOut != undefined) {
            resultOut = result;
        }
        return result;
    }
    var center = {lon: 114.302312702, lat: 30.598026044}
    var cities = [{"lon": 115.028495718, "lat": 30.200814617},
        {"lon": 110.795000473, "lat": 32.638540762},
        {"lon": 111.267729446, "lat": 30.698151246},
        {"lon": 112.126643144, "lat": 32.058588576},
        {"lon": 114.885884938, "lat": 30.395401912},
        {"lon": 112.190419415, "lat": 31.043949588},
        {"lon": 113.903569642, "lat": 30.932054050},
        {"lon": 112.226648859, "lat": 30.367904255},
        {"lon": 114.861716770, "lat": 30.468634833},
        {"lon": 114.317846048, "lat": 29.848946148},
        {"lon": 113.371985426, "lat": 31.704988330},
        {"lon": 109.468884533, "lat": 30.289012191},
        {"lon": 113.414585069, "lat": 30.368350431},
        {"lon": 112.892742589, "lat": 30.409306203},
        {"lon": 113.160853710, "lat": 30.667483468},
        {"lon": 110.670643354, "lat": 31.748540780}]
    var material = new bmgl.PolylineTrailLinkMaterialProperty(bmgl.Color.ORANGE, 3000);
    for (var j = 0; j < cities.length; j++) {
        var points = parabolaEquation({pt1: center, pt2: cities[j], height: 50000, num: 100});
        var pointArr = [];
        for (var i = 0; i < points.length; i++) {
            pointArr.push(points[i][0], points[i][1], points[i][2]);
        }
        viewer.entities.add({
            name: 'PolylineTrailLink' + j,
            polyline: {
                positions: bmgl.Cartesian3.fromDegreesArrayHeights(pointArr),
                width: 2,
                material: material
            }
        });
    }

    viewer.entities.add({
        position: bmgl.Cartesian3.fromDegrees(center.lon, center.lat, 1),
        point: {
            pixelSize: 6,
            color: bmgl.Color.BLUE
        }
    });

    for (var i = 0; i < cities.length; i++) {
        viewer.entities.add({
            position: bmgl.Cartesian3.fromDegrees(cities[i].lon, cities[i].lat, 1),
            point: {
                pixelSize: 6,
                color: bmgl.Color.RED
            }
        });
    }
    viewer.camera.flyTo({
        destination:new bmgl.Cartesian3(-2431832.05398568,5312676.685486797,2943588.1345312647),
        orientation:{
            "heading":6.0061437086517575,"roll":0.0000660000291583529,"pitch":-0.3938144380432427
        }
    });
</script>
</body>
</html>                                                                                                                                                                                                                                                                    
国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久
<code id="kseui"><acronym id="kseui"></acronym></code>
  • <abbr id="kseui"><tbody id="kseui"></tbody></abbr>
  • <button id="kseui"></button>
  • 国产一区白浆| 99综合在线| 五月天丁香综合久久国产| 好吊日精品视频| 亚洲欧美日韩在线观看a三区| 久久大片网站| 国产精品一区二区欧美| 狠狠入ady亚洲精品经典电影| 国产精品swag| 久热国产精品| 美女精品网站| 国产欧美日本在线| 99国产精品99久久久久久粉嫩| 国产亚洲亚洲| 欧美久久电影| 免费电影一区| 国产精品vip| 国产成人免费观看| 97碰碰视频| aa成人免费视频| 欧美日韩免费观看一区| 欧美日一区二区三区在线观看国产免| 久久精品国产第一区二区三区最新章节| 久久久久久久久一区| 国模精品一区二区三区| 99视频网站| 正在播放一区二区三区| 一区二区三区国| 国产亚洲网站| 亚洲欧洲国产精品久久| 欧美.日韩.国产.一区.二区| 在线观看日本一区| 久久欧美肥婆一二区| 日韩精品一区二区三区四区五区 | 亚洲欧洲一区| 蜜桃av噜噜一区二区三区| 亚洲制服欧美久久| 国产91aaa| 欧美精品一区在线发布| 亚洲高清视频一区二区| 国产欧美综合一区二区三区| 欧美日韩精品综合| 91中文字精品一区二区| 国产精品二区在线| 日韩中文字幕av在线| 国产aⅴ精品一区二区三区黄| 欧美福利电影在线观看| 亚洲人体偷拍| 亚洲一卡二卡三卡| 欧美成人一区二区在线| 日韩视频在线一区二区三区| 激情成人综合| 日产中文字幕在线精品一区 | 国产精品久久久一区二区| 欧美三日本三级少妇三99| 国产伦精品一区二区三区在线 | 成人3d动漫一区二区三区91| 国产精品www994| 日本成人黄色免费看| 国产欧美丝袜| 99精品国产高清一区二区| 一区二区高清视频| 伊人久久亚洲美女图片| 伊人天天久久大香线蕉av色| 综合久久国产| 色爱区成人综合网| 国产三区精品| 成人免费视频网站| 男人的天堂亚洲在线| 亚洲精品123区| 欧美精品二区三区四区免费看视频| 亚洲v国产v在线观看| 亚洲黄色一区| 日韩影院一区| 欧美色欧美亚洲另类七区| 国产精品久久久久av福利动漫| 久久精品电影| 久久综合五月| 国产亚洲情侣一区二区无| 99porn视频在线| 97超级碰碰| 国产高清一区二区三区| 91高跟黑色丝袜呻吟在线观看| 午夜精品福利一区二区| 久久久久久久久久久一区| 看欧美日韩国产| 亚洲aⅴ天堂av在线电影软件| 亚洲一区综合| 亚洲先锋成人| 亚洲一区欧美激情| 动漫3d精品一区二区三区| 国产女主播一区二区| 精品日韩美女| 中文字幕av日韩精品| 亚洲精品女人| 不卡日韩av| 婷婷精品国产一区二区三区日韩| 欧美午夜不卡| 久久精品一二三区| 日韩在线三区| 国产日韩欧美亚洲一区| 99久久99久久| 日韩尤物视频| 国产欧美日韩一区二区三区在线| 国产高清一区二区三区| 亚洲欧美影院| 亚洲一区图片| 日韩久久精品一区二区三区| 欧美视频福利| caoporen国产精品| 宅男噜噜99国产精品观看免费| 一本色道久久综合一区| 久久久婷婷一区二区三区不卡| 在线看视频不卡| 91aaaa| 日产精品一线二线三线芒果| 亚洲激情午夜| 久久99精品久久久久子伦 | 久久久久欧美精品| 日本一区免费看| 国产一区二区三区高清| 欧美不卡在线一区二区三区| 亚洲精品专区| 日韩av电影免费观看| 国产欧美日韩一区| 亚洲激情图片| 超碰97在线播放| 欧美日韩综合网| 久久国产精品精品国产色婷婷| 在线日本成人| 亚洲精品乱码久久久久久蜜桃91 | 免费精品视频一区| 国产精品丝袜xxxxxxx| 亚洲欧美日韩精品在线| 成人在线免费观看一区| 狠狠色噜噜狠狠狠狠色吗综合| 九九九久久久| 亚洲一区自拍| 樱桃成人精品视频在线播放| 久久日韩精品| 波多野结衣成人在线| 激情综合久久| 中文字幕一区二区三区四区五区| 久久久蜜桃一区二区人| 在线播放豆国产99亚洲| 日韩欧美精品一区二区| 国产一区二区在线网站 | 亚洲高清资源综合久久精品| 久久久久欧美| 国产日韩高清一区二区三区在线| 亚洲精品乱码视频| 精品国产综合久久| 老牛嫩草一区二区三区日本| 国产精品v日韩精品v欧美精品网站 | 久草热久草热线频97精品| 久久国产精品久久精品国产 | 亚洲欧美精品| 亚洲婷婷在线| 欧美日韩免费高清| 亚洲综合五月天| 欧美一区观看| 青娱乐一区二区| 久久天天狠狠| 久久av二区| 欧美精品v日韩精品v国产精品| 国产日韩一区欧美| 精品一区二区久久久久久久网站| 久久亚洲国产精品日日av夜夜| 亚洲经典在线看| 亚洲人成在线影院| 99热免费精品在线观看| 亚洲美女少妇无套啪啪呻吟| 99日韩精品| 免费中文字幕日韩欧美| 久久aⅴ乱码一区二区三区| 国产欧美大片| 久久一区二区精品| 国产91亚洲精品一区二区三区| 国产成人成网站在线播放青青| 99在线视频播放| 免费成人av网站| 日本成人三级电影网站| 翔田千里亚洲一二三区| 欧美 日韩 国产在线| 亚洲第一毛片| 午夜宅男久久久| 老司机久久99久久精品播放免费| 久久国产欧美精品| 黄色国产精品一区二区三区| 久热这里只精品99re8久 | 影音先锋久久资源网| 亚洲日本激情| 91手机在线观看| 精品欧美一区二区三区久久久| 日韩福利视频| 黄色国产精品一区二区三区| 国产一区二区三区免费不卡 | 久久亚洲一区二区| 精品一区二区三区视频日产| 天堂社区 天堂综合网 天堂资源最新版|