diff --git a/.eslintignore b/.eslintignore
index 776103ec61..e35cabbe24 100755
--- a/.eslintignore
+++ b/.eslintignore
@@ -1,4 +1,5 @@
build/
+bundler/
coverage/
lib/
dist/
@@ -7,4 +8,9 @@ node_modules/
demos/assets/
demos/index.html
demos/*
+<<<<<<< HEAD
+rollup/*
+webpack/*
+=======
src/core/three.js
+>>>>>>> master
diff --git a/.eslintrc b/.eslintrc
index 446574a9c4..39752e76b3 100755
--- a/.eslintrc
+++ b/.eslintrc
@@ -11,7 +11,11 @@
"G2": true,
"_": true,
"mapboxgl":true,
- "dat" : true
+ "dat" : true,
+ },
+ "env": {
+ "browser": true,
+ "node": true
},
"parser": "babel-eslint",
"parserOptions": {
diff --git a/src/attr/base.js b/src/attr/base.js
index 51a1812b5d..8da8dcca0c 100644
--- a/src/attr/base.js
+++ b/src/attr/base.js
@@ -2,8 +2,8 @@
* @fileOverview the Attribute base class
* @author huangtonger@aliyun.com
*/
-const ColorUtil = require('./color-util');
-const Util = require('../util');
+import ColorUtil from './color-util';
+import Util from '../util';
function toScaleString(scale, value) {
if (Util.isString(value)) {
@@ -171,7 +171,7 @@ class AttributeBase {
}
if (this.type === 'color' && !Util.isArray(values)) {
values = ColorUtil.toRGB(values).map(e => e / 255);
- // values[3] = values[3] * 255;
+ // values[3] = values[3] * 255;
}
if (!Util.isArray(values)) {
values = [ values ];
@@ -196,4 +196,4 @@ class AttributeBase {
}
}
-module.exports = AttributeBase;
+export default AttributeBase;
diff --git a/src/attr/color-util.js b/src/attr/color-util.js
index 32f0f6acee..e5f5aa75d1 100644
--- a/src/attr/color-util.js
+++ b/src/attr/color-util.js
@@ -2,8 +2,7 @@
* @fileOverview 颜色计算的辅助方法
* @author dxq613@gmail.com
*/
-
-const Util = require('../util');
+import Util from '../util';
const RGB_REG = /rgba?\(([\s.,0-9]+)\)/;
// const RGBA_REG = /rgba\((\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(\d+)\s*\)/;
@@ -80,7 +79,7 @@ const ColorUtil = {
}
return rst;
},
- // 转成 WebGl color buffer
+ // 转成 WebGl color buffer
color2Arr(str) {
const rgba = this.toRGB(str);
return rgba.map(v => v / 255);
@@ -112,4 +111,4 @@ const ColorUtil = {
}
};
-module.exports = ColorUtil;
+export default ColorUtil;
diff --git a/src/attr/color.js b/src/attr/color.js
index cadfdef123..625cf996a5 100644
--- a/src/attr/color.js
+++ b/src/attr/color.js
@@ -2,10 +2,9 @@
* @fileOverview the color attribute of core
* @author huangtonger@aliyun.com
*/
-
-const ColorUtil = require('./color-util');
-const Base = require('./base');
-const Util = require('../util');
+import ColorUtil from './color-util';
+import Base from './base';
+import Util from '../util';
/**
* 视觉通道 color
@@ -38,4 +37,4 @@ class Color extends Base {
}
}
-module.exports = Color;
+export default Color;
diff --git a/src/attr/colorscales.js b/src/attr/colorscales.js
index 15a5185676..bbda09d0e0 100644
--- a/src/attr/colorscales.js
+++ b/src/attr/colorscales.js
@@ -97,4 +97,4 @@ export const colorScales = {
magma: new Uint8Array([ 0, 0, 4, 255, 1, 0, 5, 255, 1, 1, 6, 255, 1, 1, 8, 255, 2, 1, 9, 255, 2, 2, 11, 255, 2, 2, 13, 255, 3, 3, 15, 255, 3, 3, 18, 255, 4, 4, 20, 255, 5, 4, 22, 255, 6, 5, 24, 255, 6, 5, 26, 255, 7, 6, 28, 255, 8, 7, 30, 255, 9, 7, 32, 255, 10, 8, 34, 255, 11, 9, 36, 255, 12, 9, 38, 255, 13, 10, 41, 255, 14, 11, 43, 255, 16, 11, 45, 255, 17, 12, 47, 255, 18, 13, 49, 255, 19, 13, 52, 255, 20, 14, 54, 255, 21, 14, 56, 255, 22, 15, 59, 255, 24, 15, 61, 255, 25, 16, 63, 255, 26, 16, 66, 255, 28, 16, 68, 255, 29, 17, 71, 255, 30, 17, 73, 255, 32, 17, 75, 255, 33, 17, 78, 255, 34, 17, 80, 255, 36, 18, 83, 255, 37, 18, 85, 255, 39, 18, 88, 255, 41, 17, 90, 255, 42, 17, 92, 255, 44, 17, 95, 255, 45, 17, 97, 255, 47, 17, 99, 255, 49, 17, 101, 255, 51, 16, 103, 255, 52, 16, 105, 255, 54, 16, 107, 255, 56, 16, 108, 255, 57, 15, 110, 255, 59, 15, 112, 255, 61, 15, 113, 255, 63, 15, 114, 255, 64, 15, 116, 255, 66, 15, 117, 255, 68, 15, 118, 255, 69, 16, 119, 255, 71, 16, 120, 255, 73, 16, 120, 255, 74, 16, 121, 255, 76, 17, 122, 255, 78, 17, 123, 255, 79, 18, 123, 255, 81, 18, 124, 255, 82, 19, 124, 255, 84, 19, 125, 255, 86, 20, 125, 255, 87, 21, 126, 255, 89, 21, 126, 255, 90, 22, 126, 255, 92, 22, 127, 255, 93, 23, 127, 255, 95, 24, 127, 255, 96, 24, 128, 255, 98, 25, 128, 255, 100, 26, 128, 255, 101, 26, 128, 255, 103, 27, 128, 255, 104, 28, 129, 255, 106, 28, 129, 255, 107, 29, 129, 255, 109, 29, 129, 255, 110, 30, 129, 255, 112, 31, 129, 255, 114, 31, 129, 255, 115, 32, 129, 255, 117, 33, 129, 255, 118, 33, 129, 255, 120, 34, 129, 255, 121, 34, 130, 255, 123, 35, 130, 255, 124, 35, 130, 255, 126, 36, 130, 255, 128, 37, 130, 255, 129, 37, 129, 255, 131, 38, 129, 255, 132, 38, 129, 255, 134, 39, 129, 255, 136, 39, 129, 255, 137, 40, 129, 255, 139, 41, 129, 255, 140, 41, 129, 255, 142, 42, 129, 255, 144, 42, 129, 255, 145, 43, 129, 255, 147, 43, 128, 255, 148, 44, 128, 255, 150, 44, 128, 255, 152, 45, 128, 255, 153, 45, 128, 255, 155, 46, 127, 255, 156, 46, 127, 255, 158, 47, 127, 255, 160, 47, 127, 255, 161, 48, 126, 255, 163, 48, 126, 255, 165, 49, 126, 255, 166, 49, 125, 255, 168, 50, 125, 255, 170, 51, 125, 255, 171, 51, 124, 255, 173, 52, 124, 255, 174, 52, 123, 255, 176, 53, 123, 255, 178, 53, 123, 255, 179, 54, 122, 255, 181, 54, 122, 255, 183, 55, 121, 255, 184, 55, 121, 255, 186, 56, 120, 255, 188, 57, 120, 255, 189, 57, 119, 255, 191, 58, 119, 255, 192, 58, 118, 255, 194, 59, 117, 255, 196, 60, 117, 255, 197, 60, 116, 255, 199, 61, 115, 255, 200, 62, 115, 255, 202, 62, 114, 255, 204, 63, 113, 255, 205, 64, 113, 255, 207, 64, 112, 255, 208, 65, 111, 255, 210, 66, 111, 255, 211, 67, 110, 255, 213, 68, 109, 255, 214, 69, 108, 255, 216, 69, 108, 255, 217, 70, 107, 255, 219, 71, 106, 255, 220, 72, 105, 255, 222, 73, 104, 255, 223, 74, 104, 255, 224, 76, 103, 255, 226, 77, 102, 255, 227, 78, 101, 255, 228, 79, 100, 255, 229, 80, 100, 255, 231, 82, 99, 255, 232, 83, 98, 255, 233, 84, 98, 255, 234, 86, 97, 255, 235, 87, 96, 255, 236, 88, 96, 255, 237, 90, 95, 255, 238, 91, 94, 255, 239, 93, 94, 255, 240, 95, 94, 255, 241, 96, 93, 255, 242, 98, 93, 255, 242, 100, 92, 255, 243, 101, 92, 255, 244, 103, 92, 255, 244, 105, 92, 255, 245, 107, 92, 255, 246, 108, 92, 255, 246, 110, 92, 255, 247, 112, 92, 255, 247, 114, 92, 255, 248, 116, 92, 255, 248, 118, 92, 255, 249, 120, 93, 255, 249, 121, 93, 255, 249, 123, 93, 255, 250, 125, 94, 255, 250, 127, 94, 255, 250, 129, 95, 255, 251, 131, 95, 255, 251, 133, 96, 255, 251, 135, 97, 255, 252, 137, 97, 255, 252, 138, 98, 255, 252, 140, 99, 255, 252, 142, 100, 255, 252, 144, 101, 255, 253, 146, 102, 255, 253, 148, 103, 255, 253, 150, 104, 255, 253, 152, 105, 255, 253, 154, 106, 255, 253, 155, 107, 255, 254, 157, 108, 255, 254, 159, 109, 255, 254, 161, 110, 255, 254, 163, 111, 255, 254, 165, 113, 255, 254, 167, 114, 255, 254, 169, 115, 255, 254, 170, 116, 255, 254, 172, 118, 255, 254, 174, 119, 255, 254, 176, 120, 255, 254, 178, 122, 255, 254, 180, 123, 255, 254, 182, 124, 255, 254, 183, 126, 255, 254, 185, 127, 255, 254, 187, 129, 255, 254, 189, 130, 255, 254, 191, 132, 255, 254, 193, 133, 255, 254, 194, 135, 255, 254, 196, 136, 255, 254, 198, 138, 255, 254, 200, 140, 255, 254, 202, 141, 255, 254, 204, 143, 255, 254, 205, 144, 255, 254, 207, 146, 255, 254, 209, 148, 255, 254, 211, 149, 255, 254, 213, 151, 255, 254, 215, 153, 255, 254, 216, 154, 255, 253, 218, 156, 255, 253, 220, 158, 255, 253, 222, 160, 255, 253, 224, 161, 255, 253, 226, 163, 255, 253, 227, 165, 255, 253, 229, 167, 255, 253, 231, 169, 255, 253, 233, 170, 255, 253, 235, 172, 255, 252, 236, 174, 255, 252, 238, 176, 255, 252, 240, 178, 255, 252, 242, 180, 255, 252, 244, 182, 255, 252, 246, 184, 255, 252, 247, 185, 255, 252, 249, 187, 255, 252, 251, 189, 255, 252, 253, 191, 255 ]),
plasma: new Uint8Array([ 13, 8, 135, 255, 16, 7, 136, 255, 19, 7, 137, 255, 22, 7, 138, 255, 25, 6, 140, 255, 27, 6, 141, 255, 29, 6, 142, 255, 32, 6, 143, 255, 34, 6, 144, 255, 36, 6, 145, 255, 38, 5, 145, 255, 40, 5, 146, 255, 42, 5, 147, 255, 44, 5, 148, 255, 46, 5, 149, 255, 47, 5, 150, 255, 49, 5, 151, 255, 51, 5, 151, 255, 53, 4, 152, 255, 55, 4, 153, 255, 56, 4, 154, 255, 58, 4, 154, 255, 60, 4, 155, 255, 62, 4, 156, 255, 63, 4, 156, 255, 65, 4, 157, 255, 67, 3, 158, 255, 68, 3, 158, 255, 70, 3, 159, 255, 72, 3, 159, 255, 73, 3, 160, 255, 75, 3, 161, 255, 76, 2, 161, 255, 78, 2, 162, 255, 80, 2, 162, 255, 81, 2, 163, 255, 83, 2, 163, 255, 85, 2, 164, 255, 86, 1, 164, 255, 88, 1, 164, 255, 89, 1, 165, 255, 91, 1, 165, 255, 92, 1, 166, 255, 94, 1, 166, 255, 96, 1, 166, 255, 97, 0, 167, 255, 99, 0, 167, 255, 100, 0, 167, 255, 102, 0, 167, 255, 103, 0, 168, 255, 105, 0, 168, 255, 106, 0, 168, 255, 108, 0, 168, 255, 110, 0, 168, 255, 111, 0, 168, 255, 113, 0, 168, 255, 114, 1, 168, 255, 116, 1, 168, 255, 117, 1, 168, 255, 119, 1, 168, 255, 120, 1, 168, 255, 122, 2, 168, 255, 123, 2, 168, 255, 125, 3, 168, 255, 126, 3, 168, 255, 128, 4, 168, 255, 129, 4, 167, 255, 131, 5, 167, 255, 132, 5, 167, 255, 134, 6, 166, 255, 135, 7, 166, 255, 136, 8, 166, 255, 138, 9, 165, 255, 139, 10, 165, 255, 141, 11, 165, 255, 142, 12, 164, 255, 143, 13, 164, 255, 145, 14, 163, 255, 146, 15, 163, 255, 148, 16, 162, 255, 149, 17, 161, 255, 150, 19, 161, 255, 152, 20, 160, 255, 153, 21, 159, 255, 154, 22, 159, 255, 156, 23, 158, 255, 157, 24, 157, 255, 158, 25, 157, 255, 160, 26, 156, 255, 161, 27, 155, 255, 162, 29, 154, 255, 163, 30, 154, 255, 165, 31, 153, 255, 166, 32, 152, 255, 167, 33, 151, 255, 168, 34, 150, 255, 170, 35, 149, 255, 171, 36, 148, 255, 172, 38, 148, 255, 173, 39, 147, 255, 174, 40, 146, 255, 176, 41, 145, 255, 177, 42, 144, 255, 178, 43, 143, 255, 179, 44, 142, 255, 180, 46, 141, 255, 181, 47, 140, 255, 182, 48, 139, 255, 183, 49, 138, 255, 184, 50, 137, 255, 186, 51, 136, 255, 187, 52, 136, 255, 188, 53, 135, 255, 189, 55, 134, 255, 190, 56, 133, 255, 191, 57, 132, 255, 192, 58, 131, 255, 193, 59, 130, 255, 194, 60, 129, 255, 195, 61, 128, 255, 196, 62, 127, 255, 197, 64, 126, 255, 198, 65, 125, 255, 199, 66, 124, 255, 200, 67, 123, 255, 201, 68, 122, 255, 202, 69, 122, 255, 203, 70, 121, 255, 204, 71, 120, 255, 204, 73, 119, 255, 205, 74, 118, 255, 206, 75, 117, 255, 207, 76, 116, 255, 208, 77, 115, 255, 209, 78, 114, 255, 210, 79, 113, 255, 211, 81, 113, 255, 212, 82, 112, 255, 213, 83, 111, 255, 213, 84, 110, 255, 214, 85, 109, 255, 215, 86, 108, 255, 216, 87, 107, 255, 217, 88, 106, 255, 218, 90, 106, 255, 218, 91, 105, 255, 219, 92, 104, 255, 220, 93, 103, 255, 221, 94, 102, 255, 222, 95, 101, 255, 222, 97, 100, 255, 223, 98, 99, 255, 224, 99, 99, 255, 225, 100, 98, 255, 226, 101, 97, 255, 226, 102, 96, 255, 227, 104, 95, 255, 228, 105, 94, 255, 229, 106, 93, 255, 229, 107, 93, 255, 230, 108, 92, 255, 231, 110, 91, 255, 231, 111, 90, 255, 232, 112, 89, 255, 233, 113, 88, 255, 233, 114, 87, 255, 234, 116, 87, 255, 235, 117, 86, 255, 235, 118, 85, 255, 236, 119, 84, 255, 237, 121, 83, 255, 237, 122, 82, 255, 238, 123, 81, 255, 239, 124, 81, 255, 239, 126, 80, 255, 240, 127, 79, 255, 240, 128, 78, 255, 241, 129, 77, 255, 241, 131, 76, 255, 242, 132, 75, 255, 243, 133, 75, 255, 243, 135, 74, 255, 244, 136, 73, 255, 244, 137, 72, 255, 245, 139, 71, 255, 245, 140, 70, 255, 246, 141, 69, 255, 246, 143, 68, 255, 247, 144, 68, 255, 247, 145, 67, 255, 247, 147, 66, 255, 248, 148, 65, 255, 248, 149, 64, 255, 249, 151, 63, 255, 249, 152, 62, 255, 249, 154, 62, 255, 250, 155, 61, 255, 250, 156, 60, 255, 250, 158, 59, 255, 251, 159, 58, 255, 251, 161, 57, 255, 251, 162, 56, 255, 252, 163, 56, 255, 252, 165, 55, 255, 252, 166, 54, 255, 252, 168, 53, 255, 252, 169, 52, 255, 253, 171, 51, 255, 253, 172, 51, 255, 253, 174, 50, 255, 253, 175, 49, 255, 253, 177, 48, 255, 253, 178, 47, 255, 253, 180, 47, 255, 253, 181, 46, 255, 254, 183, 45, 255, 254, 184, 44, 255, 254, 186, 44, 255, 254, 187, 43, 255, 254, 189, 42, 255, 254, 190, 42, 255, 254, 192, 41, 255, 253, 194, 41, 255, 253, 195, 40, 255, 253, 197, 39, 255, 253, 198, 39, 255, 253, 200, 39, 255, 253, 202, 38, 255, 253, 203, 38, 255, 252, 205, 37, 255, 252, 206, 37, 255, 252, 208, 37, 255, 252, 210, 37, 255, 251, 211, 36, 255, 251, 213, 36, 255, 251, 215, 36, 255, 250, 216, 36, 255, 250, 218, 36, 255, 249, 220, 36, 255, 249, 221, 37, 255, 248, 223, 37, 255, 248, 225, 37, 255, 247, 226, 37, 255, 247, 228, 37, 255, 246, 230, 38, 255, 246, 232, 38, 255, 245, 233, 38, 255, 245, 235, 39, 255, 244, 237, 39, 255, 243, 238, 39, 255, 243, 240, 39, 255, 242, 242, 39, 255, 241, 244, 38, 255, 241, 245, 37, 255, 240, 247, 36, 255, 240, 249, 33, 255 ])
};
-// module.exports = colorScales;
+// export default colorScales;
diff --git a/src/attr/filter.js b/src/attr/filter.js
index 8c802cfcc2..6a0b29f650 100644
--- a/src/attr/filter.js
+++ b/src/attr/filter.js
@@ -5,7 +5,7 @@
* @Last Modified time: 2018-07-15 17:26:40
*/
-const Base = require('./base');
+import Base from './base';
/**
* 视觉通道 symbol
@@ -19,4 +19,4 @@ class Filter extends Base {
this.gradient = null;
}
}
-module.exports = Filter;
+export default Filter;
diff --git a/src/attr/index.js b/src/attr/index.js
index 81a4682448..eb4d45ba47 100644
--- a/src/attr/index.js
+++ b/src/attr/index.js
@@ -1,10 +1,19 @@
-const Base = require('./base');
-Base.Color = require('./color');
-Base.Size = require('./size');
-Base.Opacity = require('./opacity');
-Base.Shape = require('./shape');
-Base.Position = require('./position');
-Base.Symbol = require('./symbol');
-Base.Filter = require('./filter');
-module.exports = Base;
+import Base from './base';
+import Color from './color';
+import Size from './size';
+import Opacity from './opacity';
+import Shape from './shape';
+import Position from './position';
+import Symbol from './symbol';
+import Filter from './filter';
+
+Base.Color = Color;
+Base.Size = Size;
+Base.Opacity = Opacity;
+Base.Shape = Shape;
+Base.Position = Position;
+Base.Symbol = Symbol;
+Base.Filter = Filter;
+
+export default Base;
diff --git a/src/attr/opacity.js b/src/attr/opacity.js
index 7d2c07155f..058b8e1450 100644
--- a/src/attr/opacity.js
+++ b/src/attr/opacity.js
@@ -3,7 +3,7 @@
* @author huangtonger@aliyun.com
*/
-const Base = require('./base');
+import Base from './base';
/**
* 视觉通道 Opacity
@@ -18,4 +18,4 @@ class Opacity extends Base {
}
}
-module.exports = Opacity;
+export default Opacity;
diff --git a/src/attr/position.js b/src/attr/position.js
index e191c33342..70c1a85de7 100644
--- a/src/attr/position.js
+++ b/src/attr/position.js
@@ -4,8 +4,8 @@
*/
-const Util = require('../util');
-const Base = require('./base');
+import Base from './base';
+import Util from '../util';
class Position extends Base {
constructor(cfg) {
@@ -88,4 +88,4 @@ class Position extends Base {
}
}
-module.exports = Position;
+export default Position;
diff --git a/src/attr/shape.js b/src/attr/shape.js
index c2daff1754..1474486394 100644
--- a/src/attr/shape.js
+++ b/src/attr/shape.js
@@ -4,7 +4,7 @@
*/
-const Base = require('./base');
+import Base from './base';
/**
* 视觉通道 Shape
@@ -26,7 +26,7 @@ class Shape extends Base {
const index = Math.round((values.length - 1) * percent);
return values[index];
}
- /**
+ /**
* @override
*/
_getAttrValue(scale, value) {
@@ -41,4 +41,4 @@ class Shape extends Base {
}
}
-module.exports = Shape;
+export default Shape;
diff --git a/src/attr/size.js b/src/attr/size.js
index 539f1d1766..ec2d9430d4 100644
--- a/src/attr/size.js
+++ b/src/attr/size.js
@@ -3,8 +3,8 @@
* @author huangtonger@aliyun.com
*/
-const Base = require('./base');
-const Util = require('../util');
+import Base from './base';
+import Util from '../util';
/**
* 视觉通道 size
@@ -20,7 +20,7 @@ class Size extends Base {
}
mapping() {
- // 重构
+ // 重构
const self = this;
const outputs = [];
const scales = self.scales;
@@ -62,4 +62,4 @@ class Size extends Base {
}
-module.exports = Size;
+export default Size;
diff --git a/src/attr/symbol.js b/src/attr/symbol.js
index 0ec2e19748..6461a381ee 100644
--- a/src/attr/symbol.js
+++ b/src/attr/symbol.js
@@ -5,7 +5,7 @@
* @Last Modified time: 2018-07-02 18:24:58
*/
-const Base = require('./base');
+import Base from './base';
/**
* 视觉通道 symbol
@@ -19,4 +19,4 @@ class Symbol extends Base {
this.gradient = null;
}
}
-module.exports = Symbol;
+export default Symbol;
diff --git a/src/component/index.js b/src/component/index.js
deleted file mode 100644
index b64cfa4ea5..0000000000
--- a/src/component/index.js
+++ /dev/null
@@ -1,12 +0,0 @@
-/**
- * @fileOverview chart component module
- * @author sima.zhang1990@gmail.com
- */
-module.exports = {
- Axis: require('./axis/index'),
- Guide: require('./guide/index'),
- Label: require('./label/index'),
- Legend: require('./legend/index'),
- Plot: require('./plot'),
- Tooltip: require('./tooltip/index')
-};
diff --git a/src/component/tooltip/index.js b/src/component/tooltip/index.js
deleted file mode 100644
index dd7ac6800e..0000000000
--- a/src/component/tooltip/index.js
+++ /dev/null
@@ -1,568 +0,0 @@
-/**
- * @fileOverview The class of tooltip
- * @author sima.zhang
- */
-const Util = require('../../util');
-const Base = require('../../base');
-const Global = require('../../global');
-const { DomUtil } = require('@antv/g');
-
-const CONTAINER_CLASS = 'g2-tooltip';
-const TITLE_CLASS = 'g2-tooltip-title';
-const LIST_CLASS = 'g2-tooltip-list';
-const MARKER_CLASS = 'g2-tooltip-marker';
-const LIST_ITEM_CLASS = 'g2-tooltip-list-item';
-
-function find(dom, cls) {
- return dom.getElementsByClassName(cls)[0];
-}
-
-function refixTooltipPosition(x, y, el, viewWidth, viewHeight) {
- const width = el.clientWidth;
- const height = el.clientHeight;
- const gap = 20;
-
- if (x + width + gap > viewWidth) {
- x -= width + gap;
- x = x < 0 ? 0 : x;
- } else {
- x += gap;
- }
- if (y + height + gap > viewHeight) {
- y -= height + gap;
- y = x < 0 ? 0 : y;
- } else {
- y += gap;
- }
- return [ x, y ];
-}
-
-function calcTooltipPosition(x, y, position, dom, target) {
- const domWidth = dom.clientWidth;
- const domHeight = dom.clientHeight;
- let rectWidth = 0;
- let rectHeight = 0;
- let gap = 20;
-
- if (target) {
- const rect = target.getBBox();
- rectWidth = rect.width;
- rectHeight = rect.height;
- x = rect.x;
- y = rect.y;
- gap = 5;
- }
- switch (position) {
- case 'inside':
- x = x + rectWidth / 2 - domWidth / 2;
- y = y + rectHeight / 2 - domHeight / 2;
- break;
- case 'top':
- x = x + rectWidth / 2 - domWidth / 2;
- y = y - domHeight - gap;
- break;
- case 'left':
- x = x - domWidth - gap;
- y = y + rectHeight / 2 - domHeight / 2;
- break;
- case 'right':
- x = x + rectWidth + gap;
- y = y + rectHeight / 2 - domHeight / 2;
- break;
- case 'bottom':
- default:
- x = x + rectWidth / 2 - domWidth / 2;
- y = y + rectHeight + gap;
- break;
- }
- return [ x, y ];
-}
-
-function confineTooltipPosition(x, y, el, plotRange) {
- const gap = 20;
- const width = el.clientWidth;
- const height = el.clientHeight;
- if (x + width > plotRange.tr.x) {
- x -= width + 2 * gap;
- }
-
- if (x < plotRange.tl.x) {
- x = plotRange.tl.x;
- }
-
- if (y + height > plotRange.bl.y) {
- y -= height + 2 * gap;
- }
-
- if (y < plotRange.tl.y) {
- y = plotRange.tl.y;
- }
-
- return [ x, y ];
-}
-
-class Tooltip extends Base {
- getDefaultCfg() {
- return {
- /**
- * 右下角坐标
- * @type {Number}
- */
- x: 0,
- /**
- * y 右下角坐标
- * @type {Number}
- */
- y: 0,
- /**
- * tooltip 记录项
- * @type {Array}
- */
- items: null,
- /**
- * 是否展示 title
- * @type {Boolean}
- */
- showTitle: true,
- /**
- * tooltip 辅助线配置
- * @type {Object}
- */
- crosshairs: null,
- /**
- * 视图范围
- * @type {Object}
- */
- plotRange: null,
- /**
- * x轴上,移动到位置的偏移量
- * @type {Number}
- */
- offset: 10,
- /**
- * 时间戳
- * @type {Number}
- */
- timeStamp: 0,
- /**
- * tooltip 容器模板
- * @type {String}
- */
- containerTpl: '
',
- /**
- * tooltip 列表项模板
- * @type {String}
- */
- itemTpl: ''
- + ''
- + '{name}: {value}',
- /**
- * 将 tooltip 展示在指定区域内
- * @type {Boolean}
- */
- inPlot: true,
- /**
- * tooltip 内容跟随鼠标移动
- * @type {Boolean}
- */
- follow: true,
- /**
- * 是否允许鼠标停留在 tooltip 上,默认不允许
- * @type {Boolean}
- */
- enterable: false
- };
- }
-
- _initTooltipWrapper() {
- const self = this;
- const containerTpl = self.get('containerTpl');
- const outterNode = self.get('canvas').get('el').parentNode;
- let container;
- if (/^\#/.test(containerTpl)) { // 如果传入 dom 节点的 id
- const id = containerTpl.replace('#', '');
- container = document.getElementById(id);
- } else {
- container = DomUtil.createDom(containerTpl);
- DomUtil.modifyCSS(container, self.get(CONTAINER_CLASS));
- outterNode.appendChild(container);
- outterNode.style.position = 'relative';
- }
- self.set('container', container);
- }
-
- _init() {
- const crosshairs = this.get('crosshairs');
- const frontPlot = this.get('frontPlot');
- const backPlot = this.get('backPlot');
- let crosshairsGroup;
-
- if (crosshairs) {
- if (crosshairs.type === 'rect') {
- this.set('crosshairs', Util.deepMix({}, Global.tooltipCrosshairsRect, crosshairs));
- crosshairsGroup = backPlot.addGroup({
- zIndex: 0
- });
- } else {
- this.set('crosshairs', Util.deepMix({}, Global.tooltipCrosshairsLine, crosshairs));
- crosshairsGroup = frontPlot.addGroup();
- }
- }
-
- this.set('crosshairsGroup', crosshairsGroup);
- this._initTooltipWrapper();
- }
-
- constructor(cfg) {
- super(cfg);
- this._init(); // 初始化属性
-
- if (this.get('items')) {
- this._renderTooltip();
- }
- this._renderCrosshairs();
- }
-
-
- _clearDom() {
- const container = this.get('container');
- const titleDom = find(container, TITLE_CLASS);
- const listDom = find(container, LIST_CLASS);
- if (titleDom) {
- titleDom.innerHTML = '';
- }
- if (listDom) {
- listDom.innerHTML = '';
- }
- }
-
- _addItem(item, index) {
- const itemTpl = this.get('itemTpl'); // TODO: 有可能是个回调函数
-
- const itemDiv = Util.substitute(itemTpl, Util.mix({
- index
- }, item));
-
- const itemDOM = DomUtil.createDom(itemDiv);
- DomUtil.modifyCSS(itemDOM, this.get(LIST_ITEM_CLASS));
- const markerDom = find(itemDOM, MARKER_CLASS);
- if (markerDom) {
- DomUtil.modifyCSS(markerDom, this.get(MARKER_CLASS));
- }
-
- return itemDOM;
- }
-
- _renderTooltip() {
- const self = this;
- const showTitle = self.get('showTitle');
- const titleContent = self.get('titleContent');
- const container = self.get('container');
- const titleDom = find(container, TITLE_CLASS);
- const listDom = find(container, LIST_CLASS);
- const items = self.get('items');
- self._clearDom();
-
- if (titleDom && showTitle) {
- DomUtil.modifyCSS(titleDom, self.get(TITLE_CLASS));
- titleDom.innerHTML = titleContent;
- }
-
- if (listDom) {
- DomUtil.modifyCSS(listDom, self.get(LIST_CLASS));
- Util.each(items, (item, index) => {
- listDom.appendChild(self._addItem(item, index));
- });
- }
- }
-
- _clearCrosshairsGroup() {
- const crosshairsGroup = this.get('crosshairsGroup');
- this.set('crossLineShapeX', null);
- this.set('crossLineShapeY', null);
- this.set('crosshairsRectShape', null);
- crosshairsGroup.clear();
- }
-
- _renderCrosshairs() {
- const crosshairs = this.get('crosshairs');
- const canvas = this.get('canvas');
- const plotRange = this.get('plotRange');
- const isTransposed = this.get('isTransposed');
- if (crosshairs) {
- this._clearCrosshairsGroup();
- switch (crosshairs.type) {
- case 'x':
- this._renderHorizontalLine(canvas, plotRange);
- break;
- case 'y':
- this._renderVerticalLine(canvas, plotRange);
- break;
- case 'cross':
- this._renderHorizontalLine(canvas, plotRange);
- this._renderVerticalLine(canvas, plotRange);
- break;
- case 'rect':
- this._renderBackground(canvas, plotRange);
- break;
- default:
- isTransposed ? this._renderHorizontalLine(canvas, plotRange) : this._renderVerticalLine(canvas, plotRange);
- }
- }
- }
-
- _addCrossLineShape(attrs, type) {
- const crosshairsGroup = this.get('crosshairsGroup');
- const shape = crosshairsGroup.addShape('line', {
- attrs
- });
- shape.hide();
- this.set('crossLineShape' + type, shape);
- return shape;
- }
-
- _renderVerticalLine(canvas, plotRange) {
- const { style } = this.get('crosshairs');
- const attrs = Util.mix({
- x1: 0,
- y1: plotRange ? plotRange.bl.y : canvas.get('height'),
- x2: 0,
- y2: plotRange ? plotRange.tl.y : 0
- }, style);
-
- this._addCrossLineShape(attrs, 'Y');
- }
-
- _renderHorizontalLine(canvas, plotRange) {
- const { style } = this.get('crosshairs');
- const attrs = Util.mix({
- x1: plotRange ? plotRange.bl.x : canvas.get('width'),
- y1: 0,
- x2: plotRange ? plotRange.br.x : 0,
- y2: 0
- }, style);
-
- this._addCrossLineShape(attrs, 'X');
- }
-
- _renderBackground(canvas, plotRange) {
- const { style } = this.get('crosshairs');
- const crosshairsGroup = this.get('crosshairsGroup');
- const attrs = Util.mix({
- x: plotRange ? plotRange.tl.x : 0,
- y: plotRange ? plotRange.tl.y : canvas.get('height'),
- width: plotRange ? plotRange.br.x - plotRange.bl.x : canvas.get('width'),
- height: plotRange ? Math.abs(plotRange.tl.y - plotRange.bl.y) : canvas.get('height')
- }, style);
-
- const shape = crosshairsGroup.addShape('rect', {
- attrs
- });
- shape.hide();
- this.set('crosshairsRectShape', shape);
- return shape;
- }
-
- isContentChange(title, items) {
- const titleContent = this.get('titleContent');
- const lastItems = this.get('items');
- let isChanged = !(title === titleContent && lastItems.length === items.length);
- if (!isChanged) {
- Util.each(items, (item, index) => {
- const preItem = lastItems[index];
- isChanged = (item.value !== preItem.value) || (item.color !== preItem.color) || (item.name !== preItem.name) || (item.title !== preItem.title);
- if (isChanged) {
- return false;
- }
- });
- }
-
- return isChanged;
- }
-
- setContent(title, items) {
- // const isChange = this.isContentChange(title, items);
- // if (isChange) {
- // 在外面进行判断是否内容发生改变
- const timeStamp = +new Date();
- this.set('items', items);
- this.set('titleContent', title);
- this.set('timeStamp', timeStamp);
- this._renderTooltip();
- // }
- return this;
- }
-
- setMarkers(markerItems, markerCfg) {
- const self = this;
- let markerGroup = self.get('markerGroup');
- const frontPlot = self.get('frontPlot');
- if (!markerGroup) {
- markerGroup = frontPlot.addGroup({
- zIndex: 1,
- capture: false // 不进行拾取
- });
- self.set('markerGroup', markerGroup);
- } else {
- markerGroup.clear();
- }
- Util.each(markerItems, item => {
- markerGroup.addShape('marker', {
- color: item.color,
- attrs: Util.mix({}, markerCfg, {
- x: item.x,
- y: item.y
- })
- });
- });
- this.set('markerItems', markerItems);
- }
-
- clearMarkers() {
- const markerGroup = this.get('markerGroup');
- markerGroup && markerGroup.clear();
- }
-
- setPosition(x, y, target) {
- const container = this.get('container');
- const crossLineShapeX = this.get('crossLineShapeX');
- const crossLineShapeY = this.get('crossLineShapeY');
- const crosshairsRectShape = this.get('crosshairsRectShape');
- let endx = x;
- let endy = y;
- // const outterNode = this.get('canvas').get('el').parentNode;
- const outterNode = this.get('canvas').get('el');
- const viewWidth = DomUtil.getWidth(outterNode);
- const viewHeight = DomUtil.getHeight(outterNode);
- let offset = this.get('offset');
-
- let position;
- if (this.get('position')) {
- position = calcTooltipPosition(x, y, this.get('position'), container, target);
- x = position[0];
- y = position[1];
- } else if (!this.get('position')) {
- position = refixTooltipPosition(x, y, container, viewWidth, viewHeight);
- x = position[0];
- y = position[1];
- }
-
- if (this.get('inPlot')) { // tooltip 必须限制在绘图区域内
- const plotRange = this.get('plotRange');
- position = confineTooltipPosition(x, y, container, plotRange);
- x = position[0];
- y = position[1];
- }
-
- if (this.get('x') !== x || this.get('y') !== y) {
- const markerItems = this.get('markerItems');
- if (!Util.isEmpty(markerItems)) {
- endx = markerItems[0].x;
- endy = markerItems[0].y;
- }
- if (crossLineShapeY) { // 第一次进入时,画布需要单独绘制,所以需要先设定corss的位置
- crossLineShapeY.move(endx, 0);
- }
- if (crossLineShapeX) {
- crossLineShapeX.move(0, endy);
- }
-
- if (crosshairsRectShape) { // 绘制矩形辅助框,只在直角坐标系下生效
- const isTransposed = this.get('isTransposed');
- const items = this.get('items');
- const firstItem = items[0];
- const lastItem = items[items.length - 1];
- const dim = isTransposed ? 'y' : 'x';
- const attr = isTransposed ? 'height' : 'width';
- let startDim = firstItem[dim];
- if (items.length > 1 && firstItem[dim] > lastItem[dim]) {
- startDim = lastItem[dim];
- }
-
- if (this.get('crosshairs').width) { // 用户定义了 width
- crosshairsRectShape.attr(dim, startDim - this.get('crosshairs').width / 2);
- crosshairsRectShape.attr(attr, this.get('crosshairs').width);
- } else {
- if (Util.isArray(firstItem.point[dim]) && !firstItem.size) { // 直方图
- const width = firstItem.point[dim][1] - firstItem.point[dim][0];
- crosshairsRectShape.attr(dim, firstItem.point[dim][0]);
- crosshairsRectShape.attr(attr, width);
- } else {
- offset = (3 * firstItem.size) / 4;
- crosshairsRectShape.attr(dim, startDim - offset);
-
- if (items.length === 1) {
- crosshairsRectShape.attr(attr, (3 * firstItem.size) / 2);
- } else {
- crosshairsRectShape.attr(attr, Math.abs(lastItem[dim] - firstItem[dim]) + 2 * offset);
- }
- }
- }
- }
-
- const follow = this.get('follow');
- container.style.left = follow ? (x + 'px') : 0;
- container.style.top = follow ? (y + 'px') : 0;
- }
- }
-
- show() {
- const crossLineShapeX = this.get('crossLineShapeX');
- const crossLineShapeY = this.get('crossLineShapeY');
- const crosshairsRectShape = this.get('crosshairsRectShape');
- const markerGroup = this.get('markerGroup');
- const container = this.get('container');
- const canvas = this.get('canvas');
- crossLineShapeX && crossLineShapeX.show();
- crossLineShapeY && crossLineShapeY.show();
- crosshairsRectShape && crosshairsRectShape.show();
- markerGroup && markerGroup.show();
- super.show();
- container.style.visibility = 'visible';
- // canvas.sort();
- canvas.draw();
- }
-
- hide() {
- const self = this;
- const container = self.get('container');
- const crossLineShapeX = self.get('crossLineShapeX');
- const crossLineShapeY = self.get('crossLineShapeY');
- const crosshairsRectShape = this.get('crosshairsRectShape');
- const markerGroup = self.get('markerGroup');
- const canvas = self.get('canvas');
- container.style.visibility = 'hidden';
- crossLineShapeX && crossLineShapeX.hide();
- crossLineShapeY && crossLineShapeY.hide();
- crosshairsRectShape && crosshairsRectShape.hide();
- markerGroup && markerGroup.hide();
- super.hide();
- canvas.draw();
- }
-
- destroy() {
- const self = this;
- const crossLineShapeX = self.get('crossLineShapeX');
- const crossLineShapeY = self.get('crossLineShapeY');
- const markerGroup = self.get('markerGroup');
- const crosshairsRectShape = self.get('crosshairsRectShape');
- const container = self.get('container');
- const containerTpl = self.get('containerTpl');
-
- if (container && !(/^\#/.test(containerTpl))) {
- container.parentNode.removeChild(container);
- }
-
- crossLineShapeX && crossLineShapeX.remove();
- crossLineShapeY && crossLineShapeY.remove();
- markerGroup && markerGroup.remove();
- crosshairsRectShape && crosshairsRectShape.remove();
- // super.remove();
- super.destroy();
- }
-}
-
-module.exports = Tooltip;
diff --git a/src/core/base.js b/src/core/base.js
index e5b3e92d7a..55ba028668 100644
--- a/src/core/base.js
+++ b/src/core/base.js
@@ -4,7 +4,7 @@
*/
import EventEmitter from 'wolfy87-eventemitter';
-import { assign } from '../util';
+import Util from '../util';
class Base extends EventEmitter {
@@ -19,7 +19,7 @@ class Base extends EventEmitter {
};
const defaultCfg = this.getDefaultCfg();
this._attrs = attrs;
- assign(attrs, defaultCfg, cfg);
+ Util.assign(attrs, defaultCfg, cfg);
}
get(name) {
diff --git a/src/core/controller/index.js b/src/core/controller/index.js
index be256246b0..183b371353 100644
--- a/src/core/controller/index.js
+++ b/src/core/controller/index.js
@@ -1,4 +1,4 @@
import Scale from './scale';
-export {
+export default {
Scale
};
diff --git a/src/core/controller/scale.js b/src/core/controller/scale.js
index 669b9ad7ec..5fd56120bd 100644
--- a/src/core/controller/scale.js
+++ b/src/core/controller/scale.js
@@ -3,9 +3,9 @@
* @author dxq613@gmail.com
*/
-const Util = require('../../util');
-const Global = require('../../global');
-const Scale = require('../../scale/');
+import Util from '../../util';
+import Global from '../../global';
+import Scale from '../../scale/';
const dateRegex = /^(?:(?!0000)[0-9]{4}([-/.]+)(?:(?:0?[1-9]|1[0-2])\1(?:0?[1-9]|1[0-9]|2[0-8])|(?:0?[13-9]|1[0-2])\1(?:29|30)|(?:0?[13578]|1[02])\1(?:31))|(?:[0-9]{2}(?:0[48]|[2468][048]|[13579][26])|(?:0[48]|[2468][048]|[13579][26])00)([-/.]?)0?2\2(?:29))(\s+([01]|([01][0-9]|2[0-3])):([0-9]|[0-5][0-9]):([0-9]|[0-5][0-9]))?$/;
const TYPES = {
LINEAR: 'linear',
@@ -111,4 +111,4 @@ class ScaleController {
}
}
-module.exports = ScaleController;
+export default ScaleController;
diff --git a/src/core/image.js b/src/core/image.js
index 845053d977..eb1ab5c415 100644
--- a/src/core/image.js
+++ b/src/core/image.js
@@ -18,7 +18,7 @@ export default class LoadImage extends EventEmitter {
this.imagesIds = [];
}
addImage(id, opt) {
- this.imagesCount ++;
+ this.imagesCount++;
this.imagesIds.push(id);
const imageCount = this.imagesCount;
const x = imageCount % 8 * this.imageWidth;
diff --git a/src/core/layer.js b/src/core/layer.js
index dc0afbd99e..9cad42e7f2 100644
--- a/src/core/layer.js
+++ b/src/core/layer.js
@@ -9,7 +9,7 @@ import source from './source';
import PickingMaterial from '../core/engine/picking/pickingMaterial';
import Attr from '../attr/index';
import Util from '../util';
-const Global = require('../global');
+import Global from '../global';
let id = 1;
function parseFields(field) {
if (Util.isArray(field)) {
@@ -183,7 +183,6 @@ export default class Layer extends Base {
if (colorItem.indexOf(item) !== -1 && styleOptions[item] !== 'none') {
styleOptions[item] = ColorUtil.color2RGBA(styleOptions[item]);
}
- styleOptions[item] = styleOptions[item];
}
this.set('styleOptions', styleOptions);
return this;
@@ -525,7 +524,7 @@ export default class Layer extends Base {
this._updateMaping();
}
- /**
+ /**
* 用于过滤数据
* @param {*} object 需要过滤的mesh
*/
diff --git a/src/core/scene.js b/src/core/scene.js
index 38e3879c48..c86c5cf65c 100644
--- a/src/core/scene.js
+++ b/src/core/scene.js
@@ -25,7 +25,7 @@ export default class Scene extends Base {
this.workerPool = new WorkerPool();
compileBuiltinModules();
}
- // 为pickup场景添加 object 对象
+ // 为pickup场景添加 object 对象
addPickMesh(object) {
this._engine._picking.add(object);
}
diff --git a/src/core/source.js b/src/core/source.js
index 259ab32179..230e9c3b33 100644
--- a/src/core/source.js
+++ b/src/core/source.js
@@ -1,6 +1,6 @@
import Base from './base';
-const Controller = require('./controller/index');
+import Controller from './controller/index';
import { getTransform, getParser } from '../source';
import { getMap } from '../map/index';
export default class Source extends Base {
diff --git a/src/core/three.js b/src/core/three.js
index 1658e39038..7b344e2b23 100644
--- a/src/core/three.js
+++ b/src/core/three.js
@@ -23,16 +23,16 @@ export { Vector2 } from 'three/src/math/Vector2.js';
export { ShaderMaterial } from 'three/src/materials/ShaderMaterial.js';
export { DataTexture } from 'three/src/textures/DataTexture.js';
export {
- Float64BufferAttribute,
- Float32BufferAttribute,
- Uint32BufferAttribute,
- Int32BufferAttribute,
- Uint16BufferAttribute,
- Int16BufferAttribute,
- Uint8ClampedBufferAttribute,
- Uint8BufferAttribute,
- Int8BufferAttribute,
- BufferAttribute
+ Float64BufferAttribute,
+ Float32BufferAttribute,
+ Uint32BufferAttribute,
+ Int32BufferAttribute,
+ Uint16BufferAttribute,
+ Int16BufferAttribute,
+ Uint8ClampedBufferAttribute,
+ Uint8BufferAttribute,
+ Int8BufferAttribute,
+ BufferAttribute
} from 'three/src/core/BufferAttribute.js';
// export * from '../../build/three.js';
diff --git a/src/geom/buffer/point.js b/src/geom/buffer/point.js
index 009c90452e..36b0aac3f1 100644
--- a/src/geom/buffer/point.js
+++ b/src/geom/buffer/point.js
@@ -3,8 +3,9 @@ import { regularShape } from '../shape/index';
import * as polygonPath from '../shape/path';
import * as polygonShape from '../shape/polygon';
import * as lineShape from '../shape/line';
-import { pointShape } from '../../global';
+import Global from '../../global';
import Util from '../../util';
+const { pointShape } = Global;
export default class PointBuffer extends BufferBase {
geometryBuffer() {
const type = this.get('type');
diff --git a/src/geom/buffer/point/fillBuffer.js b/src/geom/buffer/point/fillBuffer.js
index 7179959827..c2e861eaf6 100644
--- a/src/geom/buffer/point/fillBuffer.js
+++ b/src/geom/buffer/point/fillBuffer.js
@@ -1,8 +1,9 @@
-import { pointShape } from '../../../global';
+import Global from '../../../global';
import * as THREE from '../../../core/three';
import * as polygonShape from '../../shape/polygon';
import * as polygonPath from '../../shape/path';
import Util from '../../../util';
+const { pointShape } = Global;
export default function fillBuffer(layerData) {
const attribute = {
vertices: [],
diff --git a/src/geom/buffer/point/strokeBuffer.js b/src/geom/buffer/point/strokeBuffer.js
index eff757e3c6..7d0e59b014 100644
--- a/src/geom/buffer/point/strokeBuffer.js
+++ b/src/geom/buffer/point/strokeBuffer.js
@@ -1,7 +1,8 @@
import * as polygonPath from '../../shape/path';
import * as polygonShape from '../../shape/polygon';
import * as lineShape from '../../shape/line';
-import { pointShape } from '../../../global';
+import Global from '../../../global';
+const { pointShape } = Global;
import Util from '../../../util';
export default function StrokeBuffer(layerData, style) {
const attribute = {
@@ -26,7 +27,7 @@ export default function StrokeBuffer(layerData, style) {
} else if (pointShape['3d'].indexOf(shape) !== -1) {
Util.isArray(size) || (size = [ size, size, size ]);
const polygonExtrudePath = polygonShape.extrudeline([ path ]);
- // TODO 3d line
+ // TODO 3d line
polygon = lineShape.Line([ polygonExtrudePath ], { size: [ strokeWidth, 0 ], color: stroke, id }, positionsIndex);
diff --git a/src/geom/buffer/point/textBuffer.js b/src/geom/buffer/point/textBuffer.js
index 1d68acb3b1..211dc00ff6 100644
--- a/src/geom/buffer/point/textBuffer.js
+++ b/src/geom/buffer/point/textBuffer.js
@@ -70,7 +70,7 @@ function loadTextTexture(url, cb) {
img.src = url;
}
- /**
+/**
* 计算每个标注词语的位置
* @param {*} chars 文本信息
* @param {*} pos 文字三维空间坐标
@@ -109,18 +109,18 @@ function drawGlyph(chars, pos, text, pen, size, colors, textureElements, originP
pos[0] + originX, pos[1] + originY, 0,
pos[0] + originX, pos[1] + originY, 0,
pos[0] + originX, pos[1] + originY, 0,
- );
+ );
const bx = 0;
const by = metrics.size / 2 + buffer;
textSizes.push(
- ((bx - buffer + width) * scale), (height - by) * scale,
- ((bx - buffer) * scale), (height - by) * scale,
- ((bx - buffer) * scale), -by * scale,
+ ((bx - buffer + width) * scale), (height - by) * scale,
+ ((bx - buffer) * scale), (height - by) * scale,
+ ((bx - buffer) * scale), -by * scale,
- ((bx - buffer + width) * scale), (height - by) * scale,
- ((bx - buffer) * scale), -by * scale,
- ((bx - buffer + width) * scale), -by * scale,
- );
+ ((bx - buffer + width) * scale), (height - by) * scale,
+ ((bx - buffer) * scale), -by * scale,
+ ((bx - buffer + width) * scale), -by * scale,
+ );
textOffsets.push(
@@ -142,14 +142,14 @@ function drawGlyph(chars, pos, text, pen, size, colors, textureElements, originP
);
textureElements.push(
- posX + width, posY,
- posX, posY,
- posX, posY + height,
+ posX + width, posY,
+ posX, posY,
+ posX, posY + height,
- posX + width, posY,
- posX, posY + height,
- posX + width, posY + height
- );
+ posX + width, posY,
+ posX, posY + height,
+ posX + width, posY + height
+ );
}
pen.x = pen.x + size * 1.8;
diff --git a/src/geom/buffer/polygon.js b/src/geom/buffer/polygon.js
index 60c585d872..ab2d6c2aea 100644
--- a/src/geom/buffer/polygon.js
+++ b/src/geom/buffer/polygon.js
@@ -26,7 +26,7 @@ export default class PolygonBuffer extends BufferBase {
positions.push(extrudeData.positions);
if (shape !== 'line') {
- // faceUv.push(...extrudeData.faceUv);
+ // faceUv.push(...extrudeData.faceUv);
const count = extrudeData.faceUv.length / 2;
for (let i = 0; i < count; i++) {
// uv 系数生成等大小的窗户
diff --git a/src/geom/buffer/text.js b/src/geom/buffer/text.js
index 5f906352b4..4680ffeafe 100644
--- a/src/geom/buffer/text.js
+++ b/src/geom/buffer/text.js
@@ -116,7 +116,7 @@ export default class TextBuffer extends BufferBase {
// const horiBearingX = metric[2];
// const horiBearingY = metric[3];
- // const horiAdvance = metric[4];
+ // const horiAdvance = metric[4];
// const posX = metric[5];
// const posY = metric[6];
const posX = x;
@@ -128,7 +128,7 @@ export default class TextBuffer extends BufferBase {
width += buffer * 2;
height += buffer * 2;
- // Add a quad (= two triangles) per glyph.
+ // Add a quad (= two triangles) per glyph.
// const originX = (horiBearingX - buffer + width / 2) * scale;
// const originY = -(height - horiBearingY) * scale;
const originX = 0;
@@ -144,13 +144,13 @@ export default class TextBuffer extends BufferBase {
const offsetX = pen.x;
const offsetY = pen.y;
originPoints.push(
- pos[0] + originX, pos[1] + originY, 0,
- pos[0] + originX, pos[1] + originY, 0,
- pos[0] + originX, pos[1] + originY, 0,
- pos[0] + originX, pos[1] + originY, 0,
- pos[0] + originX, pos[1] + originY, 0,
- pos[0] + originX, pos[1] + originY, 0,
- );
+ pos[0] + originX, pos[1] + originY, 0,
+ pos[0] + originX, pos[1] + originY, 0,
+ pos[0] + originX, pos[1] + originY, 0,
+ pos[0] + originX, pos[1] + originY, 0,
+ pos[0] + originX, pos[1] + originY, 0,
+ pos[0] + originX, pos[1] + originY, 0,
+ );
// textSizes.push(
// offsetWidth, offsetHeight,
@@ -169,31 +169,31 @@ export default class TextBuffer extends BufferBase {
((bx - buffer) * scale), (height - by) * scale,
((bx - buffer) * scale), -by * scale,
- ((bx - buffer + width) * scale), (height - by) * scale,
- ((bx - buffer) * scale), -by * scale,
- ((bx - buffer + width) * scale), -by * scale,
+ ((bx - buffer + width) * scale), (height - by) * scale,
+ ((bx - buffer) * scale), -by * scale,
+ ((bx - buffer + width) * scale), -by * scale,
);
textOffsets.push(
- offsetX, offsetY,
- offsetX, offsetY,
- offsetX, offsetY,
- offsetX, offsetY,
- offsetX, offsetY,
- offsetX, offsetY,
- );
+ offsetX, offsetY,
+ offsetX, offsetY,
+ offsetX, offsetY,
+ offsetX, offsetY,
+ offsetX, offsetY,
+ offsetX, offsetY,
+ );
colors.push(
- ...color,
- ...color,
- ...color,
- ...color,
- ...color,
- ...color,
- );
+ ...color,
+ ...color,
+ ...color,
+ ...color,
+ ...color,
+ ...color,
+ );
textureElements.push(
posX + width, posY,
diff --git a/src/geom/extrude.js b/src/geom/extrude.js
index 543ccddbc6..3b3375b798 100644
--- a/src/geom/extrude.js
+++ b/src/geom/extrude.js
@@ -34,7 +34,7 @@ export default function extrudePolygon(points, extrude) {
}
}
function full() {
- // 顶部纹理
+ // 顶部纹理
triangles.forEach(() => {
faceUv.push(-1, -1);
});
@@ -85,11 +85,11 @@ export function extrudePolygonLine(points, extrude) {
extrude === 0 ? flat() : full();
function flat() {
- points[0].forEach(p => { positions.push([ p[0], p[1], 0 ]); }); // top
+ points[0].forEach(p => { positions.push([ p[0], p[1], 0 ]); }); // top
}
function full() {
points[0].forEach(p => { positions.push([ p[0], p[1], 1 ]); }); // top
- points[0].forEach(p => { positions.push([ p[0], p[1], 0 ]); }); // bottom
+ points[0].forEach(p => { positions.push([ p[0], p[1], 0 ]); }); // bottom
for (let i = 0; i < n; i++) {
if (i === (n - 1)) {
cells.push(i + n, n, i);
diff --git a/src/geom/shape/path.js b/src/geom/shape/path.js
index 6f9c269388..d4c2842a50 100644
--- a/src/geom/shape/path.js
+++ b/src/geom/shape/path.js
@@ -19,14 +19,14 @@ function hexagon() {
return polygonPath(6);
}
export {
- circle,
- square,
- triangle,
- hexagon,
- circle as cylinder,
- triangle as triangleColumn,
- hexagon as hexagonColumn,
- square as squareColumn
+ circle,
+ square,
+ triangle,
+ hexagon,
+ circle as cylinder,
+ triangle as triangleColumn,
+ hexagon as hexagonColumn,
+ square as squareColumn
};
export function polygonPath(pointCount) {
diff --git a/src/global.js b/src/global.js
index be038b3e66..83d6ab5fc5 100644
--- a/src/global.js
+++ b/src/global.js
@@ -33,4 +33,4 @@ const Global = {
};
-module.exports = Global;
+export default Global;
diff --git a/src/index.js b/src/index.js
index 3117424cd7..ab6962277f 100755
--- a/src/index.js
+++ b/src/index.js
@@ -7,7 +7,7 @@ const version = Global.version;
const track = function(enable) {
Global.trackable = enable;
};
-require('./track');
+import './track';
export {
version,
Scene,
diff --git a/src/layer/pointLayer.js b/src/layer/pointLayer.js
index 39eb197c6d..e574ae3335 100644
--- a/src/layer/pointLayer.js
+++ b/src/layer/pointLayer.js
@@ -1,12 +1,12 @@
import Layer from '../core/layer';
import * as THREE from '../core/three';
import * as drawPoint from '../layer/render/point';
-import { pointShape } from '../global';
+import Global from '../global';
// import PointBuffer from '../geom/buffer/point';
import TextBuffer from '../geom/buffer/text';
import TextMaterial from '../geom/material/textMaterial';
import * as PointBuffer from '../geom/buffer/point/index';
-
+const { pointShape } = Global;
/**
* point shape 2d circle, traingle text,image
* shape 3d cube,column, sphere
@@ -42,33 +42,33 @@ export default class PointLayer extends Layer {
switch (pointShapeType) {
case 'fill' :// 填充图形
- {
- if (fill !== 'none') { // 是否填充
- const attributes = PointBuffer.FillBuffer(this.layerData, style);
- const meshfill = drawPoint.DrawFill(attributes, this.get('styleOptions'));
- this.add(meshfill);
- }
- if (stroke !== 'none') { // 是否绘制边界
- const lineAttribute = PointBuffer.StrokeBuffer(this.layerData, style);
- const meshStroke = drawPoint.DrawStroke(lineAttribute, this.get('styleOptions'));
- this.add(meshStroke, 'line');
- }
- break;
+ {
+ if (fill !== 'none') { // 是否填充
+ const attributes = PointBuffer.FillBuffer(this.layerData, style);
+ const meshfill = drawPoint.DrawFill(attributes, this.get('styleOptions'));
+ this.add(meshfill);
}
+ if (stroke !== 'none') { // 是否绘制边界
+ const lineAttribute = PointBuffer.StrokeBuffer(this.layerData, style);
+ const meshStroke = drawPoint.DrawStroke(lineAttribute, this.get('styleOptions'));
+ this.add(meshStroke, 'line');
+ }
+ break;
+ }
case 'image':// 绘制图片标注
- {
- const imageAttribute = PointBuffer.ImageBuffer(this.layerData, { imagePos: this.scene.image.imagePos });
- const imageMesh = drawPoint.DrawImage(imageAttribute, { ...style, texture: this.scene.image.texture });
- this.add(imageMesh);
- break;
- }
+ {
+ const imageAttribute = PointBuffer.ImageBuffer(this.layerData, { imagePos: this.scene.image.imagePos });
+ const imageMesh = drawPoint.DrawImage(imageAttribute, { ...style, texture: this.scene.image.texture });
+ this.add(imageMesh);
+ break;
+ }
case 'normal' : // 原生点
- {
- const normalAttribute = PointBuffer.NormalBuffer(this.layerData, style);
- const normalPointMesh = drawPoint.DrawNormal(normalAttribute, style);
- this.add(normalPointMesh);
- break;
- }
+ {
+ const normalAttribute = PointBuffer.NormalBuffer(this.layerData, style);
+ const normalPointMesh = drawPoint.DrawNormal(normalAttribute, style);
+ this.add(normalPointMesh);
+ break;
+ }
default:
return null;
}
diff --git a/src/map/AMap.js b/src/map/AMap.js
index e54615b94a..6e9ef3b5df 100644
--- a/src/map/AMap.js
+++ b/src/map/AMap.js
@@ -1,11 +1,11 @@
import Base from '../core/base';
-import { scene } from '../global';
+import Global from '../global';
import * as Theme from '../theme/index';
import Util from '../util';
const DEG2RAD = Math.PI / 180;
export default class GaodeMap extends Base {
getDefaultCfg() {
- return Util.assign(scene, {
+ return Util.assign(Global.scene, {
resizeEnable: true,
viewMode: '3D'
});
diff --git a/src/map/mapbox.js b/src/map/mapbox.js
index 8eebadc8ef..b3e7ddf875 100644
--- a/src/map/mapbox.js
+++ b/src/map/mapbox.js
@@ -1,6 +1,6 @@
import Base from '../core/base';
import Util from '../util';
-import { scene } from '../global';
+import Global from '../global';
import * as THREE from '../core/three';
const WORLD_SIZE = 512;
const MERCATOR_A = 6378137.0;
@@ -8,7 +8,7 @@ const WORLD_SCALE = 1 / 100;
const PROJECTION_WORLD_SIZE = WORLD_SIZE / (MERCATOR_A * Math.PI) / 2;
export default class MapBox extends Base {
getDefaultCfg() {
- return Util.assign(scene, {
+ return Util.assign(Global.scene, {
resizeEnable: true,
viewMode: '3D'
});
@@ -80,10 +80,10 @@ export default class MapBox extends Base {
// Unlike the Mapbox GL JS camera, separate camera translation and rotation out into its world matrix
// If this is applied directly to the projection matrix, it will work OK but break raycasting
cameraWorldMatrix
- .premultiply(cameraTranslateZ)
- .premultiply(cameraRotateX)
- .premultiply(cameraRotateZ)
- .premultiply(cameraTranslateXY);
+ .premultiply(cameraTranslateZ)
+ .premultiply(cameraRotateX)
+ .premultiply(cameraRotateZ)
+ .premultiply(cameraTranslateXY);
camera.matrixWorld.copy(cameraWorldMatrix);
@@ -94,23 +94,23 @@ export default class MapBox extends Base {
const translateMap = new THREE.Matrix4();
const rotateMap = new THREE.Matrix4();
scale
- .makeScale(zoomPow, zoomPow, 1.0);
+ .makeScale(zoomPow, zoomPow, 1.0);
translateCenter
- .makeTranslation(WORLD_SIZE / 2, -WORLD_SIZE / 2, 0);
+ .makeTranslation(WORLD_SIZE / 2, -WORLD_SIZE / 2, 0);
translateMap
- .makeTranslation(-this.map.transform.x, this.map.transform.y, 0);
+ .makeTranslation(-this.map.transform.x, this.map.transform.y, 0);
rotateMap
- .makeRotationZ(Math.PI);
+ .makeRotationZ(Math.PI);
scene.matrix = new THREE.Matrix4();
scene.matrix
- .premultiply(rotateMap)
- .premultiply(translateCenter)
- .premultiply(scale);
+ .premultiply(rotateMap)
+ .premultiply(translateCenter)
+ .premultiply(scale);
pickScene.matrix = new THREE.Matrix4();
pickScene.matrix
- .premultiply(rotateMap)
- .premultiply(translateCenter)
- .premultiply(scale);
+ .premultiply(rotateMap)
+ .premultiply(translateCenter)
+ .premultiply(scale);
}
makePerspectiveMatrix(fovy, aspect, near, far) {
const out = new THREE.Matrix4();
diff --git a/src/scale/auto/cat.js b/src/scale/auto/cat.js
index 68095a29e5..733988eb6b 100644
--- a/src/scale/auto/cat.js
+++ b/src/scale/auto/cat.js
@@ -2,8 +2,7 @@
* @fileOverview 计算分类的的坐标点
* @author dxq613@gmail.com
*/
-
-const Util = require('../../util');
+import Util from '../../util';
const MAX_COUNT = 8;
const SUB_COUNT = 4; // 控制个数不能过小
@@ -32,7 +31,7 @@ function getGreatestFactor(count, number) {
return i;
}
-module.exports = function(info) {
+export default function(info) {
const rst = {};
const ticks = [];
const maxCount = info.maxCount || MAX_COUNT;
@@ -70,4 +69,4 @@ module.exports = function(info) {
rst.categories = categories;
rst.ticks = ticks;
return rst;
-};
+}
diff --git a/src/scale/auto/number.js b/src/scale/auto/number.js
index 09eb5f9fb7..3f370be5c4 100644
--- a/src/scale/auto/number.js
+++ b/src/scale/auto/number.js
@@ -3,13 +3,13 @@
* @author dxq613@gmail.com
*/
-const Util = require('../../util');
-const AutoUtil = require('./util');
+import Util from '../../util';
+import AutoUtil from './util';
const MIN_COUNT = 5;
const MAX_COUNT = 7;
-const Global = require('../../global');
+import Global from '../../global';
-module.exports = function(info) {
+export default function(info) {
let min = info.min;
let max = info.max;
let interval = info.interval;
@@ -116,4 +116,4 @@ module.exports = function(info) {
count,
ticks
};
-};
+}
diff --git a/src/scale/auto/time.js b/src/scale/auto/time.js
index 8a3d160e3d..0bbfb48e5d 100644
--- a/src/scale/auto/time.js
+++ b/src/scale/auto/time.js
@@ -3,8 +3,8 @@
* @author dxq613@gmail.com
*/
-const Util = require('../../util');
-const AutoUtil = require('./util');
+import Util from '../../util';
+import AutoUtil from './util';
const MAX_COUNT = 6;
const SNAP_ARRAY = [ 1, 2, 4, 6, 8, 12 ];
@@ -48,7 +48,7 @@ function diffMinus(min, max) {
return Math.ceil((max - min) / (60 * 1000));
}
-module.exports = function(info) {
+export default function(info) {
const minInterval = info.minInterval;
const ticks = [];
let min = info.min;
@@ -158,4 +158,4 @@ module.exports = function(info) {
ticks,
count: ticks.length
};
-};
+}
diff --git a/src/scale/auto/util.js b/src/scale/auto/util.js
index 890d3245ce..f559a6ee2f 100644
--- a/src/scale/auto/util.js
+++ b/src/scale/auto/util.js
@@ -85,7 +85,8 @@ function arrayCeiling(values, value) {
const Util = {
// 获取逼近的数值
- snapFactorTo(v, arr, snapType) { // 假设 v = -512,isFloor = true
+ snapFactorTo(v, arr, snapType) {
+ // 假设 v = -512,isFloor = true
if (isNaN(v)) {
return NaN;
}
@@ -112,7 +113,7 @@ const Util = {
if (Math.abs(factor) < 1 && rst.toString().length > DECIMAL_LENGTH) {
const decimalVal = parseInt(1 / factor);
const symbol = factor > 0 ? 1 : -1;
- rst = v / decimalVal * symbol;
+ rst = (v / decimalVal) * symbol;
}
return rst;
},
@@ -174,4 +175,4 @@ const Util = {
}
};
-module.exports = Util;
+export default Util;
diff --git a/src/scale/base.js b/src/scale/base.js
index f92bac46ba..91e5c148c7 100644
--- a/src/scale/base.js
+++ b/src/scale/base.js
@@ -3,13 +3,13 @@
* @author dxq613@gmail.com
*/
-const Util = require('../util');
+import Util from '../util';
/**
* 度量的构造函数
* @class Scale
*/
-class Scale {
+class Base {
/**
* 获取默认的配置属性
@@ -183,4 +183,4 @@ class Scale {
}
}
-module.exports = Scale;
+export default Base;
diff --git a/src/scale/category.js b/src/scale/category.js
index dc85509522..50d31aa212 100644
--- a/src/scale/category.js
+++ b/src/scale/category.js
@@ -4,9 +4,9 @@
*/
-const Base = require('./base');
-const Util = require('../util');
-const catAuto = require('./auto/cat');
+import Base from './base';
+import Util from '../util';
+import catAuto from './auto/cat';
/**
* 度量的构造函数
@@ -132,4 +132,4 @@ class Category extends Base {
}
}
-module.exports = Category;
+export default Category;
diff --git a/src/scale/identity.js b/src/scale/identity.js
index e11fc0af70..4d1fc55553 100644
--- a/src/scale/identity.js
+++ b/src/scale/identity.js
@@ -3,8 +3,8 @@
* @author dxq613@gmail.com
*/
-const Base = require('./base');
-const Util = require('../util');
+import Base from './base';
+import Util from '../util';
class Identity extends Base {
@@ -54,4 +54,4 @@ class Identity extends Base {
}
}
-module.exports = Identity;
+export default Identity;
diff --git a/src/scale/index.js b/src/scale/index.js
index 7c8ed3cd32..b0c27f4066 100644
--- a/src/scale/index.js
+++ b/src/scale/index.js
@@ -3,15 +3,23 @@
* @author dxq613@gmail.com
*/
-const Util = require('../util');
-const Base = require('./base');
-Base.Linear = require('./linear');
-Base.Identity = require('./identity');
-Base.Cat = require('./category');
-Base.Time = require('./time');
-Base.TimeCat = require('./time-cat');
-Base.Log = require('./log');
-Base.Pow = require('./pow');
+import Util from '../util';
+import Base from './base';
+import Linear from './linear';
+import Identity from './identity';
+import Cat from './category';
+import Time from './time';
+import TimeCat from './time-cat';
+import Log from './log';
+import Pow from './pow';
+
+Base.Linear = Linear;
+Base.Identity = Identity;
+Base.Cat = Cat;
+Base.Time = Time;
+Base.TimeCat = TimeCat;
+Base.Log = Log;
+Base.Pow = Pow;
for (const k in Base) {
if (Base.hasOwnProperty(k)) {
@@ -28,4 +36,4 @@ Base.isCategory = function(type) {
return CAT_ARR.indexOf(type) >= 0;
};
-module.exports = Base;
+export default Base;
diff --git a/src/scale/linear.js b/src/scale/linear.js
index 6070a45ccb..a80e5f732f 100644
--- a/src/scale/linear.js
+++ b/src/scale/linear.js
@@ -4,9 +4,9 @@
*/
-const Base = require('./base');
-const Util = require('../util');
-const numberAuto = require('./auto/number');
+import Base from './base';
+import Util from '../util';
+import numberAuto from './auto/number';
/**
* 线性度量
@@ -192,4 +192,4 @@ class Linear extends Base {
}
}
-module.exports = Linear;
+export default Linear;
diff --git a/src/scale/log.js b/src/scale/log.js
index a3b69a9375..1a92809b57 100644
--- a/src/scale/log.js
+++ b/src/scale/log.js
@@ -3,8 +3,8 @@
* @author dxq613@gmail.com
*/
-const Linear = require('./linear');
-const Util = require('../util');
+import Linear from './linear';
+import Util from '../util';
// 计算log
function log(a, b) {
@@ -157,4 +157,4 @@ class Log extends Linear {
}
}
-module.exports = Log;
+export default Log;
diff --git a/src/scale/pow.js b/src/scale/pow.js
index 72991bb310..f8ead37bb8 100644
--- a/src/scale/pow.js
+++ b/src/scale/pow.js
@@ -4,8 +4,8 @@
*/
-const Linear = require('./linear');
-const Util = require('../util');
+import Linear from './linear';
+import Util from '../util';
// 求以a为次幂,结果为b的基数,如 x^^a = b;求x
function calBase(a, b) {
@@ -111,4 +111,4 @@ class Pow extends Linear {
}
}
-module.exports = Pow;
+export default Pow;
diff --git a/src/scale/time-cat.js b/src/scale/time-cat.js
index 28ceacc2fc..c49eae862f 100644
--- a/src/scale/time-cat.js
+++ b/src/scale/time-cat.js
@@ -3,11 +3,11 @@
* @author dxq613@gmail.com
*/
-const Category = require('./category');
-const Util = require('../util');
-const fecha = require('fecha');
-const catAuto = require('./auto/cat');
-const TimeUtil = require('./time-util');
+import Category from './category';
+import Util from '../util';
+import fecha from 'fecha';
+import TimeUtil from './time-util';
+import catAuto from './auto/cat';
/**
* 度量的构造函数
@@ -166,4 +166,4 @@ class TimeCategory extends Category {
}
}
-module.exports = TimeCategory;
+export default TimeCategory;
diff --git a/src/scale/time-util.js b/src/scale/time-util.js
index 822be91826..2387d62268 100644
--- a/src/scale/time-util.js
+++ b/src/scale/time-util.js
@@ -3,9 +3,9 @@
* @author dxq613@gmail.com
*/
-const Util = require('../util');
+import Util from '../util';
-module.exports = {
+export default {
toTimeStamp(value) {
if (Util.isString(value)) {
if (value.indexOf('T') > 0) {
diff --git a/src/scale/time.js b/src/scale/time.js
index 60a91407ad..13a0c9b01b 100644
--- a/src/scale/time.js
+++ b/src/scale/time.js
@@ -3,11 +3,11 @@
* @author dxq613@gmail.com
*/
-const Linear = require('./linear');
-const Util = require('../util');
-const timeAuto = require('./auto/time');
-const fecha = require('fecha');
-const TimeUtil = require('./time-util');
+import Linear from './linear';
+import Util from '../util';
+import timeAuto from './auto/time';
+import fecha from 'fecha';
+import TimeUtil from './time-util';
/**
* 时间度量的构造函数
@@ -126,4 +126,4 @@ class Time extends Linear {
}
}
-module.exports = Time;
+export default Time;
diff --git a/src/theme/index.js b/src/theme/index.js
index be722b9dcf..7b4cd3a988 100644
--- a/src/theme/index.js
+++ b/src/theme/index.js
@@ -1,6 +1,3 @@
import DarkTheme from './dark';
import LightTheme from './light';
-export {
- DarkTheme,
- LightTheme
-};
+export { DarkTheme, LightTheme };
diff --git a/src/theme/light.js b/src/theme/light.js
index 0736730011..80b1082e2d 100644
--- a/src/theme/light.js
+++ b/src/theme/light.js
@@ -1,6 +1,5 @@
+const LightTheme = {
+ mapStyle: 'amap://styles/a80c558f91b29cf56fa47f895fb1773c?isPublic=true'
+};
- const LightTheme = {
- mapStyle: 'amap://styles/a80c558f91b29cf56fa47f895fb1773c?isPublic=true'
- };
-
- export default LightTheme;
+export default LightTheme;
diff --git a/src/track.js b/src/track.js
index 77295e480b..d3ebbec1ed 100644
--- a/src/track.js
+++ b/src/track.js
@@ -2,7 +2,7 @@
* @fileOverview track g2
* @author dxq613@gmail.com
*/
-const Global = require('./global');
+import Global from './global';
const SERVER_URL = 'https://kcart.alipay.com/web/bi.do';
// 延迟发送请求
diff --git a/src/util.js b/src/util.js
index 5500da1ca4..77d8948ffc 100644
--- a/src/util.js
+++ b/src/util.js
@@ -3,7 +3,7 @@
* @author dxq613@gmail.com
* @see https://github.com/lodash/lodash
*/
-const Utils = require('@antv/util');
+import Utils from '@antv/util';
const Util = Utils.mix({}, Utils, {
assign: Utils.mix, // simple mix
@@ -52,4 +52,4 @@ Util.Array = {
remove: Utils.pull
};
-module.exports = Util;
+export default Util;
diff --git a/src/util/ajax.js b/src/util/ajax.js
index c95bd487c6..1fc5541fbe 100644
--- a/src/util/ajax.js
+++ b/src/util/ajax.js
@@ -6,7 +6,7 @@ class AJAXError extends Error {
this.status = status;
this.url = url;
- // work around for https://github.com/Rich-Harris/buble/issues/40
+ // work around for https://github.com/Rich-Harris/buble/issues/40
this.name = this.constructor.name;
this.message = message;
}
@@ -88,8 +88,8 @@ function sameOrigin(url) {
const transparentPngUrl = '';
export const getImage = function(requestParameters, callback) {
- // request the image with XHR to work around caching issues
- // see https://github.com/mapbox/mapbox-gl-js/issues/1470
+ // request the image with XHR to work around caching issues
+ // see https://github.com/mapbox/mapbox-gl-js/issues/1470
return getArrayBuffer(requestParameters, (err, imgData) => {
if (err) {
callback(err);
diff --git a/src/util/common.js b/src/util/common.js
index 62987e0457..0308b370c0 100644
--- a/src/util/common.js
+++ b/src/util/common.js
@@ -2,7 +2,7 @@ const PRECISION = 0.00001; // 常量,据的精度,小于这个精度认为
const RADIAN = Math.PI / 180;
const DEGREE = 180 / Math.PI;
-module.exports = {
+export default {
isFunction: require('lodash/isFunction'),
isObject: require('lodash/isObject'),
isBoolean: require('lodash/isBoolean'),
diff --git a/src/util/dom.js b/src/util/dom.js
index 09650e3aeb..580496a676 100644
--- a/src/util/dom.js
+++ b/src/util/dom.js
@@ -1,4 +1,4 @@
-const Util = require('./common');
+import Util from './common';
const TABLE = document.createElement('table');
const TABLE_TR = document.createElement('tr');
@@ -13,7 +13,7 @@ const CONTAINERS = {
'*': document.createElement('div')
};
-module.exports = {
+export default {
getBoundingClientRect(node, defaultValue) {
if (node && node.getBoundingClientRect) {
const rect = node.getBoundingClientRect();
diff --git a/src/util/format.js b/src/util/format.js
index ce19982452..0c60414b8b 100644
--- a/src/util/format.js
+++ b/src/util/format.js
@@ -1,4 +1,4 @@
-const Util = require('../util/index');
+import Util from '../util/index';
const regexTags = /[MLHVQTCSAZ]([^MLHVQTCSAZ]*)/ig;
const regexDot = /[^\s\,]+/ig;
@@ -138,13 +138,14 @@ function parsePattern(color, self) {
} else {
img.onload = onload;
// Fix onload() bug in IE9
+ // eslint-disable-next-line
img.src = img.src;
}
return pattern;
}
-module.exports = {
+export default {
parsePath(path) {
path = path || [];
if (Util.isArray(path)) {
diff --git a/src/util/index.js b/src/util/index.js
index 2dde46b67e..5d3404b1b8 100644
--- a/src/util/index.js
+++ b/src/util/index.js
@@ -1,5 +1,5 @@
-const CommonUtil = require('./common');
-const DomUtil = require('./dom');
+import CommonUtil from './common';
+import DomUtil from './dom';
const Util = {};
@@ -22,4 +22,4 @@ CommonUtil.merge(Util, CommonUtil, DomUtil, {
}
});
-module.exports = Util;
+export default Util;
diff --git a/src/util/matrix.js b/src/util/matrix.js
index b3a61af50a..2a40f581b8 100644
--- a/src/util/matrix.js
+++ b/src/util/matrix.js
@@ -1,7 +1,7 @@
-const CommonUtil = require('./common');
-const mat3 = require('gl-matrix/src/gl-matrix/mat3');
-const vec3 = require('gl-matrix/src/gl-matrix/vec3');
-const vec2 = require('gl-matrix/src/gl-matrix/vec2');
+import CommonUtil from './common';
+import mat3 from 'gl-matrix/src/gl-matrix/mat3';
+import vec3 from 'gl-matrix/src/gl-matrix/vec3';
+import vec2 from 'gl-matrix/src/gl-matrix/vec2';
vec2.angle = function(v1, v2) {
const theta = vec2.dot(v1, v2) / (vec2.length(v1) * vec2.length(v2));
@@ -62,7 +62,7 @@ mat3.scale = function(out, a, v) {
return mat3.multiply(out, scaleMat, a);
};
-module.exports = {
+export default {
mat3,
vec2,
vec3,
diff --git a/src/util/path.js b/src/util/path.js
index df2a7a6581..0a1f3c2b83 100644
--- a/src/util/path.js
+++ b/src/util/path.js
@@ -1,4 +1,4 @@
-const Util = require('./common');
+import Util from './common';
const SPACES = '\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029';
const PATH_COMMAND = new RegExp('([a-z])[' + SPACES + ',]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?[' + SPACES + ']*,?[' + SPACES + ']*)+)', 'ig');
const PATH_VALUES = new RegExp('(-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?)[' + SPACES + ']*,?[' + SPACES + ']*', 'ig');
@@ -954,7 +954,7 @@ const pathIntersection = function(path1, path2) {
return interPathHelper(path1, path2);
};
-module.exports = {
+export default {
parsePathString,
parsePathArray,
pathTocurve,
diff --git a/src/worker/main.worker.js b/src/worker/main.worker.js
index bdefe02116..1818813de2 100644
--- a/src/worker/main.worker.js
+++ b/src/worker/main.worker.js
@@ -1,5 +1,4 @@
-
-self.addEventListener('message', e => {
+this.addEventListener('message', e => {
const res = e.data;
// res = {
// command : 'POLYGON-EXTRUDE',
@@ -16,6 +15,8 @@ self.addEventListener('message', e => {
break;
}
});
-self.addEventListener('error', function(e) {
- console.error('filename:' + e.filename + '\nmessage:' + e.message + '\nline:' + e.lineno);
+this.addEventListener('error', function(e) {
+ console.error(
+ 'filename:' + e.filename + '\nmessage:' + e.message + '\nline:' + e.lineno
+ );
});
diff --git a/webpack-dev.config.js b/webpack-dev.config.js
index fcefcc98ed..5ed7514ad1 100755
--- a/webpack-dev.config.js
+++ b/webpack-dev.config.js
@@ -1,10 +1,14 @@
const webpackConfig = require('./webpack.config');
const _ = require('lodash');
-module.exports = _.merge({
- watch: true,
- watchOptions: {
- aggregateTimeout: 300,
- poll: 1000
- }
-}, webpackConfig);
+module.exports = _.merge(
+ {
+ mode: 'development',
+ watch: true,
+ watchOptions: {
+ aggregateTimeout: 300,
+ poll: 1000
+ }
+ },
+ webpackConfig
+);