PopUpSelection2.Mesa
Copyright © 1983, 1985, 1986 by Xerox Corporation. All rights reserved.
Created by Christian Jacobi, August 3, 1983 9:47 am
Last edited by: Christian Jacobi, August 26, 1986 10:21:13 am PDT
Last tweaked by Mike Spreitzer on January 30, 1989 11:37:30 am PST
DIRECTORY Imager, PopUpButtons, Rope, ViewerClasses;
PopUpSelection2: CEDAR DEFINITIONS =
A pop-up menu abstraction.
BEGIN
ROPE: TYPE = Rope.ROPE;
All coordinates and sizes are in pixels.
Create: PROC [choices: ChoiceS, doc: ROPE, allMayBeUp: BOOL, header: Image ← NIL, left, top: Label ← nullLabel, columns: NAT ← 1, fullRows: NAT ← 0, timeOut: NAT ← 0] RETURNS [Menu];
IF NOT allMayBeUp
THEN Pop returns as soon as it notices all mouse buttons are up
ELSE Pop waits for down-click, then returns on up-click.
ChoiceList: TYPE ~ LIST OF RECORD [key: ROPE, doc: ROPENIL];
ChoiceS: TYPE = REF ChoiceSequence;
ChoiceSequence: TYPE = RECORD [elts: SEQUENCE length: NAT OF Choice];
Choice: TYPE = RECORD [
image: Image,
doc: ROPE];
nullChoice: Choice = [NIL, NIL];
Image: TYPE ~ REF ImagePrivate;
ImagePrivate: TYPE ~ PopUpButtons.ImagePrivate;
defaultFont: Imager.Font;
Colors: TYPE ~ PopUpButtons.Colors;
defaultColors, inverseColors: Colors;
dontPaint: READONLY Imager.Color;
Align: TYPE ~ PopUpButtons.Align;
bottomLeft: Align ~ [0.0, 0.0];
center: Align ~ [0.5, 0.5];
ImageForRope: PROC [rope: ROPE, colors: Colors ← NIL, font: Imager.Font ← NIL, align: Align ← bottomLeft] RETURNS [image: Image];
nullLabel: Label = NIL;
Label: TYPE = REF LabelPrivate;
LabelPrivate: TYPE = RECORD [
minSpacing--parallel to edge being labelled--, minWidth--perpendicular--: NAT,
Draw: PROC [context: Imager.Context, org: Imager.VEC, n, spacing, width: NAT, data: REF ANY],
data: REF ANY
];
MouseButton: TYPE ~ ViewerClasses.MouseButton;
Menu: TYPE = REF MenuPrivate;
MenuPrivate: TYPE;
Pop: PROC [menu: Menu, default: NAT ← 0, position: REFNIL, InNotifier: Consumer ← NIL, notifyData: REF ANYNIL] RETURNS [INT, MouseButton];
Shows a pop-up menu and returns the number of the selected entry.
returns: 1 for first choice, 2 for second...
 0 if selected outside menu or on header-line
 -1 if timed out
default:  Hint for initial selection by implicit mouse movement. 0 if no default.
position:  Hint to override mouse position. See documentation for possible types.
Pop must not be called from inside a viewers-repaint or a TIP-notify procedure. You can get the answer in the notifier process, however, by supplying InNotifier & notifyData.
Consumer: TYPE = PROC [INT, MouseButton, REF ANY];
Must not be in a local frame, because it will be called from a different process (maybe even after Pop returns, depending on scheduling).
Sequify: PROC [list: ChoiceList] RETURNS [seq: ChoiceS];
PopRopes: PROC
[
choices: ChoiceList,
doc: ROPE,
allMayBeUp: BOOL,
default: NAT ← 0,
header: ROPENIL,
left, top: Label ← nullLabel,
columns: NAT ← 1,
fullRows: NAT ← 0,
timeOut: NAT ← 0,
position: REFNIL,
InNotifier: Consumer ← NIL,
notifyData: REF ANYNIL]
RETURNS [sel: INT, mb: MouseButton];
An easy way to go.
END.