G2Plot was originally born out of the business appeal of ali Economy BI products in real scenarios. Based on G2 graph syntax, G2Plot expands common business charts with one graph and one action.
In G2Plot 2.3.14, the shape configuration is provided to allow users to customize the shape of the waterplot, and a variety of shapes are built in, as follows:
circular | Diamond (diamond) | rectangular | The water type |
There are several shapes built in, but the user’s needs are constantly changing. Therefore, we have also opened the way for custom shapes: just pass in a callback function that builds the Path, so that developers can customize the shape of the wave diagram to their own needs. Here are some custom shapes of the wave diagram.
This article will briefly introduce the use of the custom shape API, and then from the relatively simple five-pointed star, we will introduce how to customize the star water graph based on G2Plot water graph.
β For more details, see: 1. Guide to water charts; 2
Shape API brief introduction
- Shape attribute accepts a callback function, the return Path of execution types drawing instructions (similar with SVG Path, can view the detail G | Path)
- The callback parameters are center point x, y, container width, and container height. As shown in Figure 1:
Figure 1
Here is a sample code from the documentation, which we’ll explain a little bit with the comments:
function shape(x: number, y: number, width: number, height: number) {
const h = height / 2;
const w = width / 2;
return [
// Move to the top left corner of the canvas (x-w, y-h)
['M', x - w, y - h],
// Connect to top right of canvas (x + w, y-h)
['L', x + w, y - h],
// Connect the bottom right corner of the canvas (x + w, y + h)
['L', x + w, y + h],
// Connect the bottom left corner of the canvas (x-w, y + h)
['L', x - w, y + h],
// Run the close path command Z to close the path
['Z']]; }Copy the code
Preview effect is shown in Figure 2:Figure 2
Draw Star wave chart
By default, you have a certain mathematical foundation
First, we need to obtain the coordinates of each vertex, and then use moveTo (M command) and lineTo (L command) to calculate the path of the pentacle.Figure 3
Looking at Figure 3, the analysis shows that: Math.cos(18 * math. PI / 180) * w + x, -math. sin(18 * math. PI / 180) * w + y). The complete code is as follows:
shape: (x, y, width, height) = > {
const path = [];
const w = Math.min(width, height) / 2;
for (let i = 0; i < 5; i++) {
path.push([
i === 0 ? 'M' : 'L',
(Math.cos(((18 + i * 72) * Math.PI) / 180) * w) + x,
(-Math.sin(((18 + i * 72) * Math.PI) / 180) * w) + y,
]);
path.push([
'L',
(Math.cos(((54 + i * 72) * Math.PI) / 180) * w) / 2 + x,
(-Math.sin(((54 + i * 72) * Math.PI) / 180) * w) / 2 + y,
]);
}
path.push(['Z']);
return path;
}
Copy the code
Well, that’s all for today’s introduction. Overall uncomplicated (βΉ, βΉ). Look forward to using your imagination to make more interesting water charts β€ β€ β€
More and more
Summary of some links in the article
- G2Plot Water wave chart guide
- G2Plot Water graph API documentation
- Path drawing instruction β G | Path (G is AntV under an easy to use, efficient and powerful 2 d visualization rendering engine)