Sha256: df9a34a433448a61386624fc846f02869a29cbdfa1ff6e4e0d3013859a90b9e1
Contents?: true
Size: 1.69 KB
Versions: 13
Compression:
Stored size: 1.69 KB
Contents
require_relative 'node' class PSD::Node class Layer < PSD::Node include PSD::Node::LockToOrigin attr_reader :layer # Stores a reference to the PSD::Layer def initialize(layer) super([]) @layer = layer layer.node = self end # Delegates some methods to the PSD::Layer (PROPERTIES + [:text, :ref_x, :ref_y]).each do |meth| define_method meth do @layer.send(meth) end define_method "#{meth}=" do |val| @layer.send("#{meth}=", val) end end # If the method is missing, we blindly send it to the layer. # The layer handles the case in which the method doesn't exist. def method_missing(method, *args, &block) layer.send(method, *args, &block) end # Attempt to translate the layer. def translate(x=0, y=0) @layer.translate x, y end # Attempt to scale the path components of the layer. def scale_path_components(xr, yr) @layer.scale_path_components(xr, yr) end # Tries to hide the layer by moving it way off canvas. def hide! # TODO actually mess with the blend modes instead of # just putting things way off canvas return if @hidden_by_kelly translate(100000, 10000) @hidden_by_kelly = true end # Tries to re-show the canvas by moving it back to it's original position. def show! if @hidden_by_kelly translate(-100000, -10000) @hidden_by_kelly = false end end # Exports this layer to a Hash. def to_hash super.merge({ type: :layer, text: @layer.text, ref_x: @layer.reference_point.x, ref_y: @layer.reference_point.y }) end end end
Version data entries
13 entries across 13 versions & 1 rubygems