
一飞开源,介绍创意、新奇、有趣、实用的开源应用、系统、软件、硬件及技术,一个探索、发现、分享、使用与互动交流的开源技术社区平台。致力于打造活力开源社区,共建开源新生态!
UCharts 是一个基于 TypeScript 实现的类型丰富、高性能、模块化、可扩展、支持主题定制的跨平台图表库。底层渲染逻辑全部采用 TypeScript 实现,上层通过适配层(adapters)适配到不同平台,包括鸿蒙(HarmonyOS)、微信小程序、uniapp 等,真正实现"一套核心,多端复用"。
使用Apache-2.0开源协议
以下为部分图表类型的鸿蒙平台实际渲染效果:




















(更多类型和样式可参考 docs 目录)
鸿蒙平台请查看适配目录的README.md文件,其他平台可通过Github下载
<!-- 原生H5 -->
<html lang="zh-CN">
<head>
....
</head>
<body>
<canvas id="chart" width="600px" height="400px"></canvas>
...
<!-- 引入构建后的uCharts库 -->
<script src="../adapters/dist/h5/ucharts-v3.min.js"></script>
<script language="JavaScript">
function createLineChart() {
const canvas = document.getElementById('chart');
const ctx = new UCharts.H5CanvasContext(canvas.getContext("2d"));
const chart = new UCharts({
type: "line",
context: ctx,
categories: ["2018","2019","2020","2021","2022","2023"],
series: [
{
name: "成交量A",
data: [35,8,25,37,4,20]
},
{
name: "成交量B",
data: [70,40,65,100,44,68]
},
{
name: "成交量C",
data: [100,80,95,150,112,132]
}
],
padding: [15,10,0,15],
xAxis: { disableGrid: true },
yAxis: { gridType: "dash", dashLength: 2 },
extra: {
line: {
type: "straight",
width: 2,
activeType: "hollow"
}
}
});
}
// 页面加载完成后默认显示折线图
window.onload = function() {
createLineChart();
};
</script>
</body>
</html>具体平台的 context 获取方式请参考各自适配层文档。
├── core/ # 图表核心能力(平台无关)
│ ├── types/ # 类型定义
│ ├── utils/ # 工具函数
│ ├── chart/ # 各类图表渲染器
│ ├── event/ # 事件系统
│ ├── animation/ # 动画系统
│ └── factory.ts # 图表工厂
├── adapters/ # 平台适配层
│ ├── harmony/ # 鸿蒙适配
│ ├── h5/ # 原生H5适配
│ ├── wechat/ # 微信小程序适配
│ └── uniapp/ # uniapp适配
├── interface/ # 对外统一接口
│ ├── CanvasContext.ts # 跨平台统一 canvas context 接口定义
├── examples/ # 示例代码
├── docs/ # 文档
└── README.md访问一飞开源:https://code.exmay.com/
#一飞开源 #开源项目 #跨平台可视化图表库