g6/packages/site/docs/manual/introduction.en.md

198 lines
7.3 KiB
Markdown
Raw Normal View History

2023-02-02 10:31:36 +08:00
---
title: Introduction
order: 0
redirect_from:
- /en/docs/manual
---
![](https://user-images.githubusercontent.com/6113694/45008751-ea465300-b036-11e8-8e2a-166cbb338ce2.png)
2023-02-02 10:31:36 +08:00
[![travis-ci](https://img.shields.io/travis/antvis/g6/master.svg)](https://travis-ci.org/antvis/g6) [![codecov](https://codecov.io/gh/antvis/G6/branch/master/graph/badge.svg)](https://codecov.io/gh/antvis/G6) ![typescript](https://img.shields.io/badge/language-typescript-red.svg) ![MIT](https://img.shields.io/badge/license-MIT-000000.svg) [![npm package](https://img.shields.io/npm/v/@antv/g6.svg)](https://www.npmjs.com/package/@antv/g6) [![NPM downloads](http://img.shields.io/npm/dm/@antv/g6.svg)](https://npmjs.org/package/@antv/g6) [![Percentage of issues still open](http://isitmaintained.com/badge/open/antvis/g6.svg)](http://isitmaintained.com/project/antvis/g6 'Percentage of issues still open')
2023-02-02 10:31:36 +08:00
[中文 README](README.md)
2023-02-02 10:31:36 +08:00
## What is G6
[G6](https://github.com/antvis/g6) is a graph visualization engine, which provides a set of basic mechanisms, including rendering, layout, analysis, interaction, animation, and other auxiliary tools. G6 aims to simplify the relationships, and help people to obtain the insight of relational data.
2023-02-02 10:31:36 +08:00
<img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*zTjwQaXokeQAAAAAAAAAAABkARQnAQ' width=550 alt='' />
2023-02-02 10:31:36 +08:00
Developers are able to build graph visualization **analysis** applications or graph visualization **modeling** applications easily.
<img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*zau8QJcVpDQAAAAAAAAAAABkARQnAQ' height=200 alt='' /><img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*RIlETY_S6IoAAAAAAAAAAABkARQnAQ' height=200 alt='' />
2023-02-02 10:31:36 +08:00
<img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*cDzXR4jIWr8AAAAAAAAAAABkARQnAQ' height=150 alt='' /><img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*DifbSahOblAAAAAAAAAAAABkARQnAQ' height=150 alt='' /><img src='https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*HTasSJGC4koAAAAAAAAAAABkARQnAQ' height=150 alt='' />
2023-02-02 10:31:36 +08:00
> Powerful Animation and Interactions
2023-02-02 10:31:36 +08:00
<img src="https://user-images.githubusercontent.com/6113694/44995293-02858600-afd5-11e8-840c-349e4730d63d.gif" height=150 alt='' /><img src="https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*I9OdTbXJIi0AAAAAAAAAAABkARQnAQ" height=150 alt='' /><img src="https://user-images.githubusercontent.com/6113694/44995332-2ba61680-afd5-11e8-8cab-db0e9d08ceb7.gif" height=150 alt='' />
2023-02-02 10:31:36 +08:00
<img src="https://gw.alipayobjects.com/zos/rmsportal/HQxYguinFOMIXrGQOABY.gif" height=150 alt='' /><img src="https://gw.alipayobjects.com/zos/rmsportal/nAugyFgrbrUWPmDIDiQm.gif" height=150 alt='' /><img src="https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*xoufSYcjK2AAAAAAAAAAAABkARQnAQ" height=150 alt='' />
> Powerful Layouts
2023-02-02 10:31:36 +08:00
## 🎉 Features (5.0 Alpha)
2023-02-02 10:31:36 +08:00
- Extensionable: All the modules (seven types) are integrated as plugins;
- Style and animation standards, supports level of details (see the graph below);
- Beautiful Built-in Theme and cound be customized (see the graph below);
- Layouts with Great Performance: More than 10 layout algorithms, supports GPU and Rust parallel computing, and custom layouts;
2023-02-02 10:31:36 +08:00
- Steerable Interactions: More than 10 basic interaction behaviors ;
- Friendly User Experience: Complete documents for different levels of user requirements. TypeScript supported.
- Multiple renderers: Canvas, SVG, WebGL;
- 3D Graph:
The gif is not fully loaded, [Click Here to See the Original Image](https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*qPrmQrdV77gAAAAAAAAAAAAADmJ7AQ/original)
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*IUOnSbLisyoAAAAAAAAAAAAADmJ7AQ/original" width=600 height=334 alt='' />
> 3D Graph
The gif is not fully loaded, [Click Here to See the Original Image](https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*1BFvQ4r3P7UAAAAAAAAAAAAADmJ7AQ/original)
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*tPPGSokdSYsAAAAAAAAAAAAADmJ7AQ/original" width=600 height=367 alt='' />
> Animations and Level of Details
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*QjJoSbD7GTwAAAAAAAAAAAAADmJ7AQ/original" width=800 height=226 alt='' />
> Built-in Themes and Custom Themes
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*x7NTT5_baKYAAAAAAAAAAAAADmJ7AQ/original" width=400 height=218 alt='' />
> Seven Types of Plugins
2023-02-02 10:31:36 +08:00
- Abundant Built-in Items: Nodes and edges with free configurations;
- Convenient Components: Outstanding ability and performance;
- Tree Shaking to reduce the package's size.
2023-02-02 10:31:36 +08:00
G6 concentrates on the principle of 'good by default'. In addition, the custom mechanism of the item, interation behavior, and layout satisfies the customazation requirements.
2023-02-02 10:31:36 +08:00
> Abundant Built-in Items
## Installation (5.0 Beta)
2023-02-02 10:31:36 +08:00
```bash
2023-10-08 15:00:35 +08:00
$ npm install @antv/g6@5.0.0-beta.13
2023-02-02 10:31:36 +08:00
```
## Usage (5.0 Beta)
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*M-MTRaLiZN0AAAAAAAAAAAAADmJ7AQ/original" width=437 height=148 alt='' />
2023-09-01 15:41:05 +08:00
The configuration specification of the graph can be refered to: [Specification Doc](https://g6-next.antv.antgroup.com/en/apis/interfaces/graph/specification)
2023-09-01 15:41:05 +08:00
Graph API: [Graph API](https://g6-next.antv.antgroup.com/en/apis/interfaces/graph/i-graph)
2023-02-02 10:31:36 +08:00
A simple graph demo:
<img src="https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*M-MTRaLiZN0AAAAAAAAAAAAADmJ7AQ/original" width=437 height=138 alt='' />
2023-09-01 15:41:05 +08:00
[![Edit compassionate-lalande-5lxm7](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/g6-v5-beta-quick-start-m3yncv?from-embed=&file=/index.js)
```js
import G6 from '@antv/g6';
2023-02-02 10:31:36 +08:00
const data = {
nodes: [
{
id: 'node1',
data: {
x: 150,
y: 150,
label: 'Node 1',
},
2023-02-02 10:31:36 +08:00
},
{
id: 'node2',
data: {
x: 400,
y: 150,
label: 'Node 2',
},
2023-02-02 10:31:36 +08:00
},
],
edges: [
{
id: 'edge1',
2023-02-02 10:31:36 +08:00
source: 'node1',
target: 'node2',
data: {
label: 'Edge 1',
},
2023-02-02 10:31:36 +08:00
},
],
};
const graph = new G6.Graph({
container: 'container',
width: 500,
2023-02-02 10:31:36 +08:00
height: 500,
data,
node: (innerModel) => ({
...innerModel,
type: 'circle',
data: {
...innerModel.data,
labelShape: {
text: innerModel.label,
},
labelBackgroundShape: {},
iconShape: {
img: 'https://gw.alipayobjects.com/zos/basement_prod/012bcf4f-423b-4922-8c24-32a89f8c41ce.svg',
},
},
}),
edge: (innerModel) => ({
...innerModel,
type: 'line',
data: {
labelShape: {
text: innerModel.label,
},
labelBackgroundShape: {},
},
}),
2023-02-02 10:31:36 +08:00
});
```
## Development (5.0 Beta)
2023-02-02 10:31:36 +08:00
```bash
# enter packages/g6 from root of project
$ cd packages/g6
2023-02-02 10:31:36 +08:00
# install dependencies
$ npm install
2023-02-02 10:31:36 +08:00
# build
$ npm run build
2023-02-02 10:31:36 +08:00
# start the integration demos
$ npm run dev
2023-02-02 10:31:36 +08:00
# Test lint
$ npm run lint
2023-02-02 10:31:36 +08:00
# Fix lint
$ npm run fix
2023-02-02 10:31:36 +08:00
# Run all the integration tests
$ npm run test:integration
2023-02-02 10:31:36 +08:00
# Run one the integration test: modify the dir in test:integration_oneo be the one you want to test in package.json, then execute:
$ npm run test:integration_one
```
2023-02-02 10:31:36 +08:00
## How to Contribute
2023-02-02 10:31:36 +08:00
Please let us know what you are you going to help. Do check out [issues](https://github.com/antvis/g6/issues) for bug reports or suggestions first.
2023-02-02 10:31:36 +08:00
### Issue Hunt
2023-02-02 10:31:36 +08:00
Refer to the [Doc of Issue Hunt](https://github.com/antvis/G6/blob/v5-readme/ISSUEHUNT.en-US.md).
2023-02-02 10:31:36 +08:00
## License
[MIT license](./LICENSE).