class TaskJuggler::Painter
This is a vector drawing class. It can describe a canvas with lines, rectangles, circles, ellipses and text elements on it. The elements can be grouped. It currently only supports rendering as an SVG output.
Public Class Methods
new(width, height) { |self| ... }
click to toggle source
Create a canvas of dimension width times height. The block can be used to add elements to the drawing. If the block has an argument, the block content is evaluated within the current context. If no argument is provided, the newly created object will be the evaluation context of the block. This will make instance variables of the caller inaccessible. Methods of the caller will still be available.
# File lib/taskjuggler/Painter.rb, line 36 def initialize(width, height, &block) @width = width @height = height @elements = [] if block if block.arity == 1 # This is the traditional case where self is passed to the block. # All Primitives methods now must be prefixed with the block # variable to call them. yield self else # In order to have the primitives easily available in the block, we # use instance_eval to switch self to this object. But this makes the # methods of the original self no longer accessible. We work around # this by saving the original self and using method_missing to # delegate the method call to the original self. @originalSelf = eval('self', block.binding) instance_eval(&block) end end end
Public Instance Methods
method_missing(method, *args, &block)
click to toggle source
Delegator to @originalSelf.
# File lib/taskjuggler/Painter.rb, line 60 def method_missing(method, *args, &block) @originalSelf.send(method, *args, &block) end
to_svg()
click to toggle source
Render the canvas as SVG output (tree of XMLElement
objects).
# File lib/taskjuggler/Painter.rb, line 65 def to_svg XMLElement.new('svg', 'width' => "#{@width}px", 'height' => "#{@height}px") do @elements.map { |el| el.to_svg } end end