SVG::Graph
data:image/s3,"s3://crabby-images/cdbe2/cdbe2293feee071acd90ecd8845bb08d73bd87f7" alt="This project is using Percy.io for visual regression testing."
Description
This repo is the continuation of the original SVG::Graph library by Sean Russell. I'd like to thank Claudio Bustos for giving me permissions to continue publishing the gem under it's original name: svg-graph
Changelog
I'm maintaing in my free time, so I can't promise on any deadlines. Please notify me (via github messages or on the Issues section) if you find any bug.
Contribute
Pull requests are very welcome :-)
Usage
For a complete list of configuration options please have a look at the source - most important Graph.rb, also checkout the subclasses (Pie, Bar, etc.) as they might provide additional options.
You can require everything at once
require 'svggraph'
or only the individual parts you need
require 'SVG/Graph/Bar'
require 'SVG/Graph/Line'
...
In the following some examples to get you up to speed.
Bar
require 'SVG/Graph/Bar'
x_axis = ['1-10', '10-30', '30-50', '50-70', 'older']
options = {
:width => 640,
:height => 300,
:stack => :side,
:fields => x_axis,
:graph_title => "kg per head and year chocolate consumption",
:show_graph_title => true,
:show_x_title => true,
:x_title => 'Age in years',
:show_y_title => true,
:y_title => 'kg/year',
:y_title_location => :end,
:no_css => true
}
male_data = [2, 4, 6, 4, 2]
female_data = [1, 5, 4, 5, 2.7]
g = SVG::Graph::Bar.new(options)
g.add_data( {
:data => female_data,
:title => "Female"
})
g.add_data( {
:data => male_data,
:title => "Male"
})
File.open('bar.svg', 'w') {|f| f.write(g.burn_svg_only)}
data:image/s3,"s3://crabby-images/2b40e/2b40e63681d29d14c50df108150eeb041db99902" alt="example bar graph"
BarHorizontal
data:image/s3,"s3://crabby-images/dddfc/dddfce0e181090af5d826ce62dc36669290b2229" alt="example bar_horizontal graph"
ErrBar
data:image/s3,"s3://crabby-images/d1bf0/d1bf0d7568052ea70f1506dace88bbb33caf5316" alt="example err_bar graph"
Line
data:image/s3,"s3://crabby-images/4ed5c/4ed5cf1be63fb7fd7f2b5ff6e5af860a32e989e4" alt="example line graph"
Pie
data:image/s3,"s3://crabby-images/c3708/c37083616be75e78337d051614c33500e79144bc" alt="example pie graph"
Plot
data:image/s3,"s3://crabby-images/73575/735755669bea2daa3d3f374190e88080e9582492" alt="example plot graph"
Schedule
data:image/s3,"s3://crabby-images/e0e39/e0e39f8a5f304ee162da89fa85eef6dd6fe92820" alt="example schedule graph"
TimeSeries
data:image/s3,"s3://crabby-images/ed311/ed311a7d224c3d8e8ac147c1efaf81be5d972394" alt="example timeseries graph"
C3js
Source: C3js.rb
Link to Preview
Build
bundle exec rake
gem build svg-graph.gemspec
gem install svg-graph-\<version>.gem
Percy.io integration
https://docs.percy.io/docs/travis-ci
https://docs.percy.io/docs/snapshot-cli-command