diff --git a/README.md b/README.md index 24e956315c4ae22cc4e1febdf13c815415769fbb..263e8c10a8a42712f8dfb78621c730b115ae3cf9 100644 --- a/README.md +++ b/README.md @@ -1,284 +1,108 @@ -- 💘 开源不易,去 [Github给个Star](https://github.com/oi-contrib/VISLite) 吧! - -

- - downloads - - - npm - - - cdn - - - issue - - - GitHub repo stars - - - forks - - - Gitee repo stars - - - forks - -

+VISLite +=============== +VISLite(简称 Vis)是一个轻量级的可视化库,适用于支付宝小程序、微信小程序、uni-app等跨平台开发场景,提供Canvas、SVG、WebGL等多种渲染模式的支持,帮助开发者更高效地进行可视化开发。 -NPM +简介 +----------------- +VISLite 提供了丰富的可视化组件和工具类,包括Canvas、SVG、WebGL渲染模式,支持常见的可视化图表绘制,例如:柱状图、饼图、树图、3D环图、径向树图、桑基图等。此外,它还支持基础的动画、坐标变换、插值计算、地理投影等功能,方便开发者快速构建可视化项目。 -# VISLite - -`VISLite`是一个使用`TypeScript`开发的可视化库。官网地址:[https://oi-contrib.github.io/VISLite](https://oi-contrib.github.io/VISLite) - -主要提供了跨端的画布和计算,开发人员只需要按照文档的描述就可以非常简单的完成包括Web、uni-app、微信小程序、支付宝小程序等平台的可视化开发,除了初始化时可能存在一些差异外,主要的业务代码部分在不同端完全一致。 - -## 简介 - -这是一个轻量级的数据可视化资源库,目标是:帮助你更快速、简单、高效的开发出任意的可视化业务产品。 - -> 本项目已在[开源中国](https://www.oschina.net/p/vislite)中开源,欢迎关注和留言。 - -## 如何使用? - -首先,需要进行安装: - -```js -npm install --save vislite -``` - -然后,准备好画布: - -```html -
+如何使用? +----------------- +1. 安装:通过npm安装VISLite +```bash +npm install vislite ``` -现在,就可以获取画笔绘制自己需要的内容了。比如获取canvas画笔,绘制一个红色的圆: - -```js +2. 引入:根据需要引入相关模块 +```javascript import { Canvas } from 'vislite'; - -var painter = new Canvas(document.getElementById('root')); - -painter.config({ - fillStyle: "red" -}).fillCircle(200, 150, 100); +import { SVG } from 'vislite'; +import { TreeLayout } from 'vislite'; +import { PieLayout } from 'vislite'; +import { BarLayout } from 'vislite'; +import { getWebGLContext } from 'vislite'; +import { Shader } from 'vislite'; +import { Buffer } from 'vislite'; +import { Texture } from 'vislite'; ``` -更复杂的图表,我们也提供了丰富的辅助API。比如使用树布局,可以非常快速的绘制一个树图: - - - -具体代码如下: - -```js -import { Canvas, TreeLayout } from 'vislite'; - -var painter = new Canvas(document.getElementById('root')); -var treeLayout = new TreeLayout(); - -treeLayout.setOption({ - type: "rect", - direction: "TB", - x: 250, - y: 20, - width: 500, - height: 260 -}); - -var data = { - "name": "前端", - "children": [{ - "name": "基础", - "children": [{ - "name": "HTML" - }, { - "name": "CSS" - }, { - "name": "JavaScript" - }, { - "name": "DOM" - }] - }, { - "name": "框架" - }, { - "name": "小技术" - }] -}; - -var tree = treeLayout.use(data); - -// 绘制连线 -painter.config({ - strokeStyle: 'red' -}); -for (var key in tree.node) { - var pid = tree.node[key].pid; - - // 如果父结点存在,和父结点连起来 - if (pid) { - var dist = (tree.node[key].top - tree.node[pid].top) * 0.5; - - painter - .beginPath() - .moveTo(tree.node[key].left, tree.node[key].top) - .bezierCurveTo( - tree.node[key].left, tree.node[key].top - dist, - tree.node[pid].left, tree.node[pid].top + dist, - tree.node[pid].left, tree.node[pid].top - ).stroke(); - } -} - -// 绘制节点和文字 -painter.config({ - strokeStyle: 'red', - fontSize: 12 -}); -for (var key in tree.node) { - painter.config({ - fillStyle: "white" - }).fullCircle(tree.node[key].left, tree.node[key].top, 10); - - painter.config({ - fillStyle: "black" - }).fillText(key, tree.node[key].left + 15, tree.node[key].top); -} +3. 初始化:在HTML文件中创建一个画布容器 +```html +
``` -关于树布局更具体的使用细节,你可以访问:[ 《教程 / 树布局》 ](https://oi-contrib.github.io/VISLite/#/course/tree-layout)一节。 - -## 部分功能 +4. 创建实例并绘制:使用Canvas或SVG渲染图表 +```javascript +const el = document.getElementById('mycanvas'); +let painter = new Canvas(el, { width: 400, height: 400 }); +painter.fillText('Hello Vis', 10, 10); +``` +部分功能 +----------------- ### 常用的算法 - -我们通过提供可视化常用的算法来帮助你绘制复杂图表。比如下面的树图,通过简单的配置就可以把任意格式的数据变成任意绘制的带坐标的数据: - - - -> 上述例子的运行地址:[从左到右树状图](https://oi-contrib.github.io/VISLite/#/example/canvas/tree-layout-lr)。 - -除了[树布局](https://oi-contrib.github.io/VISLite/#/api/treeLayout)外,我们还提供了:[刻度尺算法](https://oi-contrib.github.io/VISLite/#/api/ruler)来帮助你计算刻度应该如何确定、[等角斜方位投影](https://oi-contrib.github.io/VISLite/#/api/eoap)和[墨卡托投影](https://oi-contrib.github.io/VISLite/#/api/mercator)来绘制地图、[插值函数](https://oi-contrib.github.io/VISLite/#/api/cardinal)来完成折线变光滑的曲线、[变换矩阵](https://oi-contrib.github.io/VISLite/#/api/matrix4)提供各种坐标变换等。 +VISLite 包含多种常用的算法和工具类,如: +- 地理投影:Mercator、Eoap +- 插值计算:Cardinal、Hermite +- 坐标变换:Matrix4 +- 数据布局:TreeLayout、PieLayout、BarLayout ### 画笔加强 - -我们对画笔进行了加强,使得其更简单好用。比如canvas,抽象出区域的概念,使得无论你绘制的图形多么的不规则,都可以很轻松的实现交互功能: - - - -> 上述例子的运行地址:[中国地图](https://oi-contrib.github.io/VISLite/#/example/canvas/china)。 - -画笔除了像上面那样为了方便交互而补充区域的设计外,还对原来的API进行了一次抽象,使得API更友好简单`(比如WebGL,即使不会3D的人也可以轻松使用,而SVG的使用,你无需去记忆那些晦涩难懂的属性)`,同时,我们还抹平了不同版本浏览器等之间的差异。 +VISLite 提供了多种画笔加强功能,如: +- 渐变支持:Canvas、SVG +- 文本绘制:fillText, strokeText, fullText +- 路径绘制:beginPath, closePath, moveTo, lineTo +- 图像绘制:drawImage ### 支持跨端开发 - -除了Web端外,我们还针对uni-app、微信小程序、支付宝小程序等端进行了支持,并且不同端API保持一致,大大提高了代码的复用性: - - - -> 上述例子的运行地址:[金额波浪球](https://oi-contrib.github.io/VISLite/#/example/svg/money-schedule)。 - -基于实际需要,我们目前对 `Canvas` 提供了跨端支持,除 `Web端` 外,还支持 `原生微信小程序` 、 `原生支付宝小程序` 和 `uni-app端` (编译成H5、微信小程序、支付宝小程序等) ,如果后续有必要,我们会对Canvas支持的端或SVG、WebGL等画笔进行更多端扩展。 - -## 特点 - -- 灵活的引入方式:包括npm安装后按照`ES Module`或`CommonJS`规范引入或直接使用script标签的`CDN`方式。 -- 按需引入或全局引入:支持源码TS引入、按需JS引入或者全量引入等多种方式。 -- 简单与复杂共存:一方面我们提供了可视化需要的基础功能,你可以按照自己的需要组合使用;另一方面,为了加速开发,我们针对常见的可视化业务场景进行了封装,可以帮助你快速完成,你可以根据实际情况进行选择。 -- 向下兼容:我们向你保证,同一个大版本下始终向下兼容`(alpha和beta版本为测试版本,不包括)`,因此,无论何时,在同一个大版本号下,最新版本总是最好的选择。 - -> 版本说明:alpha为开发阶段、beta为发布前测试、rc为候选版本、next为未来版本、无后缀的为正式版本。 - -## 需求墙 - -我们的目标是不断完善丰富可视化功能,非常希望获得你宝贵的建议和批评,无论任何想法,都可以给我们[留言](https://github.com/oi-contrib/VISLite/issues)告诉我们。 - -你所提的任何建议我们都会在最长一周内进行反馈说明。 - -## 更新日志 - -详见[正式版更新日志](./CHANGELOG),我们会在每次发布完正式版本后更新其内容。 - -## 下一步 - -我们会在这里列出接下来的工作重心: - -- 为加速开发,提供常用坐标系和布局 -- 文档优化(提高可读性、丰富用例、补充教程) - -给我们[留言](https://github.com/oi-contrib/VISLite/issues)告诉我们你希望快速扩展的功能,我们会优先你的建议考虑哦~ - -## 参与贡献 - -你可以选择下列一项或多项进行参与: - -- 代码维护:由于新功能或一些BUG的出现,对代码进行维护和升级。 -- 文档编辑:主要是接口文档和教程需要编辑,这很重要。 -- 用例开发和测试:在项目的test文件夹下有一些测试,而在docs文档中存在一些例子需要补充。 -- 参与讨论:主要是讨论未来如何发展,改造的方向等。 - -如果有意向加入我们,你可以通过提 [issue](https://github.com/oi-contrib/VISLite/issues) 和我们取到联系,请简单说明一下情况,我们会尽快回复。 - -你可以查看[VISLite 贡献指南](./.github/CONTRIBUTING.md)文件了解更多细节,查看[AUTHORS.txt](./AUTHORS.txt)了解所有的贡献者。 - -## 例子项目 - -### 水分子式 H2O - - - - - -### 手式解锁 - - - - - -### 3D环图 - - - - - -### 径向树状图 - - - - - -### 桑基图 - - - - - -### 可缩放折线图 - - - - - -### 从上到下树状图 - - - - - -### 可视化大屏 - - - - - -> 更多内容,你可以直接访问: [https://oi-contrib.github.io/h5box/dataGUI/index.html](https://oi-contrib.github.io/h5box/dataGUI/index.html) - -## 版权 - -MIT License - -Copyright (c) [zxl20070701](https://zxl20070701.github.io/notebook/home.html) 走一步,再走一步 +VISLite 可以运行在多个端,包括: +- 支付宝小程序 +- 微信小程序 +- uni-app +- H5 + +特点 +----------------- +- 轻量级:VISLite 的设计目标是提供轻量级的可视化解决方案。 +- 跨平台:支持多端开发,包括H5、小程序、uni-app等。 +- 易用:提供直观的API,方便开发者快速上手。 +- 扩展性强:支持自定义组件和扩展功能,方便开发者根据需求进行定制。 + +需求墙 +----------------- +- 更多的图表类型支持 +- 提供更多示例和文档 +- 支持更多的动画和交互功能 + +更新日志 +----------------- +请查看 [CHANGELOG](CHANGELOG) + +下一步 +----------------- +- 完善文档和示例 +- 增加更多的图表类型支持 +- 优化性能,提升渲染速度 +- 提供更多的自定义选项 + +参与贡献 +----------------- +欢迎贡献代码和文档,帮助VISLite变得更好。请查看 [.github/CONTRIBUTING.md](.github/CONTRIBUTING.md) 了解如何参与贡献。 + +例子项目 +----------------- +VISLite 提供了多个示例,包括: +- 水分子式 H2O +- 手式解锁 +- 3D环图 +- 径向树状图 +- 桑基图 +- 可缩放折线图 +- 从上到下树状图 +- 可视化大屏 + +版权 +----------------- +VISLite 采用 MIT 许可证,详情请查看 [LICENSE](LICENSE) 文件。 \ No newline at end of file