Flotomatic 技术文档
2024-12-23 02:15:19作者:彭桢灵Jeremy
1. 安装指南
要安装 Flotomatic 插件,请执行以下命令:
script/plugin install git://github.com/xdotcommer/flotomatic.git
安装后,以下是可用的 Rake 任务:
rake:默认执行 spec 测试。rake rdoc:在 rdoc 文件夹中创建文档。rake install:复制 public 目录下的 JavaScript 和样式表文件。此任务在安装时自动执行。
2. 项目使用说明
Flotomatic 是一个基于 Ruby on Rails 的 JavaScript 图表库 Flot 的封装。它最初是为了在 MigraineLiving.com 网站上绘制偏头痛历史图而开发的。
已知问题:
- 在概览图中进行缩放操作前,必须先在主图中至少缩放一次,才能正常使用缩放功能。
- 使用 flot_selections div 选择数据集时,图表的缩放会丢失,它会完全缩放到最外层。
示例
以下示例并非完整的工作示例,仅用于说明如何通过 API 进行操作。它假设已经创建了两个具有特定属性的数据集(@journals, @migraines)。
要查看一个完整的工作示例,可以在项目的 example 目录下运行 script/server,然后在浏览器中访问 http://localhost:3000/flotomatic。
控制器示例:
@flot = TimeFlot.new('graph') do |f|
f.bars
f.grid :hoverable => true
f.selection :mode => "xy"
f.filter {|collection| collection.select {|j| j.entry_date < Date.parse("7/8/2007")}}
f.series_for("压力", @journals, :x => :entry_date, :y => :stress_rating)
f.series_for("睡眠时长", @migraines, :x => :entry_date, :y => :hours_of_sleep)
f.series_for("是否良好睡眠?", @migraines, :x => :entry_date, :y => lambda {|record| record.restful_night ? 5 : 0 }, :options => {:points => {:show => true}, :bars => {:show => false}})
f.series_for("偏头痛", @migraines, :x => :entry_date, :y => lambda {|record| record.migraine? ? 4 : nil }, :options => {:points => {:show => true}, :bars => {:show => false}})
end
视图示例:
<%= flot_includes %>
<h2>绘制以下项目</h2>
<div class='flot_dataset_picker'>
<%= flot_selections %>
</div>
<h2>我的图表</h2>
<%= flot_canvas("graph") %>
<h2>缩放</h2>
<%= flot_overview("asdflkjasdf") %>
<!-- 实际绘制图表 -->
<% flot_graph("graph", @flot) do %>
<%= flot_plot(:dynamic => true, :overview => true) %>
<%= flot_tooltip %>
<% end %>
3. 项目 API 使用文档
在 <% flot_graph %> 区块内,你可以访问 flotomatic 变量。
flotomatic 变量使用 canvas div 的 ID、传递给 flot_graph 调用的 Flot 对象中的数据及选项创建。
例如:
<% flot_graph("canvas", @flot) %>
这会生成以下内容:
var flotomatic = new Flotomatic("canvas", @flot.data, @flot.options)
Flotomatic 方法
绘图方法
draw(placeholder, data, initialOptions, ranges, dynamic, zoom):实际使用$.plot绘制图表。graph(overview, dynamic):调用draw方法并设置flotomatic.plot为返回的图表句柄。graphDynamic():动态绘制具有选择输入复选框的每个数据集的图表。graphOverview():绘制概览(缩放)图表。
工具提示方法
createTooltip(tooltipFormatter):创建工具提示。tooltipFormatter(item):默认的工具提示格式化函数。
tooltipFormatter: function(item) {
var date = new Date(item.datapoint[0]),
label = item.series.label;
return label + ": " + item.datapoint[1] + " 于 " + (date.getMonth() + 1) + "/" + date.getDate();
}
4. 项目安装方式
请参考“安装指南”部分中的步骤进行安装。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
最新内容推荐
Error Correction Coding——mathematical methods and algorithms:深入理解纠错编码的数学精髓 HP DL380 Gen9iLO固件资源下载:提升服务器管理效率的利器 RTD2270CLW/RTD2280DLW VGA转LVDS原理图下载介绍:项目核心功能与场景 JADE软件下载介绍:专业的XRD数据分析工具 常见材料性能参数pdf下载说明:一键获取材料性能参数,助力工程设计与分析 SVPWM的原理及法则推导和控制算法详解第四修改版:让电机控制更高效 Oracle Instant Client for Microsoft Windows x64 10.2.0.5下载资源:高效访问Oracle数据库的利器 鼎捷软件tiptop5.3技术手册:快速掌握4gl语言的利器 源享科技资料大合集介绍:科技学习者的全面资源库 潘通色标薄全系列资源下载说明:设计师的创意助手
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
523
3.71 K
Ascend Extension for PyTorch
Python
328
384
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
876
577
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
335
161
暂无简介
Dart
762
187
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
745
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
React Native鸿蒙化仓库
JavaScript
302
349
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
112
135