# 图表模板快速参考
积木报表内置 30+ 图表模板,文件位于 `static/jmreport/desreport_/chartjson/`。
可通过 `GET /jmreport/addChart?chartType=bar.simple` 获取模板配置。
生成图表时,从模板中取 ECharts 配置,修改 `title.text`,清空 `data`(由数据集驱动),然后放入 `chartList[].config`。
## 图表分类速查
### 柱状图 (Bar)
| chartType | 说明 | 数据集要求 |
|-----------|------|-----------|
| `bar.simple` | 单系列柱状图 | `name, value` |
| `bar.multi` | 多系列柱状图 | `name, value, type` |
| `bar.stack` | 堆叠柱状图 | `name, value, type` |
| `bar.horizontal` | 横向柱状图 | `name, value` |
| `bar.multi.horizontal` | 横向多系列 | `name, value, type` |
| `bar.stack.horizontal` | 横向堆叠 | `name, value, type` |
| `bar.negative` | 正负柱状图 | `name, value, type` |
| `bar.background` | 带背景柱状图 | `name, value` |
### 折线图 (Line)
| chartType | 说明 | 数据集要求 |
|-----------|------|-----------|
| `line.simple` | 单系列折线图 | `name, value` |
| `line.multi` | 多系列折线图 | `name, value, type` |
| `line.smooth` | 平滑曲线图 | `name, value` |
| `line.area` | 面积图 | `name, value, type` |
| `line.step` | 阶梯折线图 | `name, value` |
### 饼图 (Pie)
| chartType | 说明 | 数据集要求 |
|-----------|------|-----------|
| `pie.simple` | 饼图 | `name, value` |
| `pie.doughnut` | 环形图 | `name, value` |
| `pie.rose` | 玫瑰图(南丁格尔) | `name, value` |
### 混合图
| chartType | 说明 | 数据集要求 |
|-----------|------|-----------|
| `mixed.linebar` | 柱状+折线混合 | `name, value, type` |
### 其他图表
| chartType | 说明 | 数据集要求 |
|-----------|------|-----------|
| `gauge.simple` | 仪表盘 | `name, value` |
| `gauge.simple180` | 半圆仪表盘 | `name, value` |
| `radar.basic` | 雷达图 | 特殊(indicator) |
| `radar.custom` | 自定义雷达图 | 特殊 |
| `funnel.simple` | 漏斗图 | `name, value` |
| `funnel.pyramid` | 金字塔图 | `name, value` |
| `scatter.simple` | 散点图 | 特殊 |
| `scatter.bubble` | 气泡图 | 特殊 |
| `map.simple` | 地图 | 特殊 |
| `map.scatter` | 地图散点 | 特殊 |
| `graph.simple` | 关系图 | 特殊(需两个数据集) |
| `pictorial.spirits` | 象形柱图 | `name, value` |
## 常用图表 ECharts 配置模板
### bar.simple — 单系列柱状图
```python
{
"title": {"show": True, "text": "标题", "left": "left", "top": "5",
"padding": [5,20,5,20],
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
"tooltip": {"show": True, "textStyle": {"color": "#fff", "fontSize": 18}},
"xAxis": {"show": True, "name": "", "data": [],
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
"axisLine": {"lineStyle": {"color": "#333"}}},
"yAxis": {"show": True, "name": "",
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
"axisLine": {"lineStyle": {"color": "#333"}}},
"series": [{"name": "", "type": "bar", "data": [],
"barWidth": 50, "barMinHeight": 2,
"itemStyle": {"barBorderRadius": 0, "color": "#c43632"}}]
}
```
### bar.multi — 多系列柱状图
```python
{
"title": {"show": True, "text": "标题", "left": "left",
"padding": [5,20,5,20],
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"legend": {"show": True, "data": [], "top": "top", "left": "center",
"orient": "horizontal", "padding": [25,20,25,10],
"textStyle": {"color": "#333", "fontSize": 12}},
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
"tooltip": {"show": True, "trigger": "axis",
"axisPointer": {"type": "shadow"},
"textStyle": {"color": "#fff", "fontSize": 18}},
"xAxis": {"show": True, "type": "category", "data": [],
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
"axisLine": {"lineStyle": {"color": "#333"}}},
"yAxis": {"show": True,
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
"axisLine": {"lineStyle": {"color": "#333"}}},
"series": [
{"name": "系列1", "type": "bar", "data": [], "barWidth": 0, "barMinHeight": 2,
"label": {"show": True, "position": "top", "textStyle": {"color": "black", "fontSize": 12}},
"itemStyle": {"barBorderRadius": 0, "color": ""}},
{"name": "系列2", "type": "bar", "data": [], "barWidth": 0, "barMinHeight": 2,
"label": {"show": True, "position": "top", "textStyle": {"color": "black", "fontSize": 12}},
"itemStyle": {"barBorderRadius": 0, "color": ""}}
]
}
```
### line.simple — 单系列折线图
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
"xAxis": {"show": True, "data": []},
"yAxis": {"show": True, "name": ""},
"series": [{"name": "", "type": "line", "data": [],
"smooth": False, "showSymbol": True, "symbolSize": 5,
"lineStyle": {"width": 2, "color": "#c43632"}}]
}
```
### pie.simple — 饼图
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"tooltip": {"show": True, "formatter": "{a}
{b} : {c}"},
"legend": {"show": True, "data": [], "orient": "horizontal",
"textStyle": {"color": "#333", "fontSize": 12}},
"series": [{"name": "数据", "type": "pie",
"radius": "55%", "minAngle": 0,
"center": [320, 180],
"label": {"show": True, "position": "outside"},
"data": []}]
}
```
### pie.doughnut — 环形图
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"tooltip": {"show": True, "formatter": "{a}
{b} : {c}"},
"legend": {"show": True, "data": [], "orient": "horizontal",
"textStyle": {"color": "#333", "fontSize": 12}},
"series": [{"name": "数据", "type": "pie",
"isRadius": True,
"radius": ["45%", "55%"], # 内外半径 → 环形
"minAngle": 0, "roseType": "", "isRose": False,
"center": [320, 180],
"label": {"show": True, "position": "outside"},
"data": []}]
}
```
### mixed.linebar — 柱线混合图
```python
{
"chartType": "linebar",
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"legend": {"data": []},
"xAxis": {"type": "category", "data": []},
"yAxis": [
{"type": "value", "name": "左轴"},
{"type": "value", "name": "右轴"}
],
"series": [
{"name": "柱状", "type": "bar", "data": []},
{"name": "折线", "type": "line", "data": []},
{"name": "右轴数据", "type": "bar", "yAxisIndex": 1, "data": []}
]
}
```
### gauge.simple — 仪表盘
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"tooltip": {"show": True, "formatter": "{b} : {c}"},
"series": [{"name": "业务指标", "type": "gauge",
"radius": "75%", "center": [330, 200],
"itemStyle": {"color": "#63869E"},
"pointer": {"show": True},
"detail": {"formatter": "{value}%",
"textStyle": {"color": "rgba(0,0,0,1)", "fontSize": 25}},
"axisLine": {"lineStyle": {
"color": [[0.2, "#91c7ae"], [0.8, "#63869E"], [1, "#C23531"]],
"width": 25}},
"data": [{"value": 50, "name": "完成率"}]}]
}
```
### funnel.simple — 漏斗图
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"legend": {"show": True, "data": []},
"tooltip": {"show": True, "trigger": "item", "formatter": "{b} : {c}"},
"series": [{"name": "漏斗图", "type": "funnel",
"left": "10%", "top": 60, "bottom": 60, "width": "80%",
"sort": "descending", "gap": 2, "orient": "vertical",
"label": {"show": True, "position": "inside",
"textStyle": {"fontSize": 16}},
"itemStyle": {"borderColor": "#fff", "borderWidth": 1},
"data": []}]
}
```
### radar.basic — 雷达图
```python
{
"title": {"show": True, "text": "标题",
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
"legend": {"show": True, "data": []},
"tooltip": {"show": True},
"radar": [{"shape": "polygon", "center": [320, 200],
"name": {"formatter": "【{value}】",
"textStyle": {"fontSize": 14, "color": "#72ACD1"}},
"indicator": [
{"name": "维度1", "max": 100},
{"name": "维度2", "max": 100},
{"name": "维度3", "max": 100}
]}],
"series": [{"name": "", "type": "radar",
"data": [{"value": [80, 60, 70], "name": "系列1"}]}]
}
```
## 数据集 SQL 映射规则
图表数据集使用固定的 `name`/`value`/`type` 字段映射:
```sql
-- 单系列(bar.simple, line.simple, pie.simple 等)
SELECT product_name AS name, sales_amount AS value, '' AS type
FROM sales_table
-- 多系列(bar.multi, line.multi, mixed.linebar 等)
SELECT month AS name, amount AS value, category AS type
FROM sales_table
-- 仪表盘(gauge)
SELECT '完成率' AS name, ROUND(done*100/total) AS value, '' AS type
FROM task_summary
-- 漏斗图(funnel)
SELECT stage AS name, count AS value, '' AS type
FROM funnel_data ORDER BY count DESC
```
## 快速生成图表的 Python 代码
```python
def create_chart(chart_type, title, db_code, db_id, row_start, col_start,
rows=10, cols=5, width="650", height="350"):
"""快速生成图表配置"""
layer_id = "chart_" + gen_id()
# 根据类型选择基础配置
base_configs = {
"bar.simple": {
"title": {"text": title, "left": "center", "top": "10"},
"tooltip": {"trigger": "axis", "axisPointer": {"type": "shadow"}},
"grid": {"left": "3%", "right": "4%", "bottom": "3%", "containLabel": True},
"xAxis": [{"type": "category", "data": []}],
"yAxis": [{"type": "value"}],
"series": [{"type": "bar", "data": [], "barWidth": "40%"}]
},
"pie.simple": {
"title": {"text": title, "left": "center"},
"tooltip": {"trigger": "item", "formatter": "{b}: {c} ({d}%)"},
"legend": {"bottom": "5%", "left": "center"},
"series": [{"type": "pie", "radius": "55%", "center": ["50%", "50%"], "data": []}]
},
"line.simple": {
"title": {"text": title, "left": "center"},
"tooltip": {"trigger": "axis"},
"grid": {"left": "3%", "right": "4%", "bottom": "3%", "containLabel": True},
"xAxis": [{"type": "category", "data": []}],
"yAxis": [{"type": "value"}],
"series": [{"type": "line", "smooth": True, "data": []}]
},
"gauge.simple": {
"title": {"text": title, "left": "center"},
"series": [{"type": "gauge", "radius": "75%",
"detail": {"formatter": "{value}%"},
"data": [{"value": 0, "name": ""}]}]
}
}
config = base_configs.get(chart_type, base_configs["bar.simple"])
# virtual cells
row_end = row_start + rows - 1
col_end = col_start + cols - 1
virtual_cells = [[r,c] for r in range(row_start, row_end+1) for c in range(col_start, col_end+1)]
# rows 占位
chart_rows = {}
for r in range(row_start, row_end + 1):
cells = {}
for c in range(col_start, col_end + 1):
cells[str(c)] = {"text": " ", "virtual": layer_id}
chart_rows[str(r)] = {"cells": cells}
chart_item = {
"row": row_start, "col": col_start, "colspan": 0, "rowspan": 0,
"width": width, "height": height,
"config": json.dumps(config, ensure_ascii=False),
"url": "",
"extData": {
"chartType": chart_type, "dataType": "sql",
"dataId": str(db_id), "dbCode": db_code,
"axisX": "name", "axisY": "value", "series": "type",
"xText": "", "yText": "", "apiStatus": "1"
},
"layer_id": layer_id,
"offsetX": 0, "offsetY": 0,
"backgroud": {"enabled": False, "color": "#fff", "image": ""},
"virtualCellRange": virtual_cells
}
return chart_item, chart_rows
```