'\" '\" Copyright (c) 1990 The Regents of the University of California. '\" Copyright (c) 1994-1996 Sun Microsystems, Inc. '\" '\" See the file "license.terms" for information on usage and redistribution '\" of this file, and for a DISCLAIMER OF ALL WARRANTIES. '\" '\" RCS: @(#) $Id: bindtags.n,v 1.2 2003/11/24 05:09:59 bbbush Exp $ '\" '\" The definitions below are for supplemental macros used in Tcl/Tk '\" manual entries. '\" '\" .AP type name in/out ?indent? '\" Start paragraph describing an argument to a library procedure. '\" type is type of argument (int, etc.), in/out is either "in", "out", '\" or "in/out" to describe whether procedure reads or modifies arg, '\" and indent is equivalent to second arg of .IP (shouldn't ever be '\" needed; use .AS below instead) '\" '\" .AS ?type? ?name? '\" Give maximum sizes of arguments for setting tab stops. Type and '\" name are examples of largest possible arguments that will be passed '\" to .AP later. If args are omitted, default tab stops are used. '\" '\" .BS '\" Start box enclosure. From here until next .BE, everything will be '\" enclosed in one large box. '\" '\" .BE '\" End of box enclosure. '\" '\" .CS '\" Begin code excerpt. '\" '\" .CE '\" End code excerpt. '\" '\" .VS ?version? ?br? '\" Begin vertical sidebar, for use in marking newly-changed parts '\" of man pages. The first argument is ignored and used for recording '\" the version when the .VS was added, so that the sidebars can be '\" found and removed when they reach a certain age. If another argument '\" is present, then a line break is forced before starting the sidebar. '\" '\" .VE '\" End of vertical sidebar. '\" '\" .DS '\" Begin an indented unfilled display. '\" '\" .DE '\" End of indented unfilled display. '\" '\" .SO '\" Start of list of standard options for a Tk widget. The '\" options follow on successive lines, in four columns separated '\" by tabs. '\" '\" .SE '\" End of list of standard options for a Tk widget. '\" '\" .OP cmdName dbName dbClass '\" Start of description of a specific option. cmdName gives the '\" option's name as specified in the class command, dbName gives '\" the option's name in the option database, and dbClass gives '\" the option's class in the option database. '\" '\" .UL arg1 arg2 '\" Print arg1 underlined, then print arg2 normally. '\" '\" RCS: @(#) $Id: bindtags.n,v 1.2 2003/11/24 05:09:59 bbbush Exp $ '\" '\" # Set up traps and other miscellaneous stuff for Tcl/Tk man pages. .if t .wh -1.3i ^B .nr ^l \n(.l .ad b '\" # Start an argument description .de AP .ie !"\\$4"" .TP \\$4 .el \{\ . ie !"\\$2"" .TP \\n()Cu . el .TP 15 .\} .ta \\n()Au \\n()Bu .ie !"\\$3"" \{\ \&\\$1 \\fI\\$2\\fP (\\$3) .\".b .\} .el \{\ .br .ie !"\\$2"" \{\ \&\\$1 \\fI\\$2\\fP .\} .el \{\ \&\\fI\\$1\\fP .\} .\} .. '\" # define tabbing values for .AP .de AS .nr )A 10n .if !"\\$1"" .nr )A \\w'\\$1'u+3n .nr )B \\n()Au+15n .\" .if !"\\$2"" .nr )B \\w'\\$2'u+\\n()Au+3n .nr )C \\n()Bu+\\w'(in/out)'u+2n .. .AS Tcl_Interp Tcl_CreateInterp in/out '\" # BS - start boxed text '\" # ^y = starting y location '\" # ^b = 1 .de BS .br .mk ^y .nr ^b 1u .if n .nf .if n .ti 0 .if n \l'\\n(.lu\(ul' .if n .fi .. '\" # BE - end boxed text (draw box now) .de BE .nf .ti 0 .mk ^t .ie n \l'\\n(^lu\(ul' .el \{\ .\" Draw four-sided box normally, but don't draw top of .\" box if the box started on an earlier page. .ie !\\n(^b-1 \{\ \h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul' .\} .el \}\ \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul' .\} .\} .fi .br .nr ^b 0 .. '\" # VS - start vertical sidebar '\" # ^Y = starting y location '\" # ^v = 1 (for troff; for nroff this doesn't matter) .de VS .if !"\\$2"" .br .mk ^Y .ie n 'mc \s12\(br\s0 .el .nr ^v 1u .. '\" # VE - end of vertical sidebar .de VE .ie n 'mc .el \{\ .ev 2 .nf .ti 0 .mk ^t \h'|\\n(^lu+3n'\L'|\\n(^Yu-1v\(bv'\v'\\n(^tu+1v-\\n(^Yu'\h'-|\\n(^lu+3n' .sp -1 .fi .ev .\} .nr ^v 0 .. '\" # Special macro to handle page bottom: finish off current '\" # box/sidebar if in box/sidebar mode, then invoked standard '\" # page bottom macro. .de ^B .ev 2 'ti 0 'nf .mk ^t .if \\n(^b \{\ .\" Draw three-sided box if this is the box's first page, .\" draw two sides but no top otherwise. .ie !\\n(^b-1 \h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c .el \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c .\} .if \\n(^v \{\ .nr ^x \\n(^tu+1v-\\n(^Yu \kx\h'-\\nxu'\h'|\\n(^lu+3n'\ky\L'-\\n(^xu'\v'\\n(^xu'\h'|0u'\c .\} .bp 'fi .ev .if \\n(^b \{\ .mk ^y .nr ^b 2 .\} .if \\n(^v \{\ .mk ^Y .\} .. '\" # DS - begin display .de DS .RS .nf .sp .. '\" # DE - end display .de DE .fi .RE .sp .. '\" # SO - start of list of standard options .de SO .SH "STANDARD OPTIONS" .LP .nf .ta 4c 8c 12c .ft B .. '\" # SE - end of list of standard options .de SE .fi .ft R .LP See the \\fBoptions\\fR manual entry for details on the standard options. .. '\" # OP - start of full description for a single option .de OP .LP .nf .ta 4c Command-Line Name: \\fB\\$1\\fR Database Name: \\fB\\$2\\fR Database Class: \\fB\\$3\\fR .fi .IP .. '\" # CS - begin code excerpt .de CS .RS .nf .ta .25i .5i .75i 1i .. '\" # CE - end code excerpt .de CE .fi .RE .. .de UL \\$1\l'|0\(ul'\\$2 .. .TH bindtags 3tk 4.0 Tk "Tk Built-In Commands" .BS '\" Note: do not modify the .SH NAME line immediately below! .SH NAME bindtags \- 確定對一個視窗提供那些綁定和求值的次序 .SH 總覽 SYNOPSIS \fBbindtags \fIwindow \fR?\fItagList\fR? .BE .SH 描述 DESCRIPTION .PP 用 \fBbind\fR 命令建立的一個綁定,可以關聯上一個特定的視窗如 \fB.a.b.c\fR,一個類的名字如 \fBButton\fR,關鍵字 \fBall\fR,或任何其他字符串。所有這些形式叫做綁定標簽(\fIbinding tags\fR)。每個視窗包含綁定標簽的一個列表,它決定這個視窗如何處理事件。當在一個視窗中發生一個事件,依次把它提供給這個視窗的每個標簽: 對於每個標簽,執行匹配給定標簽和事件的最明確的綁定。匹配處理的詳情請參見 \fBbind\fR。 .PP 預設的,每個視窗有四個綁定標簽,它們依次是這個視窗的名字,這個視窗的類的名字,這個視窗的最近的頂層祖先的名字,和 \fBall\fR。頂層視窗預設的只有三個標簽,因為頂層名字與這個視窗的名字相同。\fBbindtags\fR 命令允許讀取和修改一個視窗的綁定標簽。 .PP 如果只用一個參數調用 \fBbindtags\fR,則把 \fIwindow\fR 的當前綁定標簽的集合作為一個列表返回。如果對 \fBbindtags\fR 指定了 \fItagList\fR 參數,則它必須是一個正確的列表;把 \fIwindow\fR 的標簽變更為這個列表的元素。\fItagList\fR 的元素可以是任意的字符串;但是,任何以一個點號開始的標簽將被作為一個視窗的名字對待 ;如果在處理一個事件的時候不存在叫這個名字的視窗,則忽略這個事件的這個標簽。\fItagList\fR 中元素的次序決定執行綁定稿本來響應事件的次序。例如,命令 .CS \fBbindtags .b {all . Button .b}\fR .CE 對叫做 \fB.b\fR 的一個按鈕顛倒求值綁定稿本的次序,首先調用 \fBall\fR 綁定,接著是 \fB.b\fR 的頂層(「.」)的綁定,隨後是類綁定,最後是 \fB.b\fR 的綁定。如果 \fItagList\fR 是一個空列表則把 \fIwindow\fR 的綁定標簽返回為上面描述的預設狀態。 .PP 可以使用 \fBbindtags\fRs 命令來為一個視窗介入任意的補充綁定標簽,或則刪除標準標簽。例如,命令 .CS \fBbindtags .b {.b TrickyButton . all}\fR .CE 把 \fB.b\fR 的 \fBButton\fR 標簽替換為 \fBTrickyButton\fR。這意味著與 \fBButton\fR 標簽相關聯的按鈕的預設組件綁定,將不在提供給 \fB.b\fR,轉而提供與 \fBTrickyButton\fR (可能有一些新的按鈕行為)關聯的任何綁定。 .SH "參見 SEE ALSO" bind .SH 關鍵字 KEYWORDS binding, event, tag .SH [中文版維護人] .B 寒蟬退士 .SH [中文版最新更新] .B 2002/05/11 .SH 《中國 Linux 論壇 man 手冊頁翻譯計劃》: .B http://cmpp.linuxforum.net