//此方式:弹窗非iframe模式 xjsdk.widget.bindClass(xjsdk.widget.BaseWidget.extend({ options: { resources: ['view.css'], view: [ { type: "append", url: "view.html", parent: '#centerDiv' } ], }, //此数据也可以放在widget.json的配置中,但是发现很多人容易引起同名误解,所以还是放在这里 data: [ // { "name": "漫游", "icon": "fa fa-globe", "onclick": "xjsdk.widget.disableAll()", "visible": false }, { "name": "底图", "icon": "fa fa-map", "widget": "widgets/manageBasemaps/widget.js" }, { "name": "图层", "icon": "fa fa-tasks", "widget": "widgets/manageLayers/widget.js" }, { "name": "工具", "icon": "fa fa-cubes", "children": [ { "name": "图上量算", "icon": "fa fa-calculator", "widget": "widgets/measure/widget.js" }, { "name": "空间分析", "icon": "fa fa-bar-chart", "widget": "widgets/analysis/widget.js" }, { "name": "坐标定位", "icon": "fa fa-map-pin", "widget": "widgets/centerXY/widget.js" }, // { "name": "地区导航", "icon": "fa fa-paper-plane", "widget": "widgets/navXZQH/widget.js" }, // { "name": "我的标记", "icon": "fa fa-edit", "widget": "widgets/addmarker/widget.js" }, // { "name": "视角书签", "icon": "fa fa-tags", "widget": "widgets/bookmark/widget.js" }, // { "name": "分屏对比", "icon": "fa fa-window-restore", "widget": "widgets/mapCompare/widget.js" }, // { "name": "卷帘对比", "icon": "fa fa-columns", "widget": "widgets/mapSwipe/widget.js" }, { "name": "图上标绘", "icon": "fa fa-object-group", "widget": "widgets/plot/widget.js" }, //{ "name": "飞行漫游", "icon": "fa fa-send-o", "widget": "widgets/roamLine/widget.js" }, //{ "name": "路线导航", "icon": "fa fa-level-up", "widget": "widgets/queryRoute/widget.js" }, { "name": "地图打印", "icon": "fa fa-print", "widget": "widgets/print/widget.js" }, // { "name": "百度街景", "icon": "fa fa-street-view", "widget": "widgets/streetscape/widget.js" }, // { "name": "分享地图", "icon": "fa fa-share", "widget": "widgets/shareUrl/widget.js" }, { "name": "参数设置", "icon": "fa fa-cog", "widget": "widgets/setting/widget.js" } ] } ], //初始化[仅执行1次] create: function () { }, //每个窗口创建完成后调用 winCreateOK: function (viewopt, html) { if (viewopt.type != "append") return; var arr = this.config.data || this.data; //移动设备上,处理下菜单层次 if (!haoutil.system.isPCBroswer() && arr.length == 3 && arr[0].children) { var item1 = arr.shift(); var item2 = arr.shift(); arr[0].children.insert(item2, 0); arr[0].children.insert(item1, 0); } this.initMenu(arr); }, //构造 菜单 initMenu: function (arr) { var widgetObj = {}; var inhtml = ""; for (var i = 0, len = arr.length; i < len; i++) { var item = arr[i]; if (item.hasOwnProperty("visible") && !item.visible) continue; if (item.children) { //分组 inhtml += '