diff options
author | nagai <nagai@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-06-12 15:25:49 +0000 |
---|---|---|
committer | nagai <nagai@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-06-12 15:25:49 +0000 |
commit | c0271cadd7c49f2c3304e93f6190da0b8623c1f3 (patch) | |
tree | ae877225c9d33c23865c14f81a6cf6252f10e590 /ext/tk/sample/menubar2.rb | |
parent | 82593c058f0a61d8d4bcf7279fed496022330246 (diff) | |
download | ruby-c0271cadd7c49f2c3304e93f6190da0b8623c1f3.tar.gz |
* ext/tcltklib/extconf.rb: [EXPERIMENTAL] MacOS X (darwin) support
* ext/tcltklib/tcltklib.c: fix thread trouble on callback proc, and
eliminate warning about instance variable access
* ext/tk/lib/tk/menubar.rb: improve supported menu_spec
* ext/tk/lib/tk/menuspec.rb: [add] menu_spec support library
* ext/tk/lib/tk/root.rb: add menu_spec support
* ext/tk/lib/tk/text.rb: bug fix
* ext/tk/lib/tk/toplevel.rb: add menu_spec support
* ext/tk/sample/menubar?.rb: [add] sample of menu_spec usage
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6454 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/tk/sample/menubar2.rb')
-rw-r--r-- | ext/tk/sample/menubar2.rb | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/ext/tk/sample/menubar2.rb b/ext/tk/sample/menubar2.rb new file mode 100644 index 0000000000..6ca58e45a4 --- /dev/null +++ b/ext/tk/sample/menubar2.rb @@ -0,0 +1,56 @@ +# +# menubar sample 2 : use 'menu' option of root/toplevel widget +# + +require 'tk' + +radio_var = TkVariable.new('y') + +menu_spec = [ + [['File', 0], + {:label=>'Open', :command=>proc{puts('Open clicked')}, :underline=>0}, + '---', + ['Check_A', TkVariable.new(true), 6], + {:type=>'checkbutton', :label=>'Check_B', + :variable=>TkVariable.new, :underline=>6}, + '---', + ['Radio_X', [radio_var, 'x'], 6, '', {:foreground=>'black'}], + ['Radio_Y', [radio_var, 'y'], 6], + ['Radio_Z', [radio_var, 'z'], 6], + '---', + ['cascade', [ + ['sss', proc{p 'sss'}, 0], + ['ttt', proc{p 'ttt'}, 0], + ['uuu', proc{p 'uuu'}, 0], + ['vvv', proc{p 'vvv'}, 0], + ], + 0, '', + {:font=>'Courier 16 italic', + :menu_config=>{:font=>'Times -18 bold', :foreground=>'black'}}], + '---', + ['Quit', proc{exit}, 0]], + + [['Edit', 0], + ['Cut', proc{puts('Cut clicked')}, 2], + ['Copy', proc{puts('Copy clicked')}, 0], + ['Paste', proc{puts('Paste clicked')}, 0]], + + [['Help', 0, {:menu_name=>'help'}], + ['About This', proc{puts('Ruby/Tk menubar sample 2')}, 6]] +] + +mbar = Tk.root.add_menubar(menu_spec, + # followings are default configure options + 'tearoff'=>'false', + 'foreground'=>'grey40', + 'activeforeground'=>'red', + 'font'=>'Helvetia 12 bold') +# This (default configure options) is NOT same the following. +# +# mbar = Tk.root.add_menubar(menu_spec) +# mbar.configure('foreground'=>'grey40', 'activeforeground'=>'red', +# 'font'=>'Helvetia 12 bold') + +TkText.new(:wrap=>'word').pack.insert('1.0', 'Please read the sample source, and check how to override default configure options of menu entries on a menu_spec.') + +Tk.mainloop |