Files
echarts5-java/README.md

148 lines
5.9 KiB
Markdown
Raw Normal View History

2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 📙 简介
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
ECharts Java 是一款基于 [Apache ECharts](https://echarts.apache.org/en/index.html) 的,简易但全面的数据可视化库。(现支持 Apache ECharts 5.x 版本)。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
论简易性ECharts Java 重新设计了一系列和绘图有关的接口,使得绘图过程更加符合直觉和常理。同时,由于 Apache ECharts 的接口过于复杂和繁琐,我们在 ECharts Java 的图表 API 中简化了部分原本的接口设计。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
论全面ECharts Java 保留了 Apache ECharts “一切皆 Option”的设计理念。因此除了重新设计的图表 API 以外,我们还保留了自定义 Option 对象的方法。用户可以从零开始,按照 ECharts 的 Option 文档,自定义任何 ECharts 支持的 Option。除此以外我们还使用链式方法调用等方式使得 Java 开发者在构建 Option 的过程中更加方便。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 🌠 特性
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
- 简单、整洁、高度组织化的 API 接口,支持链式调用
- 完整保存 Apache ECharts 的功能
- 快速集成至当前流行的 Web 框架
- 灵活的导出格式,支持 HTMLPNG 和 JSON
- 完整、详细的文档和示例库
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 🔬 安装
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
Maven 项目:
2023-06-25 13:33:19 +08:00
```xml
2023-06-25 13:37:46 +08:00
// pom.xml
2023-06-25 13:33:19 +08:00
<dependency>
2023-06-25 13:37:46 +08:00
<groupId>com.njcn</groupId>
<artifactId>echarts5-java</artifactId>
<version>0.0.1</version>
2023-06-25 13:33:19 +08:00
</dependency>
```
2023-06-25 13:37:46 +08:00
如果你使用的是其他项目,请参阅[这里](https://search.maven.org/artifact/org.icepear.echarts/echarts-java/1.0.7/jar)。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 🔭 使用
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
### 生成 HTML 和下载图片
2023-06-25 13:33:19 +08:00
```java
public static void main(String[] args) {
2023-06-25 13:37:46 +08:00
// All methods in EChart Java supports method chaining
2023-06-25 13:33:19 +08:00
Bar bar = new Bar()
.setLegend()
.setTooltip("item")
.addXAxis(new String[] { "Matcha Latte", "Milk Tea", "Cheese Cocoa", "Walnut Brownie" })
.addYAxis()
.addSeries("2015", new Number[] { 43.3, 83.1, 86.4, 72.4 })
.addSeries("2016", new Number[] { 85.8, 73.4, 65.2, 53.9 })
.addSeries("2017", new Number[] { 93.7, 55.1, 82.5, 39.1 });
Engine engine = new Engine();
// The render method will generate our EChart into a HTML file saved locally in the current directory.
// The name of the HTML can also be set by the first parameter of the function.
engine.render("index.html", bar);
}
```
2023-06-25 13:37:46 +08:00
2023-06-25 13:33:19 +08:00
<img src="assets/imgs/multibar-render.gif" alt="multi-bar-render" style="width:85%;" />
2023-06-25 13:37:46 +08:00
### 生成 Option 对象和对应的 JSON 结构
2023-06-25 13:33:19 +08:00
```java
public static void main(String[] args) {
Line lineChart = new Line()
.addXAxis(new CategoryAxis()
.setData(new String[] { "Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun" })
.setBoundaryGap(false))
.addYAxis()
.addSeries(new LineSeries()
.setData(new Number[] { 820, 932, 901, 934, 1290, 1330, 1320 })
.setAreaStyle(new LineAreaStyle()));
Engine engine = new Engine();
// It is recommended that you can get the serialized version of Option in the representation of JSON, which can be used directly in the template or in the RESTful APIs.
String jsonStr = engine.renderJsonOption(lineChart);
}
```
2023-06-25 13:37:46 +08:00
生成的 JSON 对象如下:
2023-06-25 13:33:19 +08:00
```json
{
"xAxis": [
{
"type": "category",
"data": ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"],
"boundaryGap": false
}
],
"yAxis": [{ "type": "value" }],
"series": [
{
"type": "line",
"data": [820, 932, 901, 934, 1290, 1330, 1320],
"areaStyle": {}
}
]
}
```
2023-06-25 13:37:46 +08:00
### 集成至 Spring Boot 应用
2023-06-25 13:33:19 +08:00
<img src="assets/imgs/line-renderHtml.gif" alt="spring-boot-integration" style="width:75%;" />
2023-06-25 13:37:46 +08:00
详细内容请参阅,[文档](https://echarts.icepear.org/#/zh-cn/) [代码仓库](https://github.com/incandescentxxc/ECharts-Java-Examples)。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 🎇 示例
2023-06-25 13:33:19 +08:00
<p float="center">
<img src="assets/imgs/stacked-line.jpg" width="32%" />
<img src="assets/imgs/stacked-area.jpg" width="32%" />
<img src="assets/imgs/multiple-series-bar.jpg" width="32%" />
<img src="assets/imgs/horizontal-stacked-bar.jpg" width="32%" />
<img src="assets/imgs/basic-scatter.jpg" width="32%" />
<!-- <img src="assets/imgs/basic-boxplot.jpg" width="32%" /> -->
<img src="assets/imgs/basic-candlestick.jpg" width="32%" />
<img src="assets/imgs/basic-heatmap.jpg" width="32%" />
<img src="assets/imgs/basic-polar-line.jpg" width="32%" />
<img src="assets/imgs/tangential-polar-bar.jpg" width="32%" />
<img src="assets/imgs/basic-polar-scatter.jpg" width="32%" />
<img src="assets/imgs/basic-radar.jpg" width="32%" />
<img src="assets/imgs/basic-parallel.jpg" width="32%" />
<img src="assets/imgs/basic-theme-river.jpg" width="32%" />
<img src="assets/imgs/basic-rose.jpg" width="32%" />
<img src="assets/imgs/nested-pie.jpg" width="32%" />
<img src="assets/imgs/circular-layout-graph.jpg" width="32%" />
<img src="assets/imgs/hide-overlapped-label-graph.jpg" width="32%" />
<img src="assets/imgs/basic-sankey.jpg" width="32%" />
<img src="assets/imgs/basic-funnel.jpg" width="32%" />
<img src="assets/imgs/basic-sunburst.jpg" width="32%" />
<img src="assets/imgs/animation-gauge.jpg" width="32%" />
</p>
2023-06-25 13:37:46 +08:00
## 💡 作者
2023-06-25 13:33:19 +08:00
- [@IcePear-Jzx](https://github.com/IcePear-Jzx)
- [@incandescentxxc](https://github.com/incandescentxxc)
2023-06-25 13:37:46 +08:00
欢迎大家积极提 issuefork和其他贡献
## 💌 鸣谢
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
- 本项目灵感来源于[卡耐基梅隆大学](https://www.cmu.edu/)的课程,[Principles of Software Construction Objects, Design, and Concurrency](https://cmu-17-214.github.io/f2021/)。我们在此真诚地感谢 [Christian](https://www.cs.cmu.edu/~ckaestne/) 和 [Vincent](https://vhellendoorn.github.io/) 在 2021 秋天教授的这门课。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
- 本项目同样也受到 [pyecharts](https://github.com/pyecharts/pyecharts) 和 [go-echarts](https://github.com/go-echarts/go-echarts) 的启发。
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
## 🎈 开源协议
2023-06-25 13:33:19 +08:00
2023-06-25 13:37:46 +08:00
本项目遵循 [Apache License 2.0](LICENSE) 开源协议。