mirror of
https://github.com/ruby/ruby.git
synced 2025-09-17 17:43:59 +02:00

* ext/tk/*: Support new features of Tcl/Tk8.6b1 and minor bug fixes. ( [KNOWN BUG] Ruby/Tk on Ruby 1.9 will not work on Cygwin. ) * ext/tk/*: Unify sources between Ruby 1.8 & 1.9. Improve default_widget_set handling. * ext/tk/*: Multi-TkInterpreter (multi-tk.rb) works on Ruby 1.8 & 1.9. ( [KNOWN BUG] On Ruby 1.8, join to a long term Thread on Tk callbacks may freeze. On Ruby 1.9, cannot create a second master interpreter (creating slaves are OK); supported master interpreter is the default master interpreter only. ) * ext/tk/lib/tkextlib/*: Update supported versions of Tk extensions. Tcllib 1.8/Tklib 0.4.1 ==> Tcllib 1.11.1/Tklib 0.5 BWidgets 1.7 ==> BWidgets 1.8 TkTable 2.9 ==> TkTable 2.10 TkTreeCtrl 2005-12-02 ==> TkTreeCtrl 2.2.9 Tile 0.8.0/8.5.1 ==> Tile 0.8.3/8.6b1 IncrTcl 2005-02-14 ==> IncrTcl 2008-12-15 TclX 2005-02-07 ==> TclX 2008-12-15 Trofs 0.4.3 ==> Trofs 0.4.4 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@24064 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
66 lines
2.4 KiB
Ruby
66 lines
2.4 KiB
Ruby
# ttkprogress.rb --
|
|
#
|
|
# This demonstration script creates several progress bar widgets.
|
|
#
|
|
# based on "Id: ttkprogress.tcl,v 1.3 2007/12/13 15:27:07 dgp Exp"
|
|
|
|
if defined?($ttkprogress_demo) && $ttkprogress_demo
|
|
$ttkprogress_demo.destroy
|
|
$ttkprogress_demo = nil
|
|
end
|
|
|
|
$ttkprogress_demo = TkToplevel.new {|w|
|
|
title("Progress Bar Demonstration")
|
|
iconname("ttkprogress")
|
|
positionWindow(w)
|
|
}
|
|
|
|
base_frame = TkFrame.new($ttkprogress_demo).pack(:fill=>:both, :expand=>true)
|
|
|
|
Ttk::Label.new(base_frame, :font=>$font, :wraplength=>'4i', :justify=>:left,
|
|
:text=>Tk::UTF8_String.new(<<EOL)).pack(:side=>:top, :fill=>:x)
|
|
Below are two progress bars. \
|
|
The top one is a \\u201Cdeterminate\\u201D progress bar, \
|
|
which is used for showing how far through a defined task the program has got. \
|
|
The bottom one is an \\u201Cindeterminate\\u201D progress bar, \
|
|
which is used to show that the program is busy \
|
|
but does not know how long for. Both are run here in self-animated mode, \
|
|
which can be turned on and off using the buttons underneath.
|
|
EOL
|
|
|
|
## See Code / Dismiss buttons
|
|
Ttk::Frame.new(base_frame) {|frame|
|
|
sep = Ttk::Separator.new(frame)
|
|
Tk.grid(sep, :columnspan=>4, :row=>0, :sticky=>'ew', :pady=>2)
|
|
TkGrid('x',
|
|
Ttk::Button.new(frame, :text=>'See Code',
|
|
:image=>$image['view'], :compound=>:left,
|
|
:command=>proc{showCode 'ttkprogress'}),
|
|
Ttk::Button.new(frame, :text=>'Dismiss',
|
|
:image=>$image['delete'], :compound=>:left,
|
|
:command=>proc{
|
|
$ttkprogress_demo.destroy
|
|
$ttkprogress_demo = nil
|
|
}),
|
|
:padx=>4, :pady=>4)
|
|
grid_columnconfigure(0, :weight=>1)
|
|
pack(:side=>:bottom, :fill=>:x)
|
|
}
|
|
|
|
frame = Ttk::Frame.new(base_frame).pack(:fill=>:both, :expand=>true)
|
|
|
|
p1 = Ttk::Progressbar.new(frame, :mode=>:determinate)
|
|
p2 = Ttk::Progressbar.new(frame, :mode=>:indeterminate)
|
|
|
|
start = Ttk::Button.new(frame, :text=>'Start Progress',
|
|
:command=>proc{ p1.start; p2.start })
|
|
stop = Ttk::Button.new(frame, :text=>'Stop Progress',
|
|
:command=>proc{ p1.stop; p2.stop })
|
|
|
|
Tk.grid(p1, '-', :pady=>5, :padx=>10)
|
|
Tk.grid(p2, '-', :pady=>5, :padx=>10)
|
|
Tk.grid(start, stop, :padx=>10, :pady=>5)
|
|
start.grid_configure(:sticky=>'e')
|
|
stop.grid_configure(:sticky=>'w')
|
|
frame.grid_columnconfigure(:all, :weight=>1)
|
|
|