This commit is contained in:
2023-06-22 06:50:23 +08:00
parent 94e7e9685f
commit bb24077192
282 changed files with 800435 additions and 2020 deletions

View File

@ -0,0 +1,261 @@
.ol-box {
box-sizing: border-box;
border-radius: 2px;
border: 2px solid blue;
}
.ol-mouse-position {
top: 8px;
right: 8px;
position: absolute;
}
.ol-scale-line {
background: rgba(0,60,136,0.3);
border-radius: 4px;
bottom: 8px;
left: 8px;
padding: 2px;
position: absolute;
}
.ol-scale-line-inner {
border: 1px solid #eee;
border-top: none;
color: #eee;
font-size: 10px;
text-align: center;
margin: 1px;
will-change: contents, width;
}
.ol-overlay-container {
will-change: left,right,top,bottom;
}
.ol-unsupported {
display: none;
}
.ol-viewport, .ol-unselectable {
-webkit-touch-callout: none;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-tap-highlight-color: rgba(0,0,0,0);
}
.ol-selectable {
-webkit-touch-callout: default;
-webkit-user-select: auto;
-moz-user-select: auto;
-ms-user-select: auto;
user-select: auto;
}
.ol-grabbing {
cursor: -webkit-grabbing;
cursor: -moz-grabbing;
cursor: grabbing;
}
.ol-grab {
cursor: move;
cursor: -webkit-grab;
cursor: -moz-grab;
cursor: grab;
}
.ol-control {
position: absolute;
background-color: rgba(255,255,255,0.4);
border-radius: 4px;
padding: 2px;
}
.ol-control:hover {
background-color: rgba(255,255,255,0.6);
}
.ol-zoom {
top: .5em;
left: .5em;
}
.ol-rotate {
top: .5em;
right: .5em;
transition: opacity .25s linear, visibility 0s linear;
}
.ol-rotate.ol-hidden {
opacity: 0;
visibility: hidden;
transition: opacity .25s linear, visibility 0s linear .25s;
}
.ol-zoom-extent {
top: 4.643em;
left: .5em;
}
.ol-full-screen {
right: .5em;
top: .5em;
}
@media print {
.ol-control {
display: none;
}
}
.ol-control button {
display: block;
margin: 1px;
padding: 0;
color: white;
font-size: 1.14em;
font-weight: bold;
text-decoration: none;
text-align: center;
height: 1.375em;
width: 1.375em;
line-height: .4em;
background-color: rgba(0,60,136,0.5);
border: none;
border-radius: 2px;
}
.ol-control button::-moz-focus-inner {
border: none;
padding: 0;
}
.ol-zoom-extent button {
line-height: 1.4em;
}
.ol-compass {
display: block;
font-weight: normal;
font-size: 1.2em;
will-change: transform;
}
.ol-touch .ol-control button {
font-size: 1.5em;
}
.ol-touch .ol-zoom-extent {
top: 5.5em;
}
.ol-control button:hover,
.ol-control button:focus {
text-decoration: none;
background-color: rgba(0,60,136,0.7);
}
.ol-zoom .ol-zoom-in {
border-radius: 2px 2px 0 0;
}
.ol-zoom .ol-zoom-out {
border-radius: 0 0 2px 2px;
}
.ol-attribution {
text-align: right;
bottom: .5em;
right: .5em;
max-width: calc(100% - 1.3em);
}
.ol-attribution ul {
margin: 0;
padding: 0 .5em;
font-size: .7rem;
line-height: 1.375em;
color: #000;
text-shadow: 0 0 2px #fff;
}
.ol-attribution li {
display: inline;
list-style: none;
line-height: inherit;
}
.ol-attribution li:not(:last-child):after {
content: " ";
}
.ol-attribution img {
max-height: 2em;
max-width: inherit;
vertical-align: middle;
}
.ol-attribution ul, .ol-attribution button {
display: inline-block;
}
.ol-attribution.ol-collapsed ul {
display: none;
}
.ol-attribution.ol-logo-only ul {
display: block;
}
.ol-attribution:not(.ol-collapsed) {
background: rgba(255,255,255,0.8);
}
.ol-attribution.ol-uncollapsible {
bottom: 0;
right: 0;
border-radius: 4px 0 0;
height: 1.1em;
line-height: 1em;
}
.ol-attribution.ol-logo-only {
background: transparent;
bottom: .4em;
height: 1.1em;
line-height: 1em;
}
.ol-attribution.ol-uncollapsible img {
margin-top: -.2em;
max-height: 1.6em;
}
.ol-attribution.ol-logo-only button,
.ol-attribution.ol-uncollapsible button {
display: none;
}
.ol-zoomslider {
top: 4.5em;
left: .5em;
height: 200px;
}
.ol-zoomslider button {
position: relative;
height: 10px;
}
.ol-touch .ol-zoomslider {
top: 5.5em;
}
.ol-overviewmap {
left: 0.5em;
bottom: 0.5em;
}
.ol-overviewmap.ol-uncollapsible {
bottom: 0;
left: 0;
border-radius: 0 4px 0 0;
}
.ol-overviewmap .ol-overviewmap-map,
.ol-overviewmap button {
display: inline-block;
}
.ol-overviewmap .ol-overviewmap-map {
border: 1px solid #7b98bc;
height: 150px;
margin: 2px;
width: 150px;
}
.ol-overviewmap:not(.ol-collapsed) button{
bottom: 1px;
left: 2px;
position: absolute;
}
.ol-overviewmap.ol-collapsed .ol-overviewmap-map,
.ol-overviewmap.ol-uncollapsible button {
display: none;
}
.ol-overviewmap:not(.ol-collapsed) {
background: rgba(255,255,255,0.8);
}
.ol-overviewmap-box {
border: 2px dotted rgba(0,60,136,0.7);
}
.ol-overviewmap .ol-overviewmap-box:hover {
cursor: move;
}

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1 @@
.ol-box{box-sizing:border-box;border-radius:2px;border:2px solid #00f}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:rgba(0,60,136,.3);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid #eee;border-top:none;color:#eee;font-size:10px;text-align:center;margin:1px;will-change:contents,width}.ol-overlay-container{will-change:left,right,top,bottom}.ol-unsupported{display:none}.ol-unselectable,.ol-viewport{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:auto;-moz-user-select:auto;-ms-user-select:auto;user-select:auto}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:rgba(255,255,255,.4);border-radius:4px;padding:2px}.ol-control:hover{background-color:rgba(255,255,255,.6)}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}@media print{.ol-control{display:none}}.ol-control button{display:block;margin:1px;padding:0;color:#fff;font-size:1.14em;font-weight:700;text-decoration:none;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:rgba(0,60,136,.5);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;font-size:1.2em;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:focus,.ol-control button:hover{text-decoration:none;background-color:rgba(0,60,136,.7)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em)}.ol-attribution ul{margin:0;padding:0 .5em;font-size:.7rem;line-height:1.375em;color:#000;text-shadow:0 0 2px #fff}.ol-attribution li{display:inline;list-style:none;line-height:inherit}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button,.ol-attribution ul{display:inline-block}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution.ol-logo-only ul{display:block}.ol-attribution:not(.ol-collapsed){background:rgba(255,255,255,.8)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0;height:1.1em;line-height:1em}.ol-attribution.ol-logo-only{background:0 0;bottom:.4em;height:1.1em;line-height:1em}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-logo-only button,.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:inline-block}.ol-overviewmap .ol-overviewmap-map{border:1px solid #7b98bc;height:150px;margin:2px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:1px;left:2px;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:rgba(255,255,255,.8)}.ol-overviewmap-box{border:2px dotted rgba(0,60,136,.7)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,2 @@
.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid #b3c5db;background-color:rgba(255,255,255,.4)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:rgba(0,60,136,.3);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid #eee;border-top:none;color:#eee;font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-step-marker{width:1px;height:15px;background-color:#000;float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:12px;z-index:11;color:#000;text-shadow:-2px 0 #fff,0 2px #fff,2px 0 #fff,0 -2px #fff}.ol-scale-text{position:absolute;font-size:14px;text-align:center;bottom:25px;color:#000;text-shadow:-2px 0 #fff,0 2px #fff,2px 0 #fff,0 -2px #fff}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid #000}.ol-unsupported{display:none}.ol-unselectable,.ol-viewport{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:rgba(255,255,255,.4);border-radius:4px;padding:2px}.ol-control:hover{background-color:rgba(255,255,255,.6)}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:#fff;font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:rgba(0,60,136,.5);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;font-size:1.2em;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:focus,.ol-control button:hover{text-decoration:none;background-color:rgba(0,60,136,.7)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:rgba(0,60,136,.7);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:#000;text-shadow:0 0 2px #fff;font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:rgba(255,255,255,.8)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid #7b98bc;height:150px;margin:2px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:2px;left:2px;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:rgba(255,255,255,.8)}.ol-overviewmap-box{border:2px dotted rgba(0,60,136,.7)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}
/*# sourceMappingURL=ol.css.map */

View File

@ -0,0 +1,8 @@
{
"version": 3,
"sources": [
"src/ol/ol.css"
],
"names": [],
"mappings": "AAAA,QACE,WAAY,WACZ,cAAe,IACf,OAAQ,MAAM,MAAM,QACpB,iBAAkB,qBAGpB,mBACE,IAAK,IACL,MAAO,IACP,SAAU,SAGZ,eACE,WAAY,kBACZ,cAAe,IACf,OAAQ,IACR,KAAM,IACN,QAAS,IACT,SAAU,SAEZ,qBACE,OAAQ,IAAI,MAAM,KAClB,WAAY,KACZ,MAAO,KACP,UAAW,KACX,WAAY,OACZ,OAAQ,IACR,YAAa,QAAQ,CAAE,MACvB,WAAY,IAAI,KAElB,cACE,SAAU,SACV,OAAQ,IACR,KAAM,IAER,sBACE,MAAO,IACP,OAAQ,KACR,iBAAkB,KAClB,MAAO,MACP,QAAS,GAEX,oBACE,SAAU,SACV,OAAQ,KACR,UAAW,KACX,QAAS,GACT,MAAO,KACP,YAAa,KAAK,EAAE,IAAO,CAAE,EAAE,IAAI,IAAO,CAAE,IAAI,EAAE,IAAO,CAAE,EAAE,KAAK,KAEpE,eACE,SAAU,SACV,UAAW,KACX,WAAY,OACZ,OAAQ,KACR,MAAO,KACP,YAAa,KAAK,EAAE,IAAO,CAAE,EAAE,IAAI,IAAO,CAAE,IAAI,EAAE,IAAO,CAAE,EAAE,KAAK,KAEpE,oBACE,SAAU,SACV,OAAQ,KACR,QAAS,EACT,WAAY,WACZ,OAAQ,IAAI,MAAM,KAGpB,gBACE,QAAS,KAEG,iBAAd,aACE,sBAAuB,KACvB,oBAAqB,KACrB,iBAAkB,KAClB,gBAAiB,KACjB,YAAa,KACb,4BAA6B,YAE/B,oBACE,IAAK,MAEP,eACE,sBAAuB,QACvB,oBAAqB,KACrB,iBAAkB,KAClB,gBAAiB,KACjB,YAAa,KAEf,aACE,OAAQ,iBACR,OAAQ,cACR,OAAQ,SAEV,SACE,OAAQ,KACR,OAAQ,aACR,OAAQ,UACR,OAAQ,KAEV,YACE,SAAU,SACV,iBAAkB,qBAClB,cAAe,IACf,QAAS,IAEX,kBACE,iBAAkB,qBAEpB,SACE,IAAK,KACL,KAAM,KAER,WACE,IAAK,KACL,MAAO,KACP,WAAY,QAAQ,KAAK,MAAM,CAAE,WAAW,GAAG,OAEjD,qBACE,QAAS,EACT,WAAY,OACZ,WAAY,QAAQ,KAAK,MAAM,CAAE,WAAW,GAAG,OAAO,KAExD,gBACE,IAAK,QACL,KAAM,KAER,gBACE,MAAO,KACP,IAAK,KAGP,mBACE,QAAS,MACT,OAAQ,IACR,QAAS,EACT,MAAO,KACP,YAAa,IACb,gBAAiB,KACjB,UAAW,QACX,WAAY,OACZ,OAAQ,QACR,MAAO,QACP,YAAa,KACb,iBAAkB,kBAClB,OAAQ,KACR,cAAe,IAEjB,qCACE,OAAQ,KACR,QAAS,EAEX,uBACE,YAAa,MAEf,YACE,QAAS,MACT,YAAa,IACb,UAAW,MACX,YAAa,UAEf,6BACE,UAAW,MAEb,0BACE,IAAK,MAGP,yBADA,yBAEE,gBAAiB,KACjB,iBAAkB,kBAEpB,qBACE,cAAe,IAAI,IAAI,EAAE,EAE3B,sBACE,cAAe,EAAE,EAAE,IAAI,IAIzB,gBACE,WAAY,MACZ,OAAQ,KACR,MAAO,KACP,UAAW,mBACX,QAAS,KACT,UAAW,YACX,YAAa,OAEf,kBACE,MAAO,kBACP,gBAAiB,KAEnB,mBACE,OAAQ,EACR,QAAS,IAAI,KACb,MAAO,KACP,YAAa,EAAE,EAAE,IAAI,KACrB,UAAW,KAEb,mBACE,QAAS,OACT,WAAY,KAEd,0CACE,QAAS,IAEX,oBACE,WAAY,IACZ,UAAW,QACX,eAAgB,OAElB,uBACE,YAAa,EAEf,gCACE,QAAS,KAEX,mCACE,WAAY,qBAEd,iCACE,OAAQ,EACR,MAAO,EACP,cAAe,IAAI,EAAE,EAEvB,qCACE,WAAY,MACZ,WAAY,MAEd,wCACE,QAAS,KAGX,eACE,IAAK,MACL,KAAM,KACN,OAAQ,MAEV,sBACE,SAAU,SACV,OAAQ,KAGV,yBACE,IAAK,MAGP,gBACE,KAAM,KACN,OAAQ,KAEV,iCACE,OAAQ,EACR,KAAM,EACN,cAAe,EAAE,IAAI,EAAE,EAEzB,oCACA,uBACE,QAAS,MAEX,oCACE,OAAQ,IAAI,MAAM,QAClB,OAAQ,MACR,OAAQ,IACR,MAAO,MAET,0CACE,OAAQ,IACR,KAAM,IACN,SAAU,SAEZ,iDACA,wCACE,QAAS,KAEX,mCACE,WAAY,qBAEd,oBACE,OAAQ,IAAI,OAAO,kBAGrB,0CACE,OAAQ"
}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,681 @@
/*!
* author: FDD <smileFDD@gmail.com>
* ol3-echarts v1.3.6
* build-time: 2018-12-22 14:19
* LICENSE: MIT
* (c) 2017-2018 https://sakitam-fdd.github.io/ol3Echarts
*/
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('echarts'), require('openlayers')) :
typeof define === 'function' && define.amd ? define(['echarts', 'openlayers'], factory) :
(global.ol3Echarts = factory(global.echarts,global.ol));
}(this, (function (echarts,ol) { 'use strict';
echarts = echarts && echarts.hasOwnProperty('default') ? echarts['default'] : echarts;
ol = ol && ol.hasOwnProperty('default') ? ol['default'] : ol;
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) {
return typeof obj;
} : function (obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};
var classCallCheck = function (instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
};
var inherits = function (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 possibleConstructorReturn = function (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;
};
var isObject = function isObject(value) {
var type = typeof value === 'undefined' ? 'undefined' : _typeof(value);
return value !== null && (type === 'object' || type === 'function');
};
var merge = function merge(a, b) {
for (var key in b) {
if (isObject(b[key]) && isObject(a[key])) {
merge(a[key], b[key]);
} else {
a[key] = b[key];
}
}
return a;
};
var getTarget = function getTarget(selector) {
var doc = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document;
var dom = function () {
var found = void 0;
return doc && /^#([\w-]+)$/.test(selector) ? (found = doc.getElementById(RegExp.$1)) ? [found] : [] : Array.prototype.slice.call(/^\.([\w-]+)$/.test(selector) ? doc.getElementsByClassName(RegExp.$1) : /^[\w-]+$/.test(selector) ? doc.getElementsByTagName(selector) : doc.querySelectorAll(selector));
}();
return dom;
};
var map = function map(obj, cb, context) {
if (!(obj && cb)) {
return;
}
if (obj.map && obj.map === Array.prototype.map) {
return obj.map(cb, context);
} else {
var result = [];
for (var i = 0, len = obj.length; i < len; i++) {
result.push(cb.call(context, obj[i], i, obj));
}
return result;
}
};
var bind = function bind(func, context) {
var args = Array.prototype.slice.call(arguments, 2);
return function () {
return func.apply(context, args.concat(Array.prototype.slice.call(arguments)));
};
};
var arrayAdd = function arrayAdd(array, item) {
var i = 0;
var index = void 0;
var length = array.length;
for (; i < length; i++) {
if (array[i]['seriesIndex'] === item['seriesIndex']) {
index = i;
}
}
if (index === undefined) {
array.push(item);
} else {
array[index] = item;
}
return array;
};
var checkDecoded = function checkDecoded(json) {
if (json.UTF8Encoding) {
return false;
} else {
return true;
}
};
var decode = function decode(json) {
if (checkDecoded(json)) {
return json;
}
var encodeScale = json.UTF8Scale;
if (encodeScale == null) {
encodeScale = 1024;
}
var features = json.features;
for (var f = 0; f < features.length; f++) {
var feature = features[f];
var geometry = feature.geometry;
var _ref = [geometry.coordinates, geometry.encodeOffsets],
coordinates = _ref[0],
encodeOffsets = _ref[1];
for (var c = 0; c < coordinates.length; c++) {
var coordinate = coordinates[c];
if (geometry.type === 'Polygon') {
coordinates[c] = decodePolygon(coordinate, encodeOffsets[c], encodeScale);
} else if (geometry.type === 'MultiPolygon') {
for (var c2 = 0; c2 < coordinate.length; c2++) {
var polygon = coordinate[c2];
coordinate[c2] = decodePolygon(polygon, encodeOffsets[c][c2], encodeScale);
}
}
}
}
json.UTF8Encoding = false;
return json;
};
var decodePolygon = function decodePolygon(coordinate, encodeOffsets, encodeScale) {
var _ref2 = [[], encodeOffsets[0], encodeOffsets[1]],
result = _ref2[0],
prevX = _ref2[1],
prevY = _ref2[2];
for (var i = 0; i < coordinate.length; i += 2) {
var x = coordinate.charCodeAt(i) - 64;
var y = coordinate.charCodeAt(i + 1) - 64;
x = x >> 1 ^ -(x & 1);
y = y >> 1 ^ -(y & 1);
x += prevX;
y += prevY;
prevX = x;
prevY = y;
result.push([x / encodeScale, y / encodeScale]);
}
return result;
};
function formatGeoJSON (json) {
var geoJson = decode(json);
var _features = echarts.util.map(echarts.util.filter(geoJson.features, function (featureObj) {
return featureObj.geometry && featureObj.properties && featureObj.geometry.coordinates.length > 0;
}), function (featureObj) {
var properties = featureObj.properties;
var geo = featureObj.geometry;
var coordinates = geo.coordinates;
var geometries = [];
if (geo.type === 'Polygon') {
geometries.push(coordinates[0]);
}
if (geo.type === 'MultiPolygon') {
echarts.util.each(coordinates, function (item) {
if (item[0]) {
geometries.push(item[0]);
}
});
}
return {
type: 'Feature',
geometry: {
type: 'Polygon',
coordinates: geometries
},
properties: properties
};
});
return {
type: 'FeatureCollection',
crs: {},
features: _features
};
}
var _getCoordinateSystem = function _getCoordinateSystem(map$$1) {
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var RegisterCoordinateSystem = function RegisterCoordinateSystem() {
this._mapOffset = [0, 0];
this.dimensions = ['lng', 'lat'];
this.projCode_ = this._getProjectionCode();
};
RegisterCoordinateSystem.prototype.dimensions = ['lng', 'lat'];
RegisterCoordinateSystem.dimensions = RegisterCoordinateSystem.prototype.dimensions;
RegisterCoordinateSystem.prototype.getZoom = function () {
return map$$1.getView().getZoom();
};
RegisterCoordinateSystem.prototype.setZoom = function (zoom) {
return map$$1.getView().setZoom(zoom);
};
RegisterCoordinateSystem.prototype.getViewRectAfterRoam = function () {
return this.getViewRect().clone();
};
RegisterCoordinateSystem.prototype.setMapOffset = function (mapOffset) {
this._mapOffset = mapOffset;
};
RegisterCoordinateSystem.prototype.dataToPoint = function (coords) {
if (coords && Array.isArray(coords) && coords.length > 0) {
coords = coords.map(function (item) {
if (typeof item === 'string') {
item = Number(item);
}
return item;
});
}
var source = options['source'] || 'EPSG:4326';
var destination = options['destination'] || this.projCode_;
var pixel = map$$1.getPixelFromCoordinate(ol.proj.transform(coords, source, destination));
var mapOffset = this._mapOffset;
return [pixel[0] - mapOffset[0], pixel[1] - mapOffset[1]];
};
RegisterCoordinateSystem.prototype._getProjectionCode = function () {
var code = '';
if (map$$1) {
code = map$$1.getView() && map$$1.getView().getProjection().getCode();
} else {
code = 'EPSG:3857';
}
return code;
};
RegisterCoordinateSystem.prototype.pointToData = function (pixel) {
var mapOffset = this._mapOffset;
return map$$1.getCoordinateFromPixel([pixel[0] + mapOffset[0], pixel[1] + mapOffset[1]]);
};
RegisterCoordinateSystem.prototype.getViewRect = function () {
var size = map$$1.getSize();
return new echarts.graphic.BoundingRect(0, 0, size[0], size[1]);
};
RegisterCoordinateSystem.prototype.getRoamTransform = function () {
return echarts.matrix.create();
};
RegisterCoordinateSystem.prototype.prepareCustoms = function (data) {
var rect = this.getViewRect();
return {
coordSys: {
type: 'openlayers',
x: rect.x,
y: rect.y,
width: rect.width,
height: rect.height
},
api: {
coord: bind(this.dataToPoint, this),
size: bind(RegisterCoordinateSystem.dataToCoordSize, this)
}
};
};
RegisterCoordinateSystem.dataToCoordSize = function (dataSize, dataItem) {
dataItem = dataItem || [0, 0];
return map([0, 1], function (dimIdx) {
var val = dataItem[dimIdx];
var halfSize = dataSize[dimIdx] / 2;
var p1 = [],
p2 = [];
p1[dimIdx] = val - halfSize;
p2[dimIdx] = val + halfSize;
p1[1 - dimIdx] = p2[1 - dimIdx] = dataItem[1 - dimIdx];
return Math.abs(this.dataToPoint(p1)[dimIdx] - this.dataToPoint(p2)[dimIdx]);
}, this);
};
RegisterCoordinateSystem.create = function (echartModel, api) {
echartModel.eachSeries(function (seriesModel) {
if (seriesModel.get('coordinateSystem') === 'openlayers') {
seriesModel.coordinateSystem = new RegisterCoordinateSystem(map$$1);
}
});
};
return RegisterCoordinateSystem;
};
var pie = function pie(options, serie, coordinateSystem) {
serie.center = coordinateSystem.dataToPoint(serie.coordinates);
return serie;
};
var bar = function bar(options, serie, coordinateSystem) {
if (isObject(options.grid) && !Array.isArray(options.grid)) {
console.log(options);
} else if (Array.isArray(options.grid)) {
options.grid = options.grid.map(function (gri, index) {
var coorPixel = coordinateSystem.dataToPoint(options.series[index].coordinates);
gri.left = coorPixel[0] - parseFloat(gri.width) / 2;
gri.top = coorPixel[1] - parseFloat(gri.height) / 2;
return gri;
});
}
return serie;
};
var charts = /*#__PURE__*/Object.freeze({
pie: pie,
bar: bar
});
var _options = {
forcedRerender: false,
forcedPrecomposeRerender: false,
hideOnZooming: false,
hideOnMoving: false,
hideOnRotating: false,
convertTypes: ['pie', 'line', 'bar']
};
var ol3Echarts = function (_ol$Object) {
inherits(ol3Echarts, _ol$Object);
function ol3Echarts(chartOptions) {
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var map$$1 = arguments[2];
classCallCheck(this, ol3Echarts);
var _this = possibleConstructorReturn(this, _ol$Object.call(this));
_this.$options = merge(_options, options);
_this.$chartOptions = chartOptions;
_this.$chart = null;
_this.$Map = null;
_this._isRegistered = false;
_this._incremental = [];
_this._coordinateSystem = null;
if (map$$1) _this.appendTo(map$$1);
return _this;
}
ol3Echarts.prototype.appendTo = function appendTo(map$$1) {
if (map$$1 && map$$1 instanceof ol.Map) {
this.$Map = map$$1;
this.$Map.once('postrender', this.render, this);
this.$Map.renderSync();
this._unRegisterEvents();
this._registerEvents();
} else {
throw new Error('not map object');
}
};
ol3Echarts.prototype.getChartOptions = function getChartOptions() {
return this.$chartOptions;
};
ol3Echarts.prototype.setChartOptions = function setChartOptions() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.$chartOptions = options;
this.$Map.once('postrender', this.render, this);
this.$Map.renderSync();
return this;
};
ol3Echarts.prototype.appendData = function appendData(data) {
var save = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
if (data) {
if (save) {
this._incremental = arrayAdd(this._incremental, {
data: data.data,
seriesIndex: data.seriesIndex
});
}
this.$chart.appendData({
data: data.data.copyWithin(),
seriesIndex: data.seriesIndex
});
}
return this;
};
ol3Echarts.prototype.clear = function clear() {
this._incremental = [];
this.$chart.clear();
};
ol3Echarts.prototype.getMap = function getMap() {
return this.$Map;
};
ol3Echarts.prototype._isVisible = function _isVisible() {
return this.$container && this.$container.style.display === '';
};
ol3Echarts.prototype.show = function show() {
if (this.$container) {
this.$container.style.display = '';
}
};
ol3Echarts.prototype.hide = function hide() {
if (this.$container) {
this.$container.style.display = 'none';
}
};
ol3Echarts.prototype.remove = function remove() {
this.$chart.clear();
this.$chart.dispose();
this._unRegisterEvents();
this._incremental = [];
delete this.$chart;
delete this.$Map;
this.$container.parentNode.removeChild(this.$container);
};
ol3Echarts.prototype.showLoading = function showLoading() {
if (this.$chart) {
this.$chart.showLoading();
}
};
ol3Echarts.prototype.hideLoading = function hideLoading() {
if (this.$chart) {
this.$chart.hideLoading();
}
};
ol3Echarts.prototype._createLayerContainer = function _createLayerContainer(map$$1, options) {
var viewPort = map$$1.getViewport();
var container = this.$container = document.createElement('div');
container.style.position = 'absolute';
container.style.top = '0px';
container.style.left = '0px';
container.style.right = '0px';
container.style.bottom = '0px';
var _target = getTarget(options['target'], viewPort);
if (_target && _target[0] && _target[0] instanceof Element) {
_target[0].appendChild(container);
} else {
var _target2 = getTarget('.ol-overlaycontainer', viewPort);
if (_target2 && _target2[0] && _target2[0] instanceof Element) {
_target2[0].appendChild(container);
} else {
viewPort.appendChild(container);
}
}
};
ol3Echarts.prototype._resizeContainer = function _resizeContainer() {
var size = this.getMap().getSize();
this.$container.style.height = size[1] + 'px';
this.$container.style.width = size[0] + 'px';
};
ol3Echarts.prototype._clearAndRedraw = function _clearAndRedraw() {
if (!this.$chart || this.$container && this.$container.style.display === 'none') {
return;
}
this.dispatchEvent({
type: 'redraw',
source: this
});
if (this.$options.forcedRerender) {
this.$chart.clear();
}
this.$chart.resize();
if (this.$chartOptions) {
this._registerMap();
this.$chart.setOption(this.reConverData(this.$chartOptions), false);
if (this._incremental && this._incremental.length > 0) {
for (var i = 0; i < this._incremental.length; i++) {
this.appendData(this._incremental[i], false);
}
}
}
};
ol3Echarts.prototype.onResize = function onResize() {
this._resizeContainer();
this._clearAndRedraw();
this.dispatchEvent({
type: 'change:size',
source: this
});
};
ol3Echarts.prototype.onZoomEnd = function onZoomEnd() {
this.$options['hideOnZooming'] && this.show();
this._clearAndRedraw();
this.dispatchEvent({
type: 'zoomend',
source: this
});
};
ol3Echarts.prototype.onDragRotateEnd = function onDragRotateEnd() {
this.$options['hideOnRotating'] && this.show();
this._clearAndRedraw();
this.dispatchEvent({
type: 'change:rotation',
source: this
});
};
ol3Echarts.prototype.onMoveStart = function onMoveStart() {
this.$options['hideOnMoving'] && this.hide();
this.dispatchEvent({
type: 'movestart',
source: this
});
};
ol3Echarts.prototype.onMoveEnd = function onMoveEnd() {
this.$options['hideOnMoving'] && this.show();
this._clearAndRedraw();
this.dispatchEvent({
type: 'moveend',
source: this
});
};
ol3Echarts.prototype.onCenterChange = function onCenterChange(event) {
this._clearAndRedraw();
this.dispatchEvent({
type: 'change:center',
source: this
});
};
ol3Echarts.prototype._registerEvents = function _registerEvents() {
var Map = this.$Map;
var view = Map.getView();
if (this.$options.forcedPrecomposeRerender) {
Map.on('precompose', this.reRender, this);
}
Map.on('change:size', this.onResize, this);
view.on('change:resolution', this.onZoomEnd, this);
view.on('change:center', this.onCenterChange, this);
view.on('change:rotation', this.onDragRotateEnd, this);
Map.on('movestart', this.onMoveStart, this);
Map.on('moveend', this.onMoveEnd, this);
};
ol3Echarts.prototype._unRegisterEvents = function _unRegisterEvents() {
var Map = this.$Map;
var view = Map.getView();
Map.un('change:size', this.onResize, this);
if (this.$options.forcedPrecomposeRerender) {
Map.un('precompose', this.reRender, this);
}
view.un('change:resolution', this.onZoomEnd, this);
view.un('change:center', this.onCenterChange, this);
view.un('change:rotation', this.onDragRotateEnd, this);
Map.un('movestart', this.onMoveStart, this);
Map.un('moveend', this.onMoveEnd, this);
};
ol3Echarts.prototype._registerMap = function _registerMap() {
if (!this._isRegistered) {
echarts.registerCoordinateSystem('openlayers', _getCoordinateSystem(this.getMap(), this.$options));
this._isRegistered = true;
}
var series = this.$chartOptions.series;
if (series && isObject(series)) {
for (var i = series.length - 1; i >= 0; i--) {
if (!(this.$options.convertTypes.indexOf(series[i]['type']) > -1)) {
series[i]['coordinateSystem'] = 'openlayers';
}
series[i]['animation'] = false;
}
}
};
ol3Echarts.prototype.reConverData = function reConverData(options) {
var series = options['series'];
if (series && series.length > 0) {
if (!this._coordinateSystem) {
var _cs = _getCoordinateSystem(this.getMap(), this.$options);
this._coordinateSystem = new _cs();
}
if (series && isObject(series)) {
for (var i = series.length - 1; i >= 0; i--) {
if (this.$options.convertTypes.indexOf(series[i]['type']) > -1) {
if (series[i] && series[i].hasOwnProperty('coordinates')) {
series[i] = charts[series[i]['type']](options, series[i], this._coordinateSystem);
}
}
}
}
}
return options;
};
ol3Echarts.prototype.render = function render() {
if (!this.$container) {
this._createLayerContainer(this.$Map, this.$options);
this._resizeContainer();
}
if (!this.$chart) {
this.$chart = echarts.init(this.$container);
if (this.$chartOptions) {
this._registerMap();
this.$chart.setOption(this.reConverData(this.$chartOptions), false);
}
} else if (this._isVisible()) {
this.$chart.resize();
this.reRender();
}
};
ol3Echarts.prototype.reRender = function reRender() {
this._clearAndRedraw();
};
return ol3Echarts;
}(ol.Object);
ol3Echarts.getTarget = getTarget;
ol3Echarts.merge = merge;
ol3Echarts.map = map;
ol3Echarts.bind = bind;
ol3Echarts.formatGeoJSON = formatGeoJSON;
return ol3Echarts;
})));

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,853 @@
/*!
* author: sakitam-fdd <smilefdd@gmail.com>
* ol3-echarts v2.0.5
* build-time: 2022-1-6 15:31
* LICENSE: MIT
* (c) 2017-2022 https://sakitam-fdd.github.io/ol3Echarts
*/
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('openlayers'), require('echarts')) :
typeof define === 'function' && define.amd ? define(['openlayers', 'echarts'], factory) :
(global = global || self, global.ol3Echarts = factory(global.ol, global.echarts));
}(this, function (ol, echarts) { 'use strict';
ol = ol && ol.hasOwnProperty('default') ? ol['default'] : ol;
echarts = echarts && echarts.hasOwnProperty('default') ? echarts['default'] : echarts;
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var isObject = function (value) {
var type = typeof value;
return value !== null && (type === 'object' || type === 'function');
};
var merge = function (a, b) {
Object.keys(b).forEach(function (key) {
if (isObject(b[key]) && isObject(a[key])) {
merge(a[key], b[key]);
}
else {
a[key] = b[key];
}
});
return a;
};
var bind = function (func, context) {
var arguments$1 = arguments;
var args = [];
for (var _i = 2; _i < arguments.length; _i++) {
args[_i - 2] = arguments$1[_i];
}
return function () {
var arguments$1 = arguments;
var innerArgs = [];
for (var _i = 0; _i < arguments.length; _i++) {
innerArgs[_i] = arguments$1[_i];
}
return func.apply(context, args.concat(Array.prototype.slice.call(innerArgs)));
};
};
var arrayAdd = function (array, item) {
var i = 0;
var index;
var length = array.length;
for (; i < length; i++) {
if (array[i].index === item.index) {
index = i;
break;
}
}
if (index === undefined) {
array.push(item);
}
else {
array[index] = item;
}
return array;
};
var uuid = function () {
function rd(a) {
return a ? (a ^ Math.random() * 16 >> a / 4).toString(16)
: ([1e7] + -[1e3] + -4e3 + -8e3 + -1e11).replace(/[018]/g, rd);
}
return rd();
};
function bindAll(fns, context) {
fns.forEach(function (fn) {
if (!context[fn]) {
return;
}
context[fn] = context[fn].bind(context);
});
}
function removeNode(node) {
return node && node.parentNode ? node.parentNode.removeChild(node) : null;
}
function mockEvent(type, event) {
var e = new MouseEvent(type, {
bubbles: true,
cancelable: true,
button: event.pointerEvent.button,
buttons: event.pointerEvent.buttons,
clientX: event.pointerEvent.clientX,
clientY: event.pointerEvent.clientY,
zrX: event.pointerEvent.offsetX,
zrY: event.pointerEvent.offsetY,
movementX: event.pointerEvent.movementX,
movementY: event.pointerEvent.movementY,
relatedTarget: event.pointerEvent.relatedTarget,
screenX: event.pointerEvent.screenX,
screenY: event.pointerEvent.screenY,
view: window,
});
e.zrX = event.pointerEvent.offsetX;
e.zrY = event.pointerEvent.offsetY;
e.event = e;
return e;
}
var checkDecoded = function (json) { return !json.UTF8Encoding; };
var decodePolygon = function (coordinate, encodeOffsets, encodeScale) {
var result = [];
var _a = [encodeOffsets[0], encodeOffsets[1]], prevX = _a[0], prevY = _a[1];
for (var i = 0; i < coordinate.length; i += 2) {
var x = coordinate.charCodeAt(i) - 64;
var y = coordinate.charCodeAt(i + 1) - 64;
x = (x >> 1) ^ -(x & 1);
y = (y >> 1) ^ -(y & 1);
x += prevX;
y += prevY;
prevX = x;
prevY = y;
result.push([x / encodeScale, y / encodeScale]);
}
return result;
};
var decode = function (json) {
if (checkDecoded(json)) {
return json;
}
var encodeScale = json.UTF8Scale;
if (encodeScale == null) {
encodeScale = 1024;
}
var features = json.features;
for (var f = 0; f < features.length; f++) {
var feature = features[f];
var geometry = feature.geometry;
var _a = [geometry.coordinates, geometry.encodeOffsets], coordinates = _a[0], encodeOffsets = _a[1];
for (var c = 0; c < coordinates.length; c++) {
var coordinate = coordinates[c];
if (geometry.type === 'Polygon') {
coordinates[c] = decodePolygon(coordinate, encodeOffsets[c], encodeScale);
}
else if (geometry.type === 'MultiPolygon') {
for (var c2 = 0; c2 < coordinate.length; c2++) {
var polygon = coordinate[c2];
coordinate[c2] = decodePolygon(polygon, encodeOffsets[c][c2], encodeScale);
}
}
}
}
json.UTF8Encoding = false;
return json;
};
function formatGeoJSON (json) {
var geoJson = decode(json);
var _features = echarts.util.map(echarts.util.filter(geoJson.features, function (featureObj) {
return featureObj.geometry && featureObj.properties && featureObj.geometry.coordinates.length > 0;
}), function (featureObj) {
var properties = featureObj.properties;
var geo = featureObj.geometry;
var coordinates = geo.coordinates;
var geometries = [];
if (geo.type === 'Polygon') {
geometries.push(coordinates[0]);
}
if (geo.type === 'MultiPolygon') {
echarts.util.each(coordinates, function (item) {
if (item[0]) {
geometries.push(item[0]);
}
});
}
return {
properties: properties,
type: 'Feature',
geometry: {
type: 'Polygon',
coordinates: geometries,
},
};
});
return {
type: 'FeatureCollection',
crs: {},
features: _features,
};
}
var pie = function (_options, serie, coordinateSystem) {
serie.center = coordinateSystem.dataToPoint(serie.coordinates);
return serie;
};
var bar = function (options, serie, coordinateSystem) {
if (isObject(options.grid) && !Array.isArray(options.grid)) {
console.log(options);
}
else if (Array.isArray(options.grid)) {
options.grid = options.grid.map(function (gri, index) {
var coorPixel = coordinateSystem.dataToPoint(options.series[index].coordinates);
gri.left = coorPixel[0] - parseFloat(gri.width) / 2;
gri.top = coorPixel[1] - parseFloat(gri.height) / 2;
return gri;
});
}
return serie;
};
var line = function (options, serie, coordinateSystem) {
if (isObject(options.grid) && !Array.isArray(options.grid)) {
console.log(options);
}
else if (Array.isArray(options.grid)) {
options.grid = options.grid.map(function (gri, index) {
var coorPixel = coordinateSystem.dataToPoint(options.series[index].coordinates);
gri.left = coorPixel[0] - parseFloat(gri.width) / 2;
gri.top = coorPixel[1] - parseFloat(gri.height) / 2;
return gri;
});
}
return serie;
};
var charts = /*#__PURE__*/Object.freeze({
pie: pie,
bar: bar,
line: line
});
var Map = ol.Map;
var obj = ol.Object;
var transform = ol.proj.transform;
if (!Map.prototype.getOverlayContainer) {
Map.prototype.getOverlayContainer = function (className) {
className = className || 'ol-overlaycontainer';
var viewport = this.getViewport();
if (viewport) {
var overlays = viewport.getElementsByClassName(className);
return overlays && overlays.length > 0 ? overlays[0] : null;
}
return null;
};
}
if (!Map.prototype.getOverlayContainerStopEvent) {
Map.prototype.getOverlayContainerStopEvent = function (className) {
className = className || 'ol-overlaycontainer-stopevent';
var viewport = this.getViewport();
if (viewport) {
var overlays = viewport.getElementsByClassName(className);
return overlays && overlays.length > 0 ? overlays[0] : null;
}
return null;
};
}
var _options = {
forcedRerender: false,
forcedPrecomposeRerender: false,
hideOnZooming: false,
hideOnMoving: false,
hideOnRotating: false,
convertTypes: ['pie', 'line', 'bar'],
insertFirst: false,
stopEvent: false,
polyfillEvents: false,
};
var EChartsLayer = (function (_super) {
__extends(EChartsLayer, _super);
function EChartsLayer(chartOptions, options, map) {
var _this = this;
var opts = Object.assign(_options, options);
_this = _super.call(this, opts) || this;
_this._options = opts;
_this._chartOptions = chartOptions;
_this.set('chartOptions', chartOptions);
_this.$chart = null;
_this.$container = undefined;
_this._isRegistered = false;
_this._initEvent = false;
_this._incremental = [];
_this._coordinateSystem = null;
_this.coordinateSystemId = '';
_this.prevVisibleState = '';
bindAll([
'redraw', 'onResize', 'onZoomEnd', 'onCenterChange',
'onDragRotateEnd', 'onMoveStart', 'onMoveEnd',
'mouseDown', 'mouseUp', 'onClick', 'mouseMove' ], _this);
if (map)
{ _this.setMap(map); }
return _this;
}
EChartsLayer.prototype.appendTo = function (map, forceIgnore) {
if (forceIgnore === void 0) { forceIgnore = false; }
this.setMap(map, forceIgnore);
};
EChartsLayer.prototype.getMap = function () {
return this._map;
};
EChartsLayer.prototype.setMap = function (map, forceIgnore) {
var _this = this;
if (forceIgnore === void 0) { forceIgnore = false; }
if (map && (forceIgnore || map instanceof Map)) {
this._map = map;
this._map.once('postrender', function () {
_this.handleMapChanged();
});
this._map.renderSync();
}
else {
throw new Error('not ol map object');
}
};
EChartsLayer.prototype.getChartOptions = function () {
return this.get('chartOptions');
};
EChartsLayer.prototype.setChartOptions = function (options) {
if (options === void 0) { options = {}; }
this._chartOptions = options;
this.set('chartOptions', options);
this.clearAndRedraw();
return this;
};
EChartsLayer.prototype.appendData = function (data, save) {
if (save === void 0) { save = true; }
if (data) {
if (save) {
this._incremental = arrayAdd(this._incremental, {
index: this._incremental.length,
data: data.data,
seriesIndex: data.seriesIndex,
});
}
this.$chart.appendData({
data: data.data.copyWithin(),
seriesIndex: data.seriesIndex,
});
}
return this;
};
EChartsLayer.prototype.clear = function (keep) {
if (!keep) {
this._incremental = [];
}
if (this.$chart) {
this.$chart.clear();
}
};
EChartsLayer.prototype.remove = function () {
this.clear();
if (this.$chart) {
this.$chart.dispose();
}
if (this._initEvent && this.$container) {
this.$container && removeNode(this.$container);
this.unBindEvent();
}
delete this.$chart;
delete this._map;
};
EChartsLayer.prototype.show = function () {
this.setVisible(true);
};
EChartsLayer.prototype.innerShow = function () {
if (this.$container) {
this.$container.style.display = this.prevVisibleState;
this.prevVisibleState = '';
}
};
EChartsLayer.prototype.hide = function () {
this.setVisible(false);
};
EChartsLayer.prototype.innerHide = function () {
if (this.$container) {
this.prevVisibleState = this.$container.style.display;
this.$container.style.display = 'none';
}
};
EChartsLayer.prototype.isVisible = function () {
return this.$container && this.$container.style.display !== 'none';
};
EChartsLayer.prototype.showLoading = function () {
if (this.$chart) {
this.$chart.showLoading();
}
};
EChartsLayer.prototype.hideLoading = function () {
if (this.$chart) {
this.$chart.hideLoading();
}
};
EChartsLayer.prototype.setZIndex = function (zIndex) {
if (this.$container) {
if (typeof zIndex === 'number') {
zIndex = String(zIndex);
}
this.$container.style.zIndex = zIndex;
}
};
EChartsLayer.prototype.getZIndex = function () {
return this.$container && this.$container.style.zIndex;
};
EChartsLayer.prototype.setVisible = function (visible) {
if (visible) {
if (this.$container) {
this.$container.style.display = '';
}
this._chartOptions = this.getChartOptions();
this.clearAndRedraw();
}
else {
if (this.$container) {
this.$container.style.display = 'none';
}
this.clear(true);
this._chartOptions = {};
this.clearAndRedraw();
}
};
EChartsLayer.prototype.render = function () {
if (!this.$chart && this.$container) {
this.$chart = echarts.init(this.$container);
if (this._chartOptions) {
this.registerMap();
this.$chart.setOption(this.convertData(this._chartOptions), false);
}
this.dispatchEvent({
type: 'load',
source: this,
value: this.$chart,
});
}
else if (this.isVisible()) {
this.redraw();
}
};
EChartsLayer.prototype.redraw = function () {
this.clearAndRedraw();
};
EChartsLayer.prototype.updateViewSize = function (size) {
if (!this.$container)
{ return; }
this.$container.style.width = size[0] + "px";
this.$container.style.height = size[1] + "px";
this.$container.setAttribute('width', String(size[0]));
this.$container.setAttribute('height', String(size[1]));
};
EChartsLayer.prototype.onResize = function (event) {
var map = this.getMap();
if (map) {
var size = map.getSize();
this.updateViewSize(size);
this.clearAndRedraw();
if (event) {
this.dispatchEvent({
type: 'change:size',
source: this,
value: size,
});
}
}
};
EChartsLayer.prototype.onZoomEnd = function () {
this._options.hideOnZooming && this.innerShow();
var map = this.getMap();
if (map && map.getView()) {
this.clearAndRedraw();
this.dispatchEvent({
type: 'zoomend',
source: this,
value: map.getView().getZoom(),
});
}
};
EChartsLayer.prototype.onDragRotateEnd = function () {
this._options.hideOnRotating && this.innerShow();
var map = this.getMap();
if (map && map.getView()) {
this.clearAndRedraw();
this.dispatchEvent({
type: 'change:rotation',
source: this,
value: map.getView().getRotation(),
});
}
};
EChartsLayer.prototype.onMoveStart = function () {
this._options.hideOnMoving && this.innerHide();
var map = this.getMap();
if (map && map.getView()) {
this.dispatchEvent({
type: 'movestart',
source: this,
value: map.getView().getCenter(),
});
}
};
EChartsLayer.prototype.onMoveEnd = function () {
this._options.hideOnMoving && this.innerShow();
var map = this.getMap();
if (map && map.getView()) {
this.clearAndRedraw();
this.dispatchEvent({
type: 'moveend',
source: this,
value: map.getView().getCenter(),
});
}
};
EChartsLayer.prototype.onClick = function (event) {
if (this.$chart) {
this.$chart.getZr().painter.getViewportRoot().dispatchEvent(mockEvent('click', event));
}
};
EChartsLayer.prototype.mouseDown = function (event) {
if (this.$chart) {
this.$chart.getZr().painter.getViewportRoot().dispatchEvent(mockEvent('mousedown', event));
}
};
EChartsLayer.prototype.mouseUp = function (event) {
if (this.$chart) {
this.$chart.getZr().painter.getViewportRoot().dispatchEvent(mockEvent('mouseup', event));
}
};
EChartsLayer.prototype.mouseMove = function (event) {
if (this.$chart) {
var target = event.originalEvent.target;
while (target) {
if (target.className === 'ol-overlaycontainer-stopevent') {
this.$chart.getZr().painter.getViewportRoot().dispatchEvent(mockEvent('mousemove', event));
return;
}
target = target.parentElement;
}
}
};
EChartsLayer.prototype.onCenterChange = function () {
var map = this.getMap();
if (map && map.getView()) {
this.clearAndRedraw();
this.dispatchEvent({
type: 'change:center',
source: this,
value: map.getView().getCenter(),
});
}
};
EChartsLayer.prototype.handleMapChanged = function () {
var map = this.getMap();
if (this._initEvent && this.$container) {
this.$container && removeNode(this.$container);
this.unBindEvent();
}
if (!this.$container) {
this.createLayerContainer();
this.onResize(false);
}
if (map) {
var container = this._options.stopEvent ? map.getOverlayContainerStopEvent() : map.getOverlayContainer();
if (this._options.insertFirst) {
container.insertBefore(this.$container, container.childNodes[0] || null);
}
else {
container.appendChild(this.$container);
}
this.render();
this.bindEvent(map);
}
};
EChartsLayer.prototype.createLayerContainer = function () {
this.$container = document.createElement('div');
this.$container.style.position = 'absolute';
this.$container.style.top = '0px';
this.$container.style.left = '0px';
this.$container.style.right = '0px';
this.$container.style.bottom = '0px';
};
EChartsLayer.prototype.bindEvent = function (map) {
var view = map.getView();
if (this._options.forcedPrecomposeRerender) {
map.on('precompose', this.redraw);
}
map.on('change:size', this.onResize);
view.on('change:resolution', this.onZoomEnd);
view.on('change:center', this.onCenterChange);
view.on('change:rotation', this.onDragRotateEnd);
map.on('movestart', this.onMoveStart);
map.on('moveend', this.onMoveEnd);
if (this._options.polyfillEvents) {
map.on('pointerdown', this.mouseDown);
map.on('pointerup', this.mouseUp);
map.on('pointermove', this.mouseMove);
map.on('click', this.onClick);
}
this._initEvent = true;
};
EChartsLayer.prototype.unBindEvent = function () {
var map = this.getMap();
if (!map)
{ return; }
var view = map.getView();
if (!view)
{ return; }
map.un('precompose', this.redraw);
map.un('change:size', this.onResize);
view.un('change:resolution', this.onZoomEnd);
view.un('change:center', this.onCenterChange);
view.un('change:rotation', this.onDragRotateEnd);
map.un('movestart', this.onMoveStart);
map.un('moveend', this.onMoveEnd);
if (this._options.polyfillEvents) {
map.un('pointerdown', this.mouseDown);
map.un('pointerup', this.mouseUp);
map.un('pointermove', this.mouseMove);
map.un('click', this.onClick);
}
this._initEvent = false;
};
EChartsLayer.prototype.clearAndRedraw = function () {
if (!this.$chart || !this.isVisible())
{ return; }
if (this._options.forcedRerender) {
this.$chart.clear();
}
this.$chart.resize();
if (this._chartOptions) {
this.registerMap();
this.$chart.setOption(this.convertData(this._chartOptions), false);
if (this._incremental && this._incremental.length > 0) {
for (var i = 0; i < this._incremental.length; i++) {
this.appendData(this._incremental[i], false);
}
}
}
this.dispatchEvent({
type: 'redraw',
source: this,
});
};
EChartsLayer.prototype.registerMap = function () {
if (!this._isRegistered) {
this.coordinateSystemId = "openlayers_" + uuid();
echarts.registerCoordinateSystem(this.coordinateSystemId, this.getCoordinateSystem(this._options));
this._isRegistered = true;
}
if (this._chartOptions) {
var series = this._chartOptions.series;
if (series && isObject(series)) {
var convertTypes = this._options.convertTypes;
if (convertTypes) {
for (var i = series.length - 1; i >= 0; i--) {
if (!(convertTypes.indexOf(series[i].type) > -1)) {
series[i].coordinateSystem = this.coordinateSystemId;
}
series[i].animation = false;
}
}
}
}
};
EChartsLayer.prototype.convertData = function (options) {
var series = options.series;
if (series && series.length > 0) {
if (!this._coordinateSystem) {
var Rc = this.getCoordinateSystem(this._options);
this._coordinateSystem = new Rc(this.getMap());
}
if (series && isObject(series)) {
var convertTypes = this._options.convertTypes;
if (convertTypes) {
for (var i = series.length - 1; i >= 0; i--) {
if (convertTypes.indexOf(series[i].type) > -1) {
if (series[i] && series[i].hasOwnProperty('coordinates')) {
series[i] = charts[series[i].type](options, series[i], this._coordinateSystem);
}
}
}
}
}
}
return options;
};
EChartsLayer.prototype.getCoordinateSystem = function (options) {
var map = this.getMap();
var coordinateSystemId = this.coordinateSystemId;
var RegisterCoordinateSystem = function (map) {
this.map = map;
this._mapOffset = [0, 0];
this.dimensions = ['lng', 'lat'];
this.projCode = RegisterCoordinateSystem.getProjectionCode(this.map);
};
RegisterCoordinateSystem.dimensions = RegisterCoordinateSystem.prototype.dimensions || ['lng', 'lat'];
RegisterCoordinateSystem.prototype.getZoom = function () {
return this.map.getView().getZoom();
};
RegisterCoordinateSystem.prototype.setZoom = function (zoom) {
return this.map.getView().setZoom(zoom);
};
RegisterCoordinateSystem.prototype.getViewRectAfterRoam = function () {
return this.getViewRect().clone();
};
RegisterCoordinateSystem.prototype.setMapOffset = function (mapOffset) {
this._mapOffset = mapOffset;
};
RegisterCoordinateSystem.prototype.dataToPoint = function (data) {
var coords;
if (data && Array.isArray(data) && data.length > 0) {
coords = data.map(function (item) {
var res = 0;
if (typeof item === 'string') {
res = Number(item);
}
else {
res = item;
}
return res;
});
var source = (options && options.source) || 'EPSG:4326';
var destination = (options && options.destination) || this.projCode;
var pixel = this.map.getPixelFromCoordinate(transform(coords, source, destination));
var mapOffset = this._mapOffset;
return [pixel[0] - mapOffset[0], pixel[1] - mapOffset[1]];
}
return [0, 0];
};
RegisterCoordinateSystem.prototype.pointToData = function (pixel) {
var mapOffset = this._mapOffset;
return this.map.getCoordinateFromPixel([pixel[0] + mapOffset[0], pixel[1] + mapOffset[1]]);
};
RegisterCoordinateSystem.prototype.getViewRect = function () {
var size = this.map.getSize();
return new echarts.graphic.BoundingRect(0, 0, size[0], size[1]);
};
RegisterCoordinateSystem.prototype.getRoamTransform = function () {
return echarts.matrix.create();
};
RegisterCoordinateSystem.prototype.prepareCustoms = function () {
var rect = this.getViewRect();
return {
coordSys: {
type: coordinateSystemId,
x: rect.x,
y: rect.y,
width: rect.width,
height: rect.height,
},
api: {
coord: bind(this.dataToPoint, this),
size: bind(RegisterCoordinateSystem.dataToCoordsSize, this),
},
};
};
RegisterCoordinateSystem.create = function (echartsModel) {
echartsModel.eachSeries(function (seriesModel) {
if (seriesModel.get('coordinateSystem') === coordinateSystemId) {
seriesModel.coordinateSystem = new RegisterCoordinateSystem(map);
}
});
};
RegisterCoordinateSystem.getProjectionCode = function (map) {
var code = '';
if (map) {
code = map.getView()
&& map
.getView()
.getProjection()
.getCode();
}
else {
code = 'EPSG:3857';
}
return code;
};
RegisterCoordinateSystem.dataToCoordsSize = function (dataSize, dataItem) {
var _this = this;
if (dataItem === void 0) { dataItem = [0, 0]; }
return [0, 1].map(function (dimIdx) {
var val = dataItem[dimIdx];
var p1 = [];
var p2 = [];
var halfSize = dataSize[dimIdx] / 2;
p1[dimIdx] = val - halfSize;
p2[dimIdx] = val + halfSize;
p1[1 - dimIdx] = dataItem[1 - dimIdx];
p2[1 - dimIdx] = dataItem[1 - dimIdx];
var offset = _this.dataToPoint(p1)[dimIdx] - _this.dataToPoint(p2)[dimIdx];
return Math.abs(offset);
}, this);
};
return RegisterCoordinateSystem;
};
EChartsLayer.prototype.dispatchEvent = function (event) {
return _super.prototype.dispatchEvent.call(this, event);
};
EChartsLayer.prototype.set = function (key, value, optSilent) {
return _super.prototype.set.call(this, key, value, optSilent);
};
EChartsLayer.prototype.get = function (key) {
return _super.prototype.get.call(this, key);
};
EChartsLayer.prototype.unset = function (key, optSilent) {
return _super.prototype.unset.call(this, key, optSilent);
};
EChartsLayer.prototype.on = function (type, listener, optThis) {
return _super.prototype.on.call(this, type, listener, optThis);
};
EChartsLayer.prototype.un = function (type, listener, optThis) {
return _super.prototype.un.call(this, type, listener, optThis);
};
EChartsLayer.formatGeoJSON = formatGeoJSON;
EChartsLayer.bind = bind;
EChartsLayer.merge = merge;
EChartsLayer.uuid = uuid;
EChartsLayer.bindAll = bindAll;
EChartsLayer.arrayAdd = arrayAdd;
EChartsLayer.removeNode = removeNode;
EChartsLayer.isObject = isObject;
return EChartsLayer;
}(obj));
return EChartsLayer;
}));
//# sourceMappingURL=ol3Echarts.js.map

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,206 @@
/*
Copyright (c) 2015 Jean-Marc VIGLINO,
released under the CeCILL-B license (http://www.cecill.info/).
github: https://github.com/Viglino/OL3-AnimatedCluster
ol.layer.AnimatedCluster is a vector layer tha animate cluster
olx.layer.AnimatedClusterOptions: extend olx.layer.Options
{ animationDuration {Number} animation duration in ms, default is 700ms
animationMethod {function} easing method to use, default ol.easing.easeOut
}
*/
/**
* @constructor AnimatedCluster
* @extends {ol.layer.Vector}
* @param {olx.layer.AnimatedClusterOptions=} options
* @todo
*/
ol.layer.AnimatedCluster = function(opt_options)
{ var options = opt_options || {};
ol.layer.Vector.call (this, options);
this.oldcluster = new ol.source.Vector();
this.clusters = [];
this.animation={start:false};
this.set('animationDuration', typeof(options.animationDuration)=='number' ? options.animationDuration : 700);
this.set('animationMethod', options.animationMethod || ol.easing.easeOut);
// Save cluster before change
this.getSource().on('change', this.saveCluster, this);
// Animate the cluster
this.on('precompose', this.animate, this);
this.on('postcompose', this.postanimate, this);
};
ol.inherits (ol.layer.AnimatedCluster, ol.layer.Vector);
/** @private save cluster features before change
*/
ol.layer.AnimatedCluster.prototype.saveCluster = function()
{ this.oldcluster.clear();
if (!this.get('animationDuration')) return;
var features = this.getSource().getFeatures();
if (features.length && features[0].get('features'))
{ this.oldcluster.addFeatures (this.clusters);
this.clusters = features.slice(0);
this.sourceChanged = true;
}
};
/** @private Get the cluster that contains a feature
*/
ol.layer.AnimatedCluster.prototype.getClusterForFeature = function(f, cluster)
{ for (var j=0, c; c=cluster[j]; j++)
{ var features = cluster[j].get('features');
if (features && features.length)
{ for (var k=0, f2; f2=features[k]; k++)
{ if (f===f2)
{ return cluster[j];
}
}
}
}
return false;
};
/** @private
*/
ol.layer.AnimatedCluster.prototype.stopAnimation = function()
{ this.animation.start = false;
this.animation.cA = [];
this.animation.cB = [];
};
/** @private animate the cluster
*/
ol.layer.AnimatedCluster.prototype.animate = function(e)
{ var duration = this.get('animationDuration');
if (!duration) return;
var resolution = e.frameState.viewState.resolution;
var a = this.animation;
var time = e.frameState.time;
// Start a new animation, if change resolution and source has changed
if (a.resolution != resolution && this.sourceChanged)
{ var extent = e.frameState.extent;
if (a.resolution < resolution)
{ extent = ol.extent.buffer(extent, 100*resolution);
a.cA = this.oldcluster.getFeaturesInExtent(extent);
a.cB = this.getSource().getFeaturesInExtent(extent);
a.revers = false;
}
else
{ extent = ol.extent.buffer(extent, 100*resolution);
a.cA = this.getSource().getFeaturesInExtent(extent);
a.cB = this.oldcluster.getFeaturesInExtent(extent);
a.revers = true;
}
a.clusters = [];
for (var i=0, c0; c0=a.cA[i]; i++)
{ var f = c0.get('features');
if (f && f.length)
{ var c = this.getClusterForFeature (f[0], a.cB);
if (c) a.clusters.push({ f:c0, pt:c.getGeometry().getCoordinates() });
}
}
// Save state
a.resolution = resolution;
this.sourceChanged = false;
// No cluster or too much to animate
if (!a.clusters.length || a.clusters.length>1000)
{ this.stopAnimation();
return;
}
// Start animation from now
time = a.start = (new Date()).getTime();
}
// Run animation
if (a.start)
{ var vectorContext = e.vectorContext;
var d = (time - a.start) / duration;
// Animation ends
if (d > 1.0)
{ this.stopAnimation();
d = 1;
}
d = this.get('animationMethod')(d);
// Animate
var style = this.getStyle();
var stylefn = (typeof(style) == 'function') ? style : style.length ? function(){ return style; } : function(){ return [style]; } ;
// Layer opacity
e.context.save();
e.context.globalAlpha = this.getOpacity();
// Retina device
var ratio = e.frameState.pixelRatio;
for (var i=0, c; c=a.clusters[i]; i++)
{ var pt = c.f.getGeometry().getCoordinates();
if (a.revers)
{ pt[0] = c.pt[0] + d * (pt[0]-c.pt[0]);
pt[1] = c.pt[1] + d * (pt[1]-c.pt[1]);
}
else
{ pt[0] = pt[0] + d * (c.pt[0]-pt[0]);
pt[1] = pt[1] + d * (c.pt[1]-pt[1]);
}
// Draw feature
var st = stylefn(c.f, resolution);
/* Preserve pixel ration on retina */
var geo = new ol.geom.Point(pt);
for (var k=0; s=st[k]; k++)
{ var sc;
// OL < v4.3 : setImageStyle doesn't check retina
var imgs = ol.Map.prototype.getFeaturesAtPixel ? false : s.getImage();
if (imgs)
{ sc = imgs.getScale();
imgs.setScale(sc*ratio);
}
// OL3 > v3.14
if (vectorContext.setStyle)
{ vectorContext.setStyle(s);
vectorContext.drawGeometry(geo);
}
// older version
else
{ vectorContext.setImageStyle(imgs);
vectorContext.setTextStyle(s.getText());
vectorContext.drawPointGeometry(geo);
}
if (imgs) imgs.setScale(sc);
}
/*/
var f = new ol.Feature(new ol.geom.Point(pt));
for (var k=0; s=st[k]; k++)
{ var imgs = s.getImage();
var sc = imgs.getScale();
imgs.setScale(sc*ratio); // drawFeature don't check retina
vectorContext.drawFeature(f, s);
imgs.setScale(sc);
}
/**/
}
e.context.restore();
// tell OL3 to continue postcompose animation
e.frameState.animate = true;
// Prevent layer drawing (clip with null rect)
e.context.save();
e.context.beginPath();
e.context.rect(0,0,0,0);
e.context.clip();
this.clip_ = true;
}
return;
};
/** @private remove clipping after the layer is drawn
*/
ol.layer.AnimatedCluster.prototype.postanimate = function(e)
{ if (this.clip_)
{ e.context.restore();
this.clip_ = false;
}
};

View File

@ -0,0 +1,183 @@
.layer-switcher {
position: absolute;
top: 3.5em;
right: 0.5em;
text-align: left;
}
.layer-switcher .panel {
margin: 0;
border: 4px solid #eee;
border-radius: 4px;
background-color: white;
display: none;
max-height: inherit;
height: 100%;
box-sizing: border-box;
overflow-y: auto;
}
.layer-switcher button {
float: right;
z-index: 1;
width: 38px;
height: 38px;
background-image: url('')
/*logo.png*/;
background-repeat: no-repeat;
background-position: 2px;
background-color: white;
color: black;
border: none;
}
.layer-switcher button:focus,
.layer-switcher button:hover {
background-color: white;
}
.layer-switcher.shown {
overflow-y: hidden;
}
.layer-switcher.shown.ol-control {
background-color: transparent;
}
.layer-switcher.shown.ol-control:hover {
background-color: transparent;
}
.layer-switcher.shown .panel {
display: block;
}
.layer-switcher.shown button {
display: none;
}
.layer-switcher.shown.layer-switcher-activation-mode-click > button {
display: block;
background-image: unset;
right: 2px;
position: absolute;
background-color: #eee;
margin: 0 1px;
}
.layer-switcher.shown button:focus,
.layer-switcher.shown button:hover {
background-color: #fafafa;
}
.layer-switcher ul {
list-style: none;
margin: 1.6em 0.4em;
padding-left: 0;
}
.layer-switcher ul ul {
padding-left: 1.2em;
margin: 0.1em 0 0 0;
}
.layer-switcher li.group + li.group {
margin-top: 0.4em;
}
.layer-switcher li.group + li.layer-switcher-base-group {
}
.layer-switcher li.group > label {
font-weight: bold;
}
.layer-switcher.layer-switcher-group-select-style-none li.group > label {
padding-left: 1.2em;
}
.layer-switcher li {
position: relative;
margin-top: 0.3em;
}
.layer-switcher li input {
position: absolute;
left: 1.2em;
height: 1em;
width: 1em;
font-size: 1em;
}
.layer-switcher li label {
padding-left: 2.7em;
padding-right: 1.2em;
display: inline-block;
margin-top: 1px;
}
.layer-switcher label.disabled {
opacity: 0.4;
}
.layer-switcher input {
margin: 0px;
}
.layer-switcher.touch ::-webkit-scrollbar {
width: 4px;
}
.layer-switcher.touch ::-webkit-scrollbar-track {
-webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
border-radius: 10px;
}
.layer-switcher.touch ::-webkit-scrollbar-thumb {
border-radius: 10px;
-webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.5);
}
li.layer-switcher-base-group > label {
padding-left: 1.2em;
}
.layer-switcher .group button {
position: absolute;
left: 0;
display: inline-block;
vertical-align: top;
float: none;
font-size: 1em;
width: 1em;
height: 1em;
margin: 0;
background-position: center 2px;
background-image: url('');
-webkit-transition: -webkit-transform 0.2s ease-in-out;
-ms-transition: -ms-transform 0.2s ease-in-out;
transition: transform 0.2s ease-in-out;
}
.layer-switcher .group.layer-switcher-close button {
transform: rotate(-90deg);
-webkit-transform: rotate(-90deg);
}
.layer-switcher .group.layer-switcher-fold.layer-switcher-close > ul {
overflow: hidden;
height: 0;
}
/*layerswitcher on the right*/
.layer-switcher.shown.layer-switcher-activation-mode-click {
padding-left: 34px;
}
.layer-switcher.shown.layer-switcher-activation-mode-click > button {
left: 0;
border-right: 0;
}
/*layerswitcher on the left*/
/*
.layer-switcher.shown.layer-switcher-activation-mode-click {
padding-right: 34px;
}
.layer-switcher.shown.layer-switcher-activation-mode-click > button {
right: 0;
border-left: 0;
}
*/

View File

@ -0,0 +1,694 @@
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('ol/control/Control'), require('ol/Observable'), require('ol/layer/Group')) :
typeof define === 'function' && define.amd ? define(['ol/control/Control', 'ol/Observable', 'ol/layer/Group'], factory) :
(global.LayerSwitcher = factory(global.ol.control.Control,global.ol.Observable,global.ol.layer.Group));
}(this, (function (Control,ol_Observable,LayerGroup) { 'use strict';
Control = 'default' in Control ? Control['default'] : Control;
LayerGroup = 'default' in LayerGroup ? LayerGroup['default'] : LayerGroup;
var classCallCheck = function (instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
};
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 inherits = function (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 possibleConstructorReturn = function (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;
};
/**
* @protected
*/
var CSS_PREFIX = 'layer-switcher-';
/**
* OpenLayers LayerSwitcher Control, displays a list of layers and groups
* associated with a map which have a `title` property.
*
* To be shown in the LayerSwitcher panel layers must have a `title` property;
* base map layers should have a `type` property set to `base`. Group layers
* (`LayerGroup`) can be used to visually group layers together; a group
* with a `fold` property set to either `'open'` or `'close'` will be displayed
* with a toggle.
*
* See [BaseLayerOptions](#baselayeroptions) for a full list of LayerSwitcher
* properties for layers (`TileLayer`, `ImageLayer`, `VectorTile` etc.) and
* [GroupLayerOptions](#grouplayeroptions) for group layer (`LayerGroup`)
* LayerSwitcher properties.
*
* Layer and group properties can either be set by adding extra properties
* to their options when they are created or via their set method.
*
* Specify a `title` for a Layer by adding a `title` property to it's options object:
* ```javascript
* var lyr = new ol.layer.Tile({
* // Specify a title property which will be displayed by the layer switcher
* title: 'OpenStreetMap',
* visible: true,
* source: new ol.source.OSM()
* })
* ```
*
* Alternatively the properties can be set via the `set` method after a layer has been created:
* ```javascript
* var lyr = new ol.layer.Tile({
* visible: true,
* source: new ol.source.OSM()
* })
* // Specify a title property which will be displayed by the layer switcher
* lyr.set('title', 'OpenStreetMap');
* ```
*
* To create a LayerSwitcher and add it to a map, create a new instance then pass it to the map's [`addControl` method](https://openlayers.org/en/latest/apidoc/module-ol_PluggableMap-PluggableMap.html#addControl).
* ```javascript
* var layerSwitcher = new LayerSwitcher({
* reverse: true,
* groupSelectStyle: 'group'
* });
* map.addControl(layerSwitcher);
* ```
*
* @constructor
* @extends {ol/control/Control~Control}
* @param opt_options LayerSwitcher options, see [LayerSwitcher Options](#options) and [RenderOptions](#renderoptions) which LayerSwitcher `Options` extends for more details.
*/
var LayerSwitcher = function (_Control) {
inherits(LayerSwitcher, _Control);
function LayerSwitcher(opt_options) {
classCallCheck(this, LayerSwitcher);
var options = Object.assign({}, opt_options);
// TODO Next: Rename to showButtonTitle
var tipLabel = options.tipLabel ? options.tipLabel : 'Legend';
// TODO Next: Rename to hideButtonTitle
var collapseTipLabel = options.collapseTipLabel ? options.collapseTipLabel : 'Collapse legend';
var element = document.createElement('div');
var _this = possibleConstructorReturn(this, (LayerSwitcher.__proto__ || Object.getPrototypeOf(LayerSwitcher)).call(this, { element: element, target: options.target }));
_this.activationMode = options.activationMode || 'mouseover';
_this.startActive = options.startActive === true;
// TODO Next: Rename to showButtonContent
var label = options.label !== undefined ? options.label : '';
// TODO Next: Rename to hideButtonContent
var collapseLabel = options.collapseLabel !== undefined ? options.collapseLabel : '\xBB';
_this.groupSelectStyle = LayerSwitcher.getGroupSelectStyle(options.groupSelectStyle);
_this.reverse = options.reverse !== false;
_this.mapListeners = [];
_this.hiddenClassName = 'ol-unselectable ol-control layer-switcher';
if (LayerSwitcher.isTouchDevice_()) {
_this.hiddenClassName += ' touch';
}
_this.shownClassName = 'shown';
element.className = _this.hiddenClassName;
var button = document.createElement('button');
button.setAttribute('title', tipLabel);
button.setAttribute('aria-label', tipLabel);
element.appendChild(button);
_this.panel = document.createElement('div');
_this.panel.className = 'panel';
element.appendChild(_this.panel);
LayerSwitcher.enableTouchScroll_(_this.panel);
button.textContent = label;
element.classList.add(CSS_PREFIX + 'group-select-style-' + _this.groupSelectStyle);
element.classList.add(CSS_PREFIX + 'activation-mode-' + _this.activationMode);
if (_this.activationMode === 'click') {
// TODO Next: Remove in favour of layer-switcher-activation-mode-click
element.classList.add('activationModeClick');
if (_this.startActive) {
button.textContent = collapseLabel;
button.setAttribute('title', collapseTipLabel);
button.setAttribute('aria-label', collapseTipLabel);
}
button.onclick = function (e) {
var evt = e || window.event;
if (_this.element.classList.contains(_this.shownClassName)) {
_this.hidePanel();
button.textContent = label;
button.setAttribute('title', tipLabel);
button.setAttribute('aria-label', tipLabel);
} else {
_this.showPanel();
button.textContent = collapseLabel;
button.setAttribute('title', collapseTipLabel);
button.setAttribute('aria-label', collapseTipLabel);
}
evt.preventDefault();
};
} else {
button.onmouseover = function () {
_this.showPanel();
};
button.onclick = function (e) {
var evt = e || window.event;
_this.showPanel();
evt.preventDefault();
};
_this.panel.onmouseout = function (evt) {
if (!_this.panel.contains(evt.relatedTarget)) {
_this.hidePanel();
}
};
}
return _this;
}
/**
* Set the map instance the control is associated with.
* @param map The map instance.
*/
createClass(LayerSwitcher, [{
key: 'setMap',
value: function setMap(map) {
var _this2 = this;
// Clean up listeners associated with the previous map
for (var i = 0; i < this.mapListeners.length; i++) {
ol_Observable.unByKey(this.mapListeners[i]);
}
this.mapListeners.length = 0;
// Wire up listeners etc. and store reference to new map
get(LayerSwitcher.prototype.__proto__ || Object.getPrototypeOf(LayerSwitcher.prototype), 'setMap', this).call(this, map);
if (map) {
if (this.startActive) {
this.showPanel();
} else {
this.renderPanel();
}
if (this.activationMode !== 'click') {
this.mapListeners.push(map.on('pointerdown', function () {
_this2.hidePanel();
}));
}
}
}
/**
* Show the layer panel.
*/
}, {
key: 'showPanel',
value: function showPanel() {
if (!this.element.classList.contains(this.shownClassName)) {
this.element.classList.add(this.shownClassName);
this.renderPanel();
}
}
/**
* Hide the layer panel.
*/
}, {
key: 'hidePanel',
value: function hidePanel() {
if (this.element.classList.contains(this.shownClassName)) {
this.element.classList.remove(this.shownClassName);
}
}
/**
* Re-draw the layer panel to represent the current state of the layers.
*/
}, {
key: 'renderPanel',
value: function renderPanel() {
this.dispatchEvent('render');
LayerSwitcher.renderPanel(this.getMap(), this.panel, {
groupSelectStyle: this.groupSelectStyle,
reverse: this.reverse
});
this.dispatchEvent('rendercomplete');
}
/**
* **_[static]_** - Re-draw the layer panel to represent the current state of the layers.
* @param map The OpenLayers Map instance to render layers for
* @param panel The DOM Element into which the layer tree will be rendered
* @param options Options for panel, group, and layers
*/
}], [{
key: 'renderPanel',
value: function renderPanel(map, panel, options) {
// Create the event.
var render_event = new Event('render');
// Dispatch the event.
panel.dispatchEvent(render_event);
options = options || {};
options.groupSelectStyle = LayerSwitcher.getGroupSelectStyle(options.groupSelectStyle);
LayerSwitcher.ensureTopVisibleBaseLayerShown(map, options.groupSelectStyle);
while (panel.firstChild) {
panel.removeChild(panel.firstChild);
}
// Reset indeterminate state for all layers and groups before
// applying based on groupSelectStyle
LayerSwitcher.forEachRecursive(map, function (l, _idx, _a) {
l.set('indeterminate', false);
});
if (options.groupSelectStyle === 'children' || options.groupSelectStyle === 'none') {
// Set visibile and indeterminate state of groups based on
// their children's visibility
LayerSwitcher.setGroupVisibility(map);
} else if (options.groupSelectStyle === 'group') {
// Set child indetermiate state based on their parent's visibility
LayerSwitcher.setChildVisibility(map);
}
var ul = document.createElement('ul');
panel.appendChild(ul);
// passing two map arguments instead of lyr as we're passing the map as the root of the layers tree
LayerSwitcher.renderLayers_(map, map, ul, options, function render(_changedLyr) {
LayerSwitcher.renderPanel(map, panel, options);
});
// Create the event.
var rendercomplete_event = new Event('rendercomplete');
// Dispatch the event.
panel.dispatchEvent(rendercomplete_event);
}
/**
* **_[static]_** - Determine if a given layer group contains base layers
* @param grp Group to test
*/
}, {
key: 'isBaseGroup',
value: function isBaseGroup(grp) {
if (grp instanceof LayerGroup) {
var lyrs = grp.getLayers().getArray();
return lyrs.length && lyrs[0].get('type') === 'base';
} else {
return false;
}
}
}, {
key: 'setGroupVisibility',
value: function setGroupVisibility(map) {
// Get a list of groups, with the deepest first
var groups = LayerSwitcher.getGroupsAndLayers(map, function (l) {
return l instanceof LayerGroup && !l.get('combine') && !LayerSwitcher.isBaseGroup(l);
}).reverse();
// console.log(groups.map(g => g.get('title')));
groups.forEach(function (grp) {
// TODO Can we use getLayersArray, is it public in the esm build?
var descendantVisibility = grp.getLayersArray().map(function (l) {
var state = l.getVisible();
// console.log('>', l.get('title'), state);
return state;
});
// console.log(descendantVisibility);
if (descendantVisibility.every(function (v) {
return v === true;
})) {
grp.setVisible(true);
grp.set('indeterminate', false);
} else if (descendantVisibility.every(function (v) {
return v === false;
})) {
grp.setVisible(false);
grp.set('indeterminate', false);
} else {
grp.setVisible(true);
grp.set('indeterminate', true);
}
});
}
}, {
key: 'setChildVisibility',
value: function setChildVisibility(map) {
// console.log('setChildVisibility');
var groups = LayerSwitcher.getGroupsAndLayers(map, function (l) {
return l instanceof LayerGroup && !l.get('combine') && !LayerSwitcher.isBaseGroup(l);
});
groups.forEach(function (grp) {
var group = grp;
// console.log(group.get('title'));
var groupVisible = group.getVisible();
var groupIndeterminate = group.get('indeterminate');
group.getLayers().getArray().forEach(function (l) {
l.set('indeterminate', false);
if ((!groupVisible || groupIndeterminate) && l.getVisible()) {
l.set('indeterminate', true);
}
});
});
}
/**
* Ensure only the top-most base layer is visible if more than one is visible.
* @param map The map instance.
* @param groupSelectStyle
* @protected
*/
}, {
key: 'ensureTopVisibleBaseLayerShown',
value: function ensureTopVisibleBaseLayerShown(map, groupSelectStyle) {
var lastVisibleBaseLyr = void 0;
LayerSwitcher.forEachRecursive(map, function (lyr, _idx, _arr) {
if (lyr.get('type') === 'base' && lyr.getVisible()) {
lastVisibleBaseLyr = lyr;
}
});
if (lastVisibleBaseLyr) LayerSwitcher.setVisible_(map, lastVisibleBaseLyr, true, groupSelectStyle);
}
/**
* **_[static]_** - Get an Array of all layers and groups displayed by the LayerSwitcher (has a `'title'` property)
* contained by the specified map or layer group; optionally filtering via `filterFn`
* @param grp The map or layer group for which layers are found.
* @param filterFn Optional function used to filter the returned layers
*/
}, {
key: 'getGroupsAndLayers',
value: function getGroupsAndLayers(grp, filterFn) {
var layers = [];
filterFn = filterFn || function (_lyr, _idx, _arr) {
return true;
};
LayerSwitcher.forEachRecursive(grp, function (lyr, idx, arr) {
if (lyr.get('title')) {
if (filterFn(lyr, idx, arr)) {
layers.push(lyr);
}
}
});
return layers;
}
/**
* Toggle the visible state of a layer.
* Takes care of hiding other layers in the same exclusive group if the layer
* is toggle to visible.
* @protected
* @param map The map instance.
* @param lyr layer whose visibility will be toggled.
* @param visible Set whether the layer is shown
* @param groupSelectStyle
* @protected
*/
}, {
key: 'setVisible_',
value: function setVisible_(map, lyr, visible, groupSelectStyle) {
// console.log(lyr.get('title'), visible, groupSelectStyle);
lyr.setVisible(visible);
if (visible && lyr.get('type') === 'base') {
// Hide all other base layers regardless of grouping
LayerSwitcher.forEachRecursive(map, function (l, _idx, _arr) {
if (l != lyr && l.get('type') === 'base') {
l.setVisible(false);
}
});
}
if (lyr instanceof LayerGroup && !lyr.get('combine') && groupSelectStyle === 'children') {
lyr.getLayers().forEach(function (l) {
LayerSwitcher.setVisible_(map, l, lyr.getVisible(), groupSelectStyle);
});
}
}
/**
* Render all layers that are children of a group.
* @param map The map instance.
* @param lyr Layer to be rendered (should have a title property).
* @param idx Position in parent group list.
* @param options Options for groups and layers
* @protected
*/
}, {
key: 'renderLayer_',
value: function renderLayer_(map, lyr, idx, options, render) {
var li = document.createElement('li');
var lyrTitle = lyr.get('title');
var checkboxId = LayerSwitcher.uuid();
var label = document.createElement('label');
if (lyr instanceof LayerGroup && !lyr.get('combine')) {
var isBaseGroup = LayerSwitcher.isBaseGroup(lyr);
li.classList.add('group');
if (isBaseGroup) {
li.classList.add(CSS_PREFIX + 'base-group');
}
// Group folding
if (lyr.get('fold')) {
li.classList.add(CSS_PREFIX + 'fold');
li.classList.add(CSS_PREFIX + lyr.get('fold'));
var btn = document.createElement('button');
btn.onclick = function (e) {
var evt = e || window.event;
LayerSwitcher.toggleFold_(lyr, li);
evt.preventDefault();
};
li.appendChild(btn);
}
if (!isBaseGroup && options.groupSelectStyle != 'none') {
var input = document.createElement('input');
input.type = 'checkbox';
input.id = checkboxId;
input.checked = lyr.getVisible();
input.indeterminate = lyr.get('indeterminate');
input.onchange = function (e) {
var target = e.target;
LayerSwitcher.setVisible_(map, lyr, target.checked, options.groupSelectStyle);
render(lyr);
};
li.appendChild(input);
label.htmlFor = checkboxId;
}
label.innerHTML = lyrTitle;
li.appendChild(label);
var ul = document.createElement('ul');
li.appendChild(ul);
LayerSwitcher.renderLayers_(map, lyr, ul, options, render);
} else {
li.className = 'layer';
var _input = document.createElement('input');
if (lyr.get('type') === 'base') {
_input.type = 'radio';
_input.name = 'base';
} else {
_input.type = 'checkbox';
}
_input.id = checkboxId;
_input.checked = lyr.get('visible');
_input.indeterminate = lyr.get('indeterminate');
_input.onchange = function (e) {
var target = e.target;
LayerSwitcher.setVisible_(map, lyr, target.checked, options.groupSelectStyle);
render(lyr);
};
li.appendChild(_input);
label.htmlFor = checkboxId;
label.innerHTML = lyrTitle;
var rsl = map.getView().getResolution();
if (rsl > lyr.getMaxResolution() || rsl < lyr.getMinResolution()) {
label.className += ' disabled';
}
li.appendChild(label);
}
return li;
}
/**
* Render all layers that are children of a group.
* @param map The map instance.
* @param lyr Group layer whose children will be rendered.
* @param elm DOM element that children will be appended to.
* @param options Options for groups and layers
* @protected
*/
}, {
key: 'renderLayers_',
value: function renderLayers_(map, lyr, elm, options, render) {
var lyrs = lyr.getLayers().getArray().slice();
if (options.reverse) lyrs = lyrs.reverse();
for (var i = 0, l; i < lyrs.length; i++) {
l = lyrs[i];
if (l.get('title')) {
elm.appendChild(LayerSwitcher.renderLayer_(map, l, i, options, render));
}
}
}
/**
* **_[static]_** - Call the supplied function for each layer in the passed layer group
* recursing nested groups.
* @param lyr The layer group to start iterating from.
* @param fn Callback which will be called for each layer
* found under `lyr`.
*/
}, {
key: 'forEachRecursive',
value: function forEachRecursive(lyr, fn) {
lyr.getLayers().forEach(function (lyr, idx, a) {
fn(lyr, idx, a);
if (lyr instanceof LayerGroup) {
LayerSwitcher.forEachRecursive(lyr, fn);
}
});
}
/**
* **_[static]_** - Generate a UUID
* Adapted from http://stackoverflow.com/a/2117523/526860
* @returns {String} UUID
*/
}, {
key: 'uuid',
value: function uuid() {
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
var r = Math.random() * 16 | 0,
v = c == 'x' ? r : r & 0x3 | 0x8;
return v.toString(16);
});
}
/**
* Apply workaround to enable scrolling of overflowing content within an
* element. Adapted from https://gist.github.com/chrismbarr/4107472
* @param elm Element on which to enable touch scrolling
* @protected
*/
}, {
key: 'enableTouchScroll_',
value: function enableTouchScroll_(elm) {
if (LayerSwitcher.isTouchDevice_()) {
var scrollStartPos = 0;
elm.addEventListener('touchstart', function (event) {
scrollStartPos = this.scrollTop + event.touches[0].pageY;
}, false);
elm.addEventListener('touchmove', function (event) {
this.scrollTop = scrollStartPos - event.touches[0].pageY;
}, false);
}
}
/**
* Determine if the current browser supports touch events. Adapted from
* https://gist.github.com/chrismbarr/4107472
* @returns {Boolean} True if client can have 'TouchEvent' event
* @protected
*/
}, {
key: 'isTouchDevice_',
value: function isTouchDevice_() {
try {
document.createEvent('TouchEvent');
return true;
} catch (e) {
return false;
}
}
/**
* Fold/unfold layer group
* @param lyr Layer group to fold/unfold
* @param li List item containing layer group
* @protected
*/
}, {
key: 'toggleFold_',
value: function toggleFold_(lyr, li) {
li.classList.remove(CSS_PREFIX + lyr.get('fold'));
lyr.set('fold', lyr.get('fold') === 'open' ? 'close' : 'open');
li.classList.add(CSS_PREFIX + lyr.get('fold'));
}
/**
* If a valid groupSelectStyle value is not provided then return the default
* @param groupSelectStyle The string to check for validity
* @returns The value groupSelectStyle, if valid, the default otherwise
* @protected
*/
}, {
key: 'getGroupSelectStyle',
value: function getGroupSelectStyle(groupSelectStyle) {
return ['none', 'children', 'group'].indexOf(groupSelectStyle) >= 0 ? groupSelectStyle : 'children';
}
}]);
return LayerSwitcher;
}(Control);
if (window['ol'] && window['ol']['control']) {
window['ol']['control']['LayerSwitcher'] = LayerSwitcher;
}
return LayerSwitcher;
})));

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long