# an animator that runs for the specified number of seconds,
# and yields values between 0 and 255
class AlphaAnimator < ZeroToOneAnimator
- def initialize(duration, *objects)
+ def initialize(duration, object)
super(duration) do |v|
- objects.each { |o| o.alpha = (255 * v).to_i }
+ object.alpha = compute_alpha(v)
end
end
+
+ def compute_alpha(v)
+ (255 * v).to_i
+ end
+ end
+
+ class InverseAlphaAnimator < AlphaAnimator
+ def compute_alpha(v)
+ super((1.0 - v).abs)
+ end
end
class MoveAnimator < ZeroToOneAnimator
end
class MailboxIcon < Evas::Smart
+ class FadeOutFinishedEvent < Ecore::Event
+ attr_reader :icon
+
+ def initialize(icon)
+ super()
+
+ @icon = icon
+ end
+ end
+
attr_accessor :slot
def initialize(evas, label)
@objects = [@img, @label]
@objects.each { |o| add_member(o) }
+ set_color(255, 255, 255, 0)
@img.set_color(255, 255, 255, 0)
@label.set_color(255, 0, 0, 0)
resize(*@img.get_size)
end
+ def fade_in
+ show
+
+ @alpha_anim ||= AlphaAnimator.new(2, self)
+ @alpha_anim.on_finished { @alpha_anim = nil }
+ end
+
+ def fade_out
+ @alpha_anim ||= InverseAlphaAnimator.new(2, self)
+ @alpha_anim.on_finished do
+ @alpha_anim = nil
+ FadeOutFinishedEvent.raise(self)
+ end
+ end
+
# smart callbacks
def smart_show
@objects.each { |o| o.show }
-
- @alpha_anim ||= AlphaAnimator.new(2, @img, @label)
- @alpha_anim.on_finished { @alpha_anim = nil }
end
def smart_hide
def smart_resize(w, h)
@img.resize(w, h)
end
+
+ def smart_color_set(r, g, b, a)
+ @objects.each { |o| o.alpha = a }
+ end
end
class Container < Evas::Smart
@about_to_add = 0
@add_lock_count = 0
+
+ @handlers = [
+ Ecore::EventHandler.new(MailboxIcon::FadeOutFinishedEvent,
+ &method(:on_icon_fade_out_finished))
+ ]
end
def can_add?
i.move_relative(self, 0, 0)
i.slot = next_slot
i.clip = self
- i.show
+ i.fade_in
# check whether we need to need to move this icon
if slots_left == 1
Kernel.raise(ContainerLockedError) unless @about_to_add.zero?
Kernel.raise(ContainerLockedError) unless @add_lock_count.zero?
- # icons that are placed above the one that's deleted need
- # to be moved
- ar = @icons[(i + 1)..-1]
+ @add_lock_count += 1
+ @icons[i].fade_out
+ end
- @icons[i].delete
+ def on_icon_fade_out_finished(ev)
+ i = @icons.index(ev.icon)
+ ev.icon.delete
@icons.delete_at(i)
- return if ar.empty?
+ # icons that are placed above the one that's deleted need
+ # to be moved. check whether are there any first
+ if i == @icons.length
+ @add_lock_count -= 1
+ return
+ end
- @add_lock_count += 1
+ ar = @icons[i..-1]
@animators << MoveAnimator.new(2, Main.instance.icon_height, *ar)
@animators.last.on_finished do |ani|