本文做者:TalkingData 可视化工程师 李凤禄
inMap 是 TalkingData 可视化团队开源的一款基于 canvas 的大数据可视化库,专一于大数据方向点、线、面的可视化效果展现。目前支持散点、围栏、热力、网格、聚合等方式;致力于让大数据可视化变得简单易用。git
GitHub地址:https://github.com/TalkingData/inmap (求Star!)github
文档地址:http://inmap.talkingdata.com面试
inMap 是更加智能的地理可视化框架,主要面向从事数据可视化应用相关的工程师和设计师。算法
inMap 写的每一个算法都是为了加强用户体验,追求极致效果,咱们但愿用 inMap 可以作出伟大的产品。canvas
inMap 接口设计也很友好,但愿让开发者经过简单的配置,就能快速构建出优美可视化效果。segmentfault
咱们在项目中常常会遇到在地图上打点并标上文字的需求,咱们用某流行的可视化库展现出效果以下:多线程
(文字密密麻麻一团,都叠在一块,效果不好,估计会被要被产品经理咬住不放)框架
inMap 实现了基于文字排版算法,是否是很赞,效果图以下:性能
是否是很酷啊,inMap 实现了本身的四分位文字排版算法,听起来不明觉厉的样子,别着急,让我慢慢道来。大数据
每个标记点都有上下左右四个放文字的位子,若是左边放不下,那就放右边试试,还不行就放到下面试试,以此类推,原理就这么简单,哈哈。
实现细节以下:
后续会输出创造更好的可视化图形和算法,并后续推出 WebGL 版本。