BIGEMAP卫星地图_高清卫星地图_北斗高清地图_地图软件_矢量地图数据_专题地图

顯示源代碼
地圖二三維切換
 開發文檔
            <!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <script src="http://bigemap.com/offline_data/newjunbiao/vue.js"></script>
        <link
            href="http://ua.bigemap.com:30081/bmsdk/bigemap-gl.js/v1.1.0/Widgets/widgets.css"
            rel="stylesheet"
        />
        <script src="http://ua.bigemap.com:30081/bmsdk/bigemap-gl.js/v1.1.0/bigemap-gl.js"></script>
        <!-- elementui -->
        <script src="http://bigemap.com/offline_data/newjunbiao/elementui.js"></script>
        <link
            rel="stylesheet"
            href="http://bigemap.com/offline_data/newjunbiao/elementui.css"
        />
        <title>地圖二三維切換</title>
        <style>
            * {
                margin: 0;
                padding: 0;
            }
            html,
            body {
                width: 100%;
                height: 100%;
            }
            #app {
                width: 100%;
                height: 100%;
            }
            #baseMap {
                width: 100%;
                height: 100%;
            }
            .tools {
                position: absolute;
                z-index: 9;
                top: 40px;
                right: 60px;
                width: 420px;
                height: 40px;
                display: flex;
                align-items: center;
            }
        </style>
    </head>
    <body>
        <div id="app">
            <div class="tools">
                <el-button type="danger" size="small" @click="switchTo2d"
                    >切換為二維視角效果</el-button
                >
                <el-button
                    type="warning"
                    size="small"
                    @click="switchToColumbusView"
                    >切換為哥倫布視角效果</el-button
                >
                <el-button type="primary" size="small" @click="switchTo3d"
                    >切換為三維視角效果</el-button
                >
            </div>
            <div id="baseMap"></div>
        </div>
        <script>
            window.viewer = null;
            window.onload = () => {
                new Vue({
                    el: "#app",
                    data() {
                        return {};
                    },
                    mounted() {
                        this.initMap();
                    },
                    methods: {
                        //初始化地圖
                        initMap() {
                            bmgl.Config.HTTP_URL =
                                "http://ua.bigemap.com:30081/bmsdk/";
                            viewer = new bmgl.Viewer("baseMap", {
                                mapId: "bigemap.dc-satellite",
                                infoBox: false,
                                selectionIndicator: false,
                                requestRenderMode: false,
                            });
                        },
                        //切換為2d
                        switchTo2d() {
                            // console.log("2ddd");
                            if (viewer.scene.mode == 2) return;
                            let view = {};
                            //獲取轉換為2d模式前,當前鏡頭的經緯度位置
                            let p = bmgl.Cartographic.fromCartesian(
                                viewer.camera.position
                            );
                            view.destination = {
                                lng: bmgl.Math.toDegrees(p.longitude),
                                lat: bmgl.Math.toDegrees(p.latitude),
                                height: p.height,
                            };
                            view.orientation = {
                                heading: viewer.camera.heading,
                                roll: viewer.camera.roll,
                                pitch: viewer.camera.pitch,
                            };
                            //將3d模式切換為2d
                            // viewer.scene.morphTo2D(0);
                            viewer.scene.morphTo2D(0, (e) => {
                                console.log("Finish 2d");
                                viewer.camera.setView({
                                    destination: bmgl.Cartesian3.fromDegrees(
                                        view.destination.lng,
                                        view.destination.lat,
                                        view.destination.height
                                    ),
                                    orientation: {
                                        heading: 0,
                                        pitch: bmgl.Math.toRadians(-90),
                                        roll: 0,
                                    },
                                });
                            });
                        },
                        //切換為3d
                        switchTo3d() {
                            // console.log("3ddd");
                            if (viewer.scene.mode == 3) return;
                            let result = this.getPos();
                            viewer.scene.morphTo3D(0, (e) => {
                                viewer.camera.setView({
                                    destination: result.destination,
                                    orientation: result.orientation,
                                });
                            });
                        },
                        //切換為2.5d哥倫布視角
                        switchToColumbusView() {
                            if (viewer.scene.mode == 2.5) return;
                            let result = this.getPos();
                            viewer.scene.morphToColumbusView(0, (e) => {
                                viewer.camera.setView({
                                    destination: result.destination,
                                    orientation: result.orientation,
                                });
                            });
                        },

                        getPos() {
                            let params = {};
                            let ellipsoid = viewer.scene.globe.ellipsoid;
                            let camera = viewer.scene.camera;
                            let extend = viewer.camera.computeViewRectangle();
                            if (typeof extend === "undefined") {
                                //2D下會可能拾取不到坐標,extend返回undefined,所以做以下轉換
                                let canvas = viewer.scene.canvas;
                                let upperLeft = new bmgl.Cartesian2(0, 0); //canvas左上角坐標轉2d坐標
                                let lowerRight = new bmgl.Cartesian2(
                                    canvas.clientWidth,
                                    canvas.clientHeight
                                ); //canvas右下角坐標轉2d坐標

                                let ellipsoid = viewer.scene.globe.ellipsoid;
                                let upperLeft3 = viewer.camera.pickEllipsoid(
                                    upperLeft,
                                    ellipsoid
                                ); //2D轉3D世界坐標

                                let lowerRight3 = viewer.camera.pickEllipsoid(
                                    lowerRight,
                                    ellipsoid
                                ); //2D轉3D世界坐標

                                let upperLeftCartographic =
                                    viewer.scene.globe.ellipsoid.cartesianToCartographic(
                                        upperLeft3
                                    ); //3D世界坐標轉弧度
                                let lowerRightCartographic =
                                    viewer.scene.globe.ellipsoid.cartesianToCartographic(
                                        lowerRight3
                                    ); //3D世界坐標轉弧度

                                let minx = bmgl.Math.toDegrees(
                                    upperLeftCartographic.longitude
                                ); //弧度轉經緯度
                                let maxx = bmgl.Math.toDegrees(
                                    lowerRightCartographic.longitude
                                ); //弧度轉經緯度

                                let miny = bmgl.Math.toDegrees(
                                    lowerRightCartographic.latitude
                                ); //弧度轉經緯度
                                let maxy = bmgl.Math.toDegrees(
                                    upperLeftCartographic.latitude
                                ); //弧度轉經緯度

                                params.minx = minx; // 最小經度
                                params.maxx = maxx; // 最大經度
                                params.miny = miny; // 最小緯度
                                params.maxy = maxy; // 最大緯度
                            } else {
                                //3D獲取方式
                                // 最大經度
                                params.maxx = bmgl.Math.toDegrees(extend.east); //弧度轉經緯度
                                // 最大緯度
                                params.maxy = bmgl.Math.toDegrees(extend.north); //弧度轉經緯度
                                // 最小經度
                                params.minx = bmgl.Math.toDegrees(extend.west); //弧度轉經緯度
                                // 最小緯度
                                params.miny = bmgl.Math.toDegrees(extend.south); //弧度轉經緯度
                            }
                            let height =
                                camera.frustum.right - camera.frustum.left;

                            return {
                                destination: bmgl.Cartesian3.fromDegrees(
                                    (params.minx + params.maxx) / 2,
                                    (params.miny + params.maxy) / 2,
                                    height
                                ),

                                orientation: {
                                    heading: 0,
                                    pitch: bmgl.Math.toRadians(-90),
                                    roll: 0,
                                },
                            };
                        },
                    },
                    beforeDestroy() {
                        viewer.destroy();
                        viewer = null;
                    },
                });
            };
        </script>
    </body>
</html>
        
主站蜘蛛池模板: 生物安全柜检测,GMP设备确认,仪器性能确认,洁净厂房检测,仓储温湿度检测-上海熙迈 | 腻子粉厂家_耐水腻子粉_内墙腻子粉批发_生态腻子粉_长沙美恩生态腻子粉厂家 | 江南专汽公司首页-消防车厂家,水罐/泡沫消防车价格(热销品牌) | 呼吸家官网|肺功能检测仪生产厂家|国产肺功能仪知名品牌|肺功能检测仪|肺功能测试仪|婴幼儿肺功能仪|弥散残气肺功能仪|肺功能测试系统|广州红象医疗科技有限公司|便携式肺功能仪|大肺功能仪|呼吸康复一体机|儿童肺功能仪|肺活量计|医用简易肺功能仪|呼吸康复系统|肺功能仪|弥散肺功能仪(大肺)|便携式肺功能检测仪|肺康复|呼吸肌力测定肺功能仪|肺功能测定仪|呼吸神经肌肉刺激仪|便携式肺功能 | 卫生级自吸泵-不锈钢化工离心泵-上海胜欧泵阀有限公司 | 芜湖净水设备-纯水设备-无负压供水设备-不锈钢水箱-芜湖市百川给水设备有限责任公司 | 江苏德邦化学工业集团有限公司| 显微镜|金相显微镜|光学显微镜专业生产商-上海光学仪器厂 | 山东德曼医疗设备集团有限公司| 锯轨机|气动锯轨机|内燃锯轨机|电动钢轨钻孔机|内燃钢轨钻孔机-山东卓力铁路设备有限公司 | 免费照片视频制作软件_照片做成视频的软件_制作照片视频的软件 - 万彩影像大师官网 | 酸碱废气中和塔-酸雾废气吸收塔-酸雾废气处理塔|首页-广州市佰镀通风设备有限公司 | 济宁市兴大工程机械有限公司 | 种植槽系统,移动苗床,多层种植货架,潮汐苗床,物流苗床,潮汐面板,立体旋转育秧床,河北博超温室设备有限公司 | 喜有沃-河南不锈钢管厂家批发201,304不锈钢管-现货规格齐全 | 长沙升阳化工材料有限公司 | 锯骨机-砍排机-全自动锯骨机-商用砍排机-切丁机 - 广州市九盈机械设备有限公司 | 浙江桥梁检测车出租_杭州桥检车出租_桥梁检测车出租_桥检车租赁_桥梁检测车租赁-广州众诚设备租赁有限公司 | 深圳社区邦家政公司-保姆_月嫂_育儿嫂 _早教育婴师_家政钟点工_家政培训_家政加盟- 社区邦优质生活服务 专业、标准化、便捷、安心,一站式家庭服务平台,服务专业有保障 ! | 金华银焊条-金华银焊丝-银焊片制造商-银焊环批发商-浙江焊丝生产商-焊环厂家-浙江永旺焊材制造有限公司 | 选金银铅锌钽铌锡铂钨铑铱镐钯宝石&金属尾矿重选-青州冠诚重工机械 | 普利塞HS穿刺活检针-巴德穿刺活检针-美创爱琅Argon活检针同轴针-山东瑞玺源 | 津南人才网_津南招聘网_求职找工作平台 | 无锡亮鑫不锈钢有限公司-不锈钢炉胆,马弗炉胆,耐高温炉胆,310s炉胆,网带炉 | 铱金供应-上海钌合金-氯铱酸厂家-上海庞势新材料科技有限公司 | 天津印刷_天津印刷厂_天津印刷公司_天津包装盒厂家_天津包装盒印刷厂_七层共挤膜厂家_彩色印刷_画册印刷_礼品盒定做 _七层共挤膜_食品真空袋-欢迎访问嘉联包装官网! | 手游下载_app下载_好玩的手游下载_安卓市场下载_163下载 | 扬州市德友线缆有限公司-业从事高端特种线缆研发、制造、销售与服务。 | 硬度计,里氏硬度计,布氏硬度计,高强螺栓检测仪,平板导热仪,专业无损检测仪器商-北京时代新天测控技术有限公司-北京时代新天测控技术有限公司 | 吸管包装机_塑料杯包装机_纸杯包装机_吸管挤出机_温州恩博机械有限公司 | 数据交易导航,数据资产入表,数据交易平台,数据要素市场 | 无锡防火门|无锡放火卷帘门|无锡市防火卷帘门厂有限公司 | 真空清洗炉_电磁感应真空清洗炉-盐城市盛逸化纤机械有限公司 | 四通球阀_304真空阀_不锈钢五通球阀厂家-浙江壬丰阀门有限公司 | 郑州办公家具厂_河南办公家具厂_河南办公家具-河南华诺家具 | 铸造厂-铸铝-铸铜-铝合金铸造-重力铸造-翻砂铸造-[剑锋机械配件]专业东莞|深圳铸造厂 | 名嘉宴会【官网】_宁波冷餐_宁波茶歇_宁波酒会_宁波自助餐_宁波盛世名嘉宴会服务有限公司 | 义乌供需网-义乌外发加工来料加工,义乌采购信息供求对接平台(yiwugongxu.com) | 气瓶探伤设备-气瓶在线离线无损探伤检测系统-中高低压力容器超声波自动探伤设备-山科飞泰 | 葫芦岛装修公司,兴城装修家装公司,葫芦岛鑫昕装饰 | 塑料振动筛-防腐蚀振动筛-聚丙烯振动筛-塑料振动筛厂家河南迈能机械设备有限公司 |