依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 10|回复: 0

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库

[复制链接] 主动推送

2万

主题

2万

帖子

2万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
23151
发表于 昨天 21:45 | 显示全部楼层 |阅读模式
基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库
一个基于 TypeScript 实现的高性能、模块化、可扩展的跨平台图表库。底层渲染逻辑全部采用 TypeScript 实现,上层通过适配层(adapters)适配到不同平台,包括鸿蒙(HarmonyOS)、微信小程序、uniapp 等,真正实现"一套核心,多端复用"。
特性
  • 跨平台:支持鸿蒙、微信小程序、uniapp 等主流平台
  • 模块化设计:底层渲染与平台适配解耦,易于扩展和维护
  • TypeScript 全面支持:类型安全,开发体验优秀
  • 丰富图表类型:柱状图、条状图、折线图、区域图、山峰图等
  • 高性能渲染:底层优化,动画流畅
  • 易于扩展:支持自定义图表类型和平台适配
  • 自定义样式:支持主题定制
支持的图表类型
  • 柱状图 (column)
  • 条状图 (bar)
  • 折线图 (line)
  • 区域图 (area)
  • 山峰图 (mount)
  • 散点图 (scatter)
  • 气泡图 (bubble)
  • 混合图 (mix)
  • 饼状图 (pie)
  • 环形图 (ring)
  • 玫瑰图 (rose)
  • 雷达图 (radar)
  • 词云图 (word)
  • 进度条 (arcbar)
  • 仪表盘 (gauge)
  • 漏斗图 (funnel)
  • K线图 (candle)
  • 地图 (map)
  • 更多类型持续开发中...
快速开始
  1. <!-- 原生H5 -->
  2. <html lang="zh-CN">
  3. <head>
  4.   ....
  5. </head>
  6. <body>
  7.   <canvas id="chart" width="600px" height="400px"></canvas>
  8.   ...
  9.   <!-- 引入构建后的uCharts库 -->
  10.   <script src="../adapters/dist/h5/ucharts-v3.min.js"></script>
  11.   <script language="JavaScript">
  12.     function createLineChart() {
  13.       const canvas = document.getElementById('chart');
  14.       const ctx = new UCharts.H5CanvasContext(canvas.getContext("2d"));
  15.       const chart = new UCharts({
  16.           type: "line",
  17.           context: ctx,
  18.           categories: ["2018","2019","2020","2021","2022","2023"],
  19.           series: [
  20.               {
  21.                   name: "成交量A",
  22.                   data: [35,8,25,37,4,20]
  23.               },
  24.               {
  25.                   name: "成交量B",
  26.                   data: [70,40,65,100,44,68]
  27.               },
  28.               {
  29.                   name: "成交量C",
  30.                   data: [100,80,95,150,112,132]
  31.               }
  32.           ],
  33.           padding: [15,10,0,15],
  34.           xAxis: { disableGrid: true },
  35.           yAxis: { gridType: "dash", dashLength: 2 },
  36.           extra: {
  37.             line: {
  38.               type: "straight",
  39.               width: 2,
  40.               activeType: "hollow"
  41.             }
  42.           }
  43.       });
  44.     }
  45.     // 页面加载完成后默认显示折线图
  46.     window.onload = function() {
  47.       createLineChart();
  48.     };
  49.   </script>
  50. </body>
  51. </html>
复制代码
跨平台适配层说明
  • 每个平台在 adapters/ 下有独立目录,负责将平台 API 适配为统一的底层渲染接口。
  • 适配层需实现统一的适配接口,并暴露标准的 context、事件等能力,可参考h5实现。
  • 新增平台时,仅需在 adapters/ 下新增目录并实现适配接口,无需修改 core 层代码。
  • CanvasContext 统一接口:
    • ChartOptions.context 字段要求传入的 canvas context 必须兼容 interface/CanvasContext 类型。
    • 各平台适配层需将平台原生 canvas context 封装/适配为该接口,保证 core 层渲染逻辑的统一调用。
    • 具体接口定义见 interface/CanvasContext.ts,如需适配新平台,请实现该接口。

开发指南新增图表类型
  • 在 core/chart/ 下创建新的渲染器类,需继承 BaseRenderer,实现通用渲染逻辑。
  • 在 core/factory.ts 中注册新图表类型。
  • 在 core/types/extra.ts 和 core/types/series.ts 中添加扩展配置类型。
  • 更新文档和示例。
新增平台适配层
  • 在 adapters/ 下新建平台目录(如 myplatform/)。
  • 实现统一适配接口,封装平台 canvas、事件等能力。
  • 在平台入口文件(如 index.ts)中暴露适配能力。
  • 如有需要暴露给用户层的适配层类型,在 interface/ 下新建对应平台目录并导出。
  • 更新文档说明。
配置选项
详见 core/types/ 目录下类型定义,支持丰富的通用与扩展配置。
性能优化
  • 底层渲染优化:TypeScript 实现,便于多端编译优化
  • 动画与事件分离:动画、事件系统独立,提升流畅度
  • 按需加载:仅加载所需图表类型和适配层
兼容性
  • 鸿蒙系统:支持 HarmonyOS 5.0 及以上
  • 浏览器:支持浏览器等H5运行环境
  • 微信小程序:支持主流小程序平台(适配中...)
  • uniapp:支持主流 uniapp 运行环境(适配中...)

图表示例
以下为部分图表类型的鸿蒙平台实际渲染效果:

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...

基于 TypeScript 实现的类型丰富 高性能 模块化 可扩展、支持主题定制的跨平台图表库 ...



链接: https://pan.baidu.com/s/1dy0oFgAzp27REkKdsF8axg
提取码下载:
文件名称:提取码下载.txt 
下载次数:0  文件大小:16 Bytes  售价:29金钱 [记录]
下载权限: 不限 [购买VIP]   [充值]   [在线充值]   【VIP会员6折;永久VIP4折】
安全检测,请放心下载





相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员6折;永久VIP4折
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2025-11-9 14:27

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表