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

顯示源代碼
探測效果
 開發文檔
            <!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>探測效果</title>
    <link  rel='stylesheet' />
    <script src='http://bigemap.com:9000/bigemap-gl.js/v1.1.0/bigemap-gl.js'></script>
</head>
<style>
    body {
        margin: 0;
        padding: 0;
    }

    #container {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 100%;
    }
</style>

<body>
    <div id="container"></div>
    <canvas id="canvas-a" width="400px" height="400px"></canvas>
    <canvas id="canvas-b" width="400px" height="400px"></canvas>
    <canvas id="canvas-c" width="400px" height="400px"></canvas>

</body>
<script>
    bmgl.Config.HTTP_URL = 'http://www.bt68f.cn:9000';
    var viewer = new bmgl.Viewer('container', { mapId: 'bigemap.zhongkexingtu' });
    viewer.scene.debugShowFramesPerSecond = true;
    //必須開啟 不然模型會移位
    viewer.scene.globe.depthTestAgainstTerrain = true;
    //通過3個畫布交替切換實現探測紋理動態
    var changenum = 0;
    var curCanvas = 'a';

    function readyCanvas(convasid, radius) {
        var canvas = document.getElementById(convasid);
        let cwidth = 400;
        let cheight = 400;
        var ctx = canvas.getContext("2d");
        ctx.clearRect(0, 0, cwidth, cheight);
        ctx.fillStyle = 'rgba(255, 255, 255, 0)';
        ctx.fillRect(0, 0, cwidth, cheight);

        for (let ii = 0; radius <= 200; ii++) {
            ctx.lineWidth = 5;
            //開始一個新的繪制路徑
            ctx.beginPath();
            //設置弧線的顏色
            var trans = 1.0 - (radius / 255);
            ctx.strokeStyle = "rgba(255, 0, 255, " + trans + ")";
            var circle = {
                x: 200, //圓心的x軸坐標值
                y: 200, //圓心的y軸坐標值
                r: radius //圓的半徑
            };
            //以canvas中的坐標點(200,200)為圓心,繪制一個半徑為50px的圓形
            ctx.arc(circle.x, circle.y, circle.r, 0, Math.PI * 2, true);
            //按照指定的路徑繪制弧線
            ctx.stroke();
            radius += 20;

        }

    }
    readyCanvas("canvas-a", 5);
    readyCanvas("canvas-b", 10);
    readyCanvas("canvas-c", 15);

    //繪制canvas圖片
    function drawCanvasImage(time, result) {
        changenum++;
        var canvas = document.getElementById("canvas-" + curCanvas);
        if (changenum >= 20) {
            changenum = 0;
            if (curCanvas === 'a')
                curCanvas = 'b';
            else if (curCanvas === 'b')
                curCanvas = 'c';
            else
                curCanvas = 'a';

        }
        return canvas;

    }
    //初始位置
    var lon = -118.760842;
    var lat = 38.132073;
    let cyheight = 1200;
    var planePosition = bmgl.Cartesian3.fromDegrees(lon, lat, cyheight)
    //改變圓錐體位置,循環畫矩形
    function changePosition() {
        if (lon > -118.755842 && lat < 38.138073) {
            lat += 0.00001;

        } else if (lat > 38.138073 && lon > -118.760842) {
            lon -= 0.00001;

        } else if (lon <= -118.760842 && lat > 38.132074) {
            lat -= 0.00001

        } else {
            lon += 0.00001;

        }

        planePosition = bmgl.Cartesian3.fromDegrees(lon, lat, cyheight)
        return planePosition

    }
    //根據圓錐中心點位置動態計算朝向、圓錐體長度
    var geoD = new bmgl.EllipsoidGeodesic();
    //頂點經緯度
    var startPt = bmgl.Cartographic.fromDegrees(-118.760842, 38.132073, 0);

    function changeOrientation() {
        //計算經度方向的夾角
        var endX = bmgl.Cartographic.fromDegrees(lon, 38.132073, 0);
        geoD.setEndPoints(startPt, endX);
        var innerS = geoD.surfaceDistance;
        var angleX = Math.atan(innerS / halfLen);

        //計算圓錐體長度
        var end = bmgl.Cartographic.fromDegrees(lon, lat, 0);
        geoD.setEndPoints(startPt, end);
        innerS = geoD.surfaceDistance;
        length = Math.sqrt(innerS * innerS + halfLen * halfLen);

        //計算緯度方向的夾角
        var endY = bmgl.Cartographic.fromDegrees(-118.760842, lat, 0);
        geoD.setEndPoints(startPt, endY);
        innerS = geoD.surfaceDistance;
        var angleY = Math.asin(innerS / length);

        //計算朝向
        var hpr = new bmgl.HeadingPitchRoll(0.0, angleX, angleY);
        var orientation = bmgl.Transforms.headingPitchRollQuaternion(planePosition, hpr);

        return orientation

    }
    var halfLen = 1000.0
    var length = 1000.0;

    function changeLength() {
        return 2 * length;

    }
    //創建圓錐實體
    var cylinder = viewer.entities.add({
        name: 'Red cone',
        position: new bmgl.CallbackProperty(changePosition, false),
        orientation: new bmgl.CallbackProperty(changeOrientation, false),
        cylinder: {
            length: new bmgl.CallbackProperty(changeLength, false),
            topRadius: 0.0,
            bottomRadius: 300.0,
            //topSurface: false,    //新增參數,控制頂部是否渲染
            bottomSurface: false,    //新增參數,控制底部是否渲染
            material: new bmgl.ImageMaterialProperty({
                image: new bmgl.CallbackProperty(drawCanvasImage, false),
                transparent: true

            })
        }
    });

    //定位到圓錐體
    var initialPosition = bmgl.Cartesian3.fromDegrees(-118.760842, 38.089073, 8000); //相機視角三要素:朝向(左右偏移),傾斜(上下偏移),翻滾角度(相機視錐體中軸線旋轉角度)
    var initialOrientation = new bmgl.HeadingPitchRoll.fromDegrees(1.27879878293835, -51.34390550872461, 0.0716951918898415);
    viewer.scene.camera.setView({
        destination: initialPosition,
        orientation: initialOrientation,
        endTransform: bmgl.Matrix4.IDENTITY
    });
</script>

</html>                                            
主站蜘蛛池模板: 国产欧美精品区一区二区三区 | 亚洲av毛片成人精品 | 日本一区二区三区电影 | 国产特级毛片aaaaaa高清 | 国产精品三 | 欧美韩日一区二区 | 亚洲综合图 | 欧美日韩三级在线观看 | 日本大码a∨欧美在线 | 桃色五月 | 国产成人免费网站 | 91色视频在线 | av看片网站| 青草久久久 | 国产在线观看精品 | 欧美成人高清视频 | 911久久香蕉国产线看观看 | 免费一级毛片免费播放 | 91精品国产91久久久久久久久久久久 | 年轻母亲2在线播放 | 四季av中文字幕 | 天天操电影 | 可以看毛片的网站 | 日韩一级在线观看 | 色网站视频 | 全部孕妇毛片免费孕妇 | 国产午夜在线 | 亚洲欧美影院 | 欧美日韩亚洲在线 | 久久久精品国产免费观看一区二区 | 久草免费电影 | ww又激又色又爽又免费视频 | 国产91清纯白嫩初高中在线观看 | 91精品久久久久久久久入口 | 欧美一级片在线视频 | 久久无人码一码二码三码 | 三级特黄60分钟在线观看 | 亚洲欧美视频一区 | 国产成人免费av一区二区午夜 | 国产性猛交xxxx免费看久久 | 最近中文字幕2019在线一区 |