From a4b7a9fa715c1b05206e99f4e46f370388da45cc Mon Sep 17 00:00:00 2001 From: Bairui SU Date: Fri, 23 Feb 2024 20:46:41 +0800 Subject: [PATCH] docs(line): add demo line with area annotation (#6089) --- .../general/line/demo/line-area-clip-path.ts | 546 ++++++++++++++++++ site/examples/general/line/demo/meta.json | 10 +- 2 files changed, 555 insertions(+), 1 deletion(-) create mode 100644 site/examples/general/line/demo/line-area-clip-path.ts diff --git a/site/examples/general/line/demo/line-area-clip-path.ts b/site/examples/general/line/demo/line-area-clip-path.ts new file mode 100644 index 0000000000..93356e1d6a --- /dev/null +++ b/site/examples/general/line/demo/line-area-clip-path.ts @@ -0,0 +1,546 @@ +import { Chart } from '@antv/g2'; + +const data = [ + { + timestamp: 1705518060000, + value: 60.143229166667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: true, + }, + { + timestamp: 1705518120000, + value: 38.229166666667005, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518180000, + value: 51.71875, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518240000, + value: 45.37109375, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518420000, + value: 45.397135416667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518540000, + value: 0, + lowerValue: 27.1, + upperValue: 59.6, + isOut: true, + }, + { + timestamp: 1705518720000, + value: 54.446614583332995, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518900000, + value: 57.180989583332995, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705518960000, + value: 51.647135416667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519020000, + value: 49.0234375, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519140000, + value: 47.447916666667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519200000, + value: 49.3359375, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519260000, + value: 43.483072916667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519440000, + value: 50.66406249999999, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519500000, + value: 44.329427083333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519620000, + value: 52.46093750000001, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519680000, + value: 44.66796875, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519800000, + value: 43.359375, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705519920000, + value: 0, + lowerValue: 27.1, + upperValue: 59.6, + isOut: true, + }, + { + timestamp: 1705520040000, + value: 47.102864583333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520100000, + value: 48.1640625, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520220000, + value: 55.201822916667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520340000, + value: 49.856770833332995, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520460000, + value: 44.309895833333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520580000, + value: 44.127604166667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520700000, + value: 58.782552083332995, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520820000, + value: 46.03515625, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705520940000, + value: 69.498697916667, + lowerValue: 27.1, + upperValue: 59.6, + isOut: true, + }, + { + timestamp: 1705521000000, + value: 38.14453125, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705521060000, + value: 58.177083333333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705521360000, + value: 56.516927083333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705521480000, + value: 54.036458333333, + lowerValue: 27.1, + upperValue: 59.6, + isOut: false, + }, + { + timestamp: 1705521600000, + value: 50.397135416667005, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705521720000, + value: 45.091145833333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705521780000, + value: 49.1796875, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705521840000, + value: 44.31640625, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705521900000, + value: 49.576822916667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522080000, + value: 45.865885416667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522260000, + value: 44.986979166667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522320000, + value: 47.3828125, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522440000, + value: 45.05859375, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522560000, + value: 0, + lowerValue: 25.67, + upperValue: 61.81, + isOut: true, + }, + { + timestamp: 1705522800000, + value: 42.415364583333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522860000, + value: 48.776041666667005, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705522920000, + value: 50.084635416667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523040000, + value: 45.76171875, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523160000, + value: 49.713541666667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523220000, + value: 52.44140625, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523280000, + value: 38.743489583333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523340000, + value: 50.904947916667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523400000, + value: 39.505208333332995, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523520000, + value: 45.514322916667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705523880000, + value: 49.700520833333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524000000, + value: 46.62109375, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524120000, + value: 45.4296875, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524180000, + value: 49.00390625, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524240000, + value: 43.287760416667, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524300000, + value: 43.860677083333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524360000, + value: 55.95703125, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524420000, + value: 40.930989583333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524600000, + value: 43.958333333333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524660000, + value: 47.421875, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524780000, + value: 44.544270833333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705524960000, + value: 42.122395833333, + lowerValue: 25.67, + upperValue: 61.81, + isOut: false, + }, + { + timestamp: 1705525140000, + value: 66.97265625, + lowerValue: 25.82, + upperValue: 62, + isOut: true, + }, + { + timestamp: 1705525200000, + value: 46.744791666667, + lowerValue: 25.82, + upperValue: 62, + isOut: false, + }, + { + timestamp: 1705525380000, + value: 47.786458333333, + lowerValue: 25.82, + upperValue: 62, + isOut: false, + }, + { + timestamp: 1705525440000, + value: 45.540364583333, + lowerValue: 25.82, + upperValue: 62, + isOut: false, + }, + { + timestamp: 1705525500000, + value: 42.8515625, + lowerValue: 25.82, + upperValue: 62, + isOut: false, + }, + { + timestamp: 1705525620000, + value: 60.56640625000001, + lowerValue: 25.82, + upperValue: 62, + isOut: false, + }, +]; + +function clip(chart) { + const { canvas } = chart.getContext(); + const document = canvas.document; + const [cloned] = document.getElementsByClassName('cloned-line'); + if (cloned) cloned.remove(); + const elements = document.getElementsByClassName('element'); + const line = elements.find((d) => d.markType === 'line'); + const area = elements.find((d) => d.markType === 'area'); + const clonedLine = line.cloneNode(true); + clonedLine.__data__ = line.__data__; + clonedLine.style.stroke = 'orange'; + clonedLine.style.clipPath = null; + clonedLine.className = 'cloned-line'; + line.parentNode.insertBefore(clonedLine, line); + line.style.clipPath = area; +} + +const chart = new Chart({ + container: 'container', + autoFit: true, +}); + +chart.options({ + type: 'view', + data, + encode: { x: 'timestamp' }, + axis: { y: { title: 'value' } }, + children: [ + { + type: 'area', + encode: { y: ['lowerValue', 'upperValue'] }, + style: { + shape: 'smooth', + fillOpacity: 0.3, + fill: '#85c5A6', + }, + animate: false, + }, + { + type: 'line', + encode: { y: 'value' }, + scale: { x: { type: 'time', mask: 'HH:mm' } }, + style: { shape: 'hvh' }, + animate: false, + }, + ], +}); + +chart.on('afterrender', () => clip(chart)); + +chart.render(); diff --git a/site/examples/general/line/demo/meta.json b/site/examples/general/line/demo/meta.json index 99a439b5e7..1e9d0112ab 100644 --- a/site/examples/general/line/demo/meta.json +++ b/site/examples/general/line/demo/meta.json @@ -132,6 +132,14 @@ }, "screenshot": "https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*rHYnQ5-S6twAAAAAAAAAAAAADmJ7AQ/original" }, + { + "filename": "line-area-clip-path.ts", + "title": { + "zh": "面积标注折线图", + "en": "Line with Area Annotation" + }, + "screenshot": "https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*GK8rQY5srTgAAAAAAAAAAAAADmJ7AQ/original" + }, { "filename": "line-slope.ts", "title": { @@ -141,4 +149,4 @@ "screenshot": "https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*RF2PTL6KNIQAAAAAAAAAAAAADmJ7AQ/original" } ] -} \ No newline at end of file +}