123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371 |
- // 创建app
- var app = new THING.App({
- url: '/api/scene/0b75dc5f4460f22c329afd96',
- // url: '/api/scene/ab93bd9640a9db05a4937351',
- background: 'https://www.thingjs.com/static/images/background_img_03.png'
- });
- //设备列表
- var buildingStore;
- $.ajax({
- type: "GET",
- url:'/uploads/wechat/163607/file/杨浦16/buildingStore.json',
- dataType: "json",
- async: false,
- success: function (data) {
- console.log(data)
- buildingStore = data.buildingStore
- }
- });
- app.camera.xAngleLimitRange = [0, 90];
- var campusUrl;//场景列表
- var dataObj = { progress: 0 }; // 场景加载进度条数据对象
- var loadingPanel; // 进度条界面组件
- var curCampus;//存放园区url路径
- var company_code;
- var buildingStore;
- var miniMapCtrl = null; // 小地图控件
- var webSocket;//webSocket
- var tileLayer1 = null; // 加入地图背景后选用的图层
- var box = null; // 鼠标点击第一人称行走按钮时,红色盒子提示
- var fpsCtrl = null; // 第一人称行走控件
- var cameraInitPos = null; // 进入第一人称行走前摄像机位置
- var fullScreenState = false; // 全屏
- var skyBox = null; // 天空盒
- var hiddenControlTimer = null; // 隐藏控制按钮计时器
- var showControlTimer = null; // 显示控制按钮计时器
- var cameraDistace = [];
- var building = null, mainPanle; // 建筑
- var restartTime = 5000; // 自动旋转停止后重启时间间隔
- var rotateTimer = null; // 自动旋转计时器
- //var baseURL = "http://47.103.74.123/ThingjsIcon/";
- var baseURL = "https://s3.ax1x.com/2021/01/28/";
- var filePath = '/uploads/wechat/5oiR5pyJ5pyA6ZW/55qE572R5ZCN5LiN5L+h5L2g5pWw5pWw/file/ScenePreview/';
- // 需要用到的外部文件
- var fileArr = [
- "https://www.layuicdn.com/layui/layui.js",
- 'https://www.layuicdn.com/layui/css/layui.css',
- filePath + 'assets/css/index.css', // 功能按钮样式文件
- filePath + 'assets/font-awesome-4.7.0/css/font-awesome.min.css', // 功能按钮字体样式
- filePath + 'assets/css/myAlert.css', // 弹出框样式
- filePath + 'assets/css/sweetalert2.min.css', // 弹出框样式
- filePath + 'assets/js/sweetalert2.all.min.js', // 弹出框脚本
- filePath + 'assets/js/myAlert.js', // 弹出框脚本
- filePath + 'assets/js/posTransform.js', // 不同坐标系经纬度互相转换的脚本文件
- filePath + 'assets/js/expandFloor.js', // 楼层展开脚本
- '/guide/lib/echarts.min.js',
- '/uploads/wechat/163607/file/杨浦16/removeMark.js',//清除标注脚本
- '/uploads/wechat/163607/file/杨浦16/UIAnchor.js',//UI界面脚本
- '/uploads/wechat/163607/file/杨浦16/FloorClick.js',//创建切换楼层脚本
- '/uploads/wechat/163607/file/杨浦16/MainPanel.js',//公共工具功能脚本
- '/uploads/wechat/163607/file/杨浦16/CreateHtml.js',//创建页面元素脚本
- '/uploads/wechat/163607/file/杨浦16/public.js',//公共场景功能脚本
- '/uploads/wechat/163607/file/杨浦16/ChangeScene.js',//场景切换脚本
- ];
- /**
- * 说明:加载外部文件
- */
- THING.Utils.dynamicLoad(fileArr, function () {
- app.on('load', function (ev) {
- skyBox = app.skyBox; // 获取天空盒
- app.level.change(ev.campus); // 切换至园区层级
- ev.campus.azimuth = '180';
- mainPanle = new MainPanel(app);// 界面的类
- // setupNavpanel();
- // creatFloorChoose(); //======================================本地数据测试===============================================
- // 获取园区在CampusBuilder编辑时保存的地理位置
- let tjsLnglat = app.root.defaultCampus.extraData;
- if (tjsLnglat != undefined && tjsLnglat != null) {
- tjsLnglat = tjsLnglat.coordinates;
- if (tjsLnglat != undefined && tjsLnglat != null) {
- tjsLnglat = tjsLnglat.split(",");
- }
- } else {
- ev.campus.extraData = { coordinates: "116.4641,39.98606" } // 园区绑定默认经纬度,地图才生效
- }
- createHtml(); // 创建html
- restarRotate(); // 自动旋转
- curCampus = ev.campus;
- // 进入层级切换
- app.level.change(ev.campus);
- });
- });
- // 监听建筑层级的 LeaveLevel 事件
- app.on(THING.EventType.LeaveLevel, ".Building", function (ev) {
- // 要进入的层级对象
- var current = ev.current;
- // 上一层级对象(退出的层级)
- var preObject = ev.previous;
- if (current.parent === preObject) {
- removeMark();
- }
- else {
- removeMark();
- }
- })
- /**
- * 说明:注册事件
- */
- function registerEvent() {
- var _this = this
- // 楼层横向展开按钮的点击事件,楼层展开只在建筑有2层或2层以上的楼层才会生效
- $('#horizontalExpansion').on('click', function () {
- stopRotate();
- checkBtnActives(['#mapBg', '#sceneSetting']);
- let expandState = building.getAttribute('expandState');
- if ($(this).hasClass('active')) {
- // 楼层横向展开关闭
- if (expandState == 'horizontal') {
- $(this).removeClass('active');
- horizontalExpand(building, 'close');
- }
- } else {
- // 楼层横向展开前应判断楼层是否处于垂直展开状态,是,则应先关闭垂直展开,然后横向展开
- if (expandState != 'moving') {
- $(this).addClass('active');
- $('#verticalExpansion').removeClass('active');
- if (expandState == 'vertical') {
- verticalToHorizontal(building);
- } else {
- horizontalExpand(building, 'horizontal');
- }
- }
- }
- restarRotate();
- });
- // 楼层垂直展开按钮的点击事件,楼层展开只在建筑有2层或2层以上的楼层才会生效
- $('#verticalExpansion').on('click', function () {
- stopRotate();
- checkBtnActives(['#mapBg', '#sceneSetting']);
- let expandState = building.getAttribute('expandState');
- if ($(this).hasClass('active')) {
- // 楼层垂直展开关闭
- if (expandState == 'vertical') {
- $(this).removeClass('active');
- verticalExpand(building, 'close');
- }
- } else {
- // 楼层垂直展开前应判断楼层是否处于横向展开状态,是,则应先关闭横向展开,然后垂直展开
- if (expandState != 'moving') {
- $(this).addClass('active');
- $('#horizontalExpansion').removeClass('active');
- if (expandState == 'horizontal') {
- horizontalToVertical(building);
- } else {
- verticalExpand(building, 'vertical');
- }
- }
- }
- restarRotate();
- });
- // 设置按钮点击事件,按钮的tip与功能面板的互相切换
- $('#sceneSetting').on('click', function () {
- checkBtnActives(['#mapBg']);
- if ($(this).hasClass('active')) {
- $(this).removeClass('active');
- $(this).children('.control-menu').removeClass('actives');
- $(this).find('.tooltiptext').css({ "visibility": "visible" });
- } else {
- $(this).addClass('active');
- $(this).children('.control-menu').addClass('actives');
- $(this).find('.tooltiptext').css({ "visibility": "hidden" });
- }
- }).hover(function () {
- if (!$(this).hasClass('active')) {
- $(this).find('.tooltiptext').css({ "visibility": "visible" });
- }
- }, function () {
- $(this).find('.tooltiptext').css({ "visibility": "hidden" });
- });
- // 设置li标签添加点击事件
- $('#sceneSetting .control-menu-pane li').on('click', function (ev) {
- //ev.stopPropagation();
- if ($(this).hasClass('selected')) {
- stopRotate();
- $(this).removeClass('selected');
- } else {
- $(this).addClass('selected');
- restarRotate();
- }
- });
- // 小地图的开启/关闭按钮的鼠标点击事件
- $('#miniMap').on('click', function () {
- if ($(this).hasClass('active')) {
- $(this).removeClass('active');
- destoryMiniMap();
- } else {
- $(this).addClass('active');
- createMiniMap();
- }
- checkBtnActives(['#mapBg', '#sceneSetting']);
- });
- // 地图背景的开启/关闭按钮的鼠标点击事件,按钮的tip与功能面板的互相切换
- $('#mapBg').on('click', function () {
- checkBtnActives(['#sceneSetting']);
- if ($(this).hasClass('active')) {
- $(this).removeClass('active');
- $(this).children('.control-menu').removeClass('actives');
- $(this).find('.tooltiptext').css({ "visibility": "visible" });
- } else {
- $(this).addClass('active');
- $(this).children('.control-menu').addClass('actives');
- $(this).find('.tooltiptext').css({ "visibility": "hidden" });
- }
- }).hover(function () {
- if (!$(this).hasClass('active')) {
- $(this).find('.tooltiptext').css({ "visibility": "visible" });
- }
- }, function () {
- $(this).find('.tooltiptext').css({ "visibility": "hidden" });
- });
- // 进入层级事件
- app.on(THING.EventType.EnterLevel, function (ev) {
- stopRotate();
- // 进入建筑层级
- if (ev.object.type == 'Building') {
- //清除设备列表和面板
- _this.delMydiv();
- _this.destroy_ui();
- let floors = ev.object.floors;
- if (floors.length > 1) {
- building = ev.object;
- addFloorPos(building);
- let expandState = building.getAttribute('expandState');
- if (expandState == null) {
- building.setAttribute('expandState', 'close');
- }
- $('#horizontalExpansion').css({ 'display': 'block' });
- $('#verticalExpansion').css({ 'display': 'block' });
- }
- } else {
- $('#horizontalExpansion').css({ 'display': 'none' });
- $('#verticalExpansion').css({ 'display': 'none' });
- // 进入园区层级
- if (ev.object.type == 'Campus') {
- if (building != null) {
- exitBuildingCloseFloor(building);
- $('#horizontalExpansion').removeClass('active');
- $('#verticalExpansion').removeClass('active');
- building = null;
- }
- }
- }
- if (skyBox != null) {
- app.skyBox = skyBox;
- }
- // 重新创建小地图
- if ($('#miniMap').hasClass('active')) {
- destoryMiniMap();
- createMiniMap();
- }
- });
- // 行走按钮的鼠标点击事件
- $('#moveByFps').on('click', function () {
- stopRotate();
- if ($(this).hasClass('active')) {
- $(this).removeClass('active');
- if (box != null) {
- // 恢复默认双击进入层级事件
- app.resumeEvent(THING.EventType.DBLClick, '*', THING.EventTag.LevelEnterOperation);
- // 恢复默认右键退出层级事件
- app.resumeEvent(THING.EventType.Click, '*', THING.EventTag.LevelBackOperation);
- box.destroy();
- box = null;
- }
- if (fpsCtrl != null) {
- exitFps();
- }
- } else {
- $(this).addClass('active');
- // 禁用默认双击进入层级事件
- app.pauseEvent(THING.EventType.DBLClick, '*', THING.EventTag.LevelEnterOperation);
- // 禁用默认右键退出层级事件
- app.pauseEvent(THING.EventType.Click, '*', THING.EventTag.LevelBackOperation);
- // 记录摄像机当前位置
- cameraInitPos = [app.camera.position, app.camera.target];
- createBox();
- }
- checkBtnActives(['#mapBg', '#sceneSetting']);
- });
- // 全屏按钮的鼠标抬起事件
- $('#fullScreen').mouseup(function () {
- if (!fullScreenState) {
- $('.btn-full-screen').css('display', 'none');
- $('.btn-narrow').css('display', 'block');
- $('#fullScreen span').text('退出全屏');
- fullScreen();
- fullScreenState = true;
- } else {
- $('.btn-full-screen').css('display', 'block');
- $('.btn-narrow').css('display', 'none');
- $('#fullScreen span').text('全屏');
- exitFullScreen();
- fullScreenState = false;
- if ($('#mapBg').hasClass('active')) {
- destoryMiniMap();
- createMiniMap();
- }
- }
- checkBtnActives(['#mapBg', '#sceneSetting']);
- });
- // 鼠标键按下事件,功能按钮隐藏
- app.on(THING.EventType.MouseDown, function () {
- app.pauseEvent(THING.EventType.CameraZoom, null, '摄像机前后滚动,功能图片隐藏');
- if (showControlTimer != null) {
- clearTimeout(showControlTimer);
- showControlTimer = null;
- }
- stopRotate();
- if (hiddenControlTimer == null) {
- clearTimeout(showControlTimer);
- hiddenControlTimer = setTimeout(function () {
- $('#all-controls').css('display', 'none');
- clearTimeout(hiddenControlTimer);
- hiddenControlTimer = null;
- }, 300);
- }
- });
- // 鼠标键抬起事件,功能按钮显示
- app.on(THING.EventType.MouseUp, function () {
- app.resumeEvent(THING.EventType.CameraZoom, null, '摄像机前后滚动,功能图片隐藏');
- if (hiddenControlTimer != null) {
- clearTimeout(hiddenControlTimer);
- hiddenControlTimer = null;
- }
- if (showControlTimer == null) {
- showControlTimer = setTimeout(function () {
- $('#all-controls').css('display', 'block');
- clearTimeout(showControlTimer);
- showControlTimer = null;
- restarRotate();
- }, 300);
- }
- });
- let count = 0;
- // 鼠标滑轮滚动
- app.on(THING.EventType.CameraZoom, function () {
- if (showControlTimer != null) {
- count = 0;
- return;
- }
- stopRotate();
- if (showControlTimer == null) {
- $('#all-controls').css('display', 'none');
- showControlTimer = setInterval(function () {
- count++;
- if (count >= 2) {
- $('#all-controls').css('display', 'block');
- restarRotate();
- clearInterval(showControlTimer);
- showControlTimer = null;
- }
- }, 300);
- }
- }, '摄像机前后滚动,功能图片隐藏');
|