require File.dirname(__FILE__) + '/base' class Gruff::Line < Gruff::Base # Draw a dashed line at the given value attr_accessor :baseline_value # Color of the baseline attr_accessor :baseline_color # # Call with target pixel width of graph (800, 400, 300), and/or 'false' to omit lines (points only). # # g = Gruff::Line.new(400) # 400px wide with lines # # g = Gruff::Line.new(400, false) # 400px wide, no lines # # g = Gruff::Line.new(false) # Defaults to 800px wide, no lines def initialize(*args) raise ArgumentError, "Wrong number of arguments" if args.length > 2 if args.empty? or not Numeric === args.first then super() else super args.shift end @lines = args.empty? || args.shift # draw lines by default @baseline_color = 'red' end def draw super return unless @has_data @x_increment = @graph_width / (@column_count - 1).to_f circle_radius = clip_value_if_greater_than(@columns / (@norm_data.first[1].size * 2.5), 5.0) @d = @d.stroke_opacity 1.0 @d = @d.stroke_width clip_value_if_greater_than(@columns / (@norm_data.first[1].size * 4), 5.0) if (defined?(@norm_baseline)) then level = @graph_top + (@graph_height - @norm_baseline * @graph_height) @d = @d.push @d.stroke_color @baseline_color @d.fill_opacity 0.0 @d.stroke_dasharray(10, 20) @d.stroke_width 5 @d.line(@graph_left, level, @graph_left + @graph_width, level) @d = @d.pop end @norm_data.each do |data_row| prev_x = prev_y = 0.0 @d = @d.stroke current_color @d = @d.fill current_color data_row[1].each_with_index do |data_point, index| new_x = @graph_left + (@x_increment * index) draw_label(new_x, index) next if data_point.nil? new_y = @graph_top + (@graph_height - data_point * @graph_height) if @lines and prev_x > 0 and prev_y > 0 then @d = @d.line(prev_x, prev_y, new_x, new_y) end @d = @d.circle(new_x, new_y, new_x - circle_radius, new_y) prev_x = new_x prev_y = new_y end increment_color() end @d.draw(@base_image) end def normalize super @norm_baseline = (@baseline_value.to_f / @maximum_value.to_f) if @baseline_value end end