1

四角形/スロットを設定したいのですが、ホバーすると、四角形/スロットの側面からホバリングする小さなウィンドウが作成されます(少し重なります)。

また、小さなメニューにいくつかのボタンを配置したいと思います。小さなメニューを元の rect/slot よりも (幅方向に) 長くして、多くのボタンに合わせたいと思います。つまり、slot.hover を使用できません。 rectから離れたボタンにrect ...何か助けはありますか?

4

2 に答える 2

2

これを実現するために必要なロジックを示す例を次に示します。これらのメニューがたくさんあると、明らかに手に負えなくなります。

Shoes.app :title => "Test", :width => 1000, :height => 600 do
  @menu_hover = false
  @zone_hover = false
  @menu = nil
  @zone = stack :width => 200, :height => 100 do
    background '#DFA'
  end
  @zone.hover do
    @zone_hover = true
    app.append do
      break if not @menu.nil?
      @menu = stack :width => 230, :height => 35, :top => 50, :left => 150 do
        background '#F00'
        flow :margin => 5 do 
          button 'OK'
          button 'Cancel'
          button 'Ponies!'
        end
      end
      @menu.hover {@menu_hover = true}
      @menu.leave do
            @menu_hover = false
            break if @menu.nil? or @menu_hover or @zone_hover
            @menu.remove
            @menu = nil
      end
    end
  end

  @zone.leave do
    @zone_hover = false
    break if @menu.nil? or @menu_hover or @zone_hover
    @menu.remove
    @menu = nil
  end
end

これは、Shoes::Stack および Shoes::App クラスを拡張しhover?てスタックにメソッドを追加する上記のソリューションのリフです (デフォルトでサポートする必要があると思います)。あなたの場合、代わりにカスタム ウィジェットを作成することを検討しますが、これは使用できる構造の種類を示しています。

class Shoes::Stack
  def hover?
    @hover ||= false
  end

  alias_method :default_hover, :hover
  alias_method :default_leave, :leave

  def hover(*args, &block)
    new_block = lambda { @hover = true; block.call }
    default_hover(*args, &new_block)
  end

  def leave(*args, &block)
    new_block = lambda { @hover = false; block.call }
    default_leave(*args, &new_block)
  end
end

class Shoes::App
  alias_method :default_stack, :stack
  def stack(*args, &block)
    s = default_stack(*args, &block)
    s.hover {}
    s.leave {}
    s
  end
end

Shoes.app :title => "Test", :width => 1000, :height => 600 do
  @menu = nil
  @zone = stack :width => 200, :height => 100 do
    background '#DFA'
  end
  @zone.hover do
    app.append do
      break if not @menu.nil?
      @menu = stack :width => 230, :height => 35, :top => 50, :left => 150 do
        background '#F00'
        flow :margin => 5 do 
          button 'OK'
          button 'Cancel'
          button 'Ponies!'
        end
      end
      @menu.leave do
            break if @menu.nil? or @menu.hover? or @zone.hover?
            @menu.remove
            @menu = nil
      end
    end
  end

  @zone.leave do
    break if @menu.nil? or @menu.hover? or @zone.hover?
    @menu.remove
    @menu = nil
  end
end
于 2009-05-01T15:14:49.697 に答える
0

ボタンの上でもスロットの上でも、その四角形を開いて見えるようにするために、いくつかの追加のものを使用する必要があるようです。

それは何の上でもメニューをそこに保つべきです。

于 2009-05-01T03:19:53.563 に答える