Sha256: 48ac6ade0877efb2309fab008d0077c155156f809fcb114644aaf8788017225a
Contents?: true
Size: 1.25 KB
Versions: 31
Compression:
Stored size: 1.25 KB
Contents
# Internal representation of a tracker point with keyframes. A Tracker is an array of Keyframe objects and should act and work like one class Tracksperanto::Tracker < DelegateClass(Array) include Tracksperanto::Casts include Comparable # Contains the name of the tracker attr_accessor :name cast_to_string :name def initialize(object_attribute_hash = {}) @name = "Tracker" __setobj__(Array.new) object_attribute_hash.map { |(k, v)| send("#{k}=", v) } yield(self) if block_given? end def keyframes=(new_kf_array) __setobj__(new_kf_array.dup) end def keyframes __getobj__ end # Trackers sort by the position of the first keyframe def <=>(other_tracker) self[0].frame <=> other_tracker[0].frame end # Automatically truncate spaces in the tracker # name and replace them with underscores def name=(n) @name = n.to_s.gsub(/(\s+)/, '_') end # Create and save a keyframe in this tracker def keyframe!(options) push(Tracksperanto::Keyframe.new(options)) end def inspect "<T #{name.inspect} with #{length} keyframes>" end # Hack - prevents the Tracker to be flattened into keyframes # when an Array of Trackers gets Array#flatten'ed def to_ary; end private :to_ary end
Version data entries
31 entries across 31 versions & 1 rubygems