qd-changjing/public/leaflet/libs/gtc2017/dist/iclient9-mapboxgl.js

1323 lines
51 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*!
*
* iclient9-mapboxgl.(http://iclient.supermap.io)
* Copyright© 2000-2017 SuperMap Software Co. Ltd
* license: Apache-2.0
* version: v9.0.0
*
*/
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // identity function for calling harmony imports with the correct context
/******/ __webpack_require__.i = function(value) { return value; };
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, {
/******/ configurable: false,
/******/ enumerable: true,
/******/ get: getter
/******/ });
/******/ }
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = 9);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, exports) {
module.exports = mapboxgl;
/***/ }),
/* 1 */
/***/ (function(module, exports) {
module.exports = function(){try{return mapv}catch(e){return {}}}();
/***/ }),
/* 2 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.Logo = undefined;
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _mapboxGl = __webpack_require__(0);
var _mapboxGl2 = _interopRequireDefault(_mapboxGl);
var _iClient = __webpack_require__(8);
var _iClient2 = _interopRequireDefault(_iClient);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* @class mapboxgl.supermap.LogoControl
* @classdesc Logo控件。默认不显示</br>
*
* @example
* (start code)
* map.addControl(new mapboxgl.supermap.LogoControl(),'bottom-right');
* (end)
* @param options -{Object} logo控件配置项</br>
* imageUrl - {string} logo图片地址</br>
* width - {string} logo图片宽</br>
* height - {string} logo图片高</br>
* link - {string} 跳转链接</br>
* alt - {string} logo图片失效时显示文本
*/
var Logo = exports.Logo = function () {
//logo图片高
//跳转链接
function Logo(options) {
_classCallCheck(this, Logo);
this.imageUrl = null;
this.link = null;
this.width = null;
this.height = null;
this.alt = "SuperMap iClient";
this._extend(this, options);
}
/**
* @function mapboxgl.supermap.LogoControl.prototype.onAdd
* @description 添加一个logo
* @return {div} 返回创建的logo元素
*/
//logo图片失效时显示文本
//logo图片宽
//logo图片地址
_createClass(Logo, [{
key: 'onAdd',
value: function onAdd(map) {
this._map = map;
this._container = document.createElement('div');
this._container.className = 'mapboxgl-ctrl iclient-logo';
this._container.style.marginTop = 0;
this._container.style.marginBottom = 0;
this._container.style.marginLeft = 0;
this._container.style.marginRight = 0;
var imgSrc = _iClient2.default;
if (this.imageUrl) {
imgSrc = this.imageUrl;
}
var alt = this.alt;
var imageWidth = "94px";
var imageHeight = "29px";
var styleSize = "width:" + imageWidth + ";height:" + imageHeight + ";";
if (this.imageUrl) {
imageWidth = this.width;
imageHeight = this.height;
styleSize = "width:" + imageWidth + ";height:" + imageHeight + ";";
if (!imageWidth || !imageHeight) {
styleSize = "";
}
}
var link = this.link || "http://iclient.supermap.io";
this._container.innerHTML = "<a href='" + link + "' target='_blank'>" + "<img src=" + imgSrc + " alt='" + alt + "' style='" + styleSize + "margin-bottom: 2px'></a>";
this._createStyleSheet();
return this._container;
}
}, {
key: '_createStyleSheet',
value: function _createStyleSheet() {
var style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = ".iclient-logo{" + "margin:0 !important;" + "}" + ".iclient-logo a{" + "border: none;" + "display: block;" + "height:31px;" + "}" + ".iclient-logo img{" + "border: none;" + "white-space: nowrap" + "}";
document.getElementsByTagName('head')[0].appendChild(style);
}
}, {
key: '_extend',
value: function _extend(dest) {
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = arguments[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var src = _step.value;
for (var k in src) {
dest[k] = src[k];
}
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
return dest;
}
}]);
return Logo;
}();
_mapboxGl2.default.supermap = _mapboxGl2.default.supermap || {};
_mapboxGl2.default.supermap.LogoControl = Logo;
/***/ }),
/* 3 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.MapvLayer = undefined;
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _MapvRenderer = __webpack_require__(7);
var _MapvRenderer2 = _interopRequireDefault(_MapvRenderer);
var _mapboxGl = __webpack_require__(0);
var _mapboxGl2 = _interopRequireDefault(_mapboxGl);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* @class mapboxgl.supermap.MapvLayer
* @classdesc Mapv图层
* @param map - {Object} 地图
* @param dataSet -{Object} 数据集
* @param mapVOptions -{Object} Mapv参数
*/
var MapvLayer = exports.MapvLayer = function () {
function MapvLayer(map, dataSet, mapVOptions) {
_classCallCheck(this, MapvLayer);
this.map = map;
this.renderer = new _MapvRenderer2.default(map, this, dataSet, mapVOptions);
this.canvas = this._createCanvas();
this.renderer._canvasUpdate();
this.mapContainer = map.getCanvasContainer();
this.mapContainer.appendChild(this.canvas);
}
/**
* @function mapboxgl.supermap.MapvLayer.prototype.getTopLeft
* @description 获取左上的距离
*/
_createClass(MapvLayer, [{
key: 'getTopLeft',
value: function getTopLeft() {
var map = this.map;
var topLeft;
if (map) {
var bounds = map.getBounds();
topLeft = bounds.getNorthWest();
}
return topLeft;
}
}, {
key: 'show',
value: function show() {
if (this.renderer) {
this.renderer._show();
}
return this;
}
}, {
key: 'hide',
value: function hide() {
if (this.renderer) {
this.renderer._hide();
}
return this;
}
}, {
key: '_createCanvas',
value: function _createCanvas() {
var canvas = document.createElement('canvas');
canvas.style.position = 'absolute';
canvas.style.top = 0 + "px";
canvas.style.left = 0 + "px";
canvas.width = parseInt(this.map.getCanvas().style.width);
canvas.height = parseInt(this.map.getCanvas().style.height);
canvas.style.width = this.map.getCanvas().style.width;
canvas.style.height = this.map.getCanvas().style.height;
return canvas;
}
}]);
return MapvLayer;
}();
_mapboxGl2.default.supermap = _mapboxGl2.default.supermap || {};
_mapboxGl2.default.supermap.MapvLayer = MapvLayer;
/***/ }),
/* 4 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.RankTheme3DLayer = undefined;
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _mapboxGl = __webpack_require__(0);
var _mapboxGl2 = _interopRequireDefault(_mapboxGl);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* @class mapboxgl.supermap.RankTheme3DLayer
* @classdesc mapbox gl分段专题图
* @param id -{string} 专题图图层id
* @param map -{object} mapbox gl地图对象
* @param layerOptions -{Object} 专题图图层配置项<br>
* opacity -{number} 图层透明度默认1<br>
* parseNumber -{boolean} 是否预处理数据将数据转换为number默认false<br>
* baseHeightField -{string} 数据中表示基础高度的字段<br>
* heightField -{string} 数据中表示高度的字段<br>
* heightStops -{Array} 数据高度分段数组<br>
* colorField -{string} 数据中表示颜色的字段<br>
* colorStops -{Array} 数据颜色分段数组<br>
* base -{number} 数据分段线性增量<br>
* showLegend -{boolean} 是否显示图例,默认显示<br>
* legendTitle -{string} 图例标题<br>
* legendTheme -{string} 图例主题,取值:'light','dark'<br>
* legendRatio -{number} 图例数值扩大系数,<br>
* legendPosition -{string} 图例位置,取值:'top-right'|'top-left'|'bottom-left'|'bottom-right'<br>
*/
var RankTheme3DLayer = exports.RankTheme3DLayer = function () {
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.legendTheme -{string}
* @description 图例主题,取值:'light','dark'
* @default 'light'
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.legendTitle -{string}
* @description 图例标题
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.base -{number}
* @description 数据分段线性增量
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.colorField -{string}
* @description 数据中表示颜色的字段
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.heightField -{string}
* @description 数据中表示高度的字段
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.parseNumber -{boolean}
* @description 是否进行数据预处理,有些字段是string类型需要转换为number
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.map -{object}
* @description mapbox gl地图对象
*/
function RankTheme3DLayer(id, map, layerOptions) {
_classCallCheck(this, RankTheme3DLayer);
this.id = null;
this.map = null;
this.opacity = 1;
this.parseNumber = false;
this.baseHeightField = null;
this.heightField = null;
this.heightStops = null;
this.colorField = null;
this.colorStops = null;
this.base = null;
this.showLegend = true;
this.legendTitle = null;
this.legendRatio = 1;
this.legendTheme = 'light';
this.legendPosition = 'bottom-right';
this.id = id;
this.map = map;
this._extend(this, layerOptions);
this.heightField = layerOptions.heightField || 'height';
this.colorField = layerOptions.colorField || this.heightField;
}
/**
* @function mapboxgl.supermap.RankTheme3DLayer.prototype.setLayerOptions
* @description 设置图层相关参数
* @param layerOptions -{object} 该专题图图层相关参数<br>
* * opacity -{number} 图层透明度默认1<br>
* parseNumber -{boolean} 是否预处理数据将数据转换为number默认false<br>
* baseHeightField -{string} 数据中表示基础高度的字段<br>
* heightField -{string} 数据中表示高度的字段<br>
* heightStops -{Array} 数据高度分段数组<br>
* colorField -{string} 数据中表示颜色的字段<br>
* colorStops -{Array} 数据颜色分段数组<br>
* base -{number} 数据分段线性增量<br>
* showLegend -{boolean} 是否显示图例,默认显示<br>
* legendTitle -{string} 图例标题<br>
* legendRatio -{number} 图例数值扩大系数,<br>
* legendTheme -{string} 图例主题,取值:'light','dark'<br>
* legendPosition -{string} 图例位置,取值:'top-right'|'top-left'|'bottom-left'|'bottom-right'<br>
* @returns {mapboxgl.supermap.RankTheme3DLayer}
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.legendPosition -{string}
* @description 图例位置,取值:'top-right'|'top-left'|'bottom-left'|'bottom-right'
* @default 'bottom-right'
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.legendRatio -{number}
* @description 图例数值扩大系数
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.showLegend -{Boolean}
* @description 是否显示图例
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.colorStops -{Array}
* @description 数据颜色分段数组
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.heightStops -{Array}
* @description 数据高度分段数组
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.baseHeightField -{string}
* @description 数据中表示基础高度的字段
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.opacity -{number}
* @description 图层透明度默认1
*/
/**
* @member mapboxgl.supermap.RankTheme3DLayer.prototype.id -{string}
* @description mapbox gl图层id
*/
_createClass(RankTheme3DLayer, [{
key: 'setLayerOptions',
value: function setLayerOptions(layerOptions) {
this._extend(this, layerOptions);
return this;
}
/**
* @function mapboxgl.supermap.RankTheme3DLayer.prototype.setData
* @description 设置数据数据格式必须为geojson格式
* @param data -{object} geojson格式数据
* @param parseNumber -{object} 是否进行数据预处理,有些字段是string类型需要转换为number
*/
}, {
key: 'setData',
value: function setData(data, parseNumber) {
var me = this;
me.data = data;
if (parseNumber != null) {
me.parseNumber = parseNumber;
}
me.parseNumber && me.data && me.data.features && me.data.features.map(function (val, index) {
if (me.baseHeightField && val.properties[me.baseHeightField]) {
val.properties[baseHeightField] = parseFloat(val.properties[baseHeightField]);
}
if (me.heightField && val.properties[me.heightField]) {
val.properties[me.heightField] = parseFloat(val.properties[me.heightField]);
}
});
return this;
}
/**
* @function mapboxgl.supermap.RankTheme3DLayer.prototype.getData
* @description 获取数据返回的数据格式为geojson
* @returns {Object}
*/
}, {
key: 'getData',
value: function getData() {
return this.data;
}
/**
* @function mapboxgl.supermap.RankTheme3DLayer.prototype.show
* @description 显示图层
* @param options -{object} 图层相关参数,如图例标题和主题等
* @returns {mapboxgl.supermap.RankTheme3DLayer}
*/
}, {
key: 'show',
value: function show(options) {
this._addLayer();
this._extend(this, options);
if (this.showLegend) {
if (this.legend) {
map.addControl(legend, this.legendPosition);
} else {
var defaultLegend = this._createLegendControl();
this.map.addControl(defaultLegend, this.legendPosition);
}
}
return this;
}
}, {
key: '_createLegendControl',
value: function _createLegendControl(html) {
var me = this;
function LegendControl() {}
LegendControl.prototype.onAdd = function (map) {
this._map = map;
this._container = document.createElement('div');
var className = 'mapboxgl-ctrl legend ';
var theme = 'legend-light';
if (me.legendTheme === 'dark') {
theme = 'legend-dark';
}
this._container.className = className + theme;
if (html) {
this._container.innerHTML = html;
} else {
this._container.innerHTML = me._createLegendElement.call(me);
}
me._appendLegendCSSStyle();
return this._container;
};
LegendControl.prototype.onRemove = function () {
this._container.parentNode.removeChild(this._container);
this._map = undefined;
};
return new LegendControl();
}
}, {
key: '_createLegendElement',
value: function _createLegendElement() {
var len = this.colorStops && this.colorStops.length || 0;
var titleWidth = len * 60;
//图例标题
var titleElement = "";
var legendTitle = this.legendTitle || "";
titleElement = " <p class='legend-title' style='width: " + titleWidth + ";'>" + legendTitle + "</p>";
//颜色分段对应标识
var colorGalleryElement = "<ul>";
var valueGalleryElement = "<ul>";
for (var i = 0; i < len; i++) {
var value = this.colorStops[i][0];
this.legendRatio = this.legendRatio == null ? 1 : this.legendRatio;
value = value * this.legendRatio;
var text = this._getWrapperText(value);
var color = this.colorStops[i][1];
colorGalleryElement += "<li style='background-color:" + color + ";'></li>";
valueGalleryElement += "<li>" + text + "</li>";
}
colorGalleryElement += "</ul>";
valueGalleryElement += "</ul>";
return titleElement + colorGalleryElement + valueGalleryElement;
}
}, {
key: '_appendLegendCSSStyle',
value: function _appendLegendCSSStyle() {
var legendStyle = document.createElement('style');
legendStyle.type = 'text/css';
legendStyle.innerHTML = " .legend {\n" + " display: inline-block;\n" + " padding: 4px 10px;\n" + " border-radius: 2px;\n" + " -moz-border-radius: 2px;\n" + " -webkit-border-radius: 2px;\n" + " font-size: 12px;\n" + " color: rgba(0, 0, 0, 0.8);\n" + " background-color: rgb(255, 255, 255);\n" + " }\n" + " .legend-light {\n" + " color: rgba(0, 0, 0, 0.8);\n" + " background-color: rgb(255, 255, 255);\n" + " }\n" + " .legend-dark {\n" + " color: rgba(255, 255, 255, 0.8);\n" + " background-color: rgb(64, 64, 64);\n" + " }\n" + " .legend ul {\n" + " clear: both;\n" + " overflow: auto;\n" + " padding: 0;\n" + " margin: 0;\n" + " height: 100%;\n" + " display: block;\n" + " list-style: none;\n" + " box-sizing: border-box;\n" + " -webkit-font-smoothing: antialiased;\n" + " }\n" + " .legend li {\n" + " float: left;\n" + " width: 50px;\n" + " height: 28px;\n" + " overflow: hidden;\n" + " text-overflow: clip;\n" + " padding: 0 4px;\n" + " line-height: 28px;\n" + " }\n" + " .legend .legend-title {\n" + " min-height: 14px;\n" + " max-width: 500px;\n" + " margin: 4px 0;\n" + " }\n" + " .legend-light .legend-title {\n" + " color: rgba(0, 0, 0, 0.8);\n" + " }\n" + " .legend-dark .legend-title {\n" + " color: rgba(255, 255, 255, 0.8);\n" + " }";
document.getElementsByTagName('head')[0].appendChild(legendStyle);
}
}, {
key: '_getWrapperText',
value: function _getWrapperText(number) {
//单个颜色值宽度为60px,最大只能完全显示1000000否则就超出宽度则显示以为k计数单位的值
var num = parseFloat(number);
if (num % 1000000 <= 1000000) {
return num.toString();
}
return parseInt(num / 1000) + 'k';
}
}, {
key: '_addLayer',
value: function _addLayer() {
var paintOptions = this._getPaintOptions();
var id = this.id ? this.id : "rankTheme";
var sourceId = id + 'Source';
if (!this.map.getSource(sourceId)) {
this.map.addSource(sourceId, {
'type': 'geojson',
'data': this.data
});
} else {
this.map.removeSource(sourceId);
this.map.addSource(sourceId, {
'type': 'geojson',
'data': this.data
});
}
this.map.addLayer({
'id': id,
'type': 'fill-extrusion',
'source': sourceId,
'paint': paintOptions
}, id);
this.map.moveLayer(id);
}
}, {
key: '_getPaintOptions',
value: function _getPaintOptions() {
var opacity = this.opacity == null ? 1 : this.opacity;
opacity = isNaN(parseFloat(opacity)) ? 1 : parseFloat(opacity);
var reg = /^[0-9]+.?[0-9]*$/;
var options = {
'fill-extrusion-color': {
'stops': this.colorStops,
'property': this.colorField || this.heightField,
'base': reg.test(this.base) ? this.base : 1
},
'fill-extrusion-opacity': opacity
};
if (this.heightStops) {
options['fill-extrusion-height'] = {
'stops': this.heightStops,
'property': this.heightField || 'height',
'base': reg.test(this.base) ? this.base : 1
};
} else {
options['fill-extrusion-height'] = {
'property': this.heightField || 'height',
'type': 'identity'
};
}
if (this.baseHeightField) {
options['fill-extrusion-base'] = {
'property': this.baseHeightField,
'type': 'identity'
};
}
return options;
}
}, {
key: '_extend',
value: function _extend(dest) {
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = arguments[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var src = _step.value;
for (var k in src) {
dest[k] = src[k];
}
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
return dest;
}
}]);
return RankTheme3DLayer;
}();
_mapboxGl2.default.supermap = _mapboxGl2.default.supermap || {};
_mapboxGl2.default.supermap.RankTheme3DLayer = RankTheme3DLayer;
/***/ }),
/* 5 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.setPaintProperty = exports.setBackground = exports.getDefaultVectorTileStyle = undefined;
var _mapboxGl = __webpack_require__(0);
var _mapboxGl2 = _interopRequireDefault(_mapboxGl);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
_mapboxGl2.default.supermap = _mapboxGl2.default.supermap || {};
_mapboxGl2.default.supermap.map = _mapboxGl2.default.supermap.map || {};
/**
* 配置默认底图样式
*/
var getDefaultVectorTileStyle = exports.getDefaultVectorTileStyle = function getDefaultVectorTileStyle(urlTemplate, options) {
options = options || {};
var defaultOptions = {};
defaultOptions.version = options.version || 8;
defaultOptions.layers = options.layers || [];
defaultOptions.light = options.light || {
"anchor": "viewport",
"color": "#fcf6ef",
"intensity": 0.5,
"position": [1.15, 201, 20]
};
var style = {
"version": defaultOptions.version,
"sources": {
"vector-tiles": {
"type": "vector",
"tiles": [urlTemplate]
}
},
"layers": defaultOptions.layers,
"light": defaultOptions.light
};
if (options.sprite != null) {
style.sprite = options.sprite;
}
if (options.glyphs != null) {
style.glyphs = options.glyphs;
}
return style;
};
/**
* 设置地图背景
*/
var setBackground = exports.setBackground = function setBackground(map, color) {
if (color && map) {
map.addLayer({
"id": "background",
"type": "background",
"paint": {
"background-color": color
}
}, "background");
}
};
/**
* 设置图层风格
* @param map
* @param layerIds
* @param type
* @param paint
* @param source 非必填默认vector-tiles
* @param sourceLayers 非必填默认与id对应
*/
var setPaintProperty = exports.setPaintProperty = function setPaintProperty(map, layerIds, type, paint, source, sourceLayers) {
if (layerIds && map) {
if (Object.prototype.toString.call(layerIds) !== '[object Array]') {
layerIds = [layerIds];
}
for (var i = 0; i < layerIds.length; i++) {
var sourceLayer = sourceLayers ? sourceLayers[i] : null;
var layer = getLayer(layerIds[i], type, source, sourceLayer, paint);
map.addLayer(layer, layerIds[i]);
map.moveLayer(layerIds[i]);
}
}
};
function getLayer(id, type, source, sourceLayer, paint) {
var sourceType = source || "vector-tiles";
var sLayer = sourceLayer || id;
var layer = {
"id": id,
"type": type,
"source": sourceType,
"source-layer": sLayer,
"paint": paint
};
return layer;
}
_mapboxGl2.default.supermap.map.getDefaultVectorTileStyle = getDefaultVectorTileStyle;
_mapboxGl2.default.supermap.map.setBackground = setBackground;
_mapboxGl2.default.supermap.map.setPaintProperty = setPaintProperty;
/***/ }),
/* 6 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.MapvDataSet = undefined;
var _mapboxGl = __webpack_require__(0);
var _mapboxGl2 = _interopRequireDefault(_mapboxGl);
var _mapv = __webpack_require__(1);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
_mapboxGl2.default.supermap = _mapboxGl2.default.supermap || {};
var MapvDataSet = exports.MapvDataSet = {
/**
* 返回mapv点数据集
*/
getPoint: function getPoint(center) {
if (center && center instanceof Array) {
return new _mapv.DataSet([{
geometry: {
type: 'Point',
coordinates: center
}
}]);
}
},
/**
* 返回mapv多点数据集
*/
getPoints: function getPoints(points) {
if (points && points instanceof Array) {
var mPoints = [];
points.map(function (data) {
mPoints.push({
geometry: {
type: 'Point',
coordinates: data.geometry.coordinates
}
});
});
return new _mapv.DataSet(mPoints);
}
},
/**
* 返回mapv弧形线数据集
*/
getCurveLines: function getCurveLines(startPoint, LinePoints) {
if (startPoint && startPoint instanceof Array && LinePoints && LinePoints instanceof Array) {
var lineData = [];
LinePoints.map(function (data) {
var coords = data.geometry && data.geometry.coordinates;
var toCenter = { lng: coords[0], lat: coords[1] };
var fromCenter = { lng: startPoint[0], lat: startPoint[1] };
var cv = _mapv.utilCurve.getPoints([fromCenter, toCenter]);
lineData.push({
geometry: {
type: 'LineString',
coordinates: cv
}
});
});
return new _mapv.DataSet(lineData);
}
},
/**
* 返回mapv弧形动态点数据集
*/
getCurveDynamicPoints: function getCurveDynamicPoints(center, endPoints) {
if (center && center instanceof Array && endPoints && endPoints instanceof Array) {
var timeData = [];
endPoints.map(function (data) {
var coords = data.geometry && data.geometry.coordinates;
var toCenter = { lng: coords[0], lat: coords[1] };
var fromCenter = { lng: center[0], lat: center[1] };
var cv = _mapv.utilCurve.getPoints([fromCenter, toCenter]);
for (var j = 0; j < cv.length; j++) {
timeData.push({
geometry: {
type: 'Point',
coordinates: cv[j]
},
time: j
});
}
});
return new _mapv.DataSet(timeData);
}
}
};
_mapboxGl2.default.supermap.MapvDataSet = MapvDataSet;
/***/ }),
/* 7 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
var _mapv = __webpack_require__(1);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var BaseLayer = _mapv.baiduMapLayer ? _mapv.baiduMapLayer.__proto__ : Function;
/**
* @private
* @class mapboxgl.supermap.MapvRenderer
* @classdesc MapV图层渲染
* @param map - {string} 地图
* @param layer -{Object} 图层
* @param dataSet -{Object} 数据集
* @param options -{Object} 交互时所需可选参数。
* @extends BaseLayer
*
*/
var MapvRenderer = function (_BaseLayer) {
_inherits(MapvRenderer, _BaseLayer);
function MapvRenderer(map, layer, dataSet, options) {
_classCallCheck(this, MapvRenderer);
if (!BaseLayer) {
return _possibleConstructorReturn(_this);
}
var _this = _possibleConstructorReturn(this, (MapvRenderer.__proto__ || Object.getPrototypeOf(MapvRenderer)).call(this, map, dataSet, options));
_this.map = map;
var self = _this;
options = options || {};
self.init(options);
self.argCheck(options);
_this.canvasLayer = layer;
_this.clickEvent = _this.clickEvent.bind(_this);
_this.mousemoveEvent = _this.mousemoveEvent.bind(_this);
_this.map.on('move', _this.moveEvent.bind(_this));
_this.map.on('resize', _this.resizeEvent.bind(_this));
_this.map.on('moveend', _this.moveEndEvent.bind(_this));
_this.map.on('remove', _this.removeEvent.bind(_this));
_this.bindEvent();
return _this;
}
/**
* @function mapboxgl.supermap.prototype.clickEvent
* @description 点击绑定事件
* @param e - {Object} 事件
*/
_createClass(MapvRenderer, [{
key: 'clickEvent',
value: function clickEvent(e) {
var pixel = e.layerPoint;
_get(MapvRenderer.prototype.__proto__ || Object.getPrototypeOf(MapvRenderer.prototype), 'clickEvent', this).call(this, pixel, e);
}
/**
* @function mapboxgl.supermap.prototype.mousemoveEvent
* @description 鼠标移动事件
* @param e - {Object} 事件
*/
}, {
key: 'mousemoveEvent',
value: function mousemoveEvent(e) {
var pixel = e.layerPoint;
_get(MapvRenderer.prototype.__proto__ || Object.getPrototypeOf(MapvRenderer.prototype), 'mousemoveEvent', this).call(this, pixel, e);
}
/**
* @function mapboxgl.supermap.prototype.bindEvent
* @description 绑定事件
* @param e - {object} 触发对象
*/
}, {
key: 'bindEvent',
value: function bindEvent(e) {
var map = this.map;
if (this.options.methods) {
if (this.options.methods.click) {
map.on('click', this.clickEvent);
}
if (this.options.methods.mousemove) {
map.on('mousemove', this.mousemoveEvent);
}
}
}
/**
* @function mapboxgl.supermap.prototype.unbindEvent
* @description 解绑事件
* @param e - {object} 触发对象
*/
}, {
key: 'unbindEvent',
value: function unbindEvent(e) {
var map = this.map;
if (this.options.methods) {
if (this.options.methods.click) {
map.off('click', this.clickEvent);
}
if (this.options.methods.mousemove) {
map.off('mousemove', this.mousemoveEvent);
}
}
}
/**
* @function mapboxgl.supermap.prototype.getContext
* @description 获取信息
*/
}, {
key: 'getContext',
value: function getContext() {
return this.canvasLayer.canvas.getContext(this.context);
}
/**
* @function mapboxgl.supermap.prototype.updateData
* @param dataSet - {Object} 数据集
* @param options - {Object} 数据项配置
* @description 更新数据
*/
}, {
key: 'updateData',
value: function updateData(dataSet, options) {
if (dataSet && dataSet.get) {
this.dataSet.set(dataSet.get());
}
this.update({ options: options });
}
}, {
key: '_canvasUpdate',
value: function _canvasUpdate(time) {
if (!this.canvasLayer) {
return;
}
var self = this;
var animationOptions = self.options.animation;
var context = this.getContext();
var map = this.map;
if (self.isEnabledTime()) {
if (time === undefined) {
this.clear(context);
return;
}
if (this.context === '2d') {
context.save();
context.globalCompositeOperation = 'destination-out';
context.fillStyle = 'rgba(0, 0, 0, .1)';
context.fillRect(0, 0, context.canvas.width, context.canvas.height);
context.restore();
}
} else {
this.clear(context);
}
if (this.context === '2d') {
for (var key in self.options) {
context[key] = self.options[key];
}
} else {
context.clear(context.COLOR_BUFFER_BIT);
}
if (self.options.minZoom && map.getZoom() < self.options.minZoom || self.options.maxZoom && map.getZoom() > self.options.maxZoom) {
return;
}
var dataGetOptions = {
transferCoordinate: function transferCoordinate(coordinate) {
var worldPoint = map.project(new window.mapboxgl.LngLat(coordinate[0], coordinate[1]));
return [worldPoint.x, worldPoint.y];
}
};
if (time !== undefined) {
dataGetOptions.filter = function (item) {
var trails = animationOptions.trails || 10;
return time && item.time > time - trails && item.time < time;
};
}
var data = self.dataSet.get(dataGetOptions);
this.processData(data);
self.options._size = self.options.size;
var worldPoint = map.project(new window.mapboxgl.LngLat(0, 0));
this.drawContext(context, new mapv.DataSet(data), self.options, worldPoint);
self.options.updateCallback && self.options.updateCallback(time);
}
}, {
key: 'init',
value: function init(options) {
var self = this;
self.options = options;
this.initDataRange(options);
this.context = self.options.context || '2d';
if (self.options.zIndex) {
this.canvasLayer && this.canvasLayer.setZIndex(self.options.zIndex);
}
this.initAnimator();
}
/**
* @function mapboxgl.supermap.prototype.addAnimatorEvent
* @description 添加动画事件
*/
}, {
key: 'addAnimatorEvent',
value: function addAnimatorEvent() {}
/**
* @function mapboxgl.supermap.prototype.removeEvent
* @description 移除事件
*/
}, {
key: 'removeEvent',
value: function removeEvent() {
this.canvasLayer.mapContainer.removeChild(this.canvasLayer.canvas);
}
/**
* @function mapboxgl.supermap.prototype.moveEvent
* @description 隐藏事件
*/
}, {
key: 'moveEvent',
value: function moveEvent() {
this._hide();
}
/**
* @function mapboxgl.supermap.prototype.resizeEvent
* @description 调整事件
*/
}, {
key: 'resizeEvent',
value: function resizeEvent() {
var canvas = this.canvasLayer.canvas;
canvas.style.position = 'absolute';
canvas.style.top = 0 + "px";
canvas.style.left = 0 + "px";
canvas.width = parseInt(this.map.getCanvas().style.width);
canvas.height = parseInt(this.map.getCanvas().style.height);
canvas.style.width = this.map.getCanvas().style.width;
canvas.style.height = this.map.getCanvas().style.height;
}
/**
* @function mapboxgl.supermap.prototype.moveEndEvent
* @description 移除最后事件
*/
}, {
key: 'moveEndEvent',
value: function moveEndEvent() {
this._canvasUpdate();
this._show();
}
/**
* @function mapboxgl.supermap.prototype.clear
* @param context - {object} 当前环境
* @description 清除环境
*/
}, {
key: 'clear',
value: function clear(context) {
context && context.clearRect && context.clearRect(0, 0, context.canvas.width, context.canvas.height);
}
}, {
key: '_hide',
value: function _hide() {
this.canvasLayer.canvas.style.display = 'none';
}
}, {
key: '_show',
value: function _show() {
this.canvasLayer.canvas.style.display = 'block';
}
/**
* @function mapboxgl.supermap.prototype.draw
* @description 渲染绘制
*/
}, {
key: 'draw',
value: function draw() {
this.canvasLayer.draw();
}
}]);
return MapvRenderer;
}(BaseLayer);
exports.default = MapvRenderer;
/***/ }),
/* 8 */
/***/ (function(module, exports) {
module.exports = ""
/***/ }),
/* 9 */
/***/ (function(module, exports, __webpack_require__) {
__webpack_require__(3);
__webpack_require__(6);
__webpack_require__(5);
__webpack_require__(4);
module.exports = __webpack_require__(2);
/***/ })
/******/ ]);