SimpleView.st
author claus
Thu, 07 Sep 1995 14:31:44 +0200
changeset 180 0b3a8658d55e
parent 176 2771514750b6
child 182 b5f7fdff0f6d
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
135
claus
parents:
diff changeset
     1
"
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
claus
parents:
diff changeset
     3
	      All Rights Reserved
claus
parents:
diff changeset
     4
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents:
diff changeset
    10
 hereby transferred.
claus
parents:
diff changeset
    11
"
claus
parents:
diff changeset
    12
140
claus
parents: 138
diff changeset
    13
'From Smalltalk/X, Version:2.10.5 on 9-may-1995 at 12:08:03 pm'!
135
claus
parents:
diff changeset
    14
claus
parents:
diff changeset
    15
PseudoView subclass:#SimpleView
151
claus
parents: 145
diff changeset
    16
	 instanceVariableNames:'superView subViews components 
claus
parents: 145
diff changeset
    17
		styleSheet resources 
claus
parents: 145
diff changeset
    18
		borderColor borderWidth borderShape viewShape 
claus
parents: 145
diff changeset
    19
		top left
claus
parents: 145
diff changeset
    20
		extentChanged originChanged cornerChanged 
claus
parents: 145
diff changeset
    21
claus
parents: 145
diff changeset
    22
		relativeOrigin relativeExtent relativeCorner 
claus
parents: 145
diff changeset
    23
		originRule extentRule cornerRule
claus
parents: 145
diff changeset
    24
		insets viewport
claus
parents: 145
diff changeset
    25
claus
parents: 145
diff changeset
    26
		layout
claus
parents: 145
diff changeset
    27
		shown hiddenOnRealize name level margin innerClipRect 
claus
parents: 145
diff changeset
    28
		shadowColor lightColor 
claus
parents: 145
diff changeset
    29
		bitGravity viewGravity 
claus
parents: 145
diff changeset
    30
		controller windowGroup'
135
claus
parents:
diff changeset
    31
	 classVariableNames:'Grey CentPoint ViewSpacing DefaultStyle StyleSheet
142
claus
parents: 140
diff changeset
    32
		DefaultViewBackgroundColor DefaultBorderColor DefaultLightColor
claus
parents: 140
diff changeset
    33
		DefaultShadowColor DefaultBorderWidth DefaultFont
claus
parents: 140
diff changeset
    34
		DefaultFocusColor DefaultFocusBorderWidth'
135
claus
parents:
diff changeset
    35
	 poolDictionaries:''
claus
parents:
diff changeset
    36
	 category:'Views-Basic'
claus
parents:
diff changeset
    37
!
claus
parents:
diff changeset
    38
140
claus
parents: 138
diff changeset
    39
SimpleView class instanceVariableNames:'ClassResources'
claus
parents: 138
diff changeset
    40
claus
parents: 138
diff changeset
    41
!
135
claus
parents:
diff changeset
    42
claus
parents:
diff changeset
    43
SimpleView comment:'
claus
parents:
diff changeset
    44
COPYRIGHT (c) 1989 by Claus Gittinger
claus
parents:
diff changeset
    45
	      All Rights Reserved
claus
parents:
diff changeset
    46
180
claus
parents: 176
diff changeset
    47
$Header: /cvs/stx/stx/libview/SimpleView.st,v 1.18 1995-09-07 12:29:55 claus Exp $
135
claus
parents:
diff changeset
    48
'!
claus
parents:
diff changeset
    49
claus
parents:
diff changeset
    50
!SimpleView class methodsFor:'documentation'!
claus
parents:
diff changeset
    51
claus
parents:
diff changeset
    52
copyright
claus
parents:
diff changeset
    53
"
claus
parents:
diff changeset
    54
 COPYRIGHT (c) 1989 by Claus Gittinger
claus
parents:
diff changeset
    55
	      All Rights Reserved
claus
parents:
diff changeset
    56
claus
parents:
diff changeset
    57
 This software is furnished under a license and may be used
claus
parents:
diff changeset
    58
 only in accordance with the terms of that license and with the
claus
parents:
diff changeset
    59
 inclusion of the above copyright notice.   This software may not
claus
parents:
diff changeset
    60
 be provided or otherwise made available to, or used by, any
claus
parents:
diff changeset
    61
 other person.  No title to or ownership of the software is
claus
parents:
diff changeset
    62
 hereby transferred.
claus
parents:
diff changeset
    63
"
claus
parents:
diff changeset
    64
!
claus
parents:
diff changeset
    65
claus
parents:
diff changeset
    66
version
claus
parents:
diff changeset
    67
"
180
claus
parents: 176
diff changeset
    68
$Header: /cvs/stx/stx/libview/SimpleView.st,v 1.18 1995-09-07 12:29:55 claus Exp $
135
claus
parents:
diff changeset
    69
"
claus
parents:
diff changeset
    70
!
claus
parents:
diff changeset
    71
claus
parents:
diff changeset
    72
documentation
claus
parents:
diff changeset
    73
"
claus
parents:
diff changeset
    74
    this class implements functions common to all Views which do not work on / show a model. 
claus
parents:
diff changeset
    75
    Previously, all of this functionality used to be in the old View class, but has been
claus
parents:
diff changeset
    76
    separated into this new SimpleView (which does not know about models) and the new View, which
claus
parents:
diff changeset
    77
    does so.
claus
parents:
diff changeset
    78
    Instances of SimpleView are seldom used, most views in the system inherit 
claus
parents:
diff changeset
    79
    from this class. 
claus
parents:
diff changeset
    80
    However, sometimes a view is used to create a dummy view for framing 
claus
parents:
diff changeset
    81
    or layout purposes.
claus
parents:
diff changeset
    82
claus
parents:
diff changeset
    83
    Instance variables:
claus
parents:
diff changeset
    84
claus
parents:
diff changeset
    85
	superView               <View>                  my superview i.e. the view I am in
claus
parents:
diff changeset
    86
	subViews                <Collection>            the collection of subviews
151
claus
parents: 145
diff changeset
    87
	components              <Collection>            collection of gadgets (will be merged with subViews, soon)
claus
parents: 145
diff changeset
    88
135
claus
parents:
diff changeset
    89
	borderColor             <Color>                 color of border
claus
parents:
diff changeset
    90
	borderWidth             <Number>                borderWidth in pixels (device dep.)
claus
parents:
diff changeset
    91
	borderShape             <Form>                  shape of border (if device supports it)
claus
parents:
diff changeset
    92
	viewShape               <Form>                  shape of view (if device supports it)
151
claus
parents: 145
diff changeset
    93
	top                     <Number>                actual top coordinate (pixels) in superview
claus
parents: 145
diff changeset
    94
	left                    <Number>                actual left coordinate (pixels) in superview
135
claus
parents:
diff changeset
    95
	extendChanged           <Boolean>               true if extend changed during setup
claus
parents:
diff changeset
    96
	originChanged           <Boolean>               true if origin changed during setup
151
claus
parents: 145
diff changeset
    97
claus
parents: 145
diff changeset
    98
	viewport                <Rectangle>             my Rectangle in superviews coordinates
135
claus
parents:
diff changeset
    99
	relativeOrigin          <Number>                relative origin in percent within superview
claus
parents:
diff changeset
   100
	relativeExtent          <Number>                relative extent in percent within superview
151
claus
parents: 145
diff changeset
   101
	relativeCorner          <Number>                relative corner in percent within superview
135
claus
parents:
diff changeset
   102
	originRule              <Block>                 rule to compute origin if superview changes size
claus
parents:
diff changeset
   103
	extentRule              <Block>                 rule to compute extent if superview changes size
151
claus
parents: 145
diff changeset
   104
	cornerRule              <Block>                 rule to compute corner if superview changes size
claus
parents: 145
diff changeset
   105
	insets                  <Array>                 array with top, left, bottom & right insets (or nil)
claus
parents: 145
diff changeset
   106
claus
parents: 145
diff changeset
   107
	layout                  <LayoutObject>          not yet implemented - will replace the above layout
claus
parents: 145
diff changeset
   108
							variables.
claus
parents: 145
diff changeset
   109
135
claus
parents:
diff changeset
   110
	shown                   <Boolean>               true if visible (false if iconified, unmapped or covered)
151
claus
parents: 145
diff changeset
   111
	hiddenOnRealize         <Boolean>               dont show automatically when superview is realized
135
claus
parents:
diff changeset
   112
	name                    <String>                my name (future use for resources)
claus
parents:
diff changeset
   113
	level                   <Number>                3D level relative to superview
claus
parents:
diff changeset
   114
	margin                  <Number>                convenient margin
claus
parents:
diff changeset
   115
	innerClipRect           <Rectangle>             convenient inner clip (minus margin)
claus
parents:
diff changeset
   116
	shadowColor             <Color>                 color used to draw 3D shadowed edges
claus
parents:
diff changeset
   117
	lightColor              <Color>                 color used to draw 3D lighted edges
claus
parents:
diff changeset
   118
	bitGravity              <nil | Symbol>          gravity of contents (if device supports it)
claus
parents:
diff changeset
   119
	viewGravity             <nil | Symbol>          gravity of view (if device supports it)
claus
parents:
diff changeset
   120
	controller              <nil | Controller>      the controller (if any)
151
claus
parents: 145
diff changeset
   121
	windowGroup             <WindowGroup>           the windowGroup
135
claus
parents:
diff changeset
   122
claus
parents:
diff changeset
   123
claus
parents:
diff changeset
   124
    Class variables:
claus
parents:
diff changeset
   125
claus
parents:
diff changeset
   126
	Grey                    <Color>                 the color grey - its used so often
151
claus
parents: 145
diff changeset
   127
	ViewSpacing             <Number>                preferred spacing between views; 1mm
135
claus
parents:
diff changeset
   128
claus
parents:
diff changeset
   129
	CentPoint               <Point>                 100 @ 100 - its used so often
claus
parents:
diff changeset
   130
claus
parents:
diff changeset
   131
	StyleSheet              <ResourcePack>          contains all view-style specifics
claus
parents:
diff changeset
   132
claus
parents:
diff changeset
   133
claus
parents:
diff changeset
   134
    styleSheet parameters:
claus
parents:
diff changeset
   135
claus
parents:
diff changeset
   136
	popupShadow             <Boolean>               if true, popupViews show a shadow below
claus
parents:
diff changeset
   137
	popupLevel              <nil | Integer>         3D level
claus
parents:
diff changeset
   138
	borderWidth             <nil | Integer>         borderWidth (ignored in 3D styles)
claus
parents:
diff changeset
   139
	borderColor             <nil | Color>           borderColor (ignored in 3D styles)
claus
parents:
diff changeset
   140
	viewBackground          <nil | Color>           views background
claus
parents:
diff changeset
   141
	shadowColor             <nil | Color>           color for shadow edges (ignored in 2D styles)
claus
parents:
diff changeset
   142
	lightColor              <nil | Color>           color for light edges (ignored in 2D styles)
claus
parents:
diff changeset
   143
	font                    <nil | Font>            font to use
claus
parents:
diff changeset
   144
claus
parents:
diff changeset
   145
claus
parents:
diff changeset
   146
    TODO:
claus
parents:
diff changeset
   147
	get rid of relativeOrigin, relativeCorner, originRule, extentRule,
claus
parents:
diff changeset
   148
	and insets; replace by a single object which defines the size
claus
parents:
diff changeset
   149
	(mhmh - ST-80 seems to call this LayoutFrame ?)
claus
parents:
diff changeset
   150
	-> be prepared for a change here in the near future and ONLY use
151
claus
parents: 145
diff changeset
   151
	   access methods to get those instance variables' values
claus
parents: 145
diff changeset
   152
claus
parents: 145
diff changeset
   153
	get rid of 3D level & margin, move it to extra wrappers
claus
parents: 145
diff changeset
   154
	(although this will make view setup more complicated, it will remove
claus
parents: 145
diff changeset
   155
	 complexity from the internals of view. Also, it will allow for more
claus
parents: 145
diff changeset
   156
	 varieties of borders.)
claus
parents: 145
diff changeset
   157
        
135
claus
parents:
diff changeset
   158
	add components (could also call them gadgets or lightweight views)
claus
parents:
diff changeset
   159
	- views are expensive in terms of X resources. This would make all
claus
parents:
diff changeset
   160
	framing/edge and panel helper views become cheap ST objects, instead
claus
parents:
diff changeset
   161
	of views.
claus
parents:
diff changeset
   162
"
151
claus
parents: 145
diff changeset
   163
!
claus
parents: 145
diff changeset
   164
claus
parents: 145
diff changeset
   165
layoutComputation 
claus
parents: 145
diff changeset
   166
"
claus
parents: 145
diff changeset
   167
    Due to historic reasons, there are 2 mechanisms to resize a view:
claus
parents: 145
diff changeset
   168
	- (old, to be eliminated mechanism)
claus
parents: 145
diff changeset
   169
	    based upon info found in 
claus
parents: 145
diff changeset
   170
		relativeOrigin / relativeCorner / relativeExtent
claus
parents: 145
diff changeset
   171
		originRule / cornerRule / extentRule
claus
parents: 145
diff changeset
   172
claus
parents: 145
diff changeset
   173
	- (new, will migrate to that one)
claus
parents: 145
diff changeset
   174
	    letting a layoutObject compute things
claus
parents: 145
diff changeset
   175
claus
parents: 145
diff changeset
   176
    Actually, the old mechanism is just as powerful, as the new (layoutObject
claus
parents: 145
diff changeset
   177
    based) mechanism; with the help of block=rules, you can compute whatever
claus
parents: 145
diff changeset
   178
    geometry is desired.
claus
parents: 145
diff changeset
   179
    However, having 6 instance variables in every view creates some overhead,
claus
parents: 145
diff changeset
   180
    which can be avoided in most cases (most views are either fixed-size or
claus
parents: 145
diff changeset
   181
    relative-sized).
claus
parents: 145
diff changeset
   182
    Therefore (and also to make porting of ST-80 apps easier), ST/X will migrate 
claus
parents: 145
diff changeset
   183
    to use layoutObjects.
claus
parents: 145
diff changeset
   184
    You will not see a difference at the views protocol level, since
claus
parents: 145
diff changeset
   185
    existing interfaces will (silently) create layoutObjects as appropriate.
claus
parents: 145
diff changeset
   186
    However, you should remove all direct accesses to the above mentioned
claus
parents: 145
diff changeset
   187
    instance variables, to be prepared for that change.
claus
parents: 145
diff changeset
   188
claus
parents: 145
diff changeset
   189
    Notice, that a view recomputes its size whenever its superview
claus
parents: 145
diff changeset
   190
    changes size. This is done via:
claus
parents: 145
diff changeset
   191
	sizeChanged
claus
parents: 145
diff changeset
   192
	    -> allSubviews: superViewChangedSize
claus
parents: 145
diff changeset
   193
claus
parents: 145
diff changeset
   194
    If the geometry computation as performed in superViewChangedSize
claus
parents: 145
diff changeset
   195
    is not powerful enough for your application, you can either:
claus
parents: 145
diff changeset
   196
	- redefine superViewChangedSize
claus
parents: 145
diff changeset
   197
	- create a special layoutObject which computes a new layout.
claus
parents: 145
diff changeset
   198
"
claus
parents: 145
diff changeset
   199
!
claus
parents: 145
diff changeset
   200
claus
parents: 145
diff changeset
   201
examples 
claus
parents: 145
diff changeset
   202
"
claus
parents: 145
diff changeset
   203
    (all examples below use different viewBackgrounds, 
claus
parents: 145
diff changeset
   204
     to make the individual subviews visible)
claus
parents: 145
diff changeset
   205
claus
parents: 145
diff changeset
   206
    fixed position/size:
claus
parents: 145
diff changeset
   207
claus
parents: 145
diff changeset
   208
       |top v1 v2|
claus
parents: 145
diff changeset
   209
claus
parents: 145
diff changeset
   210
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   211
       top extent:300@300.
claus
parents: 145
diff changeset
   212
claus
parents: 145
diff changeset
   213
       v1 := View origin:10@10
claus
parents: 145
diff changeset
   214
		  corner:50@50
claus
parents: 145
diff changeset
   215
		      in:top.
claus
parents: 145
diff changeset
   216
       v2 := View origin:60@10
claus
parents: 145
diff changeset
   217
		  corner:150@100
claus
parents: 145
diff changeset
   218
		      in:top.
claus
parents: 145
diff changeset
   219
claus
parents: 145
diff changeset
   220
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   221
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   222
claus
parents: 145
diff changeset
   223
       top open
claus
parents: 145
diff changeset
   224
claus
parents: 145
diff changeset
   225
claus
parents: 145
diff changeset
   226
    same, using ST-80 way of bulding up view hierarchies
claus
parents: 145
diff changeset
   227
    (recommended, if you plan to port applications later)
claus
parents: 145
diff changeset
   228
claus
parents: 145
diff changeset
   229
       |top v1 v2|
claus
parents: 145
diff changeset
   230
claus
parents: 145
diff changeset
   231
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   232
       top extent:300@300.
claus
parents: 145
diff changeset
   233
claus
parents: 145
diff changeset
   234
       v1 := View new.
claus
parents: 145
diff changeset
   235
       v1 origin:10@10 corner:50@50.
claus
parents: 145
diff changeset
   236
claus
parents: 145
diff changeset
   237
       v2 := View new.
claus
parents: 145
diff changeset
   238
       v2 origin:60@10 corner:150@100.
claus
parents: 145
diff changeset
   239
claus
parents: 145
diff changeset
   240
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   241
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   242
claus
parents: 145
diff changeset
   243
       top add:v1.
claus
parents: 145
diff changeset
   244
       top add:v2.
claus
parents: 145
diff changeset
   245
claus
parents: 145
diff changeset
   246
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   247
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   248
claus
parents: 145
diff changeset
   249
       top open
claus
parents: 145
diff changeset
   250
claus
parents: 145
diff changeset
   251
claus
parents: 145
diff changeset
   252
    fixed origin, variable size:
claus
parents: 145
diff changeset
   253
claus
parents: 145
diff changeset
   254
       |top v1 v2|
claus
parents: 145
diff changeset
   255
claus
parents: 145
diff changeset
   256
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   257
       top extent:300@300.
claus
parents: 145
diff changeset
   258
claus
parents: 145
diff changeset
   259
       v1 := View new.
claus
parents: 145
diff changeset
   260
       v1 origin:10@10 corner:50@0.5.
claus
parents: 145
diff changeset
   261
claus
parents: 145
diff changeset
   262
       v2 := View new.
claus
parents: 145
diff changeset
   263
       v2 origin:60@10 corner:150@0.5.
claus
parents: 145
diff changeset
   264
claus
parents: 145
diff changeset
   265
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   266
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   267
claus
parents: 145
diff changeset
   268
       top add:v1.
claus
parents: 145
diff changeset
   269
       top add:v2.
claus
parents: 145
diff changeset
   270
claus
parents: 145
diff changeset
   271
       top open
claus
parents: 145
diff changeset
   272
claus
parents: 145
diff changeset
   273
claus
parents: 145
diff changeset
   274
    fixed origin, variable size, 
claus
parents: 145
diff changeset
   275
    bottomInset for constant distance from bottom:
claus
parents: 145
diff changeset
   276
claus
parents: 145
diff changeset
   277
       |top v1 v2|
claus
parents: 145
diff changeset
   278
claus
parents: 145
diff changeset
   279
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   280
       top extent:300@300.
claus
parents: 145
diff changeset
   281
claus
parents: 145
diff changeset
   282
       v1 := View new.
claus
parents: 145
diff changeset
   283
       v1 origin:10@10 corner:50@1.0.
claus
parents: 145
diff changeset
   284
       v1 bottomInset:10.
claus
parents: 145
diff changeset
   285
claus
parents: 145
diff changeset
   286
       v2 := View new.
claus
parents: 145
diff changeset
   287
       v2 origin:60@10 corner:150@1.0.
claus
parents: 145
diff changeset
   288
       v2 bottomInset:10.
claus
parents: 145
diff changeset
   289
claus
parents: 145
diff changeset
   290
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   291
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   292
claus
parents: 145
diff changeset
   293
       top add:v1.
claus
parents: 145
diff changeset
   294
       top add:v2.
claus
parents: 145
diff changeset
   295
claus
parents: 145
diff changeset
   296
       top open
claus
parents: 145
diff changeset
   297
claus
parents: 145
diff changeset
   298
claus
parents: 145
diff changeset
   299
    variable origin, variable size, 
claus
parents: 145
diff changeset
   300
claus
parents: 145
diff changeset
   301
       |top v1 v2|
claus
parents: 145
diff changeset
   302
claus
parents: 145
diff changeset
   303
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   304
       top extent:300@300.
claus
parents: 145
diff changeset
   305
claus
parents: 145
diff changeset
   306
       v1 := View new.
claus
parents: 145
diff changeset
   307
       v1 origin:0.0@0.0 corner:0.5@0.5.
claus
parents: 145
diff changeset
   308
claus
parents: 145
diff changeset
   309
       v2 := View new.
claus
parents: 145
diff changeset
   310
       v2 origin:0.5@0.0 corner:1.0@0.5.
claus
parents: 145
diff changeset
   311
claus
parents: 145
diff changeset
   312
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   313
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   314
claus
parents: 145
diff changeset
   315
       top add:v1.
claus
parents: 145
diff changeset
   316
       top add:v2.
claus
parents: 145
diff changeset
   317
claus
parents: 145
diff changeset
   318
       top open
claus
parents: 145
diff changeset
   319
claus
parents: 145
diff changeset
   320
claus
parents: 145
diff changeset
   321
    variable origin, variable size, 
claus
parents: 145
diff changeset
   322
    insets for some constant distance
claus
parents: 145
diff changeset
   323
claus
parents: 145
diff changeset
   324
       |top v1 v2|
claus
parents: 145
diff changeset
   325
claus
parents: 145
diff changeset
   326
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   327
       top extent:300@300.
claus
parents: 145
diff changeset
   328
claus
parents: 145
diff changeset
   329
       v1 := View new.
claus
parents: 145
diff changeset
   330
       v1 origin:0.0@0.0 corner:0.5@0.5.
claus
parents: 145
diff changeset
   331
       v1 rightInset:5.
claus
parents: 145
diff changeset
   332
claus
parents: 145
diff changeset
   333
       v2 := View new.
claus
parents: 145
diff changeset
   334
       v2 origin:0.5@0.0 corner:1.0@0.5.
claus
parents: 145
diff changeset
   335
       v2 leftInset:5.
claus
parents: 145
diff changeset
   336
claus
parents: 145
diff changeset
   337
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   338
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   339
claus
parents: 145
diff changeset
   340
       top add:v1.
claus
parents: 145
diff changeset
   341
       top add:v2.
claus
parents: 145
diff changeset
   342
claus
parents: 145
diff changeset
   343
       top open
claus
parents: 145
diff changeset
   344
claus
parents: 145
diff changeset
   345
claus
parents: 145
diff changeset
   346
    using layout objects (ST-80 style):
claus
parents: 145
diff changeset
   347
    fully specifying the frame
claus
parents: 145
diff changeset
   348
claus
parents: 145
diff changeset
   349
       |top v1 v2|
claus
parents: 145
diff changeset
   350
claus
parents: 145
diff changeset
   351
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   352
       top extent:300@300.
claus
parents: 145
diff changeset
   353
claus
parents: 145
diff changeset
   354
       v1 := View new.
claus
parents: 145
diff changeset
   355
       v2 := View new.
claus
parents: 145
diff changeset
   356
claus
parents: 145
diff changeset
   357
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   358
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   359
claus
parents: 145
diff changeset
   360
       top add:v1 in:(LayoutFrame new
claus
parents: 145
diff changeset
   361
			leftFraction:0.25;
claus
parents: 145
diff changeset
   362
			rightFraction:0.75;
claus
parents: 145
diff changeset
   363
			topFraction:0.0;
claus
parents: 145
diff changeset
   364
			bottomFraction:0.5).
claus
parents: 145
diff changeset
   365
       top add:v2 in:(LayoutFrame new
claus
parents: 145
diff changeset
   366
			leftFraction:0.5;
claus
parents: 145
diff changeset
   367
			rightFraction:1.0;
claus
parents: 145
diff changeset
   368
			topFraction:0.5;
claus
parents: 145
diff changeset
   369
			bottomFraction:0.75).
claus
parents: 145
diff changeset
   370
claus
parents: 145
diff changeset
   371
       top open
claus
parents: 145
diff changeset
   372
claus
parents: 145
diff changeset
   373
claus
parents: 145
diff changeset
   374
    another one, with offsets:
claus
parents: 145
diff changeset
   375
claus
parents: 145
diff changeset
   376
       |top v1 v2|
claus
parents: 145
diff changeset
   377
claus
parents: 145
diff changeset
   378
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   379
       top extent:300@300.
claus
parents: 145
diff changeset
   380
claus
parents: 145
diff changeset
   381
       v1 := View new.
claus
parents: 145
diff changeset
   382
       v2 := View new.
claus
parents: 145
diff changeset
   383
claus
parents: 145
diff changeset
   384
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   385
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   386
claus
parents: 145
diff changeset
   387
       top add:v1 in:(LayoutFrame new
claus
parents: 145
diff changeset
   388
			leftFraction:0.0 offset:10;
claus
parents: 145
diff changeset
   389
			rightFraction:1.0 offset:-10;
claus
parents: 145
diff changeset
   390
			topFraction:0.0 offset:10;
claus
parents: 145
diff changeset
   391
			bottomFraction:0.5).
claus
parents: 145
diff changeset
   392
       top add:v2 in:(LayoutFrame new
claus
parents: 145
diff changeset
   393
			leftFraction:0.0 offset:30;
claus
parents: 145
diff changeset
   394
			rightFraction:1.0 offset:-30;
claus
parents: 145
diff changeset
   395
			topFraction:0.5 offset:10;
claus
parents: 145
diff changeset
   396
			bottomFraction:0.75).
claus
parents: 145
diff changeset
   397
claus
parents: 145
diff changeset
   398
       top open
claus
parents: 145
diff changeset
   399
claus
parents: 145
diff changeset
   400
claus
parents: 145
diff changeset
   401
    specifying origin only. Extent is views preferred
claus
parents: 145
diff changeset
   402
    (notice, that plain views have some defaultExtent of 100@100)
claus
parents: 145
diff changeset
   403
claus
parents: 145
diff changeset
   404
       |top v1 v2|
claus
parents: 145
diff changeset
   405
claus
parents: 145
diff changeset
   406
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   407
       top extent:300@300.
claus
parents: 145
diff changeset
   408
claus
parents: 145
diff changeset
   409
       v1 := View new.
claus
parents: 145
diff changeset
   410
       v2 := View new.
claus
parents: 145
diff changeset
   411
claus
parents: 145
diff changeset
   412
       v1 viewBackground:(Color red).
claus
parents: 145
diff changeset
   413
       v2 viewBackground:(Color yellow).
claus
parents: 145
diff changeset
   414
claus
parents: 145
diff changeset
   415
       top add:v1 in:(LayoutOrigin new
claus
parents: 145
diff changeset
   416
			leftFraction:0.25;
claus
parents: 145
diff changeset
   417
			topFraction:0.0).
claus
parents: 145
diff changeset
   418
       top add:v2 in:(LayoutOrigin new
claus
parents: 145
diff changeset
   419
			leftFraction:0.5;
claus
parents: 145
diff changeset
   420
			topFraction:0.5).
claus
parents: 145
diff changeset
   421
claus
parents: 145
diff changeset
   422
       top open
claus
parents: 145
diff changeset
   423
claus
parents: 145
diff changeset
   424
    same example, using buttons which compute their preferredBounds:
claus
parents: 145
diff changeset
   425
claus
parents: 145
diff changeset
   426
       |top v1 v2|
claus
parents: 145
diff changeset
   427
claus
parents: 145
diff changeset
   428
       top := StandardSystemView new.
claus
parents: 145
diff changeset
   429
       top extent:300@300.
claus
parents: 145
diff changeset
   430
claus
parents: 145
diff changeset
   431
       v1 := Button label:'foo'.
claus
parents: 145
diff changeset
   432
       v2 := Button label:'a very long buttonLabel'.
claus
parents: 145
diff changeset
   433
claus
parents: 145
diff changeset
   434
       v1 backgroundColor:(Color red).
claus
parents: 145
diff changeset
   435
       v2 backgroundColor:(Color yellow).
claus
parents: 145
diff changeset
   436
claus
parents: 145
diff changeset
   437
       top add:v1 in:(LayoutOrigin new
claus
parents: 145
diff changeset
   438
			leftFraction:0.25;
claus
parents: 145
diff changeset
   439
			topFraction:0.0).
claus
parents: 145
diff changeset
   440
       top add:v2 in:(LayoutOrigin new
claus
parents: 145
diff changeset
   441
			leftFraction:0.5;
claus
parents: 145
diff changeset
   442
			topFraction:0.5).
claus
parents: 145
diff changeset
   443
claus
parents: 145
diff changeset
   444
       top open
claus
parents: 145
diff changeset
   445
claus
parents: 145
diff changeset
   446
"
135
claus
parents:
diff changeset
   447
! !
claus
parents:
diff changeset
   448
claus
parents:
diff changeset
   449
!SimpleView class methodsFor:'initialization'!
claus
parents:
diff changeset
   450
claus
parents:
diff changeset
   451
initialize
claus
parents:
diff changeset
   452
    DefaultStyle isNil ifTrue:[
claus
parents:
diff changeset
   453
	Font initialize.
claus
parents:
diff changeset
   454
	Form initialize.
claus
parents:
diff changeset
   455
	Color initialize.
claus
parents:
diff changeset
   456
claus
parents:
diff changeset
   457
	Display notNil ifTrue:[
claus
parents:
diff changeset
   458
	    self defaultStyle:#normal.
claus
parents:
diff changeset
   459
	].
claus
parents:
diff changeset
   460
claus
parents:
diff changeset
   461
"/    self updateStyleCache.
claus
parents:
diff changeset
   462
	self == SimpleView ifTrue:[
claus
parents:
diff changeset
   463
	    Smalltalk addDependent:self   "/ to get language changes
claus
parents:
diff changeset
   464
	]
claus
parents:
diff changeset
   465
    ]
claus
parents:
diff changeset
   466
!
claus
parents:
diff changeset
   467
claus
parents:
diff changeset
   468
postAutoload
claus
parents:
diff changeset
   469
    self updateStyleCache.
claus
parents:
diff changeset
   470
! !
claus
parents:
diff changeset
   471
claus
parents:
diff changeset
   472
!SimpleView class methodsFor:'instance creation'!
claus
parents:
diff changeset
   473
140
claus
parents: 138
diff changeset
   474
on:aModel
claus
parents: 138
diff changeset
   475
    "create a new drawable on aModel"
claus
parents: 138
diff changeset
   476
claus
parents: 138
diff changeset
   477
    "although this one does not know about models,
claus
parents: 138
diff changeset
   478
     it can still send the model-assign message. This was done
claus
parents: 138
diff changeset
   479
     to catch obsolete calls to on:aDevice.
claus
parents: 138
diff changeset
   480
    "
claus
parents: 138
diff changeset
   481
    ^ self new model:aModel.
135
claus
parents:
diff changeset
   482
!
claus
parents:
diff changeset
   483
claus
parents:
diff changeset
   484
in:aView
claus
parents:
diff changeset
   485
    "return a new view as a subview of aView.
claus
parents:
diff changeset
   486
     If aView is nil, it is left unspecified, in which superview
claus
parents:
diff changeset
   487
     the new view will be placed. The view can later be assigned
claus
parents:
diff changeset
   488
     by adding it to the superview via #addSubView:.
claus
parents:
diff changeset
   489
     If realized and no superview has ever been set, it will come
claus
parents:
diff changeset
   490
     up as a topview."
claus
parents:
diff changeset
   491
claus
parents:
diff changeset
   492
    |newView|
claus
parents:
diff changeset
   493
claus
parents:
diff changeset
   494
    newView := self basicNew.
claus
parents:
diff changeset
   495
    aView notNil ifTrue:[
claus
parents:
diff changeset
   496
	newView device:(aView device).
claus
parents:
diff changeset
   497
	newView superView:aView.
claus
parents:
diff changeset
   498
    ] ifFalse:[
151
claus
parents: 145
diff changeset
   499
	newView device:Screen current "Display"
135
claus
parents:
diff changeset
   500
    ].
claus
parents:
diff changeset
   501
    newView initialize.
claus
parents:
diff changeset
   502
    aView notNil ifTrue:[aView addSubView:newView].
claus
parents:
diff changeset
   503
    ^ newView
claus
parents:
diff changeset
   504
!
claus
parents:
diff changeset
   505
140
claus
parents: 138
diff changeset
   506
label:label
claus
parents: 138
diff changeset
   507
    "create a new view with given label"
135
claus
parents:
diff changeset
   508
claus
parents:
diff changeset
   509
    ^ self origin:nil extent:nil borderWidth:nil
140
claus
parents: 138
diff changeset
   510
		      font:nil label:label in:nil
claus
parents: 138
diff changeset
   511
!
claus
parents: 138
diff changeset
   512
claus
parents: 138
diff changeset
   513
origin:origin corner:corner in:aView
135
claus
parents:
diff changeset
   514
    "create a new view as a subview of aView with given origin and extent"
claus
parents:
diff changeset
   515
140
claus
parents: 138
diff changeset
   516
    ^ self origin:origin corner:corner borderWidth:nil
135
claus
parents:
diff changeset
   517
			 font:nil label:nil in:aView
claus
parents:
diff changeset
   518
!
claus
parents:
diff changeset
   519
claus
parents:
diff changeset
   520
origin:anOrigin extent:anExtent borderWidth:bw font:aFont label:aLabel in:aView
claus
parents:
diff changeset
   521
    |newView|
claus
parents:
diff changeset
   522
claus
parents:
diff changeset
   523
    aView notNil ifTrue:[
claus
parents:
diff changeset
   524
	newView := self basicNew.
claus
parents:
diff changeset
   525
	newView device:(aView device).
claus
parents:
diff changeset
   526
	aView addSubView:newView.
claus
parents:
diff changeset
   527
	newView initialize
claus
parents:
diff changeset
   528
    ] ifFalse:[
151
claus
parents: 145
diff changeset
   529
	newView := self onDevice:Screen current "Display"
135
claus
parents:
diff changeset
   530
    ].
claus
parents:
diff changeset
   531
    bw notNil ifTrue:[newView borderWidth:bw].
claus
parents:
diff changeset
   532
    anExtent notNil ifTrue:[newView extent:anExtent].
claus
parents:
diff changeset
   533
    anOrigin notNil ifTrue:[newView origin:anOrigin].
claus
parents:
diff changeset
   534
    aFont notNil ifTrue:[newView font:aFont].
claus
parents:
diff changeset
   535
    aLabel notNil ifTrue:[newView label:aLabel].
claus
parents:
diff changeset
   536
    ^ newView
claus
parents:
diff changeset
   537
!
claus
parents:
diff changeset
   538
claus
parents:
diff changeset
   539
origin:anOrigin corner:aCorner borderWidth:bw font:aFont label:aLabel in:aView
claus
parents:
diff changeset
   540
    |newView|
claus
parents:
diff changeset
   541
claus
parents:
diff changeset
   542
    aView notNil ifTrue:[
claus
parents:
diff changeset
   543
	newView := self basicNew.
claus
parents:
diff changeset
   544
	newView device:(aView device).
claus
parents:
diff changeset
   545
	aView addSubView:newView.
claus
parents:
diff changeset
   546
	newView initialize
claus
parents:
diff changeset
   547
    ] ifFalse:[
151
claus
parents: 145
diff changeset
   548
	newView := self onDevice:Screen current "Display"
135
claus
parents:
diff changeset
   549
    ].
claus
parents:
diff changeset
   550
    bw notNil ifTrue:[newView borderWidth:bw].
claus
parents:
diff changeset
   551
    anOrigin notNil ifTrue:[newView origin:anOrigin].
claus
parents:
diff changeset
   552
    aCorner notNil ifTrue:[newView corner:aCorner].
claus
parents:
diff changeset
   553
    aFont notNil ifTrue:[newView font:aFont].
claus
parents:
diff changeset
   554
    aLabel notNil ifTrue:[newView label:aLabel].
claus
parents:
diff changeset
   555
    ^ newView
claus
parents:
diff changeset
   556
!
claus
parents:
diff changeset
   557
140
claus
parents: 138
diff changeset
   558
label:label in:aView
claus
parents: 138
diff changeset
   559
    "create a new view as subview of aView with given label"
135
claus
parents:
diff changeset
   560
claus
parents:
diff changeset
   561
    ^ self origin:nil extent:nil borderWidth:nil
140
claus
parents: 138
diff changeset
   562
		      font:nil label:label in:aView
claus
parents: 138
diff changeset
   563
!
claus
parents: 138
diff changeset
   564
claus
parents: 138
diff changeset
   565
onSameDeviceAs:anotherView
claus
parents: 138
diff changeset
   566
    "create a view on the same device as anotherView.
claus
parents: 138
diff changeset
   567
     Used with popUpMenus, which should be created on the device of
claus
parents: 138
diff changeset
   568
     its masterView."
claus
parents: 138
diff changeset
   569
claus
parents: 138
diff changeset
   570
    |device|
claus
parents: 138
diff changeset
   571
claus
parents: 138
diff changeset
   572
    anotherView notNil ifTrue:[
claus
parents: 138
diff changeset
   573
	device := anotherView device.
claus
parents: 138
diff changeset
   574
    ] ifFalse:[
151
claus
parents: 145
diff changeset
   575
	device := Screen current "Display".
140
claus
parents: 138
diff changeset
   576
    ].
claus
parents: 138
diff changeset
   577
    ^ self onDevice:device
claus
parents: 138
diff changeset
   578
!
claus
parents: 138
diff changeset
   579
claus
parents: 138
diff changeset
   580
extent:extent in:aView
claus
parents: 138
diff changeset
   581
    "create a new view as a subview of aView with given extent"
claus
parents: 138
diff changeset
   582
claus
parents: 138
diff changeset
   583
    ^ self origin:nil extent:extent borderWidth:nil
claus
parents: 138
diff changeset
   584
		      font:nil label:nil in:aView
135
claus
parents:
diff changeset
   585
!
claus
parents:
diff changeset
   586
claus
parents:
diff changeset
   587
origin:anOrigin extent:anExtent
claus
parents:
diff changeset
   588
		label:aLabel icon:aForm
claus
parents:
diff changeset
   589
		minExtent:minExtent maxExtent:maxExtent
claus
parents:
diff changeset
   590
    |newView|
claus
parents:
diff changeset
   591
151
claus
parents: 145
diff changeset
   592
    newView := self onDevice:Screen current "Display".
135
claus
parents:
diff changeset
   593
    anOrigin notNil ifTrue:[newView origin:anOrigin].
claus
parents:
diff changeset
   594
    anExtent notNil ifTrue:[newView extent:anExtent].
claus
parents:
diff changeset
   595
    aLabel notNil ifTrue:[newView label:aLabel].
claus
parents:
diff changeset
   596
    aForm notNil ifTrue:[newView icon:aForm].
claus
parents:
diff changeset
   597
    minExtent notNil ifTrue:[newView minExtent:minExtent].
claus
parents:
diff changeset
   598
    maxExtent notNil ifTrue:[newView maxExtent:maxExtent].
claus
parents:
diff changeset
   599
    ^ newView
claus
parents:
diff changeset
   600
!
claus
parents:
diff changeset
   601
140
claus
parents: 138
diff changeset
   602
extent:extent
claus
parents: 138
diff changeset
   603
    "create a new view with given extent"
claus
parents: 138
diff changeset
   604
claus
parents: 138
diff changeset
   605
    ^ self origin:nil extent:extent borderWidth:nil
claus
parents: 138
diff changeset
   606
		      font:nil label:nil in:nil
claus
parents: 138
diff changeset
   607
!
claus
parents: 138
diff changeset
   608
claus
parents: 138
diff changeset
   609
origin:origin extent:extent in:aView
claus
parents: 138
diff changeset
   610
    "create a new view as a subview of aView with given origin and extent"
claus
parents: 138
diff changeset
   611
claus
parents: 138
diff changeset
   612
    ^ self origin:origin extent:extent borderWidth:nil
claus
parents: 138
diff changeset
   613
			 font:nil label:nil in:aView
claus
parents: 138
diff changeset
   614
!
claus
parents: 138
diff changeset
   615
claus
parents: 138
diff changeset
   616
origin:origin in:aView
claus
parents: 138
diff changeset
   617
    "create a new view as a subview of aView with given origin"
claus
parents: 138
diff changeset
   618
claus
parents: 138
diff changeset
   619
    ^ self origin:origin extent:nil borderWidth:nil
claus
parents: 138
diff changeset
   620
			 font:nil label:nil in:aView
claus
parents: 138
diff changeset
   621
!
claus
parents: 138
diff changeset
   622
claus
parents: 138
diff changeset
   623
origin:origin extent:extent
claus
parents: 138
diff changeset
   624
    "create a new view with given origin and extent"
claus
parents: 138
diff changeset
   625
claus
parents: 138
diff changeset
   626
    ^ self origin:origin extent:extent borderWidth:nil
claus
parents: 138
diff changeset
   627
			 font:nil label:nil in:nil
claus
parents: 138
diff changeset
   628
!
claus
parents: 138
diff changeset
   629
claus
parents: 138
diff changeset
   630
origin:origin extent:extent borderWidth:bw in:aView
claus
parents: 138
diff changeset
   631
    "create a new view as a subview of aView with given origin, extent
claus
parents: 138
diff changeset
   632
     and borderWidth"
claus
parents: 138
diff changeset
   633
claus
parents: 138
diff changeset
   634
    ^ self origin:origin extent:extent borderWidth:bw
claus
parents: 138
diff changeset
   635
			 font:nil label:nil in:aView
claus
parents: 138
diff changeset
   636
!
claus
parents: 138
diff changeset
   637
claus
parents: 138
diff changeset
   638
origin:origin extent:extent borderWidth:bw
claus
parents: 138
diff changeset
   639
    "create a new view with given origin, extent and borderWidth"
claus
parents: 138
diff changeset
   640
claus
parents: 138
diff changeset
   641
    ^ self origin:origin extent:extent borderWidth:bw
claus
parents: 138
diff changeset
   642
			 font:nil label:nil in:nil
claus
parents: 138
diff changeset
   643
!
claus
parents: 138
diff changeset
   644
135
claus
parents:
diff changeset
   645
extent:extent label:label
claus
parents:
diff changeset
   646
    "create a new view with given extent and label"
claus
parents:
diff changeset
   647
claus
parents:
diff changeset
   648
    ^ self origin:nil extent:extent borderWidth:nil
claus
parents:
diff changeset
   649
		      font:nil label:label in:nil
claus
parents:
diff changeset
   650
!
claus
parents:
diff changeset
   651
140
claus
parents: 138
diff changeset
   652
origin:origin corner:corner 
claus
parents: 138
diff changeset
   653
    "create a new view with given origin and extent"
claus
parents: 138
diff changeset
   654
claus
parents: 138
diff changeset
   655
    ^ self origin:origin corner:corner borderWidth:nil
claus
parents: 138
diff changeset
   656
			 font:nil label:nil in:nil
claus
parents: 138
diff changeset
   657
!
claus
parents: 138
diff changeset
   658
135
claus
parents:
diff changeset
   659
origin:origin extent:extent label:label
claus
parents:
diff changeset
   660
    "create a new view with given origin, extent and label"
claus
parents:
diff changeset
   661
claus
parents:
diff changeset
   662
    ^ self origin:origin extent:extent borderWidth:nil
claus
parents:
diff changeset
   663
			 font:nil label:label in:nil
claus
parents:
diff changeset
   664
!
claus
parents:
diff changeset
   665
claus
parents:
diff changeset
   666
origin:origin extent:extent font:aFont label:label
claus
parents:
diff changeset
   667
    ^ self origin:origin extent:extent borderWidth:nil
claus
parents:
diff changeset
   668
			 font:nil label:label in:nil
claus
parents:
diff changeset
   669
!
claus
parents:
diff changeset
   670
claus
parents:
diff changeset
   671
origin:origin extent:extent font:aFont label:label in:aView
claus
parents:
diff changeset
   672
    ^ self origin:origin extent:extent borderWidth:nil
claus
parents:
diff changeset
   673
			 font:aFont label:label in:aView
claus
parents:
diff changeset
   674
!
claus
parents:
diff changeset
   675
claus
parents:
diff changeset
   676
origin:origin corner:corner borderWidth:bw in:aView
claus
parents:
diff changeset
   677
    "create a new view as a subview of aView with given origin and extent"
claus
parents:
diff changeset
   678
claus
parents:
diff changeset
   679
    ^ self origin:origin corner:corner borderWidth:bw
claus
parents:
diff changeset
   680
			 font:nil label:nil in:aView
claus
parents:
diff changeset
   681
! !
claus
parents:
diff changeset
   682
claus
parents:
diff changeset
   683
!SimpleView class methodsFor:'resources'!
claus
parents:
diff changeset
   684
claus
parents:
diff changeset
   685
classResources
claus
parents:
diff changeset
   686
    "if not already loaded, get the classes resourcePack
claus
parents:
diff changeset
   687
     and return it"
claus
parents:
diff changeset
   688
claus
parents:
diff changeset
   689
    ClassResources isNil ifTrue:[
claus
parents:
diff changeset
   690
	ClassResources := ResourcePack for:self.
claus
parents:
diff changeset
   691
    ].
claus
parents:
diff changeset
   692
    ^ ClassResources
claus
parents:
diff changeset
   693
!
claus
parents:
diff changeset
   694
claus
parents:
diff changeset
   695
classResources:aResourcePack
claus
parents:
diff changeset
   696
    "allow setting of the classResources"
claus
parents:
diff changeset
   697
claus
parents:
diff changeset
   698
    ClassResources := aResourcePack
claus
parents:
diff changeset
   699
!
claus
parents:
diff changeset
   700
claus
parents:
diff changeset
   701
flushAllClassResources
claus
parents:
diff changeset
   702
    "flush all classes resource translations.
claus
parents:
diff changeset
   703
     Needed after a resource file has changed."
claus
parents:
diff changeset
   704
claus
parents:
diff changeset
   705
    ResourcePack flushCachedResourcePacks.
140
claus
parents: 138
diff changeset
   706
    SimpleView flushClassResources.
claus
parents: 138
diff changeset
   707
    SimpleView allSubclasses do:[:aClass |
135
claus
parents:
diff changeset
   708
	aClass flushClassResources.
claus
parents:
diff changeset
   709
    ]
claus
parents:
diff changeset
   710
claus
parents:
diff changeset
   711
    "
claus
parents:
diff changeset
   712
     View flushAllClassResources
claus
parents:
diff changeset
   713
    "
claus
parents:
diff changeset
   714
    "to change the language:
claus
parents:
diff changeset
   715
	Language := #english.
claus
parents:
diff changeset
   716
	Smalltalk changed:#Language.
claus
parents:
diff changeset
   717
	View flushAllClassResources
claus
parents:
diff changeset
   718
     or:
claus
parents:
diff changeset
   719
	Language := #german.
claus
parents:
diff changeset
   720
	Smalltalk changed:#Language.
claus
parents:
diff changeset
   721
	View flushAllClassResources
claus
parents:
diff changeset
   722
    "     
claus
parents:
diff changeset
   723
!
claus
parents:
diff changeset
   724
claus
parents:
diff changeset
   725
flushClassResources
claus
parents:
diff changeset
   726
    "flush classes resource string translations.
claus
parents:
diff changeset
   727
     Needed whenever a resource file or language has changed"
claus
parents:
diff changeset
   728
claus
parents:
diff changeset
   729
    ClassResources := nil.
claus
parents:
diff changeset
   730
!
claus
parents:
diff changeset
   731
claus
parents:
diff changeset
   732
updateClassResources
claus
parents:
diff changeset
   733
    "flush classes resource string translations and reload them.
claus
parents:
diff changeset
   734
     Needed whenever a resource file or language has changed"
claus
parents:
diff changeset
   735
claus
parents:
diff changeset
   736
    ClassResources := nil.
claus
parents:
diff changeset
   737
    self classResources
claus
parents:
diff changeset
   738
! !
claus
parents:
diff changeset
   739
claus
parents:
diff changeset
   740
!SimpleView class methodsFor:'defaults'!
claus
parents:
diff changeset
   741
140
claus
parents: 138
diff changeset
   742
defaultExtent
claus
parents: 138
diff changeset
   743
    "define the default extent"
claus
parents: 138
diff changeset
   744
claus
parents: 138
diff changeset
   745
    CentPoint isNil ifTrue:[CentPoint := 100 @ 100].
claus
parents: 138
diff changeset
   746
    ^ CentPoint
claus
parents: 138
diff changeset
   747
!
claus
parents: 138
diff changeset
   748
135
claus
parents:
diff changeset
   749
viewSpacing
claus
parents:
diff changeset
   750
    "return a convenient number of pixels used to separate views (usually 1mm).
claus
parents:
diff changeset
   751
     Having this value here at a common place makes certain that all views
claus
parents:
diff changeset
   752
     get a common look"
claus
parents:
diff changeset
   753
claus
parents:
diff changeset
   754
    ^ ViewSpacing
claus
parents:
diff changeset
   755
!
claus
parents:
diff changeset
   756
claus
parents:
diff changeset
   757
defaultStyle:aStyle
claus
parents:
diff changeset
   758
    "set the view style for new views"
claus
parents:
diff changeset
   759
180
claus
parents: 176
diff changeset
   760
"/    aStyle ~~ DefaultStyle ifTrue:[
135
claus
parents:
diff changeset
   761
	DefaultStyle := aStyle.
claus
parents:
diff changeset
   762
	self updateAllStyleCaches.
180
claus
parents: 176
diff changeset
   763
"/    ]
135
claus
parents:
diff changeset
   764
claus
parents:
diff changeset
   765
    "
claus
parents:
diff changeset
   766
     View defaultStyle:#next. SystemBrowser start
claus
parents:
diff changeset
   767
     View defaultStyle:#motif. SystemBrowser start
claus
parents:
diff changeset
   768
     View defaultStyle:#iris. SystemBrowser start
claus
parents:
diff changeset
   769
     View defaultStyle:#st80. SystemBrowser start
claus
parents:
diff changeset
   770
     View defaultStyle:#normal. SystemBrowser start
claus
parents:
diff changeset
   771
    "
claus
parents:
diff changeset
   772
!
claus
parents:
diff changeset
   773
claus
parents:
diff changeset
   774
updateStyleCache
claus
parents:
diff changeset
   775
    "this method gets some heavily used style stuff and keeps
claus
parents:
diff changeset
   776
     it in class-variables for faster access.
claus
parents:
diff changeset
   777
     Subclasses should redefine this to load any cached style-values
claus
parents:
diff changeset
   778
     into faster class variables as well. These should NOT do a 
claus
parents:
diff changeset
   779
     super updateStyleCache, since this method is called for all view-classes
claus
parents:
diff changeset
   780
     anyway."
claus
parents:
diff changeset
   781
claus
parents:
diff changeset
   782
    |bgGrey|
claus
parents:
diff changeset
   783
claus
parents:
diff changeset
   784
    "
claus
parents:
diff changeset
   785
     when coming here the first time, we read the styleSheet
claus
parents:
diff changeset
   786
     and keep the values in fast class variables
claus
parents:
diff changeset
   787
    "
claus
parents:
diff changeset
   788
    StyleSheet isNil ifTrue:[
claus
parents:
diff changeset
   789
	DefaultStyle := #normal.
claus
parents:
diff changeset
   790
	StyleSheet := ViewStyle fromFile:'normal.style'.
claus
parents:
diff changeset
   791
    ].
claus
parents:
diff changeset
   792
claus
parents:
diff changeset
   793
    Grey := StyleSheet viewGrey.
claus
parents:
diff changeset
   794
    Grey isNil ifTrue:[
claus
parents:
diff changeset
   795
	Grey := Color grey
claus
parents:
diff changeset
   796
    ].
claus
parents:
diff changeset
   797
    Grey := Grey on:Display.
claus
parents:
diff changeset
   798
151
claus
parents: 145
diff changeset
   799
    StyleSheet fileReadFailed ifTrue:[
claus
parents: 145
diff changeset
   800
	bgGrey := White
135
claus
parents:
diff changeset
   801
    ] ifFalse:[
151
claus
parents: 145
diff changeset
   802
	Display hasGreyscales ifTrue:[
claus
parents: 145
diff changeset
   803
	    bgGrey := Grey
claus
parents: 145
diff changeset
   804
	] ifFalse:[
claus
parents: 145
diff changeset
   805
	    bgGrey := White 
claus
parents: 145
diff changeset
   806
	]
135
claus
parents:
diff changeset
   807
    ].
151
claus
parents: 145
diff changeset
   808
    bgGrey := bgGrey on:Display.
135
claus
parents:
diff changeset
   809
claus
parents:
diff changeset
   810
    ViewSpacing := StyleSheet at:'viewSpacing'.
claus
parents:
diff changeset
   811
    ViewSpacing isNil ifTrue:[
claus
parents:
diff changeset
   812
	ViewSpacing := Display verticalPixelPerMillimeter rounded.
claus
parents:
diff changeset
   813
    ].
claus
parents:
diff changeset
   814
claus
parents:
diff changeset
   815
    DefaultBorderColor := StyleSheet colorAt:'borderColor' default:Black.
151
claus
parents: 145
diff changeset
   816
claus
parents: 145
diff changeset
   817
    StyleSheet fileReadFailed ifTrue:[
claus
parents: 145
diff changeset
   818
	DefaultBorderWidth := 1.
claus
parents: 145
diff changeset
   819
	DefaultShadowColor := Black.
claus
parents: 145
diff changeset
   820
	DefaultLightColor :=  White.
claus
parents: 145
diff changeset
   821
	DefaultFocusColor := Black.
claus
parents: 145
diff changeset
   822
	DefaultFocusBorderWidth := 2.
claus
parents: 145
diff changeset
   823
	DefaultViewBackgroundColor := bgGrey.
claus
parents: 145
diff changeset
   824
    ] ifFalse:[
claus
parents: 145
diff changeset
   825
	DefaultBorderWidth := StyleSheet at:'borderWidth' default:0.
claus
parents: 145
diff changeset
   826
	DefaultViewBackgroundColor := StyleSheet colorAt:'viewBackground' default:bgGrey.
claus
parents: 145
diff changeset
   827
	DefaultShadowColor := StyleSheet colorAt:'shadowColor'.
claus
parents: 145
diff changeset
   828
	DefaultLightColor := StyleSheet colorAt:'lightColor'.
claus
parents: 145
diff changeset
   829
	DefaultFocusColor := StyleSheet colorAt:'focusColor' default:Color red.
claus
parents: 145
diff changeset
   830
	DefaultFocusBorderWidth := StyleSheet at:'focusBorderWidth' default:2.
claus
parents: 145
diff changeset
   831
    ].
135
claus
parents:
diff changeset
   832
claus
parents:
diff changeset
   833
    DefaultFont := StyleSheet at:'font'.
claus
parents:
diff changeset
   834
    DefaultFont isNil ifTrue:[
claus
parents:
diff changeset
   835
	DefaultFont := Font family:'courier' face:'medium' style:'roman' size:12.
claus
parents:
diff changeset
   836
    ].
claus
parents:
diff changeset
   837
claus
parents:
diff changeset
   838
    DefaultFont := DefaultFont on:Display.
claus
parents:
diff changeset
   839
claus
parents:
diff changeset
   840
    DefaultViewBackgroundColor isNil ifTrue:[
claus
parents:
diff changeset
   841
	'bad viewBackground in style - using white' errorPrintNL.
claus
parents:
diff changeset
   842
	DefaultViewBackgroundColor := White
claus
parents:
diff changeset
   843
    ].
claus
parents:
diff changeset
   844
!
claus
parents:
diff changeset
   845
140
claus
parents: 138
diff changeset
   846
defaultStyle
claus
parents: 138
diff changeset
   847
    "return the default view style"
claus
parents: 138
diff changeset
   848
claus
parents: 138
diff changeset
   849
    ^ DefaultStyle
claus
parents: 138
diff changeset
   850
claus
parents: 138
diff changeset
   851
    "
claus
parents: 138
diff changeset
   852
     View defaultStyle
claus
parents: 138
diff changeset
   853
    "
claus
parents: 138
diff changeset
   854
!
claus
parents: 138
diff changeset
   855
claus
parents: 138
diff changeset
   856
updateAllStyleCaches
claus
parents: 138
diff changeset
   857
    "reload all style caches in all view classes.
claus
parents: 138
diff changeset
   858
     Needed after a style change or when a style file has been changed"
claus
parents: 138
diff changeset
   859
claus
parents: 138
diff changeset
   860
    StyleSheet := ViewStyle fromFile:(DefaultStyle , '.style').
claus
parents: 138
diff changeset
   861
    StyleSheet fileReadFailed ifTrue:[
claus
parents: 138
diff changeset
   862
	('***** WARNING: no styleSheet for ' , DefaultStyle , '-style.') errorPrintNL.
151
claus
parents: 145
diff changeset
   863
	DefaultStyle ~~ #normal ifTrue:[
claus
parents: 145
diff changeset
   864
	    DefaultStyle := #normal.
claus
parents: 145
diff changeset
   865
	    StyleSheet := ViewStyle fromFile:(DefaultStyle , '.style').
claus
parents: 145
diff changeset
   866
        
claus
parents: 145
diff changeset
   867
	    StyleSheet fileReadFailed ifTrue:[
claus
parents: 145
diff changeset
   868
		'***** WARNING: not even a styleSheet for normal-style (using defaults).' errorPrintNL.
claus
parents: 145
diff changeset
   869
	    ]
140
claus
parents: 138
diff changeset
   870
	]
claus
parents: 138
diff changeset
   871
    ].
claus
parents: 138
diff changeset
   872
claus
parents: 138
diff changeset
   873
    "
claus
parents: 138
diff changeset
   874
     tell all view classes to flush any
claus
parents: 138
diff changeset
   875
     cached style-data
claus
parents: 138
diff changeset
   876
    "
claus
parents: 138
diff changeset
   877
    self changed:#style.
claus
parents: 138
diff changeset
   878
    SimpleView updateStyleCache.
claus
parents: 138
diff changeset
   879
    SimpleView allSubclassesDo:[:aClass |
claus
parents: 138
diff changeset
   880
	(aClass class implements:#updateStyleCache) ifTrue:[aClass updateStyleCache].
claus
parents: 138
diff changeset
   881
    ]
claus
parents: 138
diff changeset
   882
claus
parents: 138
diff changeset
   883
    "
claus
parents: 138
diff changeset
   884
     View updateAllStyleCaches
claus
parents: 138
diff changeset
   885
    "
claus
parents: 138
diff changeset
   886
!
claus
parents: 138
diff changeset
   887
claus
parents: 138
diff changeset
   888
defaultFont
claus
parents: 138
diff changeset
   889
    ^ DefaultFont notNil ifTrue:[DefaultFont] ifFalse:[super defaultFont]
claus
parents: 138
diff changeset
   890
!
claus
parents: 138
diff changeset
   891
135
claus
parents:
diff changeset
   892
styleSheet:aViewStyle
claus
parents:
diff changeset
   893
    "set the view style from a style-sheet"
claus
parents:
diff changeset
   894
claus
parents:
diff changeset
   895
    StyleSheet := aViewStyle.
claus
parents:
diff changeset
   896
    DefaultStyle := (StyleSheet at:'name' ifAbsent:'unknown') asSymbol.
claus
parents:
diff changeset
   897
    self updateAllStyleCaches.
claus
parents:
diff changeset
   898
! !
claus
parents:
diff changeset
   899
140
claus
parents: 138
diff changeset
   900
!SimpleView class methodsFor:'change & update'!
claus
parents: 138
diff changeset
   901
claus
parents: 138
diff changeset
   902
update:something
claus
parents: 138
diff changeset
   903
    something == #Language ifTrue:[
claus
parents: 138
diff changeset
   904
	"flush resources on language changes"
claus
parents: 138
diff changeset
   905
	self flushAllClassResources
135
claus
parents:
diff changeset
   906
    ]
claus
parents:
diff changeset
   907
! !
claus
parents:
diff changeset
   908
151
claus
parents: 145
diff changeset
   909
!SimpleView methodsFor:'copying'!
claus
parents: 145
diff changeset
   910
claus
parents: 145
diff changeset
   911
shallowCopyForFinalization
claus
parents: 145
diff changeset
   912
    "redefined for faster creation of finalization copies
claus
parents: 145
diff changeset
   913
     (only device, gcId and drawableId are needed)"
claus
parents: 145
diff changeset
   914
claus
parents: 145
diff changeset
   915
    |aCopy|
claus
parents: 145
diff changeset
   916
claus
parents: 145
diff changeset
   917
    aCopy := DeviceViewHandle basicNew.
claus
parents: 145
diff changeset
   918
    aCopy setDevice:device id:drawableId gcId:gcId.
claus
parents: 145
diff changeset
   919
    ^ aCopy
claus
parents: 145
diff changeset
   920
! !
claus
parents: 145
diff changeset
   921
135
claus
parents:
diff changeset
   922
!SimpleView methodsFor:'accessing-transformation'!
claus
parents:
diff changeset
   923
claus
parents:
diff changeset
   924
transformation 
claus
parents:
diff changeset
   925
    "return the transformation"
claus
parents:
diff changeset
   926
154
claus
parents: 153
diff changeset
   927
    |vP org|
135
claus
parents:
diff changeset
   928
claus
parents:
diff changeset
   929
    transformation isNil ifTrue:[
claus
parents:
diff changeset
   930
	"
claus
parents:
diff changeset
   931
	 fake a transformation, if I have a non-nil window
claus
parents:
diff changeset
   932
	"
claus
parents:
diff changeset
   933
	window notNil ifTrue:[
claus
parents:
diff changeset
   934
	    superView isNil ifTrue:[
154
claus
parents: 153
diff changeset
   935
		org := 0 @ 0
135
claus
parents:
diff changeset
   936
	    ] ifFalse:[
154
claus
parents: 153
diff changeset
   937
		org := self origin
135
claus
parents:
diff changeset
   938
	    ].
154
claus
parents: 153
diff changeset
   939
	    vP := org extent:(self extent).
claus
parents: 153
diff changeset
   940
	    ^ WindowingTransformation window:window viewport:vP
135
claus
parents:
diff changeset
   941
	]
claus
parents:
diff changeset
   942
    ].
claus
parents:
diff changeset
   943
    ^ transformation
claus
parents:
diff changeset
   944
!
claus
parents:
diff changeset
   945
claus
parents:
diff changeset
   946
viewRectangle
claus
parents:
diff changeset
   947
    "return the inside area"
claus
parents:
diff changeset
   948
claus
parents:
diff changeset
   949
    |m2|
claus
parents:
diff changeset
   950
140
claus
parents: 138
diff changeset
   951
"/    innerClipRect notNil ifTrue:[
claus
parents: 138
diff changeset
   952
"/        ^ innerClipRect
claus
parents: 138
diff changeset
   953
"/    ].
135
claus
parents:
diff changeset
   954
    m2 := margin + margin.
claus
parents:
diff changeset
   955
claus
parents:
diff changeset
   956
    ^ (margin @ margin) extent:((width - m2) @ (height - m2))
claus
parents:
diff changeset
   957
!
claus
parents:
diff changeset
   958
claus
parents:
diff changeset
   959
window
claus
parents:
diff changeset
   960
    "return my window (i.e. logical coordinate space).
claus
parents:
diff changeset
   961
     If there is no window, return the extent."
claus
parents:
diff changeset
   962
claus
parents:
diff changeset
   963
    window isNil ifTrue:[^ width @ height].
claus
parents:
diff changeset
   964
    ^ window
claus
parents:
diff changeset
   965
!
claus
parents:
diff changeset
   966
claus
parents:
diff changeset
   967
window:aRectangle
claus
parents:
diff changeset
   968
    "define my window (i.e. logical coordinate space)"
claus
parents:
diff changeset
   969
claus
parents:
diff changeset
   970
    window := aRectangle.
claus
parents:
diff changeset
   971
    subViews notNil ifTrue:[
claus
parents:
diff changeset
   972
	subViews do:[:s |
claus
parents:
diff changeset
   973
	    s superViewChangedSize
claus
parents:
diff changeset
   974
	]
claus
parents:
diff changeset
   975
    ]
claus
parents:
diff changeset
   976
claus
parents:
diff changeset
   977
"
claus
parents:
diff changeset
   978
    viewport isNil ifTrue:[
claus
parents:
diff changeset
   979
	viewport := aRectangle.
claus
parents:
diff changeset
   980
    ].
claus
parents:
diff changeset
   981
"
claus
parents:
diff changeset
   982
"
claus
parents:
diff changeset
   983
    superView notNil ifTrue:[
claus
parents:
diff changeset
   984
	self superViewChangedSize
claus
parents:
diff changeset
   985
    ] ifFalse:[
claus
parents:
diff changeset
   986
	originChanged := true.
claus
parents:
diff changeset
   987
	extentChanged := true
claus
parents:
diff changeset
   988
    ]
claus
parents:
diff changeset
   989
"
claus
parents:
diff changeset
   990
!
claus
parents:
diff changeset
   991
claus
parents:
diff changeset
   992
viewOrigin
claus
parents:
diff changeset
   993
    "return the viewOrigin; thats the coordinate of the contents 
claus
parents:
diff changeset
   994
     which is shown topLeft in the view 
claus
parents:
diff changeset
   995
     (i.e. the origin of the visible part of the contents)."
claus
parents:
diff changeset
   996
claus
parents:
diff changeset
   997
    transformation isNil ifTrue:[
claus
parents:
diff changeset
   998
	^ 0@0
claus
parents:
diff changeset
   999
    ].
claus
parents:
diff changeset
  1000
    ^ transformation translation negated
claus
parents:
diff changeset
  1001
!
claus
parents:
diff changeset
  1002
claus
parents:
diff changeset
  1003
setViewOrigin:aPoint
claus
parents:
diff changeset
  1004
    "set the viewOrigin - i.e. virtually scroll without redrawing"
claus
parents:
diff changeset
  1005
claus
parents:
diff changeset
  1006
    |p|
claus
parents:
diff changeset
  1007
claus
parents:
diff changeset
  1008
    p := aPoint negated.
claus
parents:
diff changeset
  1009
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  1010
	transformation := WindowingTransformation scale:1 translation:p 
claus
parents:
diff changeset
  1011
    ] ifFalse:[
claus
parents:
diff changeset
  1012
	transformation translation:p 
claus
parents:
diff changeset
  1013
    ].
claus
parents:
diff changeset
  1014
    clipRect notNil ifTrue:[
claus
parents:
diff changeset
  1015
	self setInnerClip.
claus
parents:
diff changeset
  1016
    ].
claus
parents:
diff changeset
  1017
!
claus
parents:
diff changeset
  1018
claus
parents:
diff changeset
  1019
viewport:aRectangle
claus
parents:
diff changeset
  1020
    "define my extend in my superviews coordinate-system."
claus
parents:
diff changeset
  1021
claus
parents:
diff changeset
  1022
"/    |relW relH relX relY winW winH|
claus
parents:
diff changeset
  1023
claus
parents:
diff changeset
  1024
    viewport := aRectangle.
claus
parents:
diff changeset
  1025
    self dimensionFromViewport
claus
parents:
diff changeset
  1026
"/
claus
parents:
diff changeset
  1027
"/    superView notNil ifTrue:[
claus
parents:
diff changeset
  1028
"/        superView window isNil ifTrue:[
claus
parents:
diff changeset
  1029
"/            winW := 1.
claus
parents:
diff changeset
  1030
"/            winH := 1
claus
parents:
diff changeset
  1031
"/        ] ifFalse:[
claus
parents:
diff changeset
  1032
"/            winW := superView window width.
claus
parents:
diff changeset
  1033
"/            winH := superView window height
claus
parents:
diff changeset
  1034
"/        ].
claus
parents:
diff changeset
  1035
"/        relW := (aRectangle width / winW) asFloat.
claus
parents:
diff changeset
  1036
"/        relH := (aRectangle height / winH) asFloat.
claus
parents:
diff changeset
  1037
"/        relX := (aRectangle left / winW) asFloat.
claus
parents:
diff changeset
  1038
"/        relY := (aRectangle top / winH) asFloat.
claus
parents:
diff changeset
  1039
"/        self origin:(relX @ relY) extent:(relW @ relH)
claus
parents:
diff changeset
  1040
"/    ]
claus
parents:
diff changeset
  1041
"/
claus
parents:
diff changeset
  1042
!
claus
parents:
diff changeset
  1043
claus
parents:
diff changeset
  1044
window:aRectangle viewport:vRect
claus
parents:
diff changeset
  1045
    window := aRectangle.
claus
parents:
diff changeset
  1046
    self viewport:vRect.
claus
parents:
diff changeset
  1047
    subViews notNil ifTrue:[
claus
parents:
diff changeset
  1048
	subViews do:[:s |
claus
parents:
diff changeset
  1049
	    s superViewChangedSize
claus
parents:
diff changeset
  1050
	]
claus
parents:
diff changeset
  1051
    ]
claus
parents:
diff changeset
  1052
!
claus
parents:
diff changeset
  1053
claus
parents:
diff changeset
  1054
scale
claus
parents:
diff changeset
  1055
    "return the scale factor (as point) of the transformation"
claus
parents:
diff changeset
  1056
claus
parents:
diff changeset
  1057
    transformation isNil ifTrue:[^ 1].
claus
parents:
diff changeset
  1058
    ^ transformation scale
claus
parents:
diff changeset
  1059
!
claus
parents:
diff changeset
  1060
claus
parents:
diff changeset
  1061
scale:aPoint
claus
parents:
diff changeset
  1062
    "set the scale factor of the transformation"
claus
parents:
diff changeset
  1063
claus
parents:
diff changeset
  1064
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  1065
	aPoint = 1 ifTrue:[^ self].
claus
parents:
diff changeset
  1066
	transformation := WindowingTransformation scale:aPoint translation:0
claus
parents:
diff changeset
  1067
    ].
claus
parents:
diff changeset
  1068
claus
parents:
diff changeset
  1069
    transformation scale:aPoint.
claus
parents:
diff changeset
  1070
    self computeInnerClip
claus
parents:
diff changeset
  1071
!
claus
parents:
diff changeset
  1072
claus
parents:
diff changeset
  1073
xOriginOfContents
claus
parents:
diff changeset
  1074
    "return the x coordinate of the viewOrigin in pixels; 
claus
parents:
diff changeset
  1075
     used by scrollBars to compute thumb position within the document."
claus
parents:
diff changeset
  1076
claus
parents:
diff changeset
  1077
    ^ self viewOrigin x
claus
parents:
diff changeset
  1078
!
claus
parents:
diff changeset
  1079
claus
parents:
diff changeset
  1080
yOriginOfContents
claus
parents:
diff changeset
  1081
    "return the y coordinate of the viewOrigin in pixels; 
claus
parents:
diff changeset
  1082
     used by scrollBars to compute thumb position within the document."
claus
parents:
diff changeset
  1083
claus
parents:
diff changeset
  1084
    ^ self viewOrigin y
claus
parents:
diff changeset
  1085
!
claus
parents:
diff changeset
  1086
claus
parents:
diff changeset
  1087
heightOfContents
claus
parents:
diff changeset
  1088
    "return the height of the contents in logical units 
claus
parents:
diff changeset
  1089
     - defaults to views visible area here.
claus
parents:
diff changeset
  1090
    This method MUST be redefined in all view classess which are
claus
parents:
diff changeset
  1091
    going to be scrolled AND show data which has different size than
claus
parents:
diff changeset
  1092
    the view. For example, a view showing A4-size documents should return
claus
parents:
diff changeset
  1093
    the number of vertical pixels such a document has on this device.
claus
parents:
diff changeset
  1094
    A view showing a bitmap of height 1000 should return 1000.
claus
parents:
diff changeset
  1095
    If not redefined, scrollbars have no way of knowing the actual size
claus
parents:
diff changeset
  1096
    of the contents being shown. This is called by scrollBars to compute
claus
parents:
diff changeset
  1097
    the relative height of the document vs. the views actual size.
claus
parents:
diff changeset
  1098
    The value returned here must be based on a scale of 1, since users
claus
parents:
diff changeset
  1099
    of this will scale as appropriate."
claus
parents:
diff changeset
  1100
claus
parents:
diff changeset
  1101
    ^ self innerHeight max:(self maxSubViewBottom)
claus
parents:
diff changeset
  1102
!
claus
parents:
diff changeset
  1103
claus
parents:
diff changeset
  1104
widthOfContents
claus
parents:
diff changeset
  1105
claus
parents:
diff changeset
  1106
    ^ self innerWidth max:(self maxSubViewRight)
claus
parents:
diff changeset
  1107
claus
parents:
diff changeset
  1108
!
claus
parents:
diff changeset
  1109
claus
parents:
diff changeset
  1110
maxSubViewBottom 
claus
parents:
diff changeset
  1111
"/    subViews isNil ifTrue:[^ 0].
claus
parents:
diff changeset
  1112
"/    ^ subViews inject:0 into:[:maxSoFar :sub | (sub top + sub height) max:maxSoFar].
claus
parents:
diff changeset
  1113
      ^ 0
claus
parents:
diff changeset
  1114
!
claus
parents:
diff changeset
  1115
claus
parents:
diff changeset
  1116
maxSubViewRight 
claus
parents:
diff changeset
  1117
"/    subViews isNil ifTrue:[^ 0].
claus
parents:
diff changeset
  1118
"/    ^ subViews inject:0 into:[:maxSoFar :sub | (sub left + sub width) max:maxSoFar].
claus
parents:
diff changeset
  1119
    ^ 0
claus
parents:
diff changeset
  1120
! !
claus
parents:
diff changeset
  1121
claus
parents:
diff changeset
  1122
!SimpleView methodsFor:'accessing-misc'!
claus
parents:
diff changeset
  1123
claus
parents:
diff changeset
  1124
shown
151
claus
parents: 145
diff changeset
  1125
    "return true if the view is shown; false if not.
claus
parents: 145
diff changeset
  1126
     Shown means: the view is mapped and is not completely covered."
135
claus
parents:
diff changeset
  1127
claus
parents:
diff changeset
  1128
    ^ shown
claus
parents:
diff changeset
  1129
!
claus
parents:
diff changeset
  1130
claus
parents:
diff changeset
  1131
inputOnly
claus
parents:
diff changeset
  1132
    "return true, if this view is an input-only view;
claus
parents:
diff changeset
  1133
     input only views are transparent and can be layed on top of a view to
claus
parents:
diff changeset
  1134
     catch its input"
claus
parents:
diff changeset
  1135
claus
parents:
diff changeset
  1136
    ^ false
claus
parents:
diff changeset
  1137
!
claus
parents:
diff changeset
  1138
157
claus
parents: 154
diff changeset
  1139
isPopUpView
135
claus
parents:
diff changeset
  1140
    "return true, if this view should be put on top (raised) automatically.
claus
parents:
diff changeset
  1141
     usually this is true for alertBoxes etc."
claus
parents:
diff changeset
  1142
claus
parents:
diff changeset
  1143
    ^ false
claus
parents:
diff changeset
  1144
!
claus
parents:
diff changeset
  1145
claus
parents:
diff changeset
  1146
is3D
151
claus
parents: 145
diff changeset
  1147
    "return true, if my style is some kind of 3D style
claus
parents: 145
diff changeset
  1148
     This is OBSOLETE and will be removed."
claus
parents: 145
diff changeset
  1149
claus
parents: 145
diff changeset
  1150
    ^ styleSheet is3D
135
claus
parents:
diff changeset
  1151
!
claus
parents:
diff changeset
  1152
claus
parents:
diff changeset
  1153
viewGravity:gravity
claus
parents:
diff changeset
  1154
    "set the viewGravity - thats the direction where the view will move
claus
parents:
diff changeset
  1155
     when the superView is resized."
claus
parents:
diff changeset
  1156
claus
parents:
diff changeset
  1157
    viewGravity ~~ gravity ifTrue:[
claus
parents:
diff changeset
  1158
	viewGravity := gravity.
claus
parents:
diff changeset
  1159
	drawableId notNil ifTrue:[
claus
parents:
diff changeset
  1160
	    device setWindowGravity:gravity in:drawableId
claus
parents:
diff changeset
  1161
	]
claus
parents:
diff changeset
  1162
    ]
claus
parents:
diff changeset
  1163
!
claus
parents:
diff changeset
  1164
140
claus
parents: 138
diff changeset
  1165
hidden:aBoolean
claus
parents: 138
diff changeset
  1166
    "if the argument is true, the receiver view will not
claus
parents: 138
diff changeset
  1167
     be realized automatically when superview is realized"
claus
parents: 138
diff changeset
  1168
151
claus
parents: 145
diff changeset
  1169
    self obsoleteMethodWarning:'use #hiddenOnRealize:'.
claus
parents: 145
diff changeset
  1170
    hiddenOnRealize := aBoolean
claus
parents: 145
diff changeset
  1171
!
claus
parents: 145
diff changeset
  1172
claus
parents: 145
diff changeset
  1173
isHiddenOnRealize:aBoolean
claus
parents: 145
diff changeset
  1174
    "return true, if the receiver will NOT be mapped when
claus
parents: 145
diff changeset
  1175
     realized. False otherwise.
claus
parents: 145
diff changeset
  1176
     The hiddenOnRealize flag is useful to create views which are
claus
parents: 145
diff changeset
  1177
     to be made visible conditionally or later."
claus
parents: 145
diff changeset
  1178
claus
parents: 145
diff changeset
  1179
    ^ hiddenOnRealize
claus
parents: 145
diff changeset
  1180
!
claus
parents: 145
diff changeset
  1181
claus
parents: 145
diff changeset
  1182
hiddenOnRealize:aBoolean
claus
parents: 145
diff changeset
  1183
    "if the argument is true, the receiver view will not
claus
parents: 145
diff changeset
  1184
     be mapped automatically when the superview is realized.
claus
parents: 145
diff changeset
  1185
     The hiddenOnRealize flag is useful to create views which are
claus
parents: 145
diff changeset
  1186
     to be made visible conditionally or later."
claus
parents: 145
diff changeset
  1187
claus
parents: 145
diff changeset
  1188
    hiddenOnRealize := aBoolean
140
claus
parents: 138
diff changeset
  1189
!
claus
parents: 138
diff changeset
  1190
135
claus
parents:
diff changeset
  1191
viewGravity
claus
parents:
diff changeset
  1192
    "return the viewGravity - thats the direction where the view will move
claus
parents:
diff changeset
  1193
     when the superView is resized."
claus
parents:
diff changeset
  1194
claus
parents:
diff changeset
  1195
    ^ viewGravity
claus
parents:
diff changeset
  1196
!
claus
parents:
diff changeset
  1197
claus
parents:
diff changeset
  1198
bitGravity
claus
parents:
diff changeset
  1199
    "return the bitGravity - thats the direction where the contents will move
claus
parents:
diff changeset
  1200
     when the the view is resized."
claus
parents:
diff changeset
  1201
claus
parents:
diff changeset
  1202
    ^ bitGravity
claus
parents:
diff changeset
  1203
!
claus
parents:
diff changeset
  1204
claus
parents:
diff changeset
  1205
bitGravity:gravity
claus
parents:
diff changeset
  1206
    "set the bitGravity - thats the direction where the contents will move
claus
parents:
diff changeset
  1207
     when the view is resized."
claus
parents:
diff changeset
  1208
claus
parents:
diff changeset
  1209
    bitGravity ~~ gravity ifTrue:[
claus
parents:
diff changeset
  1210
	bitGravity := gravity.
claus
parents:
diff changeset
  1211
	drawableId notNil ifTrue:[
claus
parents:
diff changeset
  1212
	    device setBitGravity:gravity in:drawableId
claus
parents:
diff changeset
  1213
	]
claus
parents:
diff changeset
  1214
    ]
claus
parents:
diff changeset
  1215
!
claus
parents:
diff changeset
  1216
claus
parents:
diff changeset
  1217
canDrop:anObjectOrCollection
claus
parents:
diff changeset
  1218
    "return true, if anObjectOrCollection can be
claus
parents:
diff changeset
  1219
     dropped in the receiver. This method should be
claus
parents:
diff changeset
  1220
     redefined in views which can take objects"
claus
parents:
diff changeset
  1221
claus
parents:
diff changeset
  1222
    ^ false
claus
parents:
diff changeset
  1223
!
claus
parents:
diff changeset
  1224
claus
parents:
diff changeset
  1225
hidden
claus
parents:
diff changeset
  1226
    "return true, if the view does not want to be realized
claus
parents:
diff changeset
  1227
     automatically when superview is realized"
claus
parents:
diff changeset
  1228
151
claus
parents: 145
diff changeset
  1229
    self obsoleteMethodWarning:'use #hiddenOnRealize'.
claus
parents: 145
diff changeset
  1230
    ^ hiddenOnRealize
153
claus
parents: 151
diff changeset
  1231
!
claus
parents: 151
diff changeset
  1232
claus
parents: 151
diff changeset
  1233
clipRect:aRectangle
claus
parents: 151
diff changeset
  1234
    "set the clipping rectangle for drawing (in logical coordinates);
claus
parents: 151
diff changeset
  1235
     a nil argument turn off clipping (i.e. whole view is drawable).
claus
parents: 151
diff changeset
  1236
     Redefined to care for any margin."
claus
parents: 151
diff changeset
  1237
claus
parents: 151
diff changeset
  1238
    |x y w h|
claus
parents: 151
diff changeset
  1239
claus
parents: 151
diff changeset
  1240
    aRectangle isNil ifTrue:[
claus
parents: 151
diff changeset
  1241
	clipRect isNil ifTrue:[^ self].
claus
parents: 151
diff changeset
  1242
	gcId notNil ifTrue:[
claus
parents: 151
diff changeset
  1243
	    device noClipIn:gcId
claus
parents: 151
diff changeset
  1244
	]
claus
parents: 151
diff changeset
  1245
    ] ifFalse:[
claus
parents: 151
diff changeset
  1246
	clipRect notNil ifTrue:[
claus
parents: 151
diff changeset
  1247
	    (clipRect = aRectangle) ifTrue:[^ self]
claus
parents: 151
diff changeset
  1248
	].
claus
parents: 151
diff changeset
  1249
	gcId notNil ifTrue:[
claus
parents: 151
diff changeset
  1250
	    x := aRectangle left.
claus
parents: 151
diff changeset
  1251
	    y := aRectangle top.
claus
parents: 151
diff changeset
  1252
	    w := aRectangle width.
claus
parents: 151
diff changeset
  1253
	    h := aRectangle height.
claus
parents: 151
diff changeset
  1254
	    transformation notNil ifTrue:[
claus
parents: 151
diff changeset
  1255
		x := transformation applyToX:x.
claus
parents: 151
diff changeset
  1256
		y := transformation applyToY:y.
claus
parents: 151
diff changeset
  1257
		w := transformation applyScaleX:w.
claus
parents: 151
diff changeset
  1258
		h := transformation applyScaleY:h.
claus
parents: 151
diff changeset
  1259
	    ].
claus
parents: 151
diff changeset
  1260
	    (x isMemberOf:SmallInteger) ifFalse:[
claus
parents: 151
diff changeset
  1261
		w := w + (x - x truncated).
claus
parents: 151
diff changeset
  1262
		x := x truncated
claus
parents: 151
diff changeset
  1263
	    ].
claus
parents: 151
diff changeset
  1264
	    (y isMemberOf:SmallInteger) ifFalse:[
claus
parents: 151
diff changeset
  1265
		h := h + (y - y truncated).
claus
parents: 151
diff changeset
  1266
		y := y truncated
claus
parents: 151
diff changeset
  1267
	    ].
claus
parents: 151
diff changeset
  1268
	    (w isMemberOf:SmallInteger) ifFalse:[
claus
parents: 151
diff changeset
  1269
		w := w truncated + 1
claus
parents: 151
diff changeset
  1270
	    ].
claus
parents: 151
diff changeset
  1271
	    (h isMemberOf:SmallInteger) ifFalse:[
claus
parents: 151
diff changeset
  1272
		h := h truncated + 1
claus
parents: 151
diff changeset
  1273
	    ].
claus
parents: 151
diff changeset
  1274
	    x < margin ifTrue:[
claus
parents: 151
diff changeset
  1275
		x := margin.
claus
parents: 151
diff changeset
  1276
	    ].
claus
parents: 151
diff changeset
  1277
	    y < margin ifTrue:[
claus
parents: 151
diff changeset
  1278
		y := margin.
claus
parents: 151
diff changeset
  1279
	    ].
claus
parents: 151
diff changeset
  1280
	    x + w - 1 >= (width-margin) ifTrue:[
claus
parents: 151
diff changeset
  1281
		w := width - margin - x
claus
parents: 151
diff changeset
  1282
	    ].
claus
parents: 151
diff changeset
  1283
	    y + h - 1 >= (height-margin) ifTrue:[
claus
parents: 151
diff changeset
  1284
		h := height - margin - y
claus
parents: 151
diff changeset
  1285
	    ].
claus
parents: 151
diff changeset
  1286
	    device setClipX:x y:y width:w height:h in:gcId
claus
parents: 151
diff changeset
  1287
	]
claus
parents: 151
diff changeset
  1288
    ].
claus
parents: 151
diff changeset
  1289
    clipRect := aRectangle
claus
parents: 151
diff changeset
  1290
!
claus
parents: 151
diff changeset
  1291
claus
parents: 151
diff changeset
  1292
name:aString
claus
parents: 151
diff changeset
  1293
    "set my name component to be used for resource-access"
claus
parents: 151
diff changeset
  1294
claus
parents: 151
diff changeset
  1295
    name := aString
claus
parents: 151
diff changeset
  1296
!
claus
parents: 151
diff changeset
  1297
claus
parents: 151
diff changeset
  1298
name
claus
parents: 151
diff changeset
  1299
    "return my name component to be used for resource-access"
claus
parents: 151
diff changeset
  1300
claus
parents: 151
diff changeset
  1301
    ^ name
claus
parents: 151
diff changeset
  1302
!
claus
parents: 151
diff changeset
  1303
claus
parents: 151
diff changeset
  1304
fullName
claus
parents: 151
diff changeset
  1305
    "return my full name to be used for resource-access"
claus
parents: 151
diff changeset
  1306
claus
parents: 151
diff changeset
  1307
    superView notNil ifTrue:[
claus
parents: 151
diff changeset
  1308
	^ superView fullName , '.' , name
claus
parents: 151
diff changeset
  1309
    ].
claus
parents: 151
diff changeset
  1310
    ^ name
claus
parents: 151
diff changeset
  1311
!
claus
parents: 151
diff changeset
  1312
claus
parents: 151
diff changeset
  1313
processName
claus
parents: 151
diff changeset
  1314
    "return a string to be shown in the process monitor"
claus
parents: 151
diff changeset
  1315
claus
parents: 151
diff changeset
  1316
    ^ self name
135
claus
parents:
diff changeset
  1317
! !
claus
parents:
diff changeset
  1318
140
claus
parents: 138
diff changeset
  1319
!SimpleView methodsFor:'ST-80 compatibility'!
claus
parents: 138
diff changeset
  1320
claus
parents: 138
diff changeset
  1321
sensor
claus
parents: 138
diff changeset
  1322
    "return the views sensor"
claus
parents: 138
diff changeset
  1323
claus
parents: 138
diff changeset
  1324
    windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  1325
	^ windowGroup sensor.
135
claus
parents:
diff changeset
  1326
    ].
140
claus
parents: 138
diff changeset
  1327
    ^ nil
claus
parents: 138
diff changeset
  1328
!
claus
parents: 138
diff changeset
  1329
claus
parents: 138
diff changeset
  1330
checkForEvents
claus
parents: 138
diff changeset
  1331
    (shown and:[windowGroup notNil]) ifTrue:[windowGroup processEvents].
claus
parents: 138
diff changeset
  1332
! !
claus
parents: 138
diff changeset
  1333
claus
parents: 138
diff changeset
  1334
!SimpleView methodsFor:'accessing-mvc'!
claus
parents: 138
diff changeset
  1335
claus
parents: 138
diff changeset
  1336
controller
claus
parents: 138
diff changeset
  1337
    "return the controller. For non MVC views, return nil"
claus
parents: 138
diff changeset
  1338
claus
parents: 138
diff changeset
  1339
    ^ controller
claus
parents: 138
diff changeset
  1340
!
claus
parents: 138
diff changeset
  1341
claus
parents: 138
diff changeset
  1342
windowGroup
claus
parents: 138
diff changeset
  1343
    "return the window group. For old style views, return nil"
claus
parents: 138
diff changeset
  1344
claus
parents: 138
diff changeset
  1345
    ^ windowGroup
claus
parents: 138
diff changeset
  1346
!
claus
parents: 138
diff changeset
  1347
claus
parents: 138
diff changeset
  1348
controller:aController
claus
parents: 138
diff changeset
  1349
    "set the controller"
claus
parents: 138
diff changeset
  1350
claus
parents: 138
diff changeset
  1351
    controller := aController.
claus
parents: 138
diff changeset
  1352
    controller notNil ifTrue:[
claus
parents: 138
diff changeset
  1353
	controller view:self.
135
claus
parents:
diff changeset
  1354
    ]
claus
parents:
diff changeset
  1355
!
claus
parents:
diff changeset
  1356
140
claus
parents: 138
diff changeset
  1357
model
135
claus
parents:
diff changeset
  1358
    ^ nil
claus
parents:
diff changeset
  1359
!
claus
parents:
diff changeset
  1360
140
claus
parents: 138
diff changeset
  1361
windowGroup:aGroup
claus
parents: 138
diff changeset
  1362
    "set the window group."
claus
parents: 138
diff changeset
  1363
claus
parents: 138
diff changeset
  1364
    windowGroup := aGroup
135
claus
parents:
diff changeset
  1365
! !
claus
parents:
diff changeset
  1366
claus
parents:
diff changeset
  1367
!SimpleView methodsFor:'event handling'!
claus
parents:
diff changeset
  1368
140
claus
parents: 138
diff changeset
  1369
mapped
claus
parents: 138
diff changeset
  1370
    "the view has been mapped (by some outside
claus
parents: 138
diff changeset
  1371
     action - i.e. window manager de-iconified me)"
claus
parents: 138
diff changeset
  1372
claus
parents: 138
diff changeset
  1373
    "
claus
parents: 138
diff changeset
  1374
     the old code was:
claus
parents: 138
diff changeset
  1375
claus
parents: 138
diff changeset
  1376
	realized := true.
claus
parents: 138
diff changeset
  1377
	shown := true.
claus
parents: 138
diff changeset
  1378
	...
claus
parents: 138
diff changeset
  1379
claus
parents: 138
diff changeset
  1380
     this created a race condition, if the view was
claus
parents: 138
diff changeset
  1381
     realized and shortly after unrealized - before the mapped event
claus
parents: 138
diff changeset
  1382
     arrived. This lead to shown being set to true even thought the
claus
parents: 138
diff changeset
  1383
     view was not. Boy - that was a bad one (hard to reproduce and hard to find).
claus
parents: 138
diff changeset
  1384
    "
claus
parents: 138
diff changeset
  1385
claus
parents: 138
diff changeset
  1386
    realized ifTrue:[
claus
parents: 138
diff changeset
  1387
	shown := true.
claus
parents: 138
diff changeset
  1388
	"
claus
parents: 138
diff changeset
  1389
	 backed views will not get expose events - have
claus
parents: 138
diff changeset
  1390
	 to force a redraw here to get things drawn into
claus
parents: 138
diff changeset
  1391
	 backing store.
claus
parents: 138
diff changeset
  1392
	"
claus
parents: 138
diff changeset
  1393
	backed ifTrue:[
claus
parents: 138
diff changeset
  1394
	    self redraw
claus
parents: 138
diff changeset
  1395
	].
claus
parents: 138
diff changeset
  1396
	subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  1397
	    subViews do:[:v |
claus
parents: 138
diff changeset
  1398
		v superViewMapped
claus
parents: 138
diff changeset
  1399
	    ]
claus
parents: 138
diff changeset
  1400
	]
claus
parents: 138
diff changeset
  1401
    ]
claus
parents: 138
diff changeset
  1402
!
claus
parents: 138
diff changeset
  1403
claus
parents: 138
diff changeset
  1404
superViewChangedSize
claus
parents: 138
diff changeset
  1405
    "my superView has changed size; if I have relative
claus
parents: 138
diff changeset
  1406
     origin/extent or blocks to evaluate, do it now .."
claus
parents: 138
diff changeset
  1407
claus
parents: 138
diff changeset
  1408
    |oldWidth oldHeight oldTop oldLeft newExt newOrg
claus
parents: 138
diff changeset
  1409
     winSuper newWidth newHeight newLeft newTop
151
claus
parents: 145
diff changeset
  1410
     superWidth superHeight superWinWidth superWinHeight
claus
parents: 145
diff changeset
  1411
     r|
140
claus
parents: 138
diff changeset
  1412
claus
parents: 138
diff changeset
  1413
    oldWidth := width.
claus
parents: 138
diff changeset
  1414
    oldHeight := height.
claus
parents: 138
diff changeset
  1415
    oldTop := top.
claus
parents: 138
diff changeset
  1416
    oldLeft := left.
claus
parents: 138
diff changeset
  1417
151
claus
parents: 145
diff changeset
  1418
    "
claus
parents: 145
diff changeset
  1419
     if this view has a viewPort, resize a la ST-80 V2.x
claus
parents: 145
diff changeset
  1420
     this will vanish - dont use it.
claus
parents: 145
diff changeset
  1421
    "
140
claus
parents: 138
diff changeset
  1422
    viewport notNil ifTrue:[
claus
parents: 138
diff changeset
  1423
	superView isNil ifTrue:[^ self].
claus
parents: 138
diff changeset
  1424
	winSuper := superView window.
claus
parents: 138
diff changeset
  1425
	winSuper isNil ifTrue:[
claus
parents: 138
diff changeset
  1426
	    "take pixel size as window"
claus
parents: 138
diff changeset
  1427
	    winSuper := 0@0 extent:(superView width@superView height)
claus
parents: 138
diff changeset
  1428
	].
claus
parents: 138
diff changeset
  1429
claus
parents: 138
diff changeset
  1430
	superWidth := superView width.
claus
parents: 138
diff changeset
  1431
	superHeight := superView height.
claus
parents: 138
diff changeset
  1432
	superWinWidth := winSuper width.
claus
parents: 138
diff changeset
  1433
	superWinHeight := winSuper height.
claus
parents: 138
diff changeset
  1434
	newLeft := (viewport left - winSuper left) * superWidth // superWinWidth.
claus
parents: 138
diff changeset
  1435
	newTop := (viewport top - winSuper top) * superHeight // superWinHeight.
claus
parents: 138
diff changeset
  1436
	newWidth := superWidth * viewport width // superWinWidth.
claus
parents: 138
diff changeset
  1437
	newHeight := superHeight * viewport height // superWinHeight.
claus
parents: 138
diff changeset
  1438
	self pixelOrigin:(newLeft @ newTop).
claus
parents: 138
diff changeset
  1439
	self pixelExtent:(newWidth @ newHeight).
claus
parents: 138
diff changeset
  1440
	^ self
claus
parents: 138
diff changeset
  1441
    ].
claus
parents: 138
diff changeset
  1442
151
claus
parents: 145
diff changeset
  1443
    "
claus
parents: 145
diff changeset
  1444
     slowly migrating to use layoutObjects ...
claus
parents: 145
diff changeset
  1445
    "
claus
parents: 145
diff changeset
  1446
    layout isNil ifTrue:[
claus
parents: 145
diff changeset
  1447
	newOrg := self computeOrigin.
claus
parents: 145
diff changeset
  1448
	newExt := self computeExtent.
claus
parents: 145
diff changeset
  1449
    ] ifFalse:[
claus
parents: 145
diff changeset
  1450
	r := (layout rectangleRelativeTo:(superView viewRectangle)
claus
parents: 145
diff changeset
  1451
			       preferred:(self preferredBounds)).
claus
parents: 145
diff changeset
  1452
	newOrg := r origin rounded.
claus
parents: 145
diff changeset
  1453
	newExt := r extent rounded.
claus
parents: 145
diff changeset
  1454
"/ newOrg printNL.
claus
parents: 145
diff changeset
  1455
"/ newExt printNL.
claus
parents: 145
diff changeset
  1456
    ].
140
claus
parents: 138
diff changeset
  1457
claus
parents: 138
diff changeset
  1458
    newOrg notNil ifTrue:[
claus
parents: 138
diff changeset
  1459
	((newOrg x == oldLeft) and:[newOrg y == oldTop]) ifTrue:[
claus
parents: 138
diff changeset
  1460
	    newOrg := nil
claus
parents: 138
diff changeset
  1461
	]
claus
parents: 138
diff changeset
  1462
    ].
claus
parents: 138
diff changeset
  1463
    newExt notNil ifTrue:[
claus
parents: 138
diff changeset
  1464
	((newExt x == width) and:[newExt y == height]) ifTrue:[
claus
parents: 138
diff changeset
  1465
	    newExt := nil
claus
parents: 138
diff changeset
  1466
	]
claus
parents: 138
diff changeset
  1467
    ].
claus
parents: 138
diff changeset
  1468
claus
parents: 138
diff changeset
  1469
    newExt isNil ifTrue:[
claus
parents: 138
diff changeset
  1470
	newOrg notNil ifTrue:[
claus
parents: 138
diff changeset
  1471
	    self pixelOrigin:newOrg
claus
parents: 138
diff changeset
  1472
	]
claus
parents: 138
diff changeset
  1473
    ] ifFalse:[
claus
parents: 138
diff changeset
  1474
	newOrg isNil ifTrue:[
claus
parents: 138
diff changeset
  1475
	    self pixelExtent:newExt
claus
parents: 138
diff changeset
  1476
	] ifFalse:[
claus
parents: 138
diff changeset
  1477
	    self pixelOrigin:newOrg extent:newExt
claus
parents: 138
diff changeset
  1478
	]
claus
parents: 138
diff changeset
  1479
    ]
claus
parents: 138
diff changeset
  1480
!
claus
parents: 138
diff changeset
  1481
claus
parents: 138
diff changeset
  1482
configureX:x y:y width:newWidth height:newHeight
claus
parents: 138
diff changeset
  1483
    "my size has changed by window manager action"
claus
parents: 138
diff changeset
  1484
180
claus
parents: 176
diff changeset
  1485
    |how anyEdge mustRedrawBottomEdge mustRedrawRightEdge p|
claus
parents: 176
diff changeset
  1486
claus
parents: 176
diff changeset
  1487
    (superView isNil 
claus
parents: 176
diff changeset
  1488
    and:[drawableId notNil]) ifTrue:[
claus
parents: 176
diff changeset
  1489
	"/ have to be careful - some window managers (motif) wrap another
claus
parents: 176
diff changeset
  1490
	"/ view around and the reported origin is relative to that.
claus
parents: 176
diff changeset
  1491
	"/ not relative to the screen.
claus
parents: 176
diff changeset
  1492
	p := device translatePoint:0@0 from:drawableId to:device rootWindowId.
claus
parents: 176
diff changeset
  1493
	left := p x.
claus
parents: 176
diff changeset
  1494
	top := p y.
claus
parents: 176
diff changeset
  1495
    ] ifFalse:[
claus
parents: 176
diff changeset
  1496
	left := x.
claus
parents: 176
diff changeset
  1497
	top := y.
claus
parents: 176
diff changeset
  1498
    ].
140
claus
parents: 138
diff changeset
  1499
    ((width ~~ newWidth) or:[height ~~ newHeight]) ifTrue:[
claus
parents: 138
diff changeset
  1500
	realized ifFalse:[
claus
parents: 138
diff changeset
  1501
	    width := newWidth.
claus
parents: 138
diff changeset
  1502
	    height := newHeight.
claus
parents: 138
diff changeset
  1503
	    extentChanged := true.
claus
parents: 138
diff changeset
  1504
	    ^ self
claus
parents: 138
diff changeset
  1505
	].
claus
parents: 138
diff changeset
  1506
claus
parents: 138
diff changeset
  1507
	((newWidth <= width) and:[newHeight <= height]) ifTrue:[
claus
parents: 138
diff changeset
  1508
	    how := #smaller
claus
parents: 138
diff changeset
  1509
	].
claus
parents: 138
diff changeset
  1510
claus
parents: 138
diff changeset
  1511
	level ~~ 0 ifTrue:[
claus
parents: 138
diff changeset
  1512
	    mustRedrawBottomEdge := newHeight < height.
claus
parents: 138
diff changeset
  1513
	    mustRedrawRightEdge := newWidth < width.
claus
parents: 138
diff changeset
  1514
	    anyEdge := mustRedrawBottomEdge or:[mustRedrawRightEdge]
claus
parents: 138
diff changeset
  1515
	] ifFalse:[
claus
parents: 138
diff changeset
  1516
	    anyEdge := false
claus
parents: 138
diff changeset
  1517
	].
claus
parents: 138
diff changeset
  1518
claus
parents: 138
diff changeset
  1519
	width := newWidth.
claus
parents: 138
diff changeset
  1520
	height := newHeight.
claus
parents: 138
diff changeset
  1521
claus
parents: 138
diff changeset
  1522
	"recompute inner-clip if needed"
claus
parents: 138
diff changeset
  1523
	self setInnerClip.
claus
parents: 138
diff changeset
  1524
claus
parents: 138
diff changeset
  1525
	"
claus
parents: 138
diff changeset
  1526
	 must first process pending exposes;
claus
parents: 138
diff changeset
  1527
	 otherwise, those may be drawn at a wrong position
claus
parents: 138
diff changeset
  1528
	"
claus
parents: 138
diff changeset
  1529
	windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  1530
	    windowGroup processExposeEvents
claus
parents: 138
diff changeset
  1531
	].
claus
parents: 138
diff changeset
  1532
	self sizeChanged:how.
claus
parents: 138
diff changeset
  1533
claus
parents: 138
diff changeset
  1534
	(anyEdge and:[shown]) ifTrue:[
claus
parents: 138
diff changeset
  1535
	    self clipRect:nil.
claus
parents: 138
diff changeset
  1536
	    mustRedrawBottomEdge ifTrue:[
claus
parents: 138
diff changeset
  1537
		self drawBottomEdge
claus
parents: 138
diff changeset
  1538
	    ].
claus
parents: 138
diff changeset
  1539
	    mustRedrawRightEdge ifTrue:[
claus
parents: 138
diff changeset
  1540
		self drawRightEdge
claus
parents: 138
diff changeset
  1541
	    ].
claus
parents: 138
diff changeset
  1542
	    self clipRect:innerClipRect
claus
parents: 138
diff changeset
  1543
	]
claus
parents: 138
diff changeset
  1544
    ]
138
claus
parents: 137
diff changeset
  1545
!
claus
parents: 137
diff changeset
  1546
135
claus
parents:
diff changeset
  1547
exposeX:x y:y width:w height:h
claus
parents:
diff changeset
  1548
    "a low level redraw event from device
claus
parents:
diff changeset
  1549
      - let subclass handle the redraw and take care of edges here"
claus
parents:
diff changeset
  1550
claus
parents:
diff changeset
  1551
    |leftEdge topEdge rightEdge botEdge anyEdge nx ny nw nh old|
claus
parents:
diff changeset
  1552
claus
parents:
diff changeset
  1553
    nw := w.
claus
parents:
diff changeset
  1554
    nh := h.
claus
parents:
diff changeset
  1555
    nx := x.
claus
parents:
diff changeset
  1556
    ny := y.
claus
parents:
diff changeset
  1557
claus
parents:
diff changeset
  1558
    anyEdge := false.
claus
parents:
diff changeset
  1559
claus
parents:
diff changeset
  1560
    "
claus
parents:
diff changeset
  1561
     check if there is a need to draw an edge (i.e. if margin is hit)
claus
parents:
diff changeset
  1562
    "
claus
parents:
diff changeset
  1563
    (margin ~~ 0) ifTrue:[
claus
parents:
diff changeset
  1564
	leftEdge := false.
claus
parents:
diff changeset
  1565
	topEdge := false.
claus
parents:
diff changeset
  1566
	rightEdge := false.
claus
parents:
diff changeset
  1567
	botEdge := false.
claus
parents:
diff changeset
  1568
	transformation notNil ifTrue:[
claus
parents:
diff changeset
  1569
	    "
claus
parents:
diff changeset
  1570
	     need device coordinates for this test
claus
parents:
diff changeset
  1571
	    "
claus
parents:
diff changeset
  1572
	    nx := transformation applyToX:nx.
claus
parents:
diff changeset
  1573
	    ny := transformation applyToY:ny.
claus
parents:
diff changeset
  1574
	    nw := transformation applyScaleX:nw.
claus
parents:
diff changeset
  1575
	    nh := transformation applyScaleY:nh.
claus
parents:
diff changeset
  1576
	].
claus
parents:
diff changeset
  1577
	"
claus
parents:
diff changeset
  1578
	 adjust expose rectangle, to exclude the margin.
claus
parents:
diff changeset
  1579
	 Care for rounding errors ...
claus
parents:
diff changeset
  1580
	"
claus
parents:
diff changeset
  1581
	(nx isMemberOf:SmallInteger) ifFalse:[
claus
parents:
diff changeset
  1582
	    old := nx.
claus
parents:
diff changeset
  1583
	    nx := nx truncated.
claus
parents:
diff changeset
  1584
	    nw := nw + (nx - old).
claus
parents:
diff changeset
  1585
	].
claus
parents:
diff changeset
  1586
	(ny isMemberOf:SmallInteger) ifFalse:[
claus
parents:
diff changeset
  1587
	    old := ny.
claus
parents:
diff changeset
  1588
	    ny := ny truncated.
claus
parents:
diff changeset
  1589
	    nh := nh + (ny - old).
claus
parents:
diff changeset
  1590
	].
claus
parents:
diff changeset
  1591
	(nw isMemberOf:SmallInteger) ifFalse:[
claus
parents:
diff changeset
  1592
	    nw := nw truncated + 1
claus
parents:
diff changeset
  1593
	].
claus
parents:
diff changeset
  1594
	(nh isMemberOf:SmallInteger) ifFalse:[
claus
parents:
diff changeset
  1595
	    nh := nh truncated + 1
claus
parents:
diff changeset
  1596
	].
claus
parents:
diff changeset
  1597
	(nx < margin) ifTrue:[
claus
parents:
diff changeset
  1598
	    old := nx.
claus
parents:
diff changeset
  1599
	    nx := margin.
claus
parents:
diff changeset
  1600
	    nw := nw - (nx - old).
claus
parents:
diff changeset
  1601
	    leftEdge := anyEdge := true.
claus
parents:
diff changeset
  1602
	].
claus
parents:
diff changeset
  1603
	((nx + nw - 1) >= (width - margin)) ifTrue:[
claus
parents:
diff changeset
  1604
	    nw := (width - margin - nx).
claus
parents:
diff changeset
  1605
	    rightEdge := anyEdge := true.
claus
parents:
diff changeset
  1606
	].
claus
parents:
diff changeset
  1607
	(ny < margin) ifTrue:[
claus
parents:
diff changeset
  1608
	    old := ny.
claus
parents:
diff changeset
  1609
	    ny := margin.
claus
parents:
diff changeset
  1610
	    nh := nh - (ny - old).
claus
parents:
diff changeset
  1611
	    topEdge := anyEdge := true.
claus
parents:
diff changeset
  1612
	].
claus
parents:
diff changeset
  1613
	((ny + nh - 1) >= (height - margin)) ifTrue:[
claus
parents:
diff changeset
  1614
	    nh := (height - margin - ny).
claus
parents:
diff changeset
  1615
	    botEdge := anyEdge := true.
claus
parents:
diff changeset
  1616
	].
claus
parents:
diff changeset
  1617
	transformation notNil ifTrue:[
claus
parents:
diff changeset
  1618
	    "
claus
parents:
diff changeset
  1619
	     need logical coordinates for redraw
claus
parents:
diff changeset
  1620
	    "
claus
parents:
diff changeset
  1621
	    nx := transformation applyInverseToX:nx.
claus
parents:
diff changeset
  1622
	    ny := transformation applyInverseToY:ny.
claus
parents:
diff changeset
  1623
	    nw := transformation applyInverseScaleX:nw.
claus
parents:
diff changeset
  1624
	    nh := transformation applyInverseScaleY:nh.
claus
parents:
diff changeset
  1625
	].
claus
parents:
diff changeset
  1626
    ].
claus
parents:
diff changeset
  1627
claus
parents:
diff changeset
  1628
    "
claus
parents:
diff changeset
  1629
     redraw inside area
claus
parents:
diff changeset
  1630
    "
claus
parents:
diff changeset
  1631
    self redrawX:nx y:ny width:nw height:nh.
claus
parents:
diff changeset
  1632
claus
parents:
diff changeset
  1633
    "
claus
parents:
diff changeset
  1634
     redraw edge(s)
claus
parents:
diff changeset
  1635
    "
claus
parents:
diff changeset
  1636
    anyEdge ifTrue:[
claus
parents:
diff changeset
  1637
	self clipRect:nil.
claus
parents:
diff changeset
  1638
	(topEdge and:[leftEdge and:[botEdge and:[rightEdge]]]) ifTrue:[
claus
parents:
diff changeset
  1639
	    self drawEdges
claus
parents:
diff changeset
  1640
	] ifFalse:[
claus
parents:
diff changeset
  1641
	    topEdge ifTrue:[
claus
parents:
diff changeset
  1642
		self drawTopEdge
claus
parents:
diff changeset
  1643
	    ].
claus
parents:
diff changeset
  1644
	    leftEdge ifTrue:[
claus
parents:
diff changeset
  1645
		self drawLeftEdge
claus
parents:
diff changeset
  1646
	    ].
claus
parents:
diff changeset
  1647
	    botEdge ifTrue:[
claus
parents:
diff changeset
  1648
		self drawBottomEdge
claus
parents:
diff changeset
  1649
	    ].
claus
parents:
diff changeset
  1650
	    rightEdge ifTrue:[
claus
parents:
diff changeset
  1651
		self drawRightEdge
claus
parents:
diff changeset
  1652
	    ]
claus
parents:
diff changeset
  1653
	].
claus
parents:
diff changeset
  1654
	self clipRect:innerClipRect
claus
parents:
diff changeset
  1655
    ]
claus
parents:
diff changeset
  1656
!
claus
parents:
diff changeset
  1657
claus
parents:
diff changeset
  1658
superViewMapped
claus
parents:
diff changeset
  1659
    "my superview was mapped (became visible)"
claus
parents:
diff changeset
  1660
claus
parents:
diff changeset
  1661
    realized ifTrue:[
claus
parents:
diff changeset
  1662
	shown := true.
claus
parents:
diff changeset
  1663
	subViews notNil ifTrue:[
claus
parents:
diff changeset
  1664
	    subViews do:[:v |
claus
parents:
diff changeset
  1665
		v superViewMapped
claus
parents:
diff changeset
  1666
	    ]
claus
parents:
diff changeset
  1667
	]
claus
parents:
diff changeset
  1668
    ].
claus
parents:
diff changeset
  1669
!
claus
parents:
diff changeset
  1670
140
claus
parents: 138
diff changeset
  1671
unmapped
claus
parents: 138
diff changeset
  1672
    "the view has been unmapped 
claus
parents: 138
diff changeset
  1673
     (either by some outside action - i.e. window manager iconified me,
claus
parents: 138
diff changeset
  1674
     or due to unmapping of my parentView)"
claus
parents: 138
diff changeset
  1675
claus
parents: 138
diff changeset
  1676
    shown := false.
claus
parents: 138
diff changeset
  1677
    subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  1678
	subViews do:[:v |
claus
parents: 138
diff changeset
  1679
	    v superViewUnmapped
135
claus
parents:
diff changeset
  1680
	]
claus
parents:
diff changeset
  1681
    ]
claus
parents:
diff changeset
  1682
!
claus
parents:
diff changeset
  1683
140
claus
parents: 138
diff changeset
  1684
coveredBy:aView
claus
parents: 138
diff changeset
  1685
    "the receiver has been covered by another view;
claus
parents: 138
diff changeset
  1686
     we are not interrested in that here (but see modalBox for more)."
claus
parents: 138
diff changeset
  1687
!
claus
parents: 138
diff changeset
  1688
claus
parents: 138
diff changeset
  1689
superViewUnmapped
claus
parents: 138
diff changeset
  1690
    "my superView was unmapped"
claus
parents: 138
diff changeset
  1691
claus
parents: 138
diff changeset
  1692
    self unmapped
claus
parents: 138
diff changeset
  1693
!
claus
parents: 138
diff changeset
  1694
claus
parents: 138
diff changeset
  1695
sizeChanged:how
claus
parents: 138
diff changeset
  1696
    "tell subviews if I change size.
claus
parents: 138
diff changeset
  1697
     How is either #smaller, #larger or nil, and is used to control the order,
claus
parents: 138
diff changeset
  1698
     in which subviews are notified (possibly reducing redraw activity)"
claus
parents: 138
diff changeset
  1699
claus
parents: 138
diff changeset
  1700
    window notNil ifTrue:[
claus
parents: 138
diff changeset
  1701
	"compute new transformation"
135
claus
parents:
diff changeset
  1702
    ].
140
claus
parents: 138
diff changeset
  1703
    subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  1704
	(how isNil "false" 
claus
parents: 138
diff changeset
  1705
	or:[how == #smaller]) ifTrue:[
claus
parents: 138
diff changeset
  1706
	    subViews do:[:view |
claus
parents: 138
diff changeset
  1707
		view superViewChangedSize
claus
parents: 138
diff changeset
  1708
	    ]
claus
parents: 138
diff changeset
  1709
	] ifFalse:[
claus
parents: 138
diff changeset
  1710
	    "doing it reverse speeds up resizing - usually subviews
claus
parents: 138
diff changeset
  1711
	     are created from top-left to bottom-right; therefore
claus
parents: 138
diff changeset
  1712
	     bottom-right views will be moved/resized first, then top-left ones;
claus
parents: 138
diff changeset
  1713
	     this avoids multiple redraws of subviews"
claus
parents: 138
diff changeset
  1714
claus
parents: 138
diff changeset
  1715
	    subViews reverseDo:[:view |
claus
parents: 138
diff changeset
  1716
		view superViewChangedSize
claus
parents: 138
diff changeset
  1717
	    ]
135
claus
parents:
diff changeset
  1718
	]
claus
parents:
diff changeset
  1719
    ].
140
claus
parents: 138
diff changeset
  1720
    self changed:#sizeOfView with:how.
claus
parents: 138
diff changeset
  1721
!
claus
parents: 138
diff changeset
  1722
claus
parents: 138
diff changeset
  1723
reparented
claus
parents: 138
diff changeset
  1724
    "the view has changed its parent by some outside
claus
parents: 138
diff changeset
  1725
     action - i.e. window manager has added a frame.
claus
parents: 138
diff changeset
  1726
     nothing done here"
claus
parents: 138
diff changeset
  1727
claus
parents: 138
diff changeset
  1728
    ^ self
claus
parents: 138
diff changeset
  1729
!
claus
parents: 138
diff changeset
  1730
claus
parents: 138
diff changeset
  1731
keyPress:key x:x y:y
claus
parents: 138
diff changeset
  1732
    "a key has been pressed. If there are components,
claus
parents: 138
diff changeset
  1733
     pass it to the corresponding one. 
claus
parents: 138
diff changeset
  1734
     Otherwise, forward it to the superview, if there is any."
claus
parents: 138
diff changeset
  1735
claus
parents: 138
diff changeset
  1736
    components notNil ifTrue:[
claus
parents: 138
diff changeset
  1737
	components do:[:aComponent |
claus
parents: 138
diff changeset
  1738
	    |thisFrame|
claus
parents: 138
diff changeset
  1739
claus
parents: 138
diff changeset
  1740
	    thisFrame := aComponent frame.
claus
parents: 138
diff changeset
  1741
	    (thisFrame containsPointX:x y:y) ifTrue:[
claus
parents: 138
diff changeset
  1742
		aComponent keyPress:key x:x - thisFrame left
claus
parents: 138
diff changeset
  1743
					y:y - thisFrame top.
claus
parents: 138
diff changeset
  1744
		^ self
claus
parents: 138
diff changeset
  1745
	    ]
135
claus
parents:
diff changeset
  1746
	]
claus
parents:
diff changeset
  1747
    ].
claus
parents:
diff changeset
  1748
140
claus
parents: 138
diff changeset
  1749
    x >= 0 ifTrue:[
claus
parents: 138
diff changeset
  1750
	superView notNil ifTrue:[
claus
parents: 138
diff changeset
  1751
	    WindowEvent
claus
parents: 138
diff changeset
  1752
		sendEvent:#keyPress:x:y:
claus
parents: 138
diff changeset
  1753
		arguments:(Array with:key with:0 with:0)
claus
parents: 138
diff changeset
  1754
		view:superView
135
claus
parents:
diff changeset
  1755
	] ifFalse:[
140
claus
parents: 138
diff changeset
  1756
	    super keyPress:key x:x y:y
135
claus
parents:
diff changeset
  1757
	]
claus
parents:
diff changeset
  1758
    ]
claus
parents:
diff changeset
  1759
!
claus
parents:
diff changeset
  1760
claus
parents:
diff changeset
  1761
buttonPress:button x:x y:y
claus
parents:
diff changeset
  1762
    "button was pressed - if its the middle button 
claus
parents:
diff changeset
  1763
     and there is a middleButtonMenu, show it.
claus
parents:
diff changeset
  1764
     If both a model and a menuSelector is is defined, ask the model for
claus
parents:
diff changeset
  1765
     the menu and launch it. The menu is supposed to return an actionSelector
claus
parents:
diff changeset
  1766
     which in turn is sent to the model."
claus
parents:
diff changeset
  1767
153
claus
parents: 151
diff changeset
  1768
    |menu menuPerformer actionSelector actionArg|
135
claus
parents:
diff changeset
  1769
claus
parents:
diff changeset
  1770
    components notNil ifTrue:[
claus
parents:
diff changeset
  1771
	components do:[:aComponent |
claus
parents:
diff changeset
  1772
	    |thisFrame|
claus
parents:
diff changeset
  1773
claus
parents:
diff changeset
  1774
	    thisFrame := aComponent frame.
claus
parents:
diff changeset
  1775
	    (thisFrame containsPointX:x y:y) ifTrue:[
claus
parents:
diff changeset
  1776
		aComponent buttonPress:button x:x - thisFrame left
claus
parents:
diff changeset
  1777
					      y:y - thisFrame top.
claus
parents:
diff changeset
  1778
		^ self
claus
parents:
diff changeset
  1779
	    ]
claus
parents:
diff changeset
  1780
	]
claus
parents:
diff changeset
  1781
    ].
claus
parents:
diff changeset
  1782
claus
parents:
diff changeset
  1783
    ((button == 2) or:[button == #menu]) ifTrue:[
claus
parents:
diff changeset
  1784
	"
claus
parents:
diff changeset
  1785
	 try ST-80 style menus first:
claus
parents:
diff changeset
  1786
	 if there is a model, and a menuMessage is defined,
claus
parents:
diff changeset
  1787
	 ask model for the menu and launch that if non-nil.
claus
parents:
diff changeset
  1788
	"
claus
parents:
diff changeset
  1789
	menu := self yellowButtonMenu.
claus
parents:
diff changeset
  1790
	menu notNil ifTrue:[
claus
parents:
diff changeset
  1791
	    "
claus
parents:
diff changeset
  1792
	     got one, launch the menu. It is supposed
claus
parents:
diff changeset
  1793
	     to return an actionSelector.
claus
parents:
diff changeset
  1794
	    "
claus
parents:
diff changeset
  1795
	    menuPerformer := self menuPerformer.
claus
parents:
diff changeset
  1796
	    "
claus
parents:
diff changeset
  1797
	     a temporary kludge: subMenus dont know about 
claus
parents:
diff changeset
  1798
	     actionSelectors yet ...
claus
parents:
diff changeset
  1799
	    "
claus
parents:
diff changeset
  1800
	    menu receiver isNil ifTrue:[
claus
parents:
diff changeset
  1801
		menu receiver:menuPerformer
claus
parents:
diff changeset
  1802
	    ].
claus
parents:
diff changeset
  1803
	    actionSelector := menu startUp.
claus
parents:
diff changeset
  1804
142
claus
parents: 140
diff changeset
  1805
	    "
153
claus
parents: 151
diff changeset
  1806
	     mhmh - kludge for selectors with argument
claus
parents: 151
diff changeset
  1807
	    "
claus
parents: 151
diff changeset
  1808
	    (actionSelector isMemberOf:Array) ifTrue:[
claus
parents: 151
diff changeset
  1809
		actionArg := actionSelector at:2.
claus
parents: 151
diff changeset
  1810
		actionSelector := actionSelector at:1.
claus
parents: 151
diff changeset
  1811
	    ].
claus
parents: 151
diff changeset
  1812
claus
parents: 151
diff changeset
  1813
	    "
142
claus
parents: 140
diff changeset
  1814
	     mhmh - ST-80 seems to send some to the model and
claus
parents: 140
diff changeset
  1815
	     others (copy/cut/paste) to the controller/view
153
claus
parents: 151
diff changeset
  1816
	     Simulate this behavior, by looking what the model responds to.
142
claus
parents: 140
diff changeset
  1817
	    "
135
claus
parents:
diff changeset
  1818
	    (actionSelector notNil
claus
parents:
diff changeset
  1819
	    and:[actionSelector isSymbol]) ifTrue:[
142
claus
parents: 140
diff changeset
  1820
		(menuPerformer respondsTo:actionSelector) ifFalse:[
153
claus
parents: 151
diff changeset
  1821
		    (self respondsTo:actionSelector) ifTrue:[
claus
parents: 151
diff changeset
  1822
			menuPerformer := self
claus
parents: 151
diff changeset
  1823
		    ]
142
claus
parents: 140
diff changeset
  1824
		].
153
claus
parents: 151
diff changeset
  1825
		actionSelector numArgs ~~ 0 ifTrue:[
claus
parents: 151
diff changeset
  1826
		    menuPerformer perform:actionSelector with:actionArg
claus
parents: 151
diff changeset
  1827
		] ifFalse:[
claus
parents: 151
diff changeset
  1828
		    menuPerformer perform:actionSelector
claus
parents: 151
diff changeset
  1829
		]
135
claus
parents:
diff changeset
  1830
	    ].
claus
parents:
diff changeset
  1831
	    ^ self
claus
parents:
diff changeset
  1832
	].
claus
parents:
diff changeset
  1833
    ].
claus
parents:
diff changeset
  1834
    super buttonPress:button x:x y:y
claus
parents:
diff changeset
  1835
!
claus
parents:
diff changeset
  1836
140
claus
parents: 138
diff changeset
  1837
hasKeyboardFocus:aBoolean
135
claus
parents:
diff changeset
  1838
    ^ self
claus
parents:
diff changeset
  1839
!
claus
parents:
diff changeset
  1840
claus
parents:
diff changeset
  1841
focusIn
claus
parents:
diff changeset
  1842
    "got keyboard focus"
claus
parents:
diff changeset
  1843
claus
parents:
diff changeset
  1844
    self showFocus
claus
parents:
diff changeset
  1845
!
claus
parents:
diff changeset
  1846
claus
parents:
diff changeset
  1847
visibilityChange:how
claus
parents:
diff changeset
  1848
    "the visibility of the view has changed (by some outside
claus
parents:
diff changeset
  1849
     action - i.e. window manager rearranged things).
claus
parents:
diff changeset
  1850
     Using this knowledge avoids useless redraw in obsucred views."
claus
parents:
diff changeset
  1851
claus
parents:
diff changeset
  1852
    how == #fullyObscured ifTrue:[
claus
parents:
diff changeset
  1853
	shown := false
claus
parents:
diff changeset
  1854
    ] ifFalse:[
claus
parents:
diff changeset
  1855
	shown := true.
claus
parents:
diff changeset
  1856
    ]
claus
parents:
diff changeset
  1857
!
claus
parents:
diff changeset
  1858
140
claus
parents: 138
diff changeset
  1859
focusOut
claus
parents: 138
diff changeset
  1860
    "lost keyboard focus"
claus
parents: 138
diff changeset
  1861
claus
parents: 138
diff changeset
  1862
    self showNoFocus
claus
parents: 138
diff changeset
  1863
!
claus
parents: 138
diff changeset
  1864
135
claus
parents:
diff changeset
  1865
destroyed
claus
parents:
diff changeset
  1866
    "view has been destroyed by someone else (usually window system)"
claus
parents:
diff changeset
  1867
claus
parents:
diff changeset
  1868
    shown := false.
claus
parents:
diff changeset
  1869
    super destroyed
claus
parents:
diff changeset
  1870
!
claus
parents:
diff changeset
  1871
157
claus
parents: 154
diff changeset
  1872
terminate
claus
parents: 154
diff changeset
  1873
    "window manager wants me to go away;
claus
parents: 154
diff changeset
  1874
     - notice, that not all window managers are nice enough to 
claus
parents: 154
diff changeset
  1875
       send this event, but simply destroy the view instead.
claus
parents: 154
diff changeset
  1876
     Can be redefined in subclasses to do whatever cleanup is 
claus
parents: 154
diff changeset
  1877
     required."
claus
parents: 154
diff changeset
  1878
claus
parents: 154
diff changeset
  1879
    ^ self destroy
claus
parents: 154
diff changeset
  1880
!
claus
parents: 154
diff changeset
  1881
135
claus
parents:
diff changeset
  1882
saveAndTerminate
claus
parents:
diff changeset
  1883
    "window manager wants me to save and go away; 
claus
parents:
diff changeset
  1884
     - notice, that not all window managers are nice enough to 
claus
parents:
diff changeset
  1885
       send this event, but simply destroy the view instead.
claus
parents:
diff changeset
  1886
     Can be redefined in subclasses to do whatever is required
claus
parents:
diff changeset
  1887
     to prepare for restart."
claus
parents:
diff changeset
  1888
claus
parents:
diff changeset
  1889
    ^ self destroy
claus
parents:
diff changeset
  1890
! !
claus
parents:
diff changeset
  1891
140
claus
parents: 138
diff changeset
  1892
!SimpleView methodsFor:'private'!
claus
parents: 138
diff changeset
  1893
claus
parents: 138
diff changeset
  1894
setInnerClip
claus
parents: 138
diff changeset
  1895
    "compute, and set the inside clip-area"
claus
parents: 138
diff changeset
  1896
claus
parents: 138
diff changeset
  1897
    self computeInnerClip.
claus
parents: 138
diff changeset
  1898
    self clipRect:innerClipRect
claus
parents: 138
diff changeset
  1899
!
claus
parents: 138
diff changeset
  1900
claus
parents: 138
diff changeset
  1901
computeInnerClip
claus
parents: 138
diff changeset
  1902
    "compute, but do not set the inside clip-area"
claus
parents: 138
diff changeset
  1903
claus
parents: 138
diff changeset
  1904
    |m2 nX nY nW nH|
claus
parents: 138
diff changeset
  1905
claus
parents: 138
diff changeset
  1906
    (margin ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  1907
	m2 := margin + margin.
claus
parents: 138
diff changeset
  1908
	nX := nY := margin.
claus
parents: 138
diff changeset
  1909
	nW := width - m2.
claus
parents: 138
diff changeset
  1910
	nH := height - m2.
claus
parents: 138
diff changeset
  1911
	transformation notNil ifTrue:[
claus
parents: 138
diff changeset
  1912
	    nX := transformation applyInverseToX:nX.
claus
parents: 138
diff changeset
  1913
	    nY := transformation applyInverseToY:nY.
claus
parents: 138
diff changeset
  1914
	    nW := transformation applyInverseScaleX:nW.
claus
parents: 138
diff changeset
  1915
	    nH := transformation applyInverseScaleY:nH.
claus
parents: 138
diff changeset
  1916
	].
claus
parents: 138
diff changeset
  1917
	innerClipRect := Rectangle 
claus
parents: 138
diff changeset
  1918
				 left:nX 
claus
parents: 138
diff changeset
  1919
				 top:nY 
claus
parents: 138
diff changeset
  1920
				 width:nW 
claus
parents: 138
diff changeset
  1921
				 height:nH
claus
parents: 138
diff changeset
  1922
    ] ifFalse:[
claus
parents: 138
diff changeset
  1923
	"no clipping"
claus
parents: 138
diff changeset
  1924
	innerClipRect := nil
claus
parents: 138
diff changeset
  1925
    ]
claus
parents: 138
diff changeset
  1926
!
claus
parents: 138
diff changeset
  1927
claus
parents: 138
diff changeset
  1928
pixelOrigin:origin extent:extent
claus
parents: 138
diff changeset
  1929
    "set the views origin and extent in pixels"
claus
parents: 138
diff changeset
  1930
claus
parents: 138
diff changeset
  1931
    |newLeft newTop newWidth newHeight how 
claus
parents: 138
diff changeset
  1932
     mustRedrawBottomEdge mustRedrawRightEdge mustRepaintBottom
claus
parents: 138
diff changeset
  1933
     mustRepaintRight sameOrigin oldWidth oldHeight|
claus
parents: 138
diff changeset
  1934
claus
parents: 138
diff changeset
  1935
    newLeft := origin x.
claus
parents: 138
diff changeset
  1936
    newTop := origin y.
claus
parents: 138
diff changeset
  1937
    sameOrigin := ((newTop == top) and:[newLeft == left]).
claus
parents: 138
diff changeset
  1938
claus
parents: 138
diff changeset
  1939
    newWidth := extent x.
claus
parents: 138
diff changeset
  1940
    newHeight := extent y.
claus
parents: 138
diff changeset
  1941
claus
parents: 138
diff changeset
  1942
    "
claus
parents: 138
diff changeset
  1943
     X complains badly if you try to create/resize a view with
claus
parents: 138
diff changeset
  1944
     a dimension <= 0 ... (although I think that 0 maks sense ...)
claus
parents: 138
diff changeset
  1945
    "
claus
parents: 138
diff changeset
  1946
    newWidth < 1 ifTrue:[
claus
parents: 138
diff changeset
  1947
	newWidth := 1.
claus
parents: 138
diff changeset
  1948
    ].
claus
parents: 138
diff changeset
  1949
    newHeight < 1 ifTrue:[
claus
parents: 138
diff changeset
  1950
	newHeight := 1
claus
parents: 138
diff changeset
  1951
    ].
claus
parents: 138
diff changeset
  1952
claus
parents: 138
diff changeset
  1953
    ((newWidth == width) and:[newHeight == height]) ifTrue:[
claus
parents: 138
diff changeset
  1954
	sameOrigin ifTrue:[^ self].
claus
parents: 138
diff changeset
  1955
	^ self pixelOrigin:origin
claus
parents: 138
diff changeset
  1956
    ].
claus
parents: 138
diff changeset
  1957
    top := newTop.
claus
parents: 138
diff changeset
  1958
    left := newLeft.
claus
parents: 138
diff changeset
  1959
claus
parents: 138
diff changeset
  1960
"/    shown ifTrue:[                  "4-nov-94 actually correct,"
claus
parents: 138
diff changeset
  1961
    drawableId notNil ifTrue:[        "but theres a bug in menus when resized while hidden"
151
claus
parents: 145
diff changeset
  1962
	mustRedrawBottomEdge := (level ~~ 0) and:[newHeight < height].
claus
parents: 145
diff changeset
  1963
	mustRedrawRightEdge := (level ~~ 0) and:[newWidth < width].
claus
parents: 145
diff changeset
  1964
claus
parents: 145
diff changeset
  1965
	((newHeight <= height) and:[newWidth <= width]) ifTrue:[
claus
parents: 145
diff changeset
  1966
	    how := #smaller
claus
parents: 145
diff changeset
  1967
	].
claus
parents: 145
diff changeset
  1968
140
claus
parents: 138
diff changeset
  1969
	mustRepaintRight := false.
claus
parents: 138
diff changeset
  1970
	mustRepaintBottom := false.
claus
parents: 138
diff changeset
  1971
	(level ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  1972
	    "clear the old edges"
claus
parents: 138
diff changeset
  1973
claus
parents: 138
diff changeset
  1974
	    newWidth > width ifTrue:[
claus
parents: 138
diff changeset
  1975
		self clipRect:nil.
claus
parents: 138
diff changeset
  1976
		self paint:viewBackground.
claus
parents: 138
diff changeset
  1977
		self fillDeviceRectangleX:(width - margin)
claus
parents: 138
diff changeset
  1978
					y:0
claus
parents: 138
diff changeset
  1979
				    width:margin
claus
parents: 138
diff changeset
  1980
				   height:height.
claus
parents: 138
diff changeset
  1981
		mustRepaintRight := true.
claus
parents: 138
diff changeset
  1982
		oldWidth := width
claus
parents: 138
diff changeset
  1983
	    ].
claus
parents: 138
diff changeset
  1984
	    newHeight > height ifTrue:[
claus
parents: 138
diff changeset
  1985
		self clipRect:nil.
claus
parents: 138
diff changeset
  1986
		self paint:viewBackground.
claus
parents: 138
diff changeset
  1987
		self fillDeviceRectangleX:0
claus
parents: 138
diff changeset
  1988
					y:(height - margin)
claus
parents: 138
diff changeset
  1989
				    width:width
claus
parents: 138
diff changeset
  1990
				   height:margin.
claus
parents: 138
diff changeset
  1991
		mustRepaintBottom := true.
claus
parents: 138
diff changeset
  1992
		oldHeight := height
claus
parents: 138
diff changeset
  1993
	    ]
claus
parents: 138
diff changeset
  1994
	].
claus
parents: 138
diff changeset
  1995
claus
parents: 138
diff changeset
  1996
	width := newWidth.
claus
parents: 138
diff changeset
  1997
	height := newHeight.
claus
parents: 138
diff changeset
  1998
claus
parents: 138
diff changeset
  1999
	self setInnerClip.
claus
parents: 138
diff changeset
  2000
claus
parents: 138
diff changeset
  2001
	"if view becomes smaller, send sizeChanged first"
claus
parents: 138
diff changeset
  2002
	(how == #smaller) ifTrue:[
claus
parents: 138
diff changeset
  2003
	    self sizeChanged:how
claus
parents: 138
diff changeset
  2004
	].
claus
parents: 138
diff changeset
  2005
claus
parents: 138
diff changeset
  2006
	"have to tell X, when extent of view is changed"
claus
parents: 138
diff changeset
  2007
	sameOrigin ifTrue:[
claus
parents: 138
diff changeset
  2008
	    device resizeWindow:drawableId width:width height:height.
claus
parents: 138
diff changeset
  2009
	] ifFalse:[
claus
parents: 138
diff changeset
  2010
	    "claus: some xservers seem to do better when resizing
claus
parents: 138
diff changeset
  2011
	     first ...."
claus
parents: 138
diff changeset
  2012
" 
claus
parents: 138
diff changeset
  2013
	    (how == #smaller) ifTrue:[
claus
parents: 138
diff changeset
  2014
		device resizeWindow:drawableId width:width height:height.
claus
parents: 138
diff changeset
  2015
		device moveWindow:drawableId x:left y:top
claus
parents: 138
diff changeset
  2016
	    ] ifFalse:[
claus
parents: 138
diff changeset
  2017
		device moveResizeWindow:drawableId x:left y:top width:width height:height
claus
parents: 138
diff changeset
  2018
	    ].
claus
parents: 138
diff changeset
  2019
" 
claus
parents: 138
diff changeset
  2020
	    device moveResizeWindow:drawableId x:left y:top
claus
parents: 138
diff changeset
  2021
					   width:width height:height.
claus
parents: 138
diff changeset
  2022
" "
claus
parents: 138
diff changeset
  2023
	].
claus
parents: 138
diff changeset
  2024
claus
parents: 138
diff changeset
  2025
	"if view becomes bigger, send sizeChanged after"
claus
parents: 138
diff changeset
  2026
	(how ~~ #smaller) ifTrue:[
claus
parents: 138
diff changeset
  2027
	    self sizeChanged:how
claus
parents: 138
diff changeset
  2028
	].
claus
parents: 138
diff changeset
  2029
claus
parents: 138
diff changeset
  2030
	(mustRedrawBottomEdge or:[mustRedrawRightEdge]) ifTrue:[
claus
parents: 138
diff changeset
  2031
	    self clipRect:nil.
claus
parents: 138
diff changeset
  2032
	    mustRedrawBottomEdge ifTrue:[
claus
parents: 138
diff changeset
  2033
		self drawBottomEdge
claus
parents: 138
diff changeset
  2034
	    ].
claus
parents: 138
diff changeset
  2035
	    mustRedrawRightEdge ifTrue:[
claus
parents: 138
diff changeset
  2036
		self drawRightEdge
claus
parents: 138
diff changeset
  2037
	    ].
claus
parents: 138
diff changeset
  2038
	    self clipRect:innerClipRect
claus
parents: 138
diff changeset
  2039
	].
claus
parents: 138
diff changeset
  2040
claus
parents: 138
diff changeset
  2041
	mustRepaintRight ifTrue:[
claus
parents: 138
diff changeset
  2042
	    self redrawDeviceX:(oldWidth - margin)
claus
parents: 138
diff changeset
  2043
			     y:0
claus
parents: 138
diff changeset
  2044
			 width:margin
claus
parents: 138
diff changeset
  2045
			height:height.
claus
parents: 138
diff changeset
  2046
	].
claus
parents: 138
diff changeset
  2047
	mustRepaintBottom ifTrue:[
claus
parents: 138
diff changeset
  2048
	    self redrawDeviceX:0
claus
parents: 138
diff changeset
  2049
			     y:(oldHeight - margin)
claus
parents: 138
diff changeset
  2050
			 width:width
claus
parents: 138
diff changeset
  2051
			height:margin.
claus
parents: 138
diff changeset
  2052
	].
claus
parents: 138
diff changeset
  2053
    ] ifFalse:[
claus
parents: 138
diff changeset
  2054
	"otherwise memorize the need for a sizeChanged message"
claus
parents: 138
diff changeset
  2055
claus
parents: 138
diff changeset
  2056
	width := newWidth.
claus
parents: 138
diff changeset
  2057
	height := newHeight.
claus
parents: 138
diff changeset
  2058
	sameOrigin ifFalse:[
claus
parents: 138
diff changeset
  2059
	    originChanged := true.
claus
parents: 138
diff changeset
  2060
	].
claus
parents: 138
diff changeset
  2061
	extentChanged := true
claus
parents: 138
diff changeset
  2062
    ]
claus
parents: 138
diff changeset
  2063
!
claus
parents: 138
diff changeset
  2064
claus
parents: 138
diff changeset
  2065
originFromRelativeOrigin:aPoint
claus
parents: 138
diff changeset
  2066
    "compute & return pixel origin from relativeOrigin, aPoint"
claus
parents: 138
diff changeset
  2067
claus
parents: 138
diff changeset
  2068
    |p l t|
claus
parents: 138
diff changeset
  2069
claus
parents: 138
diff changeset
  2070
    p := self pointFromRelative:aPoint.
claus
parents: 138
diff changeset
  2071
claus
parents: 138
diff changeset
  2072
    insets isNil ifTrue:[
claus
parents: 138
diff changeset
  2073
	^ p
claus
parents: 138
diff changeset
  2074
    ].
claus
parents: 138
diff changeset
  2075
    l := insets at:1.
claus
parents: 138
diff changeset
  2076
    t := insets at:2.
claus
parents: 138
diff changeset
  2077
claus
parents: 138
diff changeset
  2078
"/  l := t := 0.
claus
parents: 138
diff changeset
  2079
"/    leftInset notNil ifTrue:[
claus
parents: 138
diff changeset
  2080
"/        l := leftInset
claus
parents: 138
diff changeset
  2081
"/    ].
claus
parents: 138
diff changeset
  2082
"/    topInset notNil ifTrue:[
claus
parents: 138
diff changeset
  2083
"/        t := topInset
claus
parents: 138
diff changeset
  2084
"/    ].
claus
parents: 138
diff changeset
  2085
    ((l ~~ 0) or:[t ~~ 0]) ifTrue:[
claus
parents: 138
diff changeset
  2086
	^ (p x + l) @ (p y + t)
claus
parents: 138
diff changeset
  2087
    ].
claus
parents: 138
diff changeset
  2088
    ^ p
claus
parents: 138
diff changeset
  2089
!
claus
parents: 138
diff changeset
  2090
claus
parents: 138
diff changeset
  2091
pixelOrigin:origin
claus
parents: 138
diff changeset
  2092
    "set the views origin in pixels. For subviews. the origin is relative
claus
parents: 138
diff changeset
  2093
     to the superviews top-left. For topViews, its the screen origin."
claus
parents: 138
diff changeset
  2094
claus
parents: 138
diff changeset
  2095
    |newLeft newTop|
claus
parents: 138
diff changeset
  2096
claus
parents: 138
diff changeset
  2097
    newLeft := origin x.
claus
parents: 138
diff changeset
  2098
    newTop := origin y.
claus
parents: 138
diff changeset
  2099
    ((newTop ~~ top) or:[newLeft ~~ left]) ifTrue:[
claus
parents: 138
diff changeset
  2100
	top := newTop.
claus
parents: 138
diff changeset
  2101
	left := newLeft.
claus
parents: 138
diff changeset
  2102
claus
parents: 138
diff changeset
  2103
	"
claus
parents: 138
diff changeset
  2104
	 if the receiver is visible, or is a topView, perform the
claus
parents: 138
diff changeset
  2105
	 operation right away - otherwise, simply remember that the
claus
parents: 138
diff changeset
  2106
	 origin has changed - will tell the display once we get realized
claus
parents: 138
diff changeset
  2107
	"
151
claus
parents: 145
diff changeset
  2108
"/        (shown 
claus
parents: 145
diff changeset
  2109
"/        or:[superView isNil and:[drawableId notNil]]) ifTrue:[
claus
parents: 145
diff changeset
  2110
claus
parents: 145
diff changeset
  2111
	"/ no, have to do it if drawableId is there
claus
parents: 145
diff changeset
  2112
	"/ (otherwise, we could not move unmapped views around ...
claus
parents: 145
diff changeset
  2113
	"/
claus
parents: 145
diff changeset
  2114
	drawableId notNil ifTrue:[
140
claus
parents: 138
diff changeset
  2115
	    device moveWindow:drawableId x:left y:top
claus
parents: 138
diff changeset
  2116
	] ifFalse:[
claus
parents: 138
diff changeset
  2117
	    originChanged := true
135
claus
parents:
diff changeset
  2118
	]
claus
parents:
diff changeset
  2119
    ]
claus
parents:
diff changeset
  2120
!
claus
parents:
diff changeset
  2121
140
claus
parents: 138
diff changeset
  2122
pixelExtent:extent
claus
parents: 138
diff changeset
  2123
    "set the views extent in pixels"
claus
parents: 138
diff changeset
  2124
claus
parents: 138
diff changeset
  2125
    self pixelOrigin:(left @ top) extent:extent
claus
parents: 138
diff changeset
  2126
!
claus
parents: 138
diff changeset
  2127
claus
parents: 138
diff changeset
  2128
cornerFromRelativeCorner:aPoint
claus
parents: 138
diff changeset
  2129
    "compute & return pixel corner from a relativeCorner, aPoint"
claus
parents: 138
diff changeset
  2130
claus
parents: 138
diff changeset
  2131
    |p r b bw|
claus
parents: 138
diff changeset
  2132
claus
parents: 138
diff changeset
  2133
    p := self pointFromRelative:aPoint.
claus
parents: 138
diff changeset
  2134
claus
parents: 138
diff changeset
  2135
    bw := borderWidth.
claus
parents: 138
diff changeset
  2136
    insets isNil ifTrue:[
claus
parents: 138
diff changeset
  2137
	bw == 0 ifTrue:[
claus
parents: 138
diff changeset
  2138
	    ^ p
claus
parents: 138
diff changeset
  2139
	].
claus
parents: 138
diff changeset
  2140
	^ (p x - bw) @ (p y - bw)
claus
parents: 138
diff changeset
  2141
    ].
claus
parents: 138
diff changeset
  2142
    r := (insets at:3) + bw.
claus
parents: 138
diff changeset
  2143
    b := (insets at:4) + bw.
claus
parents: 138
diff changeset
  2144
claus
parents: 138
diff changeset
  2145
"/    r := b := bw.
claus
parents: 138
diff changeset
  2146
"/    rightInset notNil ifTrue:[
claus
parents: 138
diff changeset
  2147
"/        r := rightInset + bw
claus
parents: 138
diff changeset
  2148
"/    ].
claus
parents: 138
diff changeset
  2149
"/    bottomInset notNil ifTrue:[
claus
parents: 138
diff changeset
  2150
"/        b := bottomInset + bw
claus
parents: 138
diff changeset
  2151
"/    ].
claus
parents: 138
diff changeset
  2152
    ((r ~~ 0) or:[b ~~ 0]) ifTrue:[
claus
parents: 138
diff changeset
  2153
	^ (p x - r) @ (p y - b)
claus
parents: 138
diff changeset
  2154
    ].
claus
parents: 138
diff changeset
  2155
    ^ p
claus
parents: 138
diff changeset
  2156
!
claus
parents: 138
diff changeset
  2157
claus
parents: 138
diff changeset
  2158
cornerFromRelativeCorner
claus
parents: 138
diff changeset
  2159
    "compute & return pixel corner from relativeCorner"
claus
parents: 138
diff changeset
  2160
claus
parents: 138
diff changeset
  2161
    ^ self cornerFromRelativeCorner:relativeCorner
claus
parents: 138
diff changeset
  2162
!
claus
parents: 138
diff changeset
  2163
claus
parents: 138
diff changeset
  2164
pointFromRelative:p
claus
parents: 138
diff changeset
  2165
    "compute absolute coordinate from p"
claus
parents: 138
diff changeset
  2166
claus
parents: 138
diff changeset
  2167
    |newX newY rel inRect bw superWidth superHeight superLeft superTop |
claus
parents: 138
diff changeset
  2168
claus
parents: 138
diff changeset
  2169
    bw := borderWidth.
claus
parents: 138
diff changeset
  2170
claus
parents: 138
diff changeset
  2171
    superView isNil ifTrue:[
claus
parents: 138
diff changeset
  2172
	superWidth := device width + bw.      
claus
parents: 138
diff changeset
  2173
	superHeight := device height + bw.
claus
parents: 138
diff changeset
  2174
	superLeft := superTop := 0.
claus
parents: 138
diff changeset
  2175
    ] ifFalse:[
claus
parents: 138
diff changeset
  2176
	inRect := superView viewRectangle.
claus
parents: 138
diff changeset
  2177
	superWidth := inRect width.
claus
parents: 138
diff changeset
  2178
	superHeight := inRect height.
claus
parents: 138
diff changeset
  2179
	superLeft := inRect left.
claus
parents: 138
diff changeset
  2180
	superTop := inRect top.
claus
parents: 138
diff changeset
  2181
    ].
claus
parents: 138
diff changeset
  2182
claus
parents: 138
diff changeset
  2183
    rel := p x.
claus
parents: 138
diff changeset
  2184
    rel isInteger ifTrue:[
claus
parents: 138
diff changeset
  2185
	newX := rel
claus
parents: 138
diff changeset
  2186
    ] ifFalse:[
claus
parents: 138
diff changeset
  2187
	newX := (rel * superWidth) asInteger + superLeft.
claus
parents: 138
diff changeset
  2188
	(bw ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2189
	    rel ~= 1.0 ifTrue:[
claus
parents: 138
diff changeset
  2190
		newX := newX - bw
claus
parents: 138
diff changeset
  2191
	    ]
claus
parents: 138
diff changeset
  2192
	]
claus
parents: 138
diff changeset
  2193
    ].
claus
parents: 138
diff changeset
  2194
claus
parents: 138
diff changeset
  2195
    rel := p y.
claus
parents: 138
diff changeset
  2196
    rel isInteger ifTrue:[
claus
parents: 138
diff changeset
  2197
	newY := rel
claus
parents: 138
diff changeset
  2198
    ] ifFalse:[
claus
parents: 138
diff changeset
  2199
	newY := (rel * superHeight) asInteger + superTop.
claus
parents: 138
diff changeset
  2200
	(bw ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2201
	    rel ~= 1.0 ifTrue:[
claus
parents: 138
diff changeset
  2202
		newY := newY - bw
claus
parents: 138
diff changeset
  2203
	    ]
claus
parents: 138
diff changeset
  2204
	]
claus
parents: 138
diff changeset
  2205
    ].
claus
parents: 138
diff changeset
  2206
    ^ newX @ newY
claus
parents: 138
diff changeset
  2207
!
claus
parents: 138
diff changeset
  2208
claus
parents: 138
diff changeset
  2209
originFromRelativeOrigin
claus
parents: 138
diff changeset
  2210
    "compute & return pixel origin from relativeOrigin"
claus
parents: 138
diff changeset
  2211
claus
parents: 138
diff changeset
  2212
    ^ self originFromRelativeOrigin:relativeOrigin
claus
parents: 138
diff changeset
  2213
!
claus
parents: 138
diff changeset
  2214
claus
parents: 138
diff changeset
  2215
pixelCorner:corner
claus
parents: 138
diff changeset
  2216
    "set the views corner in pixels"
claus
parents: 138
diff changeset
  2217
claus
parents: 138
diff changeset
  2218
    |w h|
claus
parents: 138
diff changeset
  2219
180
claus
parents: 176
diff changeset
  2220
    w := corner x - left + 1.
claus
parents: 176
diff changeset
  2221
    h := corner y - top + 1.
140
claus
parents: 138
diff changeset
  2222
    self pixelOrigin:(left @ top) extent:(w @ h)
180
claus
parents: 176
diff changeset
  2223
claus
parents: 176
diff changeset
  2224
    "Modified: 31.8.1995 / 18:20:22 / claus"
140
claus
parents: 138
diff changeset
  2225
!
claus
parents: 138
diff changeset
  2226
claus
parents: 138
diff changeset
  2227
extentFromRelativeExtent:aPoint
claus
parents: 138
diff changeset
  2228
    "compute & return pixel extent from relativeExtent, aPoint"
claus
parents: 138
diff changeset
  2229
claus
parents: 138
diff changeset
  2230
    |rel newX newY inRect bw2 i|
claus
parents: 138
diff changeset
  2231
claus
parents: 138
diff changeset
  2232
    superView isNil ifTrue:[
claus
parents: 138
diff changeset
  2233
	inRect := 0@0 extent:device extent
claus
parents: 138
diff changeset
  2234
    ] ifFalse:[
claus
parents: 138
diff changeset
  2235
	inRect := superView viewRectangle.
claus
parents: 138
diff changeset
  2236
    ].
claus
parents: 138
diff changeset
  2237
claus
parents: 138
diff changeset
  2238
    bw2 := borderWidth * 2.
claus
parents: 138
diff changeset
  2239
claus
parents: 138
diff changeset
  2240
    rel := aPoint x.
175
claus
parents: 173
diff changeset
  2241
    rel isInteger ifFalse:[
140
claus
parents: 138
diff changeset
  2242
	newX := (rel * (inRect width + bw2)) asInteger + inRect left.
claus
parents: 138
diff changeset
  2243
	(borderWidth ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2244
	    newX := newX - borderWidth
claus
parents: 138
diff changeset
  2245
	].
175
claus
parents: 173
diff changeset
  2246
    ] ifTrue:[
140
claus
parents: 138
diff changeset
  2247
	newX := rel
claus
parents: 138
diff changeset
  2248
    ].
claus
parents: 138
diff changeset
  2249
claus
parents: 138
diff changeset
  2250
    rel := aPoint y.
175
claus
parents: 173
diff changeset
  2251
    rel isInteger ifFalse:[
140
claus
parents: 138
diff changeset
  2252
	newY := (rel * (inRect height + bw2)) asInteger + inRect top.
claus
parents: 138
diff changeset
  2253
	(borderWidth ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2254
	    newY := newY - borderWidth
claus
parents: 138
diff changeset
  2255
	].
175
claus
parents: 173
diff changeset
  2256
    ] ifTrue:[
140
claus
parents: 138
diff changeset
  2257
	newY := rel
claus
parents: 138
diff changeset
  2258
    ].
claus
parents: 138
diff changeset
  2259
claus
parents: 138
diff changeset
  2260
    insets notNil ifTrue:[
claus
parents: 138
diff changeset
  2261
	i := insets at:1.   "top"
claus
parents: 138
diff changeset
  2262
	(i  ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2263
	    newX := newX - i
claus
parents: 138
diff changeset
  2264
	].
claus
parents: 138
diff changeset
  2265
	i := insets at:3.   "left"
claus
parents: 138
diff changeset
  2266
	(i  ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2267
	    newX := newX - i
claus
parents: 138
diff changeset
  2268
	].
claus
parents: 138
diff changeset
  2269
	i := insets at:2.   "right"
claus
parents: 138
diff changeset
  2270
	(i ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2271
	    newY := newY - i
claus
parents: 138
diff changeset
  2272
	].
claus
parents: 138
diff changeset
  2273
	i := insets at:4.   "bottom"
claus
parents: 138
diff changeset
  2274
	(i ~~ 0) ifTrue:[
claus
parents: 138
diff changeset
  2275
	    newY := newY - i
claus
parents: 138
diff changeset
  2276
	].
claus
parents: 138
diff changeset
  2277
    ].
claus
parents: 138
diff changeset
  2278
    ^ newX @ newY
claus
parents: 138
diff changeset
  2279
!
claus
parents: 138
diff changeset
  2280
claus
parents: 138
diff changeset
  2281
extentFromRelativeExtent
claus
parents: 138
diff changeset
  2282
    "compute & return pixel extent from relativeExtent"
claus
parents: 138
diff changeset
  2283
claus
parents: 138
diff changeset
  2284
    ^ self extentFromRelativeExtent:relativeExtent
claus
parents: 138
diff changeset
  2285
!
claus
parents: 138
diff changeset
  2286
claus
parents: 138
diff changeset
  2287
pixelOrigin:origin corner:corner
180
claus
parents: 176
diff changeset
  2288
    "set the views origin and corner in pixels"
140
claus
parents: 138
diff changeset
  2289
claus
parents: 138
diff changeset
  2290
    |w h|
claus
parents: 138
diff changeset
  2291
180
claus
parents: 176
diff changeset
  2292
    w := corner x - origin x + 1.
claus
parents: 176
diff changeset
  2293
    h := corner y - origin y + 1.
140
claus
parents: 138
diff changeset
  2294
    self pixelOrigin:origin extent:(w @ h)
180
claus
parents: 176
diff changeset
  2295
claus
parents: 176
diff changeset
  2296
    "Modified: 31.8.1995 / 18:24:16 / claus"
140
claus
parents: 138
diff changeset
  2297
!
claus
parents: 138
diff changeset
  2298
claus
parents: 138
diff changeset
  2299
setBorderColor
claus
parents: 138
diff changeset
  2300
    "set my borderColor"
claus
parents: 138
diff changeset
  2301
claus
parents: 138
diff changeset
  2302
    |id dither|
claus
parents: 138
diff changeset
  2303
claus
parents: 138
diff changeset
  2304
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  2305
	borderColor := borderColor on:device.
claus
parents: 138
diff changeset
  2306
	id := borderColor colorId.
claus
parents: 138
diff changeset
  2307
	id notNil ifTrue:[
claus
parents: 138
diff changeset
  2308
	    device setWindowBorderColor:id in:drawableId
claus
parents: 138
diff changeset
  2309
	] ifFalse:[
claus
parents: 138
diff changeset
  2310
	    dither := borderColor ditherForm.
claus
parents: 138
diff changeset
  2311
	    dither notNil ifTrue:[
claus
parents: 138
diff changeset
  2312
		device setWindowBorderPixmap:(dither id) in:drawableId
claus
parents: 138
diff changeset
  2313
	    ] ifFalse:[
145
claus
parents: 144
diff changeset
  2314
		'VIEW: bad borderColor' errorPrintNL
135
claus
parents:
diff changeset
  2315
	    ]
claus
parents:
diff changeset
  2316
	]
claus
parents:
diff changeset
  2317
    ]
claus
parents:
diff changeset
  2318
!
claus
parents:
diff changeset
  2319
140
claus
parents: 138
diff changeset
  2320
dimensionFromViewport
claus
parents: 138
diff changeset
  2321
    "define my origin/extend from viewport"
claus
parents: 138
diff changeset
  2322
claus
parents: 138
diff changeset
  2323
    |relW relH relX relY winW winH org ext|
claus
parents: 138
diff changeset
  2324
claus
parents: 138
diff changeset
  2325
    superView notNil ifTrue:[
claus
parents: 138
diff changeset
  2326
	superView window isNil ifTrue:[
claus
parents: 138
diff changeset
  2327
"
claus
parents: 138
diff changeset
  2328
	    v := superView.
claus
parents: 138
diff changeset
  2329
	    (v notNil and:[v window isNil]) whileTrue:[
claus
parents: 138
diff changeset
  2330
		v := v superview
claus
parents: 138
diff changeset
  2331
	    ].
claus
parents: 138
diff changeset
  2332
	    v notNil ifTrue:[
claus
parents: 138
diff changeset
  2333
		w := v window
claus
parents: 138
diff changeset
  2334
	    ].
claus
parents: 138
diff changeset
  2335
"
claus
parents: 138
diff changeset
  2336
"
claus
parents: 138
diff changeset
  2337
	    winW := 1.
claus
parents: 138
diff changeset
  2338
	    winH := 1
claus
parents: 138
diff changeset
  2339
"
claus
parents: 138
diff changeset
  2340
	    winW := superView width.
claus
parents: 138
diff changeset
  2341
	    winH := superView height.
claus
parents: 138
diff changeset
  2342
claus
parents: 138
diff changeset
  2343
	] ifFalse:[
claus
parents: 138
diff changeset
  2344
	    winW := superView window width.
claus
parents: 138
diff changeset
  2345
	    winH := superView window height
claus
parents: 138
diff changeset
  2346
	].
claus
parents: 138
diff changeset
  2347
	relW := (viewport width / winW) asFloat.
claus
parents: 138
diff changeset
  2348
	relH := (viewport height / winH) asFloat.
claus
parents: 138
diff changeset
  2349
	relX := (viewport left / winW) asFloat.
claus
parents: 138
diff changeset
  2350
	relY := (viewport top / winH) asFloat.
claus
parents: 138
diff changeset
  2351
	"bad coding style ... misuse other method"
claus
parents: 138
diff changeset
  2352
	relativeOrigin := (relX @ relY).
claus
parents: 138
diff changeset
  2353
	org := self originFromRelativeOrigin.
claus
parents: 138
diff changeset
  2354
	relativeOrigin := nil.
claus
parents: 138
diff changeset
  2355
claus
parents: 138
diff changeset
  2356
	"bad coding style ...misuse other method"
claus
parents: 138
diff changeset
  2357
	relativeExtent := (relW @ relH).
claus
parents: 138
diff changeset
  2358
	ext := self extentFromRelativeExtent.
claus
parents: 138
diff changeset
  2359
	relativeExtent := nil.
claus
parents: 138
diff changeset
  2360
claus
parents: 138
diff changeset
  2361
	self pixelOrigin:org extent:ext.
claus
parents: 138
diff changeset
  2362
    ]
claus
parents: 138
diff changeset
  2363
! !
claus
parents: 138
diff changeset
  2364
claus
parents: 138
diff changeset
  2365
!SimpleView methodsFor:'accessing-dimensions'!
claus
parents: 138
diff changeset
  2366
151
claus
parents: 145
diff changeset
  2367
layout
claus
parents: 145
diff changeset
  2368
    "return the layout object which controls my geometry.
claus
parents: 145
diff changeset
  2369
     Currently, this is nil in most cases, and my geometry is
claus
parents: 145
diff changeset
  2370
     defined by relativeOrigin/relativeCorner/relativeExtent,
claus
parents: 145
diff changeset
  2371
     originRule/extentRule/cornerRule and inset.
claus
parents: 145
diff changeset
  2372
     Applications should be changed to use layoutObjects,
claus
parents: 145
diff changeset
  2373
     since the above listed instance variables will vanish."
claus
parents: 145
diff changeset
  2374
claus
parents: 145
diff changeset
  2375
    ^ layout
claus
parents: 145
diff changeset
  2376
!
claus
parents: 145
diff changeset
  2377
157
claus
parents: 154
diff changeset
  2378
geometryLayout
claus
parents: 154
diff changeset
  2379
    "this method will vanish, as soon as all implementations of
claus
parents: 154
diff changeset
  2380
     #layout: are removed ...
claus
parents: 154
diff changeset
  2381
     (conflict for example in label>>layout:).
claus
parents: 154
diff changeset
  2382
     DO NOT USE #geometryLayout: in your code; it will be removed without
claus
parents: 154
diff changeset
  2383
     notice."
claus
parents: 154
diff changeset
  2384
claus
parents: 154
diff changeset
  2385
    ^ here layout
claus
parents: 154
diff changeset
  2386
!
claus
parents: 154
diff changeset
  2387
153
claus
parents: 151
diff changeset
  2388
geometryLayout:aLayoutObject
claus
parents: 151
diff changeset
  2389
    "this method will vanish, as soon as all implementations of
claus
parents: 151
diff changeset
  2390
     #layout: are removed ...
claus
parents: 151
diff changeset
  2391
     (conflict for example in label>>layout:).
claus
parents: 151
diff changeset
  2392
     DO NOT USE #geometryLayout: in your code; it will be removed without
claus
parents: 151
diff changeset
  2393
     notice."
claus
parents: 151
diff changeset
  2394
claus
parents: 151
diff changeset
  2395
    here layout:aLayoutObject
claus
parents: 151
diff changeset
  2396
!
claus
parents: 151
diff changeset
  2397
151
claus
parents: 145
diff changeset
  2398
layout:aLayoutObject
claus
parents: 145
diff changeset
  2399
    "set the layout object which controls my geometry.
claus
parents: 145
diff changeset
  2400
     Currently, this is almost nowhere used but views will be
claus
parents: 145
diff changeset
  2401
     incrementally changed to use this new geometry management."
claus
parents: 145
diff changeset
  2402
claus
parents: 145
diff changeset
  2403
    layout := aLayoutObject.
180
claus
parents: 176
diff changeset
  2404
"/    originChanged := cornerChanged := extentChanged := true
claus
parents: 176
diff changeset
  2405
    self superViewChangedSize.
151
claus
parents: 145
diff changeset
  2406
!
claus
parents: 145
diff changeset
  2407
140
claus
parents: 138
diff changeset
  2408
computeOrigin
151
claus
parents: 145
diff changeset
  2409
    "compute my origin; if I have a layoutObject, a relative origin
claus
parents: 145
diff changeset
  2410
     or blocks to evaluate, compute it now ..
claus
parents: 145
diff changeset
  2411
     Blocks may return relative values or nil; nil means: take current value.
claus
parents: 145
diff changeset
  2412
     Returns the origin point in device coordinates (pixels)."
140
claus
parents: 138
diff changeset
  2413
claus
parents: 138
diff changeset
  2414
    |newOrg x y|
claus
parents: 138
diff changeset
  2415
151
claus
parents: 145
diff changeset
  2416
    "
claus
parents: 145
diff changeset
  2417
     slowly migrating to use layoutObjects ...
claus
parents: 145
diff changeset
  2418
    "
claus
parents: 145
diff changeset
  2419
    layout notNil ifTrue:[
claus
parents: 145
diff changeset
  2420
	^ (layout rectangleRelativeTo:(superView viewRectangle)
claus
parents: 145
diff changeset
  2421
			    preferred:(self preferredBounds)) origin rounded
claus
parents: 145
diff changeset
  2422
    ].
claus
parents: 145
diff changeset
  2423
140
claus
parents: 138
diff changeset
  2424
    (originRule notNil) ifTrue:[
claus
parents: 138
diff changeset
  2425
	newOrg := originRule value.
claus
parents: 138
diff changeset
  2426
	"
claus
parents: 138
diff changeset
  2427
	 allow return of relative values ...
claus
parents: 138
diff changeset
  2428
	"
claus
parents: 138
diff changeset
  2429
	x := newOrg x.
claus
parents: 138
diff changeset
  2430
	y := newOrg y.
claus
parents: 138
diff changeset
  2431
	x isNil ifTrue:[x := self origin x].
claus
parents: 138
diff changeset
  2432
	y isNil ifTrue:[y := self origin y].
claus
parents: 138
diff changeset
  2433
	((x isInteger not) or:[y isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2434
	    newOrg := self originFromRelativeOrigin:x@y.
claus
parents: 138
diff changeset
  2435
	]
claus
parents: 138
diff changeset
  2436
    ] ifFalse:[
claus
parents: 138
diff changeset
  2437
	(relativeOrigin notNil) ifTrue:[
claus
parents: 138
diff changeset
  2438
	    newOrg := self originFromRelativeOrigin:relativeOrigin.
claus
parents: 138
diff changeset
  2439
	] ifFalse:[
claus
parents: 138
diff changeset
  2440
	    ^ (left @ top).
claus
parents: 138
diff changeset
  2441
	].
claus
parents: 138
diff changeset
  2442
    ].
claus
parents: 138
diff changeset
  2443
    ^ newOrg
claus
parents: 138
diff changeset
  2444
!
claus
parents: 138
diff changeset
  2445
claus
parents: 138
diff changeset
  2446
computeExtent
151
claus
parents: 145
diff changeset
  2447
    "compute my extent; if I have a layoutObject, a relative extent 
claus
parents: 145
diff changeset
  2448
     or blocks to evaluate, compute it now ..
140
claus
parents: 138
diff changeset
  2449
     There is one catch here, if the dimension was defined
claus
parents: 138
diff changeset
  2450
     by origin/corner, compute them here and take that value.
151
claus
parents: 145
diff changeset
  2451
     I.e. origin/corner definition has precedence over extent definition.
claus
parents: 145
diff changeset
  2452
     Returns the extent in device coordinates (pixels)."
140
claus
parents: 138
diff changeset
  2453
claus
parents: 138
diff changeset
  2454
    |newOrg newExt newCorner x y|
claus
parents: 138
diff changeset
  2455
151
claus
parents: 145
diff changeset
  2456
    "
claus
parents: 145
diff changeset
  2457
     slowly migrating to use layoutObjects ...
claus
parents: 145
diff changeset
  2458
    "
claus
parents: 145
diff changeset
  2459
    layout notNil ifTrue:[
claus
parents: 145
diff changeset
  2460
	^ (layout rectangleRelativeTo:(superView viewRectangle)
claus
parents: 145
diff changeset
  2461
			    preferred:(self preferredBounds)) extent rounded
claus
parents: 145
diff changeset
  2462
    ].
claus
parents: 145
diff changeset
  2463
140
claus
parents: 138
diff changeset
  2464
    (cornerRule notNil) ifTrue:[
claus
parents: 138
diff changeset
  2465
	newCorner := cornerRule value.
claus
parents: 138
diff changeset
  2466
	"
claus
parents: 138
diff changeset
  2467
	 allow return of relative values ...
claus
parents: 138
diff changeset
  2468
	"
claus
parents: 138
diff changeset
  2469
	x := newCorner x.
claus
parents: 138
diff changeset
  2470
	y := newCorner y.
claus
parents: 138
diff changeset
  2471
	x isNil ifTrue:[x := self corner x].
claus
parents: 138
diff changeset
  2472
	y isNil ifTrue:[y := self corner y].
claus
parents: 138
diff changeset
  2473
	((x isInteger not) or:[y isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2474
	    newCorner := self cornerFromRelativeCorner:x@y
claus
parents: 138
diff changeset
  2475
	]
claus
parents: 138
diff changeset
  2476
    ] ifFalse:[
claus
parents: 138
diff changeset
  2477
	(relativeCorner notNil) ifTrue:[
claus
parents: 138
diff changeset
  2478
	    newCorner := self cornerFromRelativeCorner:relativeCorner
claus
parents: 138
diff changeset
  2479
	] ifFalse:[
claus
parents: 138
diff changeset
  2480
	    (extentRule notNil) ifTrue:[
claus
parents: 138
diff changeset
  2481
		newExt := extentRule value.
claus
parents: 138
diff changeset
  2482
		"
claus
parents: 138
diff changeset
  2483
		 allow return of relative values ...
claus
parents: 138
diff changeset
  2484
		"
claus
parents: 138
diff changeset
  2485
		x := newExt x.
claus
parents: 138
diff changeset
  2486
		y := newExt y.
claus
parents: 138
diff changeset
  2487
		x isNil ifTrue:[x := width].
claus
parents: 138
diff changeset
  2488
		y isNil ifTrue:[y := height].
claus
parents: 138
diff changeset
  2489
		((x isInteger not) or:[y isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2490
		    newExt := self extentFromRelativeExtent:x@y
claus
parents: 138
diff changeset
  2491
		]
claus
parents: 138
diff changeset
  2492
	    ] ifFalse:[
claus
parents: 138
diff changeset
  2493
		(relativeExtent notNil) ifTrue:[
claus
parents: 138
diff changeset
  2494
		    newExt := self extentFromRelativeExtent:relativeExtent
claus
parents: 138
diff changeset
  2495
		] ifFalse:[
claus
parents: 138
diff changeset
  2496
		    newExt := (width @ height).
claus
parents: 138
diff changeset
  2497
		].
claus
parents: 138
diff changeset
  2498
	    ].
claus
parents: 138
diff changeset
  2499
	].
claus
parents: 138
diff changeset
  2500
    ].
claus
parents: 138
diff changeset
  2501
claus
parents: 138
diff changeset
  2502
    newCorner notNil ifTrue:[
claus
parents: 138
diff changeset
  2503
	newOrg := self computeOrigin.
claus
parents: 138
diff changeset
  2504
	^ newCorner - newOrg.
claus
parents: 138
diff changeset
  2505
    ].
claus
parents: 138
diff changeset
  2506
    ^ newExt.
claus
parents: 138
diff changeset
  2507
!
claus
parents: 138
diff changeset
  2508
claus
parents: 138
diff changeset
  2509
extent:extent
151
claus
parents: 145
diff changeset
  2510
    "set the views extent; 
claus
parents: 145
diff changeset
  2511
     extent may be:
claus
parents: 145
diff changeset
  2512
	a point 
claus
parents: 145
diff changeset
  2513
	    where integer fields mean 'pixel-values'
claus
parents: 145
diff changeset
  2514
	    and float values mean 'relative-to-superview'
claus
parents: 145
diff changeset
  2515
	    and nil means 'leave current value';
claus
parents: 145
diff changeset
  2516
     or a block returning a point which is interpreted as above.
claus
parents: 145
diff changeset
  2517
     Be careful when using relative extents: rounding errors may
claus
parents: 145
diff changeset
  2518
     accumulate. Better use origin/corner. 
claus
parents: 145
diff changeset
  2519
     Best: migrate to use layour objects."
140
claus
parents: 138
diff changeset
  2520
claus
parents: 138
diff changeset
  2521
    |w h pixelExtent e|
claus
parents: 138
diff changeset
  2522
claus
parents: 138
diff changeset
  2523
    extent isBlock ifTrue:[
claus
parents: 138
diff changeset
  2524
	extentRule := extent.
claus
parents: 138
diff changeset
  2525
	drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  2526
	    pixelExtent := extent value
claus
parents: 138
diff changeset
  2527
	] ifFalse:[
claus
parents: 138
diff changeset
  2528
	    extentChanged := true
claus
parents: 138
diff changeset
  2529
	]
claus
parents: 138
diff changeset
  2530
    ] ifFalse:[
claus
parents: 138
diff changeset
  2531
	w := extent x.
claus
parents: 138
diff changeset
  2532
	h := extent y.
claus
parents: 138
diff changeset
  2533
	w isNil ifTrue:[w := width].
claus
parents: 138
diff changeset
  2534
	h isNil ifTrue:[h := height].
claus
parents: 138
diff changeset
  2535
	e := w@h.
claus
parents: 138
diff changeset
  2536
	((w isInteger not) or:[h isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2537
	    relativeExtent := e.
claus
parents: 138
diff changeset
  2538
	    pixelExtent := self extentFromRelativeExtent.
claus
parents: 138
diff changeset
  2539
	    pixelExtent isNil ifTrue:[
claus
parents: 138
diff changeset
  2540
		extentChanged := true
claus
parents: 138
diff changeset
  2541
	    ]
claus
parents: 138
diff changeset
  2542
	] ifFalse:[
claus
parents: 138
diff changeset
  2543
	    pixelExtent := e
claus
parents: 138
diff changeset
  2544
	]
claus
parents: 138
diff changeset
  2545
    ].
claus
parents: 138
diff changeset
  2546
    pixelExtent notNil ifTrue:[
claus
parents: 138
diff changeset
  2547
	self pixelExtent:pixelExtent
claus
parents: 138
diff changeset
  2548
    ]
claus
parents: 138
diff changeset
  2549
!
claus
parents: 138
diff changeset
  2550
claus
parents: 138
diff changeset
  2551
origin:origin
151
claus
parents: 145
diff changeset
  2552
    "set the views origin; 
claus
parents: 145
diff changeset
  2553
     origin may be:
claus
parents: 145
diff changeset
  2554
	a point 
claus
parents: 145
diff changeset
  2555
	    where integer fields mean 'pixel-values'
claus
parents: 145
diff changeset
  2556
	    and float values mean 'relative-to-superview'
claus
parents: 145
diff changeset
  2557
	    and nil means 'take current value';
claus
parents: 145
diff changeset
  2558
     or a block returning a point which is interpreted as above.
claus
parents: 145
diff changeset
  2559
     Please migrate to use layout objects."
140
claus
parents: 138
diff changeset
  2560
claus
parents: 138
diff changeset
  2561
    |newLeft newTop pixelOrigin o|
claus
parents: 138
diff changeset
  2562
claus
parents: 138
diff changeset
  2563
    origin isBlock ifTrue:[
claus
parents: 138
diff changeset
  2564
	originRule := origin.
claus
parents: 138
diff changeset
  2565
	drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  2566
	    pixelOrigin := origin value
claus
parents: 138
diff changeset
  2567
	] ifFalse:[
claus
parents: 138
diff changeset
  2568
	    originChanged := true
claus
parents: 138
diff changeset
  2569
	]
claus
parents: 138
diff changeset
  2570
    ] ifFalse:[
claus
parents: 138
diff changeset
  2571
	o := origin.
claus
parents: 138
diff changeset
  2572
	newLeft := origin x.
claus
parents: 138
diff changeset
  2573
	newTop := origin y.
claus
parents: 138
diff changeset
  2574
	newLeft isNil ifTrue:[newLeft := left].
claus
parents: 138
diff changeset
  2575
	newTop isNil ifTrue:[newTop := top].
claus
parents: 138
diff changeset
  2576
	o := newLeft @ newTop.
claus
parents: 138
diff changeset
  2577
	((newLeft isInteger not) or:[newTop isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2578
	    relativeOrigin := o.
claus
parents: 138
diff changeset
  2579
	    pixelOrigin := self originFromRelativeOrigin.
claus
parents: 138
diff changeset
  2580
	    pixelOrigin isNil ifTrue:[
claus
parents: 138
diff changeset
  2581
		originChanged := true
claus
parents: 138
diff changeset
  2582
	    ]
claus
parents: 138
diff changeset
  2583
	] ifFalse:[
claus
parents: 138
diff changeset
  2584
	    pixelOrigin := o
claus
parents: 138
diff changeset
  2585
	]
claus
parents: 138
diff changeset
  2586
    ].
claus
parents: 138
diff changeset
  2587
    pixelOrigin notNil ifTrue:[
claus
parents: 138
diff changeset
  2588
	self pixelOrigin:pixelOrigin
claus
parents: 138
diff changeset
  2589
    ].
claus
parents: 138
diff changeset
  2590
!
claus
parents: 138
diff changeset
  2591
claus
parents: 138
diff changeset
  2592
top
claus
parents: 138
diff changeset
  2593
    "return the y position of the top border"
claus
parents: 138
diff changeset
  2594
claus
parents: 138
diff changeset
  2595
    ^ top
claus
parents: 138
diff changeset
  2596
!
claus
parents: 138
diff changeset
  2597
claus
parents: 138
diff changeset
  2598
origin
claus
parents: 138
diff changeset
  2599
    "return the origin (in pixels)"
claus
parents: 138
diff changeset
  2600
claus
parents: 138
diff changeset
  2601
    ^ left@top
claus
parents: 138
diff changeset
  2602
!
claus
parents: 138
diff changeset
  2603
claus
parents: 138
diff changeset
  2604
height:aNumber
claus
parents: 138
diff changeset
  2605
    "set the views height in pixels"
claus
parents: 138
diff changeset
  2606
claus
parents: 138
diff changeset
  2607
    self extent:(width @ aNumber)
claus
parents: 138
diff changeset
  2608
!
claus
parents: 138
diff changeset
  2609
claus
parents: 138
diff changeset
  2610
innerWidth
claus
parents: 138
diff changeset
  2611
    "return the width of the view minus any 3D-shadow-borders"
claus
parents: 138
diff changeset
  2612
claus
parents: 138
diff changeset
  2613
    (level == 0) ifTrue:[^ width].
claus
parents: 138
diff changeset
  2614
    ^ width - (2 * margin)
claus
parents: 138
diff changeset
  2615
!
claus
parents: 138
diff changeset
  2616
claus
parents: 138
diff changeset
  2617
corner:corner 
151
claus
parents: 145
diff changeset
  2618
    "set the views corner; 
claus
parents: 145
diff changeset
  2619
     the corner argument may be:
claus
parents: 145
diff changeset
  2620
	 a point 
claus
parents: 145
diff changeset
  2621
	    where integer fields mean 'pixel-values'
claus
parents: 145
diff changeset
  2622
	    and float values mean 'relative-to-superview'
claus
parents: 145
diff changeset
  2623
	    and nil means 'take current value';
claus
parents: 145
diff changeset
  2624
     or a block returning a point which is interpreted as above.
claus
parents: 145
diff changeset
  2625
     Please migrate to use layoutObjects, if possible."
140
claus
parents: 138
diff changeset
  2626
claus
parents: 138
diff changeset
  2627
    |x y pixelCorner c|
claus
parents: 138
diff changeset
  2628
claus
parents: 138
diff changeset
  2629
    corner isBlock ifTrue:[
claus
parents: 138
diff changeset
  2630
	cornerRule := corner.
claus
parents: 138
diff changeset
  2631
	drawableId notNil ifTrue:[    
claus
parents: 138
diff changeset
  2632
	    pixelCorner := corner value
claus
parents: 138
diff changeset
  2633
	] ifFalse:[
claus
parents: 138
diff changeset
  2634
	    extentChanged := true
claus
parents: 138
diff changeset
  2635
	]
claus
parents: 138
diff changeset
  2636
    ] ifFalse:[
claus
parents: 138
diff changeset
  2637
	x := corner x.
claus
parents: 138
diff changeset
  2638
	y := corner y.
claus
parents: 138
diff changeset
  2639
	x isNil ifTrue:[x := self corner x].
claus
parents: 138
diff changeset
  2640
	y isNil ifTrue:[y := self corner y].
claus
parents: 138
diff changeset
  2641
	c := x @ y.
claus
parents: 138
diff changeset
  2642
	((x isInteger not) or:[y isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  2643
	    relativeCorner := c.
claus
parents: 138
diff changeset
  2644
	    pixelCorner := self cornerFromRelativeCorner.
claus
parents: 138
diff changeset
  2645
	    pixelCorner isNil ifTrue:[
claus
parents: 138
diff changeset
  2646
		extentChanged := true
claus
parents: 138
diff changeset
  2647
	    ]
claus
parents: 138
diff changeset
  2648
	] ifFalse:[
claus
parents: 138
diff changeset
  2649
	    pixelCorner := c
claus
parents: 138
diff changeset
  2650
	]
claus
parents: 138
diff changeset
  2651
    ].
claus
parents: 138
diff changeset
  2652
claus
parents: 138
diff changeset
  2653
    pixelCorner notNil ifTrue:[
claus
parents: 138
diff changeset
  2654
	self pixelCorner:pixelCorner
claus
parents: 138
diff changeset
  2655
    ]
claus
parents: 138
diff changeset
  2656
!
claus
parents: 138
diff changeset
  2657
claus
parents: 138
diff changeset
  2658
origin:origin extent:extent
claus
parents: 138
diff changeset
  2659
    "set both origin and extent"
claus
parents: 138
diff changeset
  2660
claus
parents: 138
diff changeset
  2661
    |newLeft newTop newWidth newHeight|
claus
parents: 138
diff changeset
  2662
claus
parents: 138
diff changeset
  2663
    "do it as one operation if possible"
claus
parents: 138
diff changeset
  2664
claus
parents: 138
diff changeset
  2665
    origin isBlock ifFalse:[
claus
parents: 138
diff changeset
  2666
	extent isBlock ifFalse:[
claus
parents: 138
diff changeset
  2667
	    newLeft := origin x.
151
claus
parents: 145
diff changeset
  2668
	    newLeft isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2669
		newTop := origin y.
151
claus
parents: 145
diff changeset
  2670
		newTop isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2671
		    newWidth := extent x.
151
claus
parents: 145
diff changeset
  2672
		    newWidth isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2673
			newHeight := extent y.
151
claus
parents: 145
diff changeset
  2674
			newHeight isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2675
			    self pixelOrigin:origin extent:extent
claus
parents: 138
diff changeset
  2676
			]
claus
parents: 138
diff changeset
  2677
		    ]
claus
parents: 138
diff changeset
  2678
		]
claus
parents: 138
diff changeset
  2679
	    ]
claus
parents: 138
diff changeset
  2680
	]
claus
parents: 138
diff changeset
  2681
    ].
claus
parents: 138
diff changeset
  2682
    self extent:extent.
claus
parents: 138
diff changeset
  2683
    self origin:origin
claus
parents: 138
diff changeset
  2684
!
claus
parents: 138
diff changeset
  2685
claus
parents: 138
diff changeset
  2686
origin:origin corner:corner 
claus
parents: 138
diff changeset
  2687
    "set both origin and extent"
claus
parents: 138
diff changeset
  2688
claus
parents: 138
diff changeset
  2689
    |newLeft newTop newRight newBot|
claus
parents: 138
diff changeset
  2690
claus
parents: 138
diff changeset
  2691
    "do it as one operation if possible"
claus
parents: 138
diff changeset
  2692
claus
parents: 138
diff changeset
  2693
    origin isBlock ifFalse:[
claus
parents: 138
diff changeset
  2694
	corner isBlock ifFalse:[
claus
parents: 138
diff changeset
  2695
	    newLeft := origin x.
175
claus
parents: 173
diff changeset
  2696
	    newLeft isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2697
		newTop := origin y.
175
claus
parents: 173
diff changeset
  2698
		newTop isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2699
		    newRight := corner x.
175
claus
parents: 173
diff changeset
  2700
		    newRight isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2701
			newBot := corner y.
175
claus
parents: 173
diff changeset
  2702
			newBot isInteger ifTrue:[
140
claus
parents: 138
diff changeset
  2703
			    self pixelOrigin:origin corner:corner 
claus
parents: 138
diff changeset
  2704
			]
claus
parents: 138
diff changeset
  2705
		    ]
claus
parents: 138
diff changeset
  2706
		]
claus
parents: 138
diff changeset
  2707
	    ]
135
claus
parents:
diff changeset
  2708
	]
claus
parents:
diff changeset
  2709
    ].
140
claus
parents: 138
diff changeset
  2710
    self origin:origin.
claus
parents: 138
diff changeset
  2711
    self corner:corner 
claus
parents: 138
diff changeset
  2712
!
claus
parents: 138
diff changeset
  2713
claus
parents: 138
diff changeset
  2714
relativeCorner
claus
parents: 138
diff changeset
  2715
    "return the relative corner or nil"
claus
parents: 138
diff changeset
  2716
claus
parents: 138
diff changeset
  2717
    ^ relativeCorner
claus
parents: 138
diff changeset
  2718
!
claus
parents: 138
diff changeset
  2719
claus
parents: 138
diff changeset
  2720
makeFullyVisible
claus
parents: 138
diff changeset
  2721
    "make sure, that the view is fully visible by shifting it
claus
parents: 138
diff changeset
  2722
     into the visible screen area if nescessary.
claus
parents: 138
diff changeset
  2723
     This method will be moved to StandardSystemView ..."
claus
parents: 138
diff changeset
  2724
claus
parents: 138
diff changeset
  2725
    ((top + height) > (device height)) ifTrue:[
claus
parents: 138
diff changeset
  2726
	self top:(device height - height)
claus
parents: 138
diff changeset
  2727
    ].
claus
parents: 138
diff changeset
  2728
    ((left + width) > (device width)) ifTrue:[
claus
parents: 138
diff changeset
  2729
	self left:(device width - width)
claus
parents: 138
diff changeset
  2730
    ].
claus
parents: 138
diff changeset
  2731
    (top < 0) ifTrue:[
claus
parents: 138
diff changeset
  2732
	self top:0
claus
parents: 138
diff changeset
  2733
    ].
claus
parents: 138
diff changeset
  2734
    (left < 0) ifTrue:[
claus
parents: 138
diff changeset
  2735
	self left:0
claus
parents: 138
diff changeset
  2736
    ].
claus
parents: 138
diff changeset
  2737
!
claus
parents: 138
diff changeset
  2738
157
claus
parents: 154
diff changeset
  2739
width:aNumber
claus
parents: 154
diff changeset
  2740
    "set the views width in pixels"
claus
parents: 154
diff changeset
  2741
claus
parents: 154
diff changeset
  2742
    self extent:(aNumber @ height)
claus
parents: 154
diff changeset
  2743
!
claus
parents: 154
diff changeset
  2744
claus
parents: 154
diff changeset
  2745
inset:aNumber
claus
parents: 154
diff changeset
  2746
    "set all insets; positive makes the view smaller,
claus
parents: 154
diff changeset
  2747
     negative makes it larger."
claus
parents: 154
diff changeset
  2748
claus
parents: 154
diff changeset
  2749
    self allInset:aNumber
claus
parents: 154
diff changeset
  2750
!
claus
parents: 154
diff changeset
  2751
153
claus
parents: 151
diff changeset
  2752
allInset:aNumber
157
claus
parents: 154
diff changeset
  2753
    "set all insets; positive makes the view smaller,
claus
parents: 154
diff changeset
  2754
     negative makes it larger."
153
claus
parents: 151
diff changeset
  2755
claus
parents: 151
diff changeset
  2756
    insets isNil ifTrue:[
claus
parents: 151
diff changeset
  2757
	insets := Array new:4.
claus
parents: 151
diff changeset
  2758
    ].
claus
parents: 151
diff changeset
  2759
    insets atAllPut:aNumber.
claus
parents: 151
diff changeset
  2760
claus
parents: 151
diff changeset
  2761
    "force recomputation"
180
claus
parents: 176
diff changeset
  2762
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2763
"/        originChanged := true
claus
parents: 176
diff changeset
  2764
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2765
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2766
"/    ]
153
claus
parents: 151
diff changeset
  2767
!
claus
parents: 151
diff changeset
  2768
157
claus
parents: 154
diff changeset
  2769
horizontalInset:aNumber
claus
parents: 154
diff changeset
  2770
    "set the insets of the left/right edge; 
claus
parents: 154
diff changeset
  2771
     positive makes it smaller, negative makes it larger"
claus
parents: 154
diff changeset
  2772
claus
parents: 154
diff changeset
  2773
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2774
	insets := Array with:0 with:0 with:0 with:0
157
claus
parents: 154
diff changeset
  2775
    ].
claus
parents: 154
diff changeset
  2776
    insets at:1 put:aNumber.
claus
parents: 154
diff changeset
  2777
    insets at:3 put:aNumber.
claus
parents: 154
diff changeset
  2778
claus
parents: 154
diff changeset
  2779
    "force recomputation"
180
claus
parents: 176
diff changeset
  2780
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2781
"/        originChanged := true
claus
parents: 176
diff changeset
  2782
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2783
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2784
"/    ]
157
claus
parents: 154
diff changeset
  2785
!
claus
parents: 154
diff changeset
  2786
claus
parents: 154
diff changeset
  2787
verticalInset:aNumber
claus
parents: 154
diff changeset
  2788
    "set the insets of the top/bottom edge; 
claus
parents: 154
diff changeset
  2789
     positive makes it smaller, negative makes it larger"
claus
parents: 154
diff changeset
  2790
claus
parents: 154
diff changeset
  2791
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2792
	insets := Array with:0 with:0 with:0 with:0
157
claus
parents: 154
diff changeset
  2793
    ].
claus
parents: 154
diff changeset
  2794
    insets at:2 put:aNumber.
claus
parents: 154
diff changeset
  2795
    insets at:4 put:aNumber.
claus
parents: 154
diff changeset
  2796
claus
parents: 154
diff changeset
  2797
    "force recomputation"
180
claus
parents: 176
diff changeset
  2798
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2799
"/        originChanged := true
claus
parents: 176
diff changeset
  2800
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2801
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2802
"/    ]
157
claus
parents: 154
diff changeset
  2803
!
claus
parents: 154
diff changeset
  2804
claus
parents: 154
diff changeset
  2805
rightInset:aNumber
claus
parents: 154
diff changeset
  2806
    "set the inset of the right edge; 
claus
parents: 154
diff changeset
  2807
     positive is to the left (view becomes smaller), 
claus
parents: 154
diff changeset
  2808
     negative to the right (becomes larger)"
claus
parents: 154
diff changeset
  2809
claus
parents: 154
diff changeset
  2810
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2811
	insets := Array with:0 with:0 with:0 with:0
157
claus
parents: 154
diff changeset
  2812
    ].
claus
parents: 154
diff changeset
  2813
    insets at:3 put:aNumber.
claus
parents: 154
diff changeset
  2814
claus
parents: 154
diff changeset
  2815
    "force recomputation"
180
claus
parents: 176
diff changeset
  2816
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2817
"/        originChanged := true
claus
parents: 176
diff changeset
  2818
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2819
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2820
"/    ]
157
claus
parents: 154
diff changeset
  2821
!
claus
parents: 154
diff changeset
  2822
140
claus
parents: 138
diff changeset
  2823
leftInset:aNumber
157
claus
parents: 154
diff changeset
  2824
    "set the inset of the left edge; 
claus
parents: 154
diff changeset
  2825
     positive is to the right (view becomes smaller),
claus
parents: 154
diff changeset
  2826
     negative to the left (becomes larger)"
140
claus
parents: 138
diff changeset
  2827
claus
parents: 138
diff changeset
  2828
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2829
	insets := Array with:0 with:0 with:0 with:0
140
claus
parents: 138
diff changeset
  2830
    ].
claus
parents: 138
diff changeset
  2831
    insets at:1 put:aNumber.
claus
parents: 138
diff changeset
  2832
claus
parents: 138
diff changeset
  2833
    "force recomputation"
180
claus
parents: 176
diff changeset
  2834
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2835
"/        originChanged := true
claus
parents: 176
diff changeset
  2836
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2837
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2838
"/    ]
140
claus
parents: 138
diff changeset
  2839
!
claus
parents: 138
diff changeset
  2840
claus
parents: 138
diff changeset
  2841
topInset:aNumber
157
claus
parents: 154
diff changeset
  2842
    "set the inset of the top edge; 
claus
parents: 154
diff changeset
  2843
     positive is to the bottom (view becomes smaller),
claus
parents: 154
diff changeset
  2844
     negative to the top (becomes larger)"
140
claus
parents: 138
diff changeset
  2845
claus
parents: 138
diff changeset
  2846
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2847
	insets := Array with:0 with:0 with:0 with:0
140
claus
parents: 138
diff changeset
  2848
    ].
claus
parents: 138
diff changeset
  2849
    insets at:2 put:aNumber.
claus
parents: 138
diff changeset
  2850
claus
parents: 138
diff changeset
  2851
    "force recomputation"
180
claus
parents: 176
diff changeset
  2852
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2853
"/        originChanged := true
claus
parents: 176
diff changeset
  2854
"/    ] ifFalse:[
claus
parents: 176
diff changeset
  2855
	self superViewChangedSize.
claus
parents: 176
diff changeset
  2856
"/    ]
140
claus
parents: 138
diff changeset
  2857
!
claus
parents: 138
diff changeset
  2858
157
claus
parents: 154
diff changeset
  2859
bottomInset:aNumber
claus
parents: 154
diff changeset
  2860
    "set the inset of the bottom edge; 
claus
parents: 154
diff changeset
  2861
     positive is to the top (view becomes smaller),
claus
parents: 154
diff changeset
  2862
     negative to the bottom (becomes larger)"
claus
parents: 154
diff changeset
  2863
claus
parents: 154
diff changeset
  2864
    insets isNil ifTrue:[
160
claus
parents: 157
diff changeset
  2865
	insets := Array with:0 with:0 with:0 with:0
157
claus
parents: 154
diff changeset
  2866
    ].
claus
parents: 154
diff changeset
  2867
    insets at:4 put:aNumber.
claus
parents: 154
diff changeset
  2868
claus
parents: 154
diff changeset
  2869
    "force recomputation"
180
claus
parents: 176
diff changeset
  2870
"/    drawableId isNil ifTrue:[
claus
parents: 176
diff changeset
  2871
"/        originChanged := true
claus
parents: 176
diff changeset
  2872
"/    ] ifFalse:[
157
claus
parents: 154
diff changeset
  2873
	self superViewChangedSize
180
claus
parents: 176
diff changeset
  2874
"/    ]
157
claus
parents: 154
diff changeset
  2875
!
claus
parents: 154
diff changeset
  2876
140
claus
parents: 138
diff changeset
  2877
left:aNumber
claus
parents: 138
diff changeset
  2878
    "set the x position"
claus
parents: 138
diff changeset
  2879
claus
parents: 138
diff changeset
  2880
    self origin:(aNumber @ top)
claus
parents: 138
diff changeset
  2881
!
claus
parents: 138
diff changeset
  2882
claus
parents: 138
diff changeset
  2883
relativeOrigin
claus
parents: 138
diff changeset
  2884
    "return the relative origin or nil"
claus
parents: 138
diff changeset
  2885
claus
parents: 138
diff changeset
  2886
    ^ relativeOrigin
claus
parents: 138
diff changeset
  2887
!
claus
parents: 138
diff changeset
  2888
claus
parents: 138
diff changeset
  2889
innerHeight
claus
parents: 138
diff changeset
  2890
    "return the height of the view minus any 3D-shadow-borders"
claus
parents: 138
diff changeset
  2891
claus
parents: 138
diff changeset
  2892
    (margin == 0) ifTrue:[^ height].
claus
parents: 138
diff changeset
  2893
    ^ height - (2 * margin)
claus
parents: 138
diff changeset
  2894
!
claus
parents: 138
diff changeset
  2895
153
claus
parents: 151
diff changeset
  2896
heightIncludingBorder
claus
parents: 151
diff changeset
  2897
    "return my height including border 
claus
parents: 151
diff changeset
  2898
     (this is my height as seen from the outside view;
claus
parents: 151
diff changeset
  2899
      while #height returns the height as seen by myself)"
claus
parents: 151
diff changeset
  2900
claus
parents: 151
diff changeset
  2901
    ^ height + (2*borderWidth)
claus
parents: 151
diff changeset
  2902
!
claus
parents: 151
diff changeset
  2903
claus
parents: 151
diff changeset
  2904
widthIncludingBorder
claus
parents: 151
diff changeset
  2905
    "return my width including border
claus
parents: 151
diff changeset
  2906
     (this is my width as seen from the outside view;
claus
parents: 151
diff changeset
  2907
      while #width returns the width as seen by myself)"
claus
parents: 151
diff changeset
  2908
claus
parents: 151
diff changeset
  2909
    ^ width + (2*borderWidth)
claus
parents: 151
diff changeset
  2910
!
claus
parents: 151
diff changeset
  2911
140
claus
parents: 138
diff changeset
  2912
originRelativeTo:aView
claus
parents: 138
diff changeset
  2913
    "return the origin (in pixels) relative to a superView,
151
claus
parents: 145
diff changeset
  2914
     or relative to the rootView (if the aView argument is nil).
153
claus
parents: 151
diff changeset
  2915
     If the receiver is nonNil and not a subview of aView, return nil."
140
claus
parents: 138
diff changeset
  2916
claus
parents: 138
diff changeset
  2917
    |currentView
claus
parents: 138
diff changeset
  2918
     org  "{ Class: Point }"
claus
parents: 138
diff changeset
  2919
     sumX "{ Class: SmallInteger }"
claus
parents: 138
diff changeset
  2920
     sumY "{ Class: SmallInteger }" |
claus
parents: 138
diff changeset
  2921
claus
parents: 138
diff changeset
  2922
    currentView := self.
claus
parents: 138
diff changeset
  2923
    sumX := 0.
claus
parents: 138
diff changeset
  2924
    sumY := 0.
claus
parents: 138
diff changeset
  2925
    [currentView notNil] whileTrue:[
claus
parents: 138
diff changeset
  2926
	(currentView == aView) ifTrue:[
claus
parents: 138
diff changeset
  2927
	    ^ (sumX @ sumY)
claus
parents: 138
diff changeset
  2928
	].
claus
parents: 138
diff changeset
  2929
	org := currentView origin.
claus
parents: 138
diff changeset
  2930
	sumX := sumX + org x.
claus
parents: 138
diff changeset
  2931
	sumY := sumY + org y.
claus
parents: 138
diff changeset
  2932
	currentView := currentView superView
claus
parents: 138
diff changeset
  2933
    ].
claus
parents: 138
diff changeset
  2934
    (aView isNil or:[aView == RootView]) ifTrue:[
claus
parents: 138
diff changeset
  2935
	"return relative to screen ..."
claus
parents: 138
diff changeset
  2936
	^ (sumX @ sumY)
claus
parents: 138
diff changeset
  2937
    ].
claus
parents: 138
diff changeset
  2938
    ^ nil
153
claus
parents: 151
diff changeset
  2939
claus
parents: 151
diff changeset
  2940
    "
claus
parents: 151
diff changeset
  2941
     |top sub1 sub2|
claus
parents: 151
diff changeset
  2942
claus
parents: 151
diff changeset
  2943
     top := StandardSystemView new.
claus
parents: 151
diff changeset
  2944
     top extent:200@200.   
claus
parents: 151
diff changeset
  2945
     sub1 := View origin:0.2 @ 0.2 corner:0.8 @ 0.8 in:top.
claus
parents: 151
diff changeset
  2946
     sub2 := Button origin:0.3 @ 0.3 corner:0.7 @ 0.7 in:sub1.
claus
parents: 151
diff changeset
  2947
     top openAndWait.
claus
parents: 151
diff changeset
  2948
     Transcript show:'button in top:'; showCr:(sub2 originRelativeTo:top).
claus
parents: 151
diff changeset
  2949
     Transcript show:'button on screen:'; showCr:(sub2 originRelativeTo:nil).
claus
parents: 151
diff changeset
  2950
    "
140
claus
parents: 138
diff changeset
  2951
!
claus
parents: 138
diff changeset
  2952
claus
parents: 138
diff changeset
  2953
relativeCorner:aPoint
claus
parents: 138
diff changeset
  2954
    "set the relative corner"
claus
parents: 138
diff changeset
  2955
claus
parents: 138
diff changeset
  2956
    relativeCorner := aPoint
claus
parents: 138
diff changeset
  2957
!
claus
parents: 138
diff changeset
  2958
claus
parents: 138
diff changeset
  2959
relativeOrigin:aPoint
claus
parents: 138
diff changeset
  2960
    "set the relative origin"
claus
parents: 138
diff changeset
  2961
claus
parents: 138
diff changeset
  2962
    relativeOrigin := aPoint
claus
parents: 138
diff changeset
  2963
!
claus
parents: 138
diff changeset
  2964
claus
parents: 138
diff changeset
  2965
leftInset
claus
parents: 138
diff changeset
  2966
    "return the inset of the left edge; positive is to the right,
claus
parents: 138
diff changeset
  2967
     negative to the left"
claus
parents: 138
diff changeset
  2968
claus
parents: 138
diff changeset
  2969
    insets isNil ifTrue:[^ 0].
claus
parents: 138
diff changeset
  2970
    ^ insets at:1 
claus
parents: 138
diff changeset
  2971
!
claus
parents: 138
diff changeset
  2972
claus
parents: 138
diff changeset
  2973
sizeFixed:aBoolean
claus
parents: 138
diff changeset
  2974
    "set/clear the fix-size attribute, if supported by concrete subclasses.
claus
parents: 138
diff changeset
  2975
     Views which want to resize themselfes as appropriate to their contents
claus
parents: 138
diff changeset
  2976
     should cease to do so and take their current size if sizeFixed is set to
claus
parents: 138
diff changeset
  2977
     true. Currently, only supported by Labels.
144
claus
parents: 142
diff changeset
  2978
     This does NOT prevent the window manager from resizing the view, 
claus
parents: 142
diff changeset
  2979
     instead it tell the view to NOT resize ITSELF.
claus
parents: 142
diff changeset
  2980
     Added here to provide a common protocol for all views."
140
claus
parents: 138
diff changeset
  2981
claus
parents: 138
diff changeset
  2982
    ^ self
claus
parents: 138
diff changeset
  2983
!
claus
parents: 138
diff changeset
  2984
claus
parents: 138
diff changeset
  2985
top:aNumber
claus
parents: 138
diff changeset
  2986
    "set the y position"
claus
parents: 138
diff changeset
  2987
claus
parents: 138
diff changeset
  2988
    self origin:(left @ aNumber)
claus
parents: 138
diff changeset
  2989
!
claus
parents: 138
diff changeset
  2990
claus
parents: 138
diff changeset
  2991
rightInset
claus
parents: 138
diff changeset
  2992
    "return the inset of the right edge; positive is to the left,
claus
parents: 138
diff changeset
  2993
     negative to the right"
claus
parents: 138
diff changeset
  2994
claus
parents: 138
diff changeset
  2995
    insets isNil ifTrue:[^ 0].
claus
parents: 138
diff changeset
  2996
    ^ insets at:3 
claus
parents: 138
diff changeset
  2997
!
claus
parents: 138
diff changeset
  2998
claus
parents: 138
diff changeset
  2999
topInset
claus
parents: 138
diff changeset
  3000
    "return the inset of the top edge; positive is to the bottom,
claus
parents: 138
diff changeset
  3001
     negative to the top"
claus
parents: 138
diff changeset
  3002
claus
parents: 138
diff changeset
  3003
    insets isNil ifTrue:[^ 0].
claus
parents: 138
diff changeset
  3004
    ^ insets at:2 
claus
parents: 138
diff changeset
  3005
!
claus
parents: 138
diff changeset
  3006
claus
parents: 138
diff changeset
  3007
left
173
claus
parents: 162
diff changeset
  3008
    "return the x position of the left border (in pixels)"
140
claus
parents: 138
diff changeset
  3009
claus
parents: 138
diff changeset
  3010
    ^ left
claus
parents: 138
diff changeset
  3011
!
claus
parents: 138
diff changeset
  3012
claus
parents: 138
diff changeset
  3013
corner
173
claus
parents: 162
diff changeset
  3014
    "return the lower right corner-point (in pixels)"
claus
parents: 162
diff changeset
  3015
180
claus
parents: 176
diff changeset
  3016
"/    ^ (left + width "- 1") @ (top + height "- 1")
claus
parents: 176
diff changeset
  3017
    ^ (left + width - 1) @ (top + height - 1)
claus
parents: 176
diff changeset
  3018
claus
parents: 176
diff changeset
  3019
    "Modified: 31.8.1995 / 16:51:40 / claus"
140
claus
parents: 138
diff changeset
  3020
!
claus
parents: 138
diff changeset
  3021
claus
parents: 138
diff changeset
  3022
bottomInset
claus
parents: 138
diff changeset
  3023
    "return the inset of the bottom edge; positive is to the top,
claus
parents: 138
diff changeset
  3024
     negative to the bottom"
claus
parents: 138
diff changeset
  3025
claus
parents: 138
diff changeset
  3026
    insets isNil ifTrue:[^ 0].
claus
parents: 138
diff changeset
  3027
    ^ insets at:4
claus
parents: 138
diff changeset
  3028
!
claus
parents: 138
diff changeset
  3029
claus
parents: 138
diff changeset
  3030
right:aNumber
claus
parents: 138
diff changeset
  3031
    "set the corners x position"
claus
parents: 138
diff changeset
  3032
claus
parents: 138
diff changeset
  3033
    self corner:(aNumber @ self corner y)
claus
parents: 138
diff changeset
  3034
!
claus
parents: 138
diff changeset
  3035
claus
parents: 138
diff changeset
  3036
bottom:aNumber
claus
parents: 138
diff changeset
  3037
    "set the corners y position"
claus
parents: 138
diff changeset
  3038
claus
parents: 138
diff changeset
  3039
    self corner:(self corner x @ aNumber)
claus
parents: 138
diff changeset
  3040
!
claus
parents: 138
diff changeset
  3041
claus
parents: 138
diff changeset
  3042
right
173
claus
parents: 162
diff changeset
  3043
    "return the x position of the right edge  (in pixels)"
claus
parents: 162
diff changeset
  3044
180
claus
parents: 176
diff changeset
  3045
    ^ left + width - 1
claus
parents: 176
diff changeset
  3046
claus
parents: 176
diff changeset
  3047
    "Modified: 31.8.1995 / 19:31:10 / claus"
140
claus
parents: 138
diff changeset
  3048
!
claus
parents: 138
diff changeset
  3049
claus
parents: 138
diff changeset
  3050
bottom
173
claus
parents: 162
diff changeset
  3051
    "return the y position of the actual bottom edge (in pixels)"
claus
parents: 162
diff changeset
  3052
180
claus
parents: 176
diff changeset
  3053
    ^ top + height - 1
140
claus
parents: 138
diff changeset
  3054
!
claus
parents: 138
diff changeset
  3055
claus
parents: 138
diff changeset
  3056
relativeExtent
claus
parents: 138
diff changeset
  3057
    "return the relative extent or nil"
claus
parents: 138
diff changeset
  3058
claus
parents: 138
diff changeset
  3059
    ^ relativeExtent
claus
parents: 138
diff changeset
  3060
!
claus
parents: 138
diff changeset
  3061
claus
parents: 138
diff changeset
  3062
left:newLeft top:newTop width:newWidth height:newHeight
claus
parents: 138
diff changeset
  3063
    "another way of specifying origin and extent"
claus
parents: 138
diff changeset
  3064
claus
parents: 138
diff changeset
  3065
    self origin:(newLeft @ newTop) extent:(newWidth @ newHeight)
claus
parents: 138
diff changeset
  3066
!
claus
parents: 138
diff changeset
  3067
claus
parents: 138
diff changeset
  3068
relativeExtent:aPoint
claus
parents: 138
diff changeset
  3069
    "set the relative extent"
claus
parents: 138
diff changeset
  3070
claus
parents: 138
diff changeset
  3071
    relativeExtent := aPoint
claus
parents: 138
diff changeset
  3072
!
claus
parents: 138
diff changeset
  3073
claus
parents: 138
diff changeset
  3074
center:newCenter
claus
parents: 138
diff changeset
  3075
    "move the receiver so that newCenter, aPoint becomes the center point"
claus
parents: 138
diff changeset
  3076
claus
parents: 138
diff changeset
  3077
    self origin:(newCenter - ((width // 2) @ (height // 2)))
claus
parents: 138
diff changeset
  3078
!
claus
parents: 138
diff changeset
  3079
claus
parents: 138
diff changeset
  3080
center
151
claus
parents: 145
diff changeset
  3081
    "return the point at the center of the receiver (in pixels)"
140
claus
parents: 138
diff changeset
  3082
claus
parents: 138
diff changeset
  3083
    ^ (left + (width // 2)) @ (top + (height // 2))
claus
parents: 138
diff changeset
  3084
!
claus
parents: 138
diff changeset
  3085
claus
parents: 138
diff changeset
  3086
computeCorner
151
claus
parents: 145
diff changeset
  3087
    "compute my corner; if I have a layoutObject,
claus
parents: 145
diff changeset
  3088
     relative origins or blocks to evaluate, compute it now ..
claus
parents: 145
diff changeset
  3089
     Blocks may return relative values or nil; nil means: take current value.
claus
parents: 145
diff changeset
  3090
     Returns the corner point in device coordinates (pixels)."
140
claus
parents: 138
diff changeset
  3091
claus
parents: 138
diff changeset
  3092
    |org newCorner newExt x y|
claus
parents: 138
diff changeset
  3093
151
claus
parents: 145
diff changeset
  3094
    "
claus
parents: 145
diff changeset
  3095
     slowly migrating to use layoutObjects ...
claus
parents: 145
diff changeset
  3096
    "
claus
parents: 145
diff changeset
  3097
    layout notNil ifTrue:[
claus
parents: 145
diff changeset
  3098
	^ (layout rectangleRelativeTo:(superView viewRectangle)
claus
parents: 145
diff changeset
  3099
			    preferred:(self preferredBounds)) corner rounded
claus
parents: 145
diff changeset
  3100
    ].
claus
parents: 145
diff changeset
  3101
140
claus
parents: 138
diff changeset
  3102
    (cornerRule notNil) ifTrue:[
claus
parents: 138
diff changeset
  3103
	newCorner := cornerRule value.
claus
parents: 138
diff changeset
  3104
	"
claus
parents: 138
diff changeset
  3105
	 allow return of relative values ...
claus
parents: 138
diff changeset
  3106
	"
claus
parents: 138
diff changeset
  3107
	x := newCorner x.
claus
parents: 138
diff changeset
  3108
	y := newCorner y.
claus
parents: 138
diff changeset
  3109
	x isNil ifTrue:[x := self corner x].
claus
parents: 138
diff changeset
  3110
	y isNil ifTrue:[y := self corner y].
claus
parents: 138
diff changeset
  3111
	((x isInteger not) or:[y isInteger not]) ifTrue:[
claus
parents: 138
diff changeset
  3112
	    newCorner := self cornerFromRelativeCorner:x@y 
claus
parents: 138
diff changeset
  3113
	]
claus
parents: 138
diff changeset
  3114
    ] ifFalse:[
claus
parents: 138
diff changeset
  3115
	(relativeCorner notNil) ifTrue:[
claus
parents: 138
diff changeset
  3116
	    newCorner := self cornerFromRelativeCorner:relativeCorner
claus
parents: 138
diff changeset
  3117
	] ifFalse:[
claus
parents: 138
diff changeset
  3118
	    org := self computeOrigin.
claus
parents: 138
diff changeset
  3119
	    (extentRule notNil) ifTrue:[
claus
parents: 138
diff changeset
  3120
		newExt := extentRule value
claus
parents: 138
diff changeset
  3121
	    ] ifFalse:[
claus
parents: 138
diff changeset
  3122
		(relativeExtent notNil) ifTrue:[
claus
parents: 138
diff changeset
  3123
		    newExt := self extentFromRelativeExtent:relativeExtent 
claus
parents: 138
diff changeset
  3124
		]
claus
parents: 138
diff changeset
  3125
	    ].
claus
parents: 138
diff changeset
  3126
	    newCorner := org + newExt
claus
parents: 138
diff changeset
  3127
	]
claus
parents: 138
diff changeset
  3128
    ].
claus
parents: 138
diff changeset
  3129
    ^ newCorner
claus
parents: 138
diff changeset
  3130
! !
claus
parents: 138
diff changeset
  3131
claus
parents: 138
diff changeset
  3132
!SimpleView methodsFor:'realization'!
claus
parents: 138
diff changeset
  3133
151
claus
parents: 145
diff changeset
  3134
map
claus
parents: 145
diff changeset
  3135
    "make the view visible on the screen"
claus
parents: 145
diff changeset
  3136
claus
parents: 145
diff changeset
  3137
    realized ifFalse:[
claus
parents: 145
diff changeset
  3138
	"
claus
parents: 145
diff changeset
  3139
	 now, make the view visible
claus
parents: 145
diff changeset
  3140
	"
claus
parents: 145
diff changeset
  3141
	device mapWindow:drawableId.
claus
parents: 145
diff changeset
  3142
	realized := true.
claus
parents: 145
diff changeset
  3143
    ]
claus
parents: 145
diff changeset
  3144
!
claus
parents: 145
diff changeset
  3145
claus
parents: 145
diff changeset
  3146
unmap
claus
parents: 145
diff changeset
  3147
    "hide me - the view stays created, and can be mapped again later."
140
claus
parents: 138
diff changeset
  3148
claus
parents: 138
diff changeset
  3149
    realized ifTrue:[
135
claus
parents:
diff changeset
  3150
	drawableId notNil ifTrue:[
140
claus
parents: 138
diff changeset
  3151
	    device unmapWindow:drawableId
claus
parents: 138
diff changeset
  3152
	].
claus
parents: 138
diff changeset
  3153
	realized := shown := false.
151
claus
parents: 145
diff changeset
  3154
    ].
claus
parents: 145
diff changeset
  3155
claus
parents: 145
diff changeset
  3156
    "
claus
parents: 145
diff changeset
  3157
     |top sub|
claus
parents: 145
diff changeset
  3158
claus
parents: 145
diff changeset
  3159
     top := StandardSystemView new.
claus
parents: 145
diff changeset
  3160
     top extent:200@200.
claus
parents: 145
diff changeset
  3161
claus
parents: 145
diff changeset
  3162
     sub := View
claus
parents: 145
diff changeset
  3163
		origin:0.2@0.2
claus
parents: 145
diff changeset
  3164
		corner:0.8@0.8
claus
parents: 145
diff changeset
  3165
		in:top.
claus
parents: 145
diff changeset
  3166
claus
parents: 145
diff changeset
  3167
     sub viewBackground:Color red.
claus
parents: 145
diff changeset
  3168
     sub hiddenOnRealize:true.
claus
parents: 145
diff changeset
  3169
claus
parents: 145
diff changeset
  3170
     top open.
claus
parents: 145
diff changeset
  3171
     (Delay forSeconds:5) wait.
claus
parents: 145
diff changeset
  3172
     sub map.
claus
parents: 145
diff changeset
  3173
     (Delay forSeconds:3) wait.
claus
parents: 145
diff changeset
  3174
     sub unmap.
claus
parents: 145
diff changeset
  3175
     sub viewBackground:(Color green).
claus
parents: 145
diff changeset
  3176
     (Delay forSeconds:3) wait.
claus
parents: 145
diff changeset
  3177
     sub map.
claus
parents: 145
diff changeset
  3178
    "
claus
parents: 145
diff changeset
  3179
!
claus
parents: 145
diff changeset
  3180
claus
parents: 145
diff changeset
  3181
unrealize
claus
parents: 145
diff changeset
  3182
    "alias for unmap, for historic reasons"
claus
parents: 145
diff changeset
  3183
claus
parents: 145
diff changeset
  3184
    self unmap.
140
claus
parents: 138
diff changeset
  3185
!
claus
parents: 138
diff changeset
  3186
claus
parents: 138
diff changeset
  3187
physicalCreate
151
claus
parents: 145
diff changeset
  3188
    "common code for create & recreate: 
claus
parents: 145
diff changeset
  3189
     physically create (but do not map) the view on the device."
140
claus
parents: 138
diff changeset
  3190
claus
parents: 138
diff changeset
  3191
    "associate colors to device"
claus
parents: 138
diff changeset
  3192
claus
parents: 138
diff changeset
  3193
    drawableId := device 
claus
parents: 138
diff changeset
  3194
		      createWindowFor:self 
claus
parents: 138
diff changeset
  3195
			  origin:(left @ top)
claus
parents: 138
diff changeset
  3196
			  extent:(width @ height)
claus
parents: 138
diff changeset
  3197
			  minExtent:nil
claus
parents: 138
diff changeset
  3198
			  maxExtent:nil
claus
parents: 138
diff changeset
  3199
			  borderWidth:borderWidth
claus
parents: 138
diff changeset
  3200
			  subViewOf:superView
157
claus
parents: 154
diff changeset
  3201
			  onTop:(self isPopUpView)
140
claus
parents: 138
diff changeset
  3202
			  inputOnly:(self inputOnly)
claus
parents: 138
diff changeset
  3203
			  label:nil
claus
parents: 138
diff changeset
  3204
			  cursor:cursor
claus
parents: 138
diff changeset
  3205
			  icon:nil
claus
parents: 138
diff changeset
  3206
			  iconView:nil.
claus
parents: 138
diff changeset
  3207
162
claus
parents: 160
diff changeset
  3208
    Lobby registerChange:self.
140
claus
parents: 138
diff changeset
  3209
    extentChanged := false.
claus
parents: 138
diff changeset
  3210
    originChanged := false.
claus
parents: 138
diff changeset
  3211
claus
parents: 138
diff changeset
  3212
    (borderColor notNil and:[borderColor ~~ Black]) ifTrue:[
claus
parents: 138
diff changeset
  3213
"/        borderColor := borderColor on:device.
claus
parents: 138
diff changeset
  3214
	self setBorderColor
claus
parents: 138
diff changeset
  3215
    ].
claus
parents: 138
diff changeset
  3216
    (viewGravity notNil "and:[viewGravity ~~ #NorthWest]") ifTrue:[
claus
parents: 138
diff changeset
  3217
	device setWindowGravity:viewGravity in:drawableId
claus
parents: 138
diff changeset
  3218
    ].
claus
parents: 138
diff changeset
  3219
    (bitGravity notNil "and:[bitGravity ~~ #NorthWest]") ifTrue:[
claus
parents: 138
diff changeset
  3220
	device setBitGravity:bitGravity in:drawableId
claus
parents: 138
diff changeset
  3221
    ].
claus
parents: 138
diff changeset
  3222
    borderShape notNil ifTrue:[
claus
parents: 138
diff changeset
  3223
	device setWindowBorderShape:(borderShape id) in:drawableId
claus
parents: 138
diff changeset
  3224
    ].
claus
parents: 138
diff changeset
  3225
    viewShape notNil ifTrue:[
claus
parents: 138
diff changeset
  3226
	device setWindowShape:(viewShape id) in:drawableId
claus
parents: 138
diff changeset
  3227
    ].
claus
parents: 138
diff changeset
  3228
    (backed notNil and:[backed ~~ false]) ifTrue:[
claus
parents: 138
diff changeset
  3229
	device setBackingStore:backed in:drawableId
claus
parents: 138
diff changeset
  3230
    ].
claus
parents: 138
diff changeset
  3231
    saveUnder ifTrue:[
claus
parents: 138
diff changeset
  3232
	device setSaveUnder:true in:drawableId
claus
parents: 138
diff changeset
  3233
    ].
claus
parents: 138
diff changeset
  3234
!
claus
parents: 138
diff changeset
  3235
claus
parents: 138
diff changeset
  3236
fixSize
claus
parents: 138
diff changeset
  3237
    "This is called right before the view is made visible.
claus
parents: 138
diff changeset
  3238
     Adjust the size of the view according to either relative/abs or
claus
parents: 138
diff changeset
  3239
     block extent; also set origin. Also, subclasses may redefine this
claus
parents: 138
diff changeset
  3240
     method to adjust the size based on some extent (for example, PopUpMenus
claus
parents: 138
diff changeset
  3241
     do so to take care of changed number of menu entries)."
claus
parents: 138
diff changeset
  3242
151
claus
parents: 145
diff changeset
  3243
    |org ext r|
claus
parents: 145
diff changeset
  3244
claus
parents: 145
diff changeset
  3245
    "please: no longer use window/viewport - they will vanish"
140
claus
parents: 138
diff changeset
  3246
    window notNil ifTrue:[
claus
parents: 138
diff changeset
  3247
	^ self superViewChangedSize
claus
parents: 138
diff changeset
  3248
    ].
claus
parents: 138
diff changeset
  3249
151
claus
parents: 145
diff changeset
  3250
    "
claus
parents: 145
diff changeset
  3251
     slowly migrating to use layoutObjects ...
claus
parents: 145
diff changeset
  3252
    "
claus
parents: 145
diff changeset
  3253
    layout notNil ifTrue:[
claus
parents: 145
diff changeset
  3254
	(originChanged or:[extentChanged or:[cornerChanged]]) ifTrue:[
claus
parents: 145
diff changeset
  3255
	    r := (layout rectangleRelativeTo:(superView viewRectangle)
claus
parents: 145
diff changeset
  3256
				   preferred:(self preferredBounds)).
claus
parents: 145
diff changeset
  3257
	    org := r origin rounded.
claus
parents: 145
diff changeset
  3258
	    ext := r extent rounded.
claus
parents: 145
diff changeset
  3259
	    self pixelOrigin:org extent:ext.
claus
parents: 145
diff changeset
  3260
	].
claus
parents: 145
diff changeset
  3261
	^ self.
claus
parents: 145
diff changeset
  3262
    ].
claus
parents: 145
diff changeset
  3263
140
claus
parents: 138
diff changeset
  3264
    "if the extent is not the one we created the window with ..."
claus
parents: 138
diff changeset
  3265
    extentChanged ifTrue:[
claus
parents: 138
diff changeset
  3266
	self sizeChanged:nil.
claus
parents: 138
diff changeset
  3267
	extentChanged := false
claus
parents: 138
diff changeset
  3268
    ].
claus
parents: 138
diff changeset
  3269
claus
parents: 138
diff changeset
  3270
    originChanged ifTrue:[
claus
parents: 138
diff changeset
  3271
"/        org := self computeOrigin.
claus
parents: 138
diff changeset
  3272
"/        self pixelOrigin:org.    
claus
parents: 138
diff changeset
  3273
	originRule notNil ifTrue:[
claus
parents: 138
diff changeset
  3274
	    self pixelOrigin:self computeOrigin
claus
parents: 138
diff changeset
  3275
	] ifFalse:[
claus
parents: 138
diff changeset
  3276
	    relativeOrigin notNil ifTrue:[
claus
parents: 138
diff changeset
  3277
		self originFromRelativeOrigin:relativeOrigin
claus
parents: 138
diff changeset
  3278
	    ] ifFalse:[
151
claus
parents: 145
diff changeset
  3279
		shown ifTrue:[
claus
parents: 145
diff changeset
  3280
		    device moveWindow:drawableId x:left y:top.
claus
parents: 145
diff changeset
  3281
		] ifFalse:[
claus
parents: 145
diff changeset
  3282
		    self pixelOrigin:left@top
claus
parents: 145
diff changeset
  3283
		].
140
claus
parents: 138
diff changeset
  3284
	    ].
claus
parents: 138
diff changeset
  3285
	].
claus
parents: 138
diff changeset
  3286
	originChanged := false
claus
parents: 138
diff changeset
  3287
    ]
claus
parents: 138
diff changeset
  3288
!
claus
parents: 138
diff changeset
  3289
claus
parents: 138
diff changeset
  3290
create
151
claus
parents: 145
diff changeset
  3291
    "create (i.e. tell my device about me) if not already created.
claus
parents: 145
diff changeset
  3292
     This does not make the view visible (needs a #map for that)"
140
claus
parents: 138
diff changeset
  3293
claus
parents: 138
diff changeset
  3294
    drawableId isNil ifTrue:[
claus
parents: 138
diff changeset
  3295
	"
claus
parents: 138
diff changeset
  3296
	 make certain that superview is created also
claus
parents: 138
diff changeset
  3297
	"
claus
parents: 138
diff changeset
  3298
	superView notNil ifTrue:[
claus
parents: 138
diff changeset
  3299
"/            superView id isNil ifTrue:[
claus
parents: 138
diff changeset
  3300
		superView create.
claus
parents: 138
diff changeset
  3301
"/            ].
claus
parents: 138
diff changeset
  3302
claus
parents: 138
diff changeset
  3303
"/            "and put my controller into the superviews controller list"
claus
parents: 138
diff changeset
  3304
"/            controller notNil ifTrue:[
claus
parents: 138
diff changeset
  3305
"/                superView controller notNil ifTrue:[
claus
parents: 138
diff changeset
  3306
"/                    controller manager:(superView controller manager)
claus
parents: 138
diff changeset
  3307
"/                ]
claus
parents: 138
diff changeset
  3308
"/            ]
claus
parents: 138
diff changeset
  3309
	].
claus
parents: 138
diff changeset
  3310
claus
parents: 138
diff changeset
  3311
	cursor := cursor on:device.
claus
parents: 138
diff changeset
  3312
claus
parents: 138
diff changeset
  3313
	self physicalCreate.
claus
parents: 138
diff changeset
  3314
claus
parents: 138
diff changeset
  3315
	viewBackground notNil ifTrue:[
claus
parents: 138
diff changeset
  3316
	   self setViewBackground
claus
parents: 138
diff changeset
  3317
	].
claus
parents: 138
diff changeset
  3318
claus
parents: 138
diff changeset
  3319
	self initializeMiddleButtonMenu.
claus
parents: 138
diff changeset
  3320
	self initEvents.
claus
parents: 138
diff changeset
  3321
claus
parents: 138
diff changeset
  3322
	"
claus
parents: 138
diff changeset
  3323
	 this is the first create,
claus
parents: 138
diff changeset
  3324
	 force sizechange messages to be sent to the view
claus
parents: 138
diff changeset
  3325
	"
claus
parents: 138
diff changeset
  3326
	extentChanged := true.
claus
parents: 138
diff changeset
  3327
	originChanged := true
claus
parents: 138
diff changeset
  3328
    ]
claus
parents: 138
diff changeset
  3329
!
claus
parents: 138
diff changeset
  3330
claus
parents: 138
diff changeset
  3331
realizeLeavingGroup:leaveGroupAsIs 
151
claus
parents: 145
diff changeset
  3332
    "common helper for realize and realizeInGroup.
claus
parents: 145
diff changeset
  3333
     Create the view, if the argument is not true, assign my windowGroup,
claus
parents: 145
diff changeset
  3334
     if hiddenOnRealize is not true, map it."
140
claus
parents: 138
diff changeset
  3335
claus
parents: 138
diff changeset
  3336
    |superGroup groupChange|
claus
parents: 138
diff changeset
  3337
claus
parents: 138
diff changeset
  3338
    drawableId isNil ifTrue:[
claus
parents: 138
diff changeset
  3339
	self create.
claus
parents: 138
diff changeset
  3340
    ].
claus
parents: 138
diff changeset
  3341
claus
parents: 138
diff changeset
  3342
    leaveGroupAsIs ifFalse:[
claus
parents: 138
diff changeset
  3343
	"
claus
parents: 138
diff changeset
  3344
	 put myself into superviews windowgroup if there is a superview
claus
parents: 138
diff changeset
  3345
	"
claus
parents: 138
diff changeset
  3346
	groupChange := false.
claus
parents: 138
diff changeset
  3347
	superView notNil ifTrue:[
claus
parents: 138
diff changeset
  3348
	    superGroup := superView windowGroup.
claus
parents: 138
diff changeset
  3349
	    (windowGroup notNil and:[superGroup ~~ windowGroup]) ifTrue:[
claus
parents: 138
diff changeset
  3350
		"
claus
parents: 138
diff changeset
  3351
		 mhmh - seems that the windowgroup has changed ....
claus
parents: 138
diff changeset
  3352
		"
145
claus
parents: 144
diff changeset
  3353
"/                'oops - wgroup change on realize' printNL.
140
claus
parents: 138
diff changeset
  3354
		windowGroup removeView:self.
claus
parents: 138
diff changeset
  3355
		windowGroup := nil
claus
parents: 138
diff changeset
  3356
	    ].
claus
parents: 138
diff changeset
  3357
	    superGroup ~~ windowGroup ifTrue:[
claus
parents: 138
diff changeset
  3358
		groupChange := true.
claus
parents: 138
diff changeset
  3359
		windowGroup := superGroup.
claus
parents: 138
diff changeset
  3360
		windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  3361
		    windowGroup addView:self.
claus
parents: 138
diff changeset
  3362
		]
claus
parents: 138
diff changeset
  3363
	    ]
claus
parents: 138
diff changeset
  3364
	].
claus
parents: 138
diff changeset
  3365
    ].
claus
parents: 138
diff changeset
  3366
151
claus
parents: 145
diff changeset
  3367
    hiddenOnRealize ifFalse:[
175
claus
parents: 173
diff changeset
  3368
	(originChanged or:[extentChanged]) ifTrue:[
claus
parents: 173
diff changeset
  3369
	    self fixSize.
claus
parents: 173
diff changeset
  3370
	    self sizeChanged:nil.   "/ new 29-aug-1995
claus
parents: 173
diff changeset
  3371
	].
140
claus
parents: 138
diff changeset
  3372
claus
parents: 138
diff changeset
  3373
	(realized not or:[groupChange]) ifTrue:[
claus
parents: 138
diff changeset
  3374
	    subViews notNil ifTrue:[
180
claus
parents: 176
diff changeset
  3375
		self realizeAllSubViews.
140
claus
parents: 138
diff changeset
  3376
	    ].
claus
parents: 138
diff changeset
  3377
	].
claus
parents: 138
diff changeset
  3378
	self setInnerClip.
claus
parents: 138
diff changeset
  3379
claus
parents: 138
diff changeset
  3380
	realized ifFalse:[
claus
parents: 138
diff changeset
  3381
	    "
claus
parents: 138
diff changeset
  3382
	     now, make the view visible
claus
parents: 138
diff changeset
  3383
	    "
151
claus
parents: 145
diff changeset
  3384
	    self map
140
claus
parents: 138
diff changeset
  3385
	]
claus
parents: 138
diff changeset
  3386
    ].
claus
parents: 138
diff changeset
  3387
claus
parents: 138
diff changeset
  3388
    controller notNil ifTrue:[
claus
parents: 138
diff changeset
  3389
	controller startUp
claus
parents: 138
diff changeset
  3390
    ]
claus
parents: 138
diff changeset
  3391
!
claus
parents: 138
diff changeset
  3392
claus
parents: 138
diff changeset
  3393
realize
claus
parents: 138
diff changeset
  3394
    "realize - make visible;
claus
parents: 138
diff changeset
  3395
     realizing is done very late (after layout is fixed) to avoid
claus
parents: 138
diff changeset
  3396
     visible rearranging of windows on the screen"
claus
parents: 138
diff changeset
  3397
claus
parents: 138
diff changeset
  3398
    self realizeLeavingGroup:false
claus
parents: 138
diff changeset
  3399
!
claus
parents: 138
diff changeset
  3400
claus
parents: 138
diff changeset
  3401
destroy
claus
parents: 138
diff changeset
  3402
    "unrealize & destroy - make me invisible, destroy subviews then
claus
parents: 138
diff changeset
  3403
     make me unknown to the device"
claus
parents: 138
diff changeset
  3404
claus
parents: 138
diff changeset
  3405
    |subs|
claus
parents: 138
diff changeset
  3406
claus
parents: 138
diff changeset
  3407
    realized ifTrue:[
claus
parents: 138
diff changeset
  3408
	self unrealize.            
claus
parents: 138
diff changeset
  3409
	"make it go away immediately
claus
parents: 138
diff changeset
  3410
	 - also, this hides the subview killing"
claus
parents: 138
diff changeset
  3411
"
claus
parents: 138
diff changeset
  3412
	device synchronizeOutput. 
claus
parents: 138
diff changeset
  3413
"
claus
parents: 138
diff changeset
  3414
    ].
claus
parents: 138
diff changeset
  3415
157
claus
parents: 154
diff changeset
  3416
"/    controller notNil ifTrue:[
160
claus
parents: 157
diff changeset
  3417
"/      controller release.
claus
parents: 157
diff changeset
  3418
"/      controller := nil.
157
claus
parents: 154
diff changeset
  3419
"/    ].
140
claus
parents: 138
diff changeset
  3420
claus
parents: 138
diff changeset
  3421
    subs := subViews.
claus
parents: 138
diff changeset
  3422
    subs notNil ifTrue:[
claus
parents: 138
diff changeset
  3423
	"stupid: destroy removes itself from the subview list
claus
parents: 138
diff changeset
  3424
	 - therefore we have to loop over a copy here"
claus
parents: 138
diff changeset
  3425
claus
parents: 138
diff changeset
  3426
	subViews := nil.
claus
parents: 138
diff changeset
  3427
	subs do:[:aView |
claus
parents: 138
diff changeset
  3428
	    aView notNil ifTrue:[aView destroy]             
claus
parents: 138
diff changeset
  3429
	]
claus
parents: 138
diff changeset
  3430
    ].
135
claus
parents:
diff changeset
  3431
    superView notNil ifTrue:[
140
claus
parents: 138
diff changeset
  3432
	superView removeSubView:self.
claus
parents: 138
diff changeset
  3433
	superView := nil
claus
parents: 138
diff changeset
  3434
    ].
claus
parents: 138
diff changeset
  3435
    super destroy.
claus
parents: 138
diff changeset
  3436
157
claus
parents: 154
diff changeset
  3437
    controller notNil ifTrue:[
claus
parents: 154
diff changeset
  3438
	controller release.
claus
parents: 154
diff changeset
  3439
	controller := nil.
claus
parents: 154
diff changeset
  3440
    ].
claus
parents: 154
diff changeset
  3441
140
claus
parents: 138
diff changeset
  3442
    windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  3443
	windowGroup removeView:self.
claus
parents: 138
diff changeset
  3444
	windowGroup := nil
135
claus
parents:
diff changeset
  3445
    ].
140
claus
parents: 138
diff changeset
  3446
!
claus
parents: 138
diff changeset
  3447
157
claus
parents: 154
diff changeset
  3448
rerealizeInGroup:aWindowGroup
claus
parents: 154
diff changeset
  3449
    "rerealize at old position in (a possibly different) windowGroup."
claus
parents: 154
diff changeset
  3450
claus
parents: 154
diff changeset
  3451
    drawableId isNil ifTrue:[
claus
parents: 154
diff changeset
  3452
	self create
claus
parents: 154
diff changeset
  3453
    ].
claus
parents: 154
diff changeset
  3454
    drawableId notNil ifTrue:[
claus
parents: 154
diff changeset
  3455
	aWindowGroup ~~ windowGroup ifTrue:[
claus
parents: 154
diff changeset
  3456
	    windowGroup notNil ifTrue:[
claus
parents: 154
diff changeset
  3457
		windowGroup removeView:self
claus
parents: 154
diff changeset
  3458
	    ].
claus
parents: 154
diff changeset
  3459
	    windowGroup := aWindowGroup.
claus
parents: 154
diff changeset
  3460
	    aWindowGroup addTopView:self.
claus
parents: 154
diff changeset
  3461
	].
claus
parents: 154
diff changeset
  3462
	self rerealize.
claus
parents: 154
diff changeset
  3463
    ]
claus
parents: 154
diff changeset
  3464
!
claus
parents: 154
diff changeset
  3465
140
claus
parents: 138
diff changeset
  3466
rerealize
claus
parents: 138
diff changeset
  3467
    "rerealize at old position"
claus
parents: 138
diff changeset
  3468
claus
parents: 138
diff changeset
  3469
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  3470
	realized := true.
claus
parents: 138
diff changeset
  3471
	device mapView:self id:drawableId iconified:false
claus
parents: 138
diff changeset
  3472
		   atX:left y:top width:width height:height
claus
parents: 138
diff changeset
  3473
    ]
claus
parents: 138
diff changeset
  3474
!
claus
parents: 138
diff changeset
  3475
claus
parents: 138
diff changeset
  3476
resize
claus
parents: 138
diff changeset
  3477
    "resize myself to make everything fit into me.
claus
parents: 138
diff changeset
  3478
     Nothing special done here, but redefined in some subclasses"
claus
parents: 138
diff changeset
  3479
151
claus
parents: 145
diff changeset
  3480
    self extent:(self preferredExtent)
140
claus
parents: 138
diff changeset
  3481
!
claus
parents: 138
diff changeset
  3482
claus
parents: 138
diff changeset
  3483
recreate
claus
parents: 138
diff changeset
  3484
    "recreate (i.e. tell X about me) after a snapin"
claus
parents: 138
diff changeset
  3485
claus
parents: 138
diff changeset
  3486
    drawableId isNil ifTrue:[
claus
parents: 138
diff changeset
  3487
	super recreate.
claus
parents: 138
diff changeset
  3488
	self physicalCreate.
claus
parents: 138
diff changeset
  3489
claus
parents: 138
diff changeset
  3490
	viewBackground notNil ifTrue:[
claus
parents: 138
diff changeset
  3491
	    self setViewBackground 
claus
parents: 138
diff changeset
  3492
	].
claus
parents: 138
diff changeset
  3493
claus
parents: 138
diff changeset
  3494
	"
claus
parents: 138
diff changeset
  3495
	 XXX has to be changed: eventmasks are device specific -
claus
parents: 138
diff changeset
  3496
	 XXX will not allow restart on another Workstation-type.
claus
parents: 138
diff changeset
  3497
	 XXX event masks must become symbolic
claus
parents: 138
diff changeset
  3498
	"
claus
parents: 138
diff changeset
  3499
	device setEventMask:eventMask in:drawableId
claus
parents: 138
diff changeset
  3500
    ]
claus
parents: 138
diff changeset
  3501
!
claus
parents: 138
diff changeset
  3502
claus
parents: 138
diff changeset
  3503
createWithAllSubViews
claus
parents: 138
diff changeset
  3504
    "create, then create all subviews"
claus
parents: 138
diff changeset
  3505
claus
parents: 138
diff changeset
  3506
    drawableId isNil ifTrue:[self create].
claus
parents: 138
diff changeset
  3507
    subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  3508
	subViews do:[:subView | subView createWithAllSubViews]
claus
parents: 138
diff changeset
  3509
    ]
claus
parents: 138
diff changeset
  3510
!
claus
parents: 138
diff changeset
  3511
claus
parents: 138
diff changeset
  3512
realizeInGroup
claus
parents: 138
diff changeset
  3513
    "special realize - leave windowgroup as is; 
claus
parents: 138
diff changeset
  3514
     This allows a view to be realized in any windowgroup; 
claus
parents: 138
diff changeset
  3515
     for special applications, like the kill button in the Filebrowser which has
claus
parents: 138
diff changeset
  3516
     another windowGroup as its superview and is handled as a separate process."
claus
parents: 138
diff changeset
  3517
claus
parents: 138
diff changeset
  3518
    self realizeLeavingGroup:true
claus
parents: 138
diff changeset
  3519
!
claus
parents: 138
diff changeset
  3520
claus
parents: 138
diff changeset
  3521
rerealizeWithAllSubViews
claus
parents: 138
diff changeset
  3522
    "rerealize myself with all subviews"
claus
parents: 138
diff changeset
  3523
claus
parents: 138
diff changeset
  3524
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  3525
	realized := true.
claus
parents: 138
diff changeset
  3526
	subViews notNil ifTrue:[
180
claus
parents: 176
diff changeset
  3527
	    self realizeAllSubViews.
140
claus
parents: 138
diff changeset
  3528
	].
claus
parents: 138
diff changeset
  3529
	device mapView:self id:drawableId iconified:false
claus
parents: 138
diff changeset
  3530
		   atX:left y:top width:width height:height
claus
parents: 138
diff changeset
  3531
    ]
180
claus
parents: 176
diff changeset
  3532
!
claus
parents: 176
diff changeset
  3533
claus
parents: 176
diff changeset
  3534
realizeAllSubViews
claus
parents: 176
diff changeset
  3535
    "realize all my subviews"
claus
parents: 176
diff changeset
  3536
claus
parents: 176
diff changeset
  3537
    subViews notNil ifTrue:[
claus
parents: 176
diff changeset
  3538
	subViews do:[:subView |
claus
parents: 176
diff changeset
  3539
	    subView realize
claus
parents: 176
diff changeset
  3540
	]
claus
parents: 176
diff changeset
  3541
    ].
claus
parents: 176
diff changeset
  3542
claus
parents: 176
diff changeset
  3543
    "Modified: 5.9.1995 / 23:30:47 / claus"
151
claus
parents: 145
diff changeset
  3544
! !
claus
parents: 145
diff changeset
  3545
claus
parents: 145
diff changeset
  3546
!SimpleView methodsFor:'startup'!
claus
parents: 145
diff changeset
  3547
claus
parents: 145
diff changeset
  3548
open
claus
parents: 145
diff changeset
  3549
    "open up the view - for normal views, this is a modeless open
claus
parents: 145
diff changeset
  3550
     (i.e. the new view comes up as independent process).
claus
parents: 145
diff changeset
  3551
     Although #open is only to be sent to topviews (i.e. it could have been
claus
parents: 145
diff changeset
  3552
     implemented in TopView), it is implemented here - therefore, every view
claus
parents: 145
diff changeset
  3553
     can be opened as a topView.
claus
parents: 145
diff changeset
  3554
     This is redefined in ModalBox, which comes up modal (i.e. 
claus
parents: 145
diff changeset
  3555
     control is under the current process, so that interaction with the
claus
parents: 145
diff changeset
  3556
     current group is blocked while the modalBox is active)."
claus
parents: 145
diff changeset
  3557
claus
parents: 145
diff changeset
  3558
    ^ self openModeless
claus
parents: 145
diff changeset
  3559
claus
parents: 145
diff changeset
  3560
    "
claus
parents: 145
diff changeset
  3561
     View new open
claus
parents: 145
diff changeset
  3562
claus
parents: 145
diff changeset
  3563
     (Button label:'hello') open
claus
parents: 145
diff changeset
  3564
claus
parents: 145
diff changeset
  3565
     |top|
claus
parents: 145
diff changeset
  3566
     top := StandardSystemView new.
claus
parents: 145
diff changeset
  3567
     top extent:200@200.
claus
parents: 145
diff changeset
  3568
     Button label:'hello' in:top.
claus
parents: 145
diff changeset
  3569
     top open
claus
parents: 145
diff changeset
  3570
claus
parents: 145
diff changeset
  3571
     YesNoBox new open
claus
parents: 145
diff changeset
  3572
    "
claus
parents: 145
diff changeset
  3573
!
claus
parents: 145
diff changeset
  3574
claus
parents: 145
diff changeset
  3575
openModeless
claus
parents: 145
diff changeset
  3576
    "create and schedule a new windowgroup for me and open the view.
claus
parents: 145
diff changeset
  3577
     The view will be handled by its own process, effectively running in
claus
parents: 145
diff changeset
  3578
     parallel (i.e. control is returned to the sender immediately)."
claus
parents: 145
diff changeset
  3579
claus
parents: 145
diff changeset
  3580
    ProcessorScheduler isPureEventDriven ifFalse:[
claus
parents: 145
diff changeset
  3581
	windowGroup isNil ifTrue:[
claus
parents: 145
diff changeset
  3582
	    windowGroup := WindowGroup new.
claus
parents: 145
diff changeset
  3583
	    windowGroup addTopView:self.
157
claus
parents: 154
diff changeset
  3584
	    windowGroup startup:false.
claus
parents: 154
diff changeset
  3585
	] ifFalse:[
claus
parents: 154
diff changeset
  3586
	    windowGroup startup:false.
claus
parents: 154
diff changeset
  3587
	    self realizeInGroup.
151
claus
parents: 145
diff changeset
  3588
	].
claus
parents: 145
diff changeset
  3589
    ] ifTrue:[
claus
parents: 145
diff changeset
  3590
	self realize
claus
parents: 145
diff changeset
  3591
    ]
claus
parents: 145
diff changeset
  3592
claus
parents: 145
diff changeset
  3593
    "
claus
parents: 145
diff changeset
  3594
     the same:
claus
parents: 145
diff changeset
  3595
	 (Button label:'hello') open
claus
parents: 145
diff changeset
  3596
claus
parents: 145
diff changeset
  3597
	 (Button label:'hello') openModeless
claus
parents: 145
diff changeset
  3598
claus
parents: 145
diff changeset
  3599
     different:
claus
parents: 145
diff changeset
  3600
	 YesNoBox new open
claus
parents: 145
diff changeset
  3601
claus
parents: 145
diff changeset
  3602
	 YesNoBox new openModeless
claus
parents: 145
diff changeset
  3603
    "
claus
parents: 145
diff changeset
  3604
!
claus
parents: 145
diff changeset
  3605
claus
parents: 145
diff changeset
  3606
openModal
claus
parents: 145
diff changeset
  3607
    "create a new windowgroup, but start processing in the current process
claus
parents: 145
diff changeset
  3608
     actually suspending event processing for the currently active group.
claus
parents: 145
diff changeset
  3609
     Stay in modalLoop while view is visible.
claus
parents: 145
diff changeset
  3610
     (i.e. control is returned to the sender when the receiver is closed)"
claus
parents: 145
diff changeset
  3611
claus
parents: 145
diff changeset
  3612
    self openModal:[true]
claus
parents: 145
diff changeset
  3613
claus
parents: 145
diff changeset
  3614
    "
claus
parents: 145
diff changeset
  3615
     the same:
claus
parents: 145
diff changeset
  3616
	 YesNoBox new open
claus
parents: 145
diff changeset
  3617
claus
parents: 145
diff changeset
  3618
	 YesNoBox new openModal
claus
parents: 145
diff changeset
  3619
claus
parents: 145
diff changeset
  3620
     different:
claus
parents: 145
diff changeset
  3621
	 (Button label:'hello') open
claus
parents: 145
diff changeset
  3622
claus
parents: 145
diff changeset
  3623
	 (Button label:'hello') openModal
claus
parents: 145
diff changeset
  3624
    "
claus
parents: 145
diff changeset
  3625
!
claus
parents: 145
diff changeset
  3626
claus
parents: 145
diff changeset
  3627
openModal:aBlock
claus
parents: 145
diff changeset
  3628
    "create a new windowgroup, but start processing in the current process -
claus
parents: 145
diff changeset
  3629
     actually suspending event processing for the currently active group.
claus
parents: 145
diff changeset
  3630
     Stay in this modal loop while aBlock evaluates to true AND the receiver is
claus
parents: 145
diff changeset
  3631
     visible.
claus
parents: 145
diff changeset
  3632
     (i.e. control is returned to the sender when the receiver is closed)
claus
parents: 145
diff changeset
  3633
     This makes any interaction with the current window impossible - 
claus
parents: 145
diff changeset
  3634
     however, other views (in other windowgroups) still work."
claus
parents: 145
diff changeset
  3635
claus
parents: 145
diff changeset
  3636
    |activeGroup tops|
claus
parents: 145
diff changeset
  3637
claus
parents: 145
diff changeset
  3638
    Processor activeProcessIsSystemProcess ifTrue:[
claus
parents: 145
diff changeset
  3639
	self realize
claus
parents: 145
diff changeset
  3640
    ] ifFalse:[
claus
parents: 145
diff changeset
  3641
	activeGroup := WindowGroup activeGroup.
claus
parents: 145
diff changeset
  3642
claus
parents: 145
diff changeset
  3643
	"
claus
parents: 145
diff changeset
  3644
	 create a new window group and put myself into it
claus
parents: 145
diff changeset
  3645
	"
claus
parents: 145
diff changeset
  3646
	windowGroup := WindowGroup new.
claus
parents: 145
diff changeset
  3647
	windowGroup addTopView:self.
claus
parents: 145
diff changeset
  3648
	"
claus
parents: 145
diff changeset
  3649
	 go dispatch events in this new group
claus
parents: 145
diff changeset
  3650
	 (thus current windowgroup is blocked from interaction)
claus
parents: 145
diff changeset
  3651
	"
claus
parents: 145
diff changeset
  3652
	Object abortSignal handle:[:ex |
claus
parents: 145
diff changeset
  3653
	    self hide.
claus
parents: 145
diff changeset
  3654
	    ex return.
claus
parents: 145
diff changeset
  3655
	] do:[
claus
parents: 145
diff changeset
  3656
	    [
claus
parents: 145
diff changeset
  3657
		windowGroup startupModal:[realized and:aBlock]
claus
parents: 145
diff changeset
  3658
	    ] valueOnUnwindDo:[
claus
parents: 145
diff changeset
  3659
		self hide.
claus
parents: 145
diff changeset
  3660
	    ]
claus
parents: 145
diff changeset
  3661
	].
claus
parents: 145
diff changeset
  3662
	"
claus
parents: 145
diff changeset
  3663
	 return input focus to previously active groups top.
claus
parents: 145
diff changeset
  3664
	 This helps with windowmanagers which need an explicit click
claus
parents: 145
diff changeset
  3665
	 on the view for the focus.
claus
parents: 145
diff changeset
  3666
	"
claus
parents: 145
diff changeset
  3667
	activeGroup notNil ifTrue:[
claus
parents: 145
diff changeset
  3668
	    tops := activeGroup topViews.
claus
parents: 145
diff changeset
  3669
	    (tops notNil and:[tops notEmpty]) ifTrue:[
claus
parents: 145
diff changeset
  3670
		tops first getKeyboardFocus
claus
parents: 145
diff changeset
  3671
	    ]
claus
parents: 145
diff changeset
  3672
	]
claus
parents: 145
diff changeset
  3673
    ]
140
claus
parents: 138
diff changeset
  3674
!
claus
parents: 138
diff changeset
  3675
claus
parents: 138
diff changeset
  3676
openAutonomous
claus
parents: 138
diff changeset
  3677
    "create and schedule a new windowgroup for me and open the view.
claus
parents: 138
diff changeset
  3678
     The view will be handled by its own process, effectively running in
claus
parents: 138
diff changeset
  3679
     parallel. This entry is for non-topviews, which want to be served
claus
parents: 138
diff changeset
  3680
     autonomous from the topview. (see the fileBrowsers kill-button
claus
parents: 138
diff changeset
  3681
     when executing unix commands as an example)"
claus
parents: 138
diff changeset
  3682
claus
parents: 138
diff changeset
  3683
    |wg|
claus
parents: 138
diff changeset
  3684
claus
parents: 138
diff changeset
  3685
    ProcessorScheduler isPureEventDriven ifFalse:[
claus
parents: 138
diff changeset
  3686
	wg := WindowGroup new.
claus
parents: 138
diff changeset
  3687
	self windowGroup:wg.
claus
parents: 138
diff changeset
  3688
	wg addView:self.
claus
parents: 138
diff changeset
  3689
	wg startup:false.
claus
parents: 138
diff changeset
  3690
	self realizeInGroup.
claus
parents: 138
diff changeset
  3691
    ] ifTrue:[
claus
parents: 138
diff changeset
  3692
	self realize
claus
parents: 138
diff changeset
  3693
    ]
151
claus
parents: 145
diff changeset
  3694
!
claus
parents: 145
diff changeset
  3695
157
claus
parents: 154
diff changeset
  3696
waitUntilVisible
claus
parents: 154
diff changeset
  3697
    "wait until the receiver visible.
claus
parents: 154
diff changeset
  3698
     In normal applications, you do not need to wait till a view is
claus
parents: 154
diff changeset
  3699
     open - it should do all of its drawing itself when it gets the
claus
parents: 154
diff changeset
  3700
     first expose event.
claus
parents: 154
diff changeset
  3701
     However, if you want to 'manually' draw into the view (for example,
claus
parents: 154
diff changeset
  3702
     in doIt expressions), or subsequent views depend on some state of
claus
parents: 154
diff changeset
  3703
     another view (which is only available once visible), 
claus
parents: 154
diff changeset
  3704
     use this to suspend the current process until the receiver is shown."
claus
parents: 154
diff changeset
  3705
claus
parents: 154
diff changeset
  3706
    Processor activeProcess withPriority:1 do:[
claus
parents: 154
diff changeset
  3707
	[self shown] whileFalse:[
claus
parents: 154
diff changeset
  3708
	    Processor yield
claus
parents: 154
diff changeset
  3709
	]
claus
parents: 154
diff changeset
  3710
    ].
claus
parents: 154
diff changeset
  3711
claus
parents: 154
diff changeset
  3712
    "does not work:
claus
parents: 154
diff changeset
  3713
claus
parents: 154
diff changeset
  3714
	|v|
claus
parents: 154
diff changeset
  3715
claus
parents: 154
diff changeset
  3716
	v := View new open.
claus
parents: 154
diff changeset
  3717
	v displayLineFrom:0@0 to:50@50
claus
parents: 154
diff changeset
  3718
claus
parents: 154
diff changeset
  3719
     does work:
claus
parents: 154
diff changeset
  3720
claus
parents: 154
diff changeset
  3721
	|v|
claus
parents: 154
diff changeset
  3722
claus
parents: 154
diff changeset
  3723
	v := View new open.
claus
parents: 154
diff changeset
  3724
	v waitUntilVisible.
claus
parents: 154
diff changeset
  3725
	v displayLineFrom:0@0 to:50@50
claus
parents: 154
diff changeset
  3726
    "
claus
parents: 154
diff changeset
  3727
!
claus
parents: 154
diff changeset
  3728
151
claus
parents: 145
diff changeset
  3729
openAndWait
claus
parents: 145
diff changeset
  3730
    "open up the view - wait until it is visible.
claus
parents: 145
diff changeset
  3731
     In normal applications, you do not need to wait till the view is
claus
parents: 145
diff changeset
  3732
     open - it should do all of its drawing itself when it gets the
claus
parents: 145
diff changeset
  3733
     first expose event.
claus
parents: 145
diff changeset
  3734
     However, if you want to 'manually' draw into the view (for example,
claus
parents: 145
diff changeset
  3735
     in doIt expressions) the view must be visible (realized) before doing so.
claus
parents: 145
diff changeset
  3736
     Use this open in those situations."
claus
parents: 145
diff changeset
  3737
claus
parents: 145
diff changeset
  3738
    self open.
157
claus
parents: 154
diff changeset
  3739
    self waitUntilVisible.
151
claus
parents: 145
diff changeset
  3740
claus
parents: 145
diff changeset
  3741
    "does not work:
claus
parents: 145
diff changeset
  3742
claus
parents: 145
diff changeset
  3743
	|v|
claus
parents: 145
diff changeset
  3744
claus
parents: 145
diff changeset
  3745
	v := View new open.
claus
parents: 145
diff changeset
  3746
	v displayLineFrom:0@0 to:50@50
claus
parents: 145
diff changeset
  3747
claus
parents: 145
diff changeset
  3748
     does work:
claus
parents: 145
diff changeset
  3749
claus
parents: 145
diff changeset
  3750
	|v|
claus
parents: 145
diff changeset
  3751
claus
parents: 145
diff changeset
  3752
	v := View new openAndWait.
claus
parents: 145
diff changeset
  3753
	v displayLineFrom:0@0 to:50@50
claus
parents: 145
diff changeset
  3754
    "
135
claus
parents:
diff changeset
  3755
! !
claus
parents:
diff changeset
  3756
151
claus
parents: 145
diff changeset
  3757
!SimpleView methodsFor:'edge drawing'!
135
claus
parents:
diff changeset
  3758
140
claus
parents: 138
diff changeset
  3759
drawBottomEdge
claus
parents: 138
diff changeset
  3760
    "draw bottom 3D edge into window frame"
claus
parents: 138
diff changeset
  3761
claus
parents: 138
diff changeset
  3762
    self drawBottomEdgeLevel:level
claus
parents: 138
diff changeset
  3763
		      shadow:shadowColor 
claus
parents: 138
diff changeset
  3764
		      light:lightColor
claus
parents: 138
diff changeset
  3765
		      halfShadow:nil 
claus
parents: 138
diff changeset
  3766
		      halfLight:nil
claus
parents: 138
diff changeset
  3767
		      style:nil.
claus
parents: 138
diff changeset
  3768
!
claus
parents: 138
diff changeset
  3769
claus
parents: 138
diff changeset
  3770
drawLeftEdge
claus
parents: 138
diff changeset
  3771
    "draw left 3D edge into window frame"
claus
parents: 138
diff changeset
  3772
claus
parents: 138
diff changeset
  3773
    self drawLeftEdgeLevel:level
claus
parents: 138
diff changeset
  3774
		    shadow:shadowColor 
claus
parents: 138
diff changeset
  3775
		     light:lightColor
claus
parents: 138
diff changeset
  3776
		     halfShadow:nil 
claus
parents: 138
diff changeset
  3777
		     halfLight:nil
claus
parents: 138
diff changeset
  3778
		     style:nil.
claus
parents: 138
diff changeset
  3779
!
claus
parents: 138
diff changeset
  3780
claus
parents: 138
diff changeset
  3781
drawRightEdge
claus
parents: 138
diff changeset
  3782
    "draw right 3D edge into window frame"
claus
parents: 138
diff changeset
  3783
claus
parents: 138
diff changeset
  3784
    self drawRightEdgeLevel:level
claus
parents: 138
diff changeset
  3785
		     shadow:shadowColor 
claus
parents: 138
diff changeset
  3786
		      light:lightColor
claus
parents: 138
diff changeset
  3787
		      halfShadow:nil 
claus
parents: 138
diff changeset
  3788
		      halfLight:nil
claus
parents: 138
diff changeset
  3789
		      style:nil.
claus
parents: 138
diff changeset
  3790
!
claus
parents: 138
diff changeset
  3791
claus
parents: 138
diff changeset
  3792
drawTopEdge
claus
parents: 138
diff changeset
  3793
    "draw top 3D edge into window frame"
claus
parents: 138
diff changeset
  3794
claus
parents: 138
diff changeset
  3795
    self drawTopEdgeLevel:level
claus
parents: 138
diff changeset
  3796
		   shadow:shadowColor 
claus
parents: 138
diff changeset
  3797
		    light:lightColor
claus
parents: 138
diff changeset
  3798
		    halfShadow:nil 
claus
parents: 138
diff changeset
  3799
		    halfLight:nil
claus
parents: 138
diff changeset
  3800
		    style:nil.
claus
parents: 138
diff changeset
  3801
!
claus
parents: 138
diff changeset
  3802
claus
parents: 138
diff changeset
  3803
drawEdges
claus
parents: 138
diff changeset
  3804
    "draw all of my 3D edges"
claus
parents: 138
diff changeset
  3805
claus
parents: 138
diff changeset
  3806
    self drawEdgesForX:0 y:0 width:width height:height level:level
claus
parents: 138
diff changeset
  3807
		shadow:shadowColor 
claus
parents: 138
diff changeset
  3808
		light:lightColor
claus
parents: 138
diff changeset
  3809
		halfShadow:nil 
claus
parents: 138
diff changeset
  3810
		halfLight:nil 
claus
parents: 138
diff changeset
  3811
		style:nil 
claus
parents: 138
diff changeset
  3812
!
claus
parents: 138
diff changeset
  3813
135
claus
parents:
diff changeset
  3814
drawEdgesForX:x y:y width:w height:h level:l 
claus
parents:
diff changeset
  3815
		shadow:shadowColor light:lightColor
claus
parents:
diff changeset
  3816
		halfShadow:halfShadowColor halfLight:halfLightColor
claus
parents:
diff changeset
  3817
		style:edgeStyle
claus
parents:
diff changeset
  3818
claus
parents:
diff changeset
  3819
    "draw 3D edges into a rectangle"
claus
parents:
diff changeset
  3820
claus
parents:
diff changeset
  3821
    |topLeftFg botRightFg topLeftHalfFg botRightHalfFg
claus
parents:
diff changeset
  3822
     count "{ Class: SmallInteger }"
claus
parents:
diff changeset
  3823
     r     "{ Class: SmallInteger }"
claus
parents:
diff changeset
  3824
     b     "{ Class: SmallInteger }"
claus
parents:
diff changeset
  3825
     xi    "{ Class: SmallInteger }"
claus
parents:
diff changeset
  3826
     yi    "{ Class: SmallInteger }"
claus
parents:
diff changeset
  3827
     run paint|
claus
parents:
diff changeset
  3828
claus
parents:
diff changeset
  3829
    count := l.
claus
parents:
diff changeset
  3830
    (count < 0) ifTrue:[
claus
parents:
diff changeset
  3831
	topLeftFg := shadowColor.
claus
parents:
diff changeset
  3832
	botRightFg := lightColor.
claus
parents:
diff changeset
  3833
	topLeftHalfFg := halfShadowColor.
claus
parents:
diff changeset
  3834
	botRightHalfFg := halfLightColor.
claus
parents:
diff changeset
  3835
	count := count negated
claus
parents:
diff changeset
  3836
    ] ifFalse:[
claus
parents:
diff changeset
  3837
	topLeftFg := lightColor.
claus
parents:
diff changeset
  3838
	botRightFg := shadowColor.
claus
parents:
diff changeset
  3839
	topLeftHalfFg := halfLightColor.
claus
parents:
diff changeset
  3840
	botRightHalfFg := halfShadowColor.
claus
parents:
diff changeset
  3841
    ].
claus
parents:
diff changeset
  3842
    topLeftHalfFg isNil ifTrue:[
claus
parents:
diff changeset
  3843
	topLeftHalfFg := topLeftFg
claus
parents:
diff changeset
  3844
    ].
claus
parents:
diff changeset
  3845
    botRightHalfFg isNil ifTrue:[
claus
parents:
diff changeset
  3846
	botRightHalfFg := botRightFg
claus
parents:
diff changeset
  3847
    ].
claus
parents:
diff changeset
  3848
claus
parents:
diff changeset
  3849
    r := x + w - 1. "right"
claus
parents:
diff changeset
  3850
    b := y + h - 1. "bottom"
claus
parents:
diff changeset
  3851
claus
parents:
diff changeset
  3852
    super lineWidth:0.
claus
parents:
diff changeset
  3853
claus
parents:
diff changeset
  3854
    "top and left edges"
151
claus
parents: 145
diff changeset
  3855
    ((edgeStyle == #soft) and:["l" count > 0]) ifTrue:[
135
claus
parents:
diff changeset
  3856
	paint := topLeftHalfFg
claus
parents:
diff changeset
  3857
    ] ifFalse:[
claus
parents:
diff changeset
  3858
	paint := topLeftFg
claus
parents:
diff changeset
  3859
    ].
claus
parents:
diff changeset
  3860
    super paint:paint.
claus
parents:
diff changeset
  3861
claus
parents:
diff changeset
  3862
    0 to:(count - 1) do:[:i |
claus
parents:
diff changeset
  3863
	run := y + i.
claus
parents:
diff changeset
  3864
	super displayDeviceLineFromX:x y:run toX:r y:run. "top"
claus
parents:
diff changeset
  3865
	run := x + i.
claus
parents:
diff changeset
  3866
	super displayDeviceLineFromX:run y:y toX:run y:b  "left"
claus
parents:
diff changeset
  3867
    ].
claus
parents:
diff changeset
  3868
    (edgeStyle == #soft) ifTrue:[
claus
parents:
diff changeset
  3869
"
claus
parents:
diff changeset
  3870
	super paint:topLeftFg.
claus
parents:
diff changeset
  3871
	super displayDeviceLineFromX:x y:y toX:r y:y. 
claus
parents:
diff changeset
  3872
	super displayDeviceLineFromX:x y:y toX:x y:b        
claus
parents:
diff changeset
  3873
"
claus
parents:
diff changeset
  3874
	(l > 2) ifTrue:[
claus
parents:
diff changeset
  3875
	    super paint:Black.
claus
parents:
diff changeset
  3876
	    super displayDeviceLineFromX:x y:y toX:r y:y. 
claus
parents:
diff changeset
  3877
	    super displayDeviceLineFromX:x y:y toX:x y:b. 
claus
parents:
diff changeset
  3878
	]
claus
parents:
diff changeset
  3879
    ].
claus
parents:
diff changeset
  3880
claus
parents:
diff changeset
  3881
    xi := x + 1.
claus
parents:
diff changeset
  3882
    yi := y + 1.
claus
parents:
diff changeset
  3883
claus
parents:
diff changeset
  3884
"/ does not look good
claus
parents:
diff changeset
  3885
"/ style == #st80 iftrue:[
claus
parents:
diff changeset
  3886
"/  yi := yi + 1
claus
parents:
diff changeset
  3887
"/ ].
claus
parents:
diff changeset
  3888
claus
parents:
diff changeset
  3889
    "bottom and right edges"
151
claus
parents: 145
diff changeset
  3890
    (edgeStyle == #soft "new:" and:[count > 1]) ifTrue:[
135
claus
parents:
diff changeset
  3891
	paint := botRightHalfFg
claus
parents:
diff changeset
  3892
    ] ifFalse:[
claus
parents:
diff changeset
  3893
	paint := botRightFg
claus
parents:
diff changeset
  3894
    ].
claus
parents:
diff changeset
  3895
claus
parents:
diff changeset
  3896
    super paint:paint.
claus
parents:
diff changeset
  3897
    0 to:(count - 1) do:[:i |
claus
parents:
diff changeset
  3898
	run := b - i.
claus
parents:
diff changeset
  3899
	super displayDeviceLineFromX:xi-1 y:run toX:r y:run. "bottom"
claus
parents:
diff changeset
  3900
	run := r - i.
claus
parents:
diff changeset
  3901
	super displayDeviceLineFromX:run y:yi-1 toX:run y:b.  "right"
claus
parents:
diff changeset
  3902
	xi := xi + 1.
claus
parents:
diff changeset
  3903
	yi := yi + 1
claus
parents:
diff changeset
  3904
    ].
claus
parents:
diff changeset
  3905
    ((edgeStyle == #soft) and:[l > 1]) ifTrue:[
claus
parents:
diff changeset
  3906
	super paint:Black "shadowColor".
154
claus
parents: 153
diff changeset
  3907
	super displayDeviceLineFromX:(x + (1 - 1)) y:b toX:r y:b. 
claus
parents: 153
diff changeset
  3908
	super displayDeviceLineFromX:r y:(y + (1 - 1)) toX:r y:b        
135
claus
parents:
diff changeset
  3909
    ]
claus
parents:
diff changeset
  3910
!
claus
parents:
diff changeset
  3911
claus
parents:
diff changeset
  3912
drawTopEdgeLevel:level shadow:shadowColor light:lightColor halfShadow:halfShadowColor halfLight:halfLightColor style:edgeStyle 
claus
parents:
diff changeset
  3913
    |topFg topHalfFg paint r
claus
parents:
diff changeset
  3914
     count "{ Class: SmallInteger }" |
claus
parents:
diff changeset
  3915
claus
parents:
diff changeset
  3916
    count := level.
claus
parents:
diff changeset
  3917
    count == 0 ifTrue:[^ self].
claus
parents:
diff changeset
  3918
claus
parents:
diff changeset
  3919
    (count < 0) ifTrue:[
claus
parents:
diff changeset
  3920
	topFg := shadowColor.
claus
parents:
diff changeset
  3921
	topHalfFg := halfShadowColor.
claus
parents:
diff changeset
  3922
	count := count negated
claus
parents:
diff changeset
  3923
    ] ifFalse:[
claus
parents:
diff changeset
  3924
	topFg := lightColor.
claus
parents:
diff changeset
  3925
	topHalfFg := halfLightColor.
claus
parents:
diff changeset
  3926
    ].
claus
parents:
diff changeset
  3927
    topHalfFg isNil ifTrue:[
claus
parents:
diff changeset
  3928
	topHalfFg := topFg
claus
parents:
diff changeset
  3929
    ].
claus
parents:
diff changeset
  3930
claus
parents:
diff changeset
  3931
    ((edgeStyle == #soft) and:[level > 0]) ifTrue:[
claus
parents:
diff changeset
  3932
	paint := topHalfFg
claus
parents:
diff changeset
  3933
    ] ifFalse:[
claus
parents:
diff changeset
  3934
	paint := topFg
claus
parents:
diff changeset
  3935
    ].
claus
parents:
diff changeset
  3936
    super paint:paint.
claus
parents:
diff changeset
  3937
    super lineWidth:0.
claus
parents:
diff changeset
  3938
claus
parents:
diff changeset
  3939
    r := width - 1.
claus
parents:
diff changeset
  3940
    0 to:(count - 1) do:[:i |
claus
parents:
diff changeset
  3941
	super displayDeviceLineFromX:i y:i toX:(r - i) y:i
claus
parents:
diff changeset
  3942
    ].
claus
parents:
diff changeset
  3943
    ((edgeStyle == #soft) and:[level > 2]) ifTrue:[
claus
parents:
diff changeset
  3944
	super paint:Black.
claus
parents:
diff changeset
  3945
	super displayDeviceLineFromX:0 y:0 toX:r y:0. 
claus
parents:
diff changeset
  3946
    ]
claus
parents:
diff changeset
  3947
!
claus
parents:
diff changeset
  3948
claus
parents:
diff changeset
  3949
drawBottomEdgeLevel:level shadow:shadowColor light:lightColor halfShadow:halfShadowColor halfLight:halfLightColor style:edgeStyle
claus
parents:
diff changeset
  3950
    |botFg
claus
parents:
diff changeset
  3951
     count "{ Class: SmallInteger }" 
claus
parents:
diff changeset
  3952
     b r|
claus
parents:
diff changeset
  3953
claus
parents:
diff changeset
  3954
    count := level.
claus
parents:
diff changeset
  3955
    count == 0 ifTrue:[^ self].
claus
parents:
diff changeset
  3956
claus
parents:
diff changeset
  3957
    (count < 0) ifTrue:[
claus
parents:
diff changeset
  3958
	botFg := lightColor.
claus
parents:
diff changeset
  3959
	count := count negated
claus
parents:
diff changeset
  3960
    ] ifFalse:[
claus
parents:
diff changeset
  3961
	((edgeStyle == #soft) and:[level > 1]) ifTrue:[
claus
parents:
diff changeset
  3962
	    botFg := halfShadowColor
claus
parents:
diff changeset
  3963
	] ifFalse:[
claus
parents:
diff changeset
  3964
	    botFg := shadowColor
claus
parents:
diff changeset
  3965
	].
claus
parents:
diff changeset
  3966
    ].
claus
parents:
diff changeset
  3967
    super paint:botFg.
claus
parents:
diff changeset
  3968
    super lineWidth:0.
claus
parents:
diff changeset
  3969
claus
parents:
diff changeset
  3970
    r := width - 1.
claus
parents:
diff changeset
  3971
    0 to:(count - 1) do:[:i |
claus
parents:
diff changeset
  3972
	b := height - 1 - i.
claus
parents:
diff changeset
  3973
	super displayDeviceLineFromX:i y:b toX:(r - i) y:b
claus
parents:
diff changeset
  3974
    ].
claus
parents:
diff changeset
  3975
claus
parents:
diff changeset
  3976
    ((edgeStyle == #soft) and:[level > 1]) ifTrue:[
claus
parents:
diff changeset
  3977
	b := height - 1.
claus
parents:
diff changeset
  3978
	super paint:shadowColor.
claus
parents:
diff changeset
  3979
	super displayDeviceLineFromX:1 y:b toX:r y:b. 
claus
parents:
diff changeset
  3980
    ]
claus
parents:
diff changeset
  3981
!
claus
parents:
diff changeset
  3982
claus
parents:
diff changeset
  3983
drawLeftEdgeLevel:level shadow:shadowColor light:lightColor halfShadow:halfShadowColor halfLight:halfLightColor style:edgeStyle 
claus
parents:
diff changeset
  3984
    |leftFg leftHalfFg paint b
claus
parents:
diff changeset
  3985
     count "{ Class: SmallInteger }" |
claus
parents:
diff changeset
  3986
claus
parents:
diff changeset
  3987
    count := level.
claus
parents:
diff changeset
  3988
    count == 0 ifTrue:[^ self].
claus
parents:
diff changeset
  3989
    
claus
parents:
diff changeset
  3990
    (count < 0) ifTrue:[
claus
parents:
diff changeset
  3991
	leftFg := shadowColor.
claus
parents:
diff changeset
  3992
	leftHalfFg := halfShadowColor.
claus
parents:
diff changeset
  3993
	count := count negated.
claus
parents:
diff changeset
  3994
    ] ifFalse:[
claus
parents:
diff changeset
  3995
	leftFg := lightColor.
claus
parents:
diff changeset
  3996
	leftHalfFg := halfLightColor.
claus
parents:
diff changeset
  3997
    ].
claus
parents:
diff changeset
  3998
    leftHalfFg isNil ifTrue:[
claus
parents:
diff changeset
  3999
	leftHalfFg := leftFg
claus
parents:
diff changeset
  4000
    ].
claus
parents:
diff changeset
  4001
claus
parents:
diff changeset
  4002
    ((edgeStyle == #soft) and:[level > 0]) ifTrue:[
claus
parents:
diff changeset
  4003
	paint := leftHalfFg
claus
parents:
diff changeset
  4004
    ] ifFalse:[
claus
parents:
diff changeset
  4005
	paint := leftFg
claus
parents:
diff changeset
  4006
    ].
claus
parents:
diff changeset
  4007
    super paint:paint.
claus
parents:
diff changeset
  4008
    super lineWidth:0.
claus
parents:
diff changeset
  4009
claus
parents:
diff changeset
  4010
    b := height - 1.
claus
parents:
diff changeset
  4011
    0 to:(count - 1) do:[:i |
claus
parents:
diff changeset
  4012
	super displayDeviceLineFromX:i y:i toX:i y:(b - i)
claus
parents:
diff changeset
  4013
    ].
claus
parents:
diff changeset
  4014
claus
parents:
diff changeset
  4015
    ((edgeStyle == #soft) and:[level > 2]) ifTrue:[
claus
parents:
diff changeset
  4016
	super paint:Black.
claus
parents:
diff changeset
  4017
	super displayDeviceLineFromX:0 y:0 toX:0 y:b. 
claus
parents:
diff changeset
  4018
    ]
claus
parents:
diff changeset
  4019
!
claus
parents:
diff changeset
  4020
140
claus
parents: 138
diff changeset
  4021
drawRightEdgeLevel:level shadow:shadowColor light:lightColor halfShadow:halfShadowColor halfLight:halfLightColor style:edgeStyle 
claus
parents: 138
diff changeset
  4022
    |rightFg
claus
parents: 138
diff changeset
  4023
     count "{ Class: SmallInteger }" 
claus
parents: 138
diff changeset
  4024
     r b|
claus
parents: 138
diff changeset
  4025
claus
parents: 138
diff changeset
  4026
    count := level.
claus
parents: 138
diff changeset
  4027
    count == 0 ifTrue:[^ self].
claus
parents: 138
diff changeset
  4028
claus
parents: 138
diff changeset
  4029
    (count < 0) ifTrue:[
claus
parents: 138
diff changeset
  4030
	rightFg := lightColor.
claus
parents: 138
diff changeset
  4031
	count := count negated
claus
parents: 138
diff changeset
  4032
    ] ifFalse:[
claus
parents: 138
diff changeset
  4033
	((edgeStyle == #soft) and:[level > 1]) ifTrue:[
claus
parents: 138
diff changeset
  4034
	    rightFg := halfShadowColor
claus
parents: 138
diff changeset
  4035
	] ifFalse:[
claus
parents: 138
diff changeset
  4036
	    rightFg := shadowColor
claus
parents: 138
diff changeset
  4037
	].
claus
parents: 138
diff changeset
  4038
    ].
claus
parents: 138
diff changeset
  4039
    super paint:rightFg.
claus
parents: 138
diff changeset
  4040
    super lineWidth:0.
claus
parents: 138
diff changeset
  4041
claus
parents: 138
diff changeset
  4042
    b := height - 1.
claus
parents: 138
diff changeset
  4043
    0 to:(count - 1) do:[:i |
claus
parents: 138
diff changeset
  4044
	r := width - 1 - i.
claus
parents: 138
diff changeset
  4045
	super displayDeviceLineFromX:r y:i toX:r y:(b - i)
claus
parents: 138
diff changeset
  4046
    ].
claus
parents: 138
diff changeset
  4047
    ((edgeStyle == #soft) and:[level > 1]) ifTrue:[
claus
parents: 138
diff changeset
  4048
	r := width - 1.
claus
parents: 138
diff changeset
  4049
	super paint:shadowColor.
claus
parents: 138
diff changeset
  4050
	super displayDeviceLineFromX:r y:1 toX:r y:b. 
claus
parents: 138
diff changeset
  4051
    ]
claus
parents: 138
diff changeset
  4052
!
claus
parents: 138
diff changeset
  4053
135
claus
parents:
diff changeset
  4054
drawEdgesForX:x y:y width:w height:h level:l
claus
parents:
diff changeset
  4055
    "draw 3D edges into a rectangle"
claus
parents:
diff changeset
  4056
claus
parents:
diff changeset
  4057
    self drawEdgesForX:x y:y width:w height:h level:l 
claus
parents:
diff changeset
  4058
		shadow:shadowColor 
claus
parents:
diff changeset
  4059
		light:lightColor
claus
parents:
diff changeset
  4060
		halfShadow:nil 
claus
parents:
diff changeset
  4061
		halfLight:nil 
claus
parents:
diff changeset
  4062
		style:nil 
claus
parents:
diff changeset
  4063
!
claus
parents:
diff changeset
  4064
151
claus
parents: 145
diff changeset
  4065
redrawEdges
claus
parents: 145
diff changeset
  4066
    "redraw my edges (if any)"
claus
parents: 145
diff changeset
  4067
claus
parents: 145
diff changeset
  4068
    (level ~~ 0) ifTrue:[
claus
parents: 145
diff changeset
  4069
	shown ifTrue:[
claus
parents: 145
diff changeset
  4070
	    self clipRect:nil.
claus
parents: 145
diff changeset
  4071
	    self drawEdges.
claus
parents: 145
diff changeset
  4072
	    self clipRect:innerClipRect
claus
parents: 145
diff changeset
  4073
	]                  
claus
parents: 145
diff changeset
  4074
    ]                  
claus
parents: 145
diff changeset
  4075
! !
claus
parents: 145
diff changeset
  4076
claus
parents: 145
diff changeset
  4077
!SimpleView methodsFor:'redrawing'!
claus
parents: 145
diff changeset
  4078
claus
parents: 145
diff changeset
  4079
redrawX:x y:y width:w height:h
claus
parents: 145
diff changeset
  4080
    "have to redraw part of myself, given logical coordinates (if trans is nonNil)
claus
parents: 145
diff changeset
  4081
     default is to redraw everything - subclasses should add intelligence"
claus
parents: 145
diff changeset
  4082
claus
parents: 145
diff changeset
  4083
    |area|
claus
parents: 145
diff changeset
  4084
claus
parents: 145
diff changeset
  4085
    shown ifFalse:[^ self].
claus
parents: 145
diff changeset
  4086
claus
parents: 145
diff changeset
  4087
    area := Rectangle left:x top:y width:w height:h.      
claus
parents: 145
diff changeset
  4088
    self clippedTo:area do:[
claus
parents: 145
diff changeset
  4089
"/        controller notNil ifTrue:[
claus
parents: 145
diff changeset
  4090
"/            "ST-80 updating"
claus
parents: 145
diff changeset
  4091
"/            self update:#rectangle with:area
claus
parents: 145
diff changeset
  4092
"/        ] ifFalse:[
claus
parents: 145
diff changeset
  4093
	    components notNil ifTrue:[
claus
parents: 145
diff changeset
  4094
		components do:[:aComponent |
claus
parents: 145
diff changeset
  4095
		    |thisFrame is|
claus
parents: 145
diff changeset
  4096
claus
parents: 145
diff changeset
  4097
		    thisFrame := aComponent frame.
claus
parents: 145
diff changeset
  4098
		    (thisFrame intersects:area) ifTrue:[
claus
parents: 145
diff changeset
  4099
			is := thisFrame intersect:(x@y extent:w@h).
claus
parents: 145
diff changeset
  4100
			is = thisFrame ifTrue:[
claus
parents: 145
diff changeset
  4101
			    aComponent redraw
claus
parents: 145
diff changeset
  4102
			] ifFalse:[
claus
parents: 145
diff changeset
  4103
			    aComponent redrawX:is left
claus
parents: 145
diff changeset
  4104
					     y:is top
claus
parents: 145
diff changeset
  4105
					 width:is width
claus
parents: 145
diff changeset
  4106
					height:is height.
claus
parents: 145
diff changeset
  4107
			].        
claus
parents: 145
diff changeset
  4108
			"/ aComponent drawIn:self offset:0@0
claus
parents: 145
diff changeset
  4109
		    ]
claus
parents: 145
diff changeset
  4110
		]
claus
parents: 145
diff changeset
  4111
	    ] ifFalse:[
claus
parents: 145
diff changeset
  4112
		self redraw
claus
parents: 145
diff changeset
  4113
	    ]
claus
parents: 145
diff changeset
  4114
"/        ]
claus
parents: 145
diff changeset
  4115
    ]                                                              
claus
parents: 145
diff changeset
  4116
!
claus
parents: 145
diff changeset
  4117
claus
parents: 145
diff changeset
  4118
redraw
claus
parents: 145
diff changeset
  4119
    "redraw myself
claus
parents: 145
diff changeset
  4120
     cannot do much here - has to be redefined in subclasses"
claus
parents: 145
diff changeset
  4121
claus
parents: 145
diff changeset
  4122
!
claus
parents: 145
diff changeset
  4123
135
claus
parents:
diff changeset
  4124
redrawDeviceX:x y:y width:w height:h
claus
parents:
diff changeset
  4125
    "have to redraw part of the view.
claus
parents:
diff changeset
  4126
     The coordinates are in device space - if there is a transformation,
claus
parents:
diff changeset
  4127
     must inverse-transform back to logical coordinates. (since the view thinks
claus
parents:
diff changeset
  4128
     in its coordinate space)"
claus
parents:
diff changeset
  4129
claus
parents:
diff changeset
  4130
    |lx ly lw lh|
claus
parents:
diff changeset
  4131
claus
parents:
diff changeset
  4132
    lx := x.
claus
parents:
diff changeset
  4133
    ly := y.
claus
parents:
diff changeset
  4134
    lw := w.
claus
parents:
diff changeset
  4135
    lh := h.
claus
parents:
diff changeset
  4136
claus
parents:
diff changeset
  4137
    transformation notNil ifTrue:[
claus
parents:
diff changeset
  4138
	lx := transformation applyInverseToX:lx.
claus
parents:
diff changeset
  4139
	ly := transformation applyInverseToY:ly.
claus
parents:
diff changeset
  4140
	lw := transformation applyInverseScaleX:lw.
claus
parents:
diff changeset
  4141
	lh := transformation applyInverseScaleY:lh.
claus
parents:
diff changeset
  4142
    ].
claus
parents:
diff changeset
  4143
    self redrawX:lx y:ly width:lw height:lh
claus
parents:
diff changeset
  4144
!
claus
parents:
diff changeset
  4145
claus
parents:
diff changeset
  4146
showFocus
claus
parents:
diff changeset
  4147
    "highlight myself somehow to tell user that I have the focus"
claus
parents:
diff changeset
  4148
claus
parents:
diff changeset
  4149
    |delta|
claus
parents:
diff changeset
  4150
claus
parents:
diff changeset
  4151
    drawableId notNil ifTrue:[
claus
parents:
diff changeset
  4152
	delta := DefaultFocusBorderWidth - borderWidth.
claus
parents:
diff changeset
  4153
	delta ~~ 0 ifTrue:[
claus
parents:
diff changeset
  4154
	    device moveWindow:drawableId x:left-delta y:top-delta
claus
parents:
diff changeset
  4155
	].
claus
parents:
diff changeset
  4156
	device setWindowBorderWidth:DefaultFocusBorderWidth in:drawableId.
claus
parents:
diff changeset
  4157
	device setWindowBorderColor:(DefaultFocusColor on:device) colorId in:drawableId.
claus
parents:
diff changeset
  4158
    ]
claus
parents:
diff changeset
  4159
!
claus
parents:
diff changeset
  4160
claus
parents:
diff changeset
  4161
showNoFocus
claus
parents:
diff changeset
  4162
    "undo the effect of showFocus"
claus
parents:
diff changeset
  4163
claus
parents:
diff changeset
  4164
    |delta|
claus
parents:
diff changeset
  4165
claus
parents:
diff changeset
  4166
    drawableId notNil ifTrue:[
claus
parents:
diff changeset
  4167
	delta := DefaultFocusBorderWidth - borderWidth.
claus
parents:
diff changeset
  4168
	delta ~~ 0 ifTrue:[
claus
parents:
diff changeset
  4169
	    device moveWindow:drawableId x:left+delta y:top+delta
claus
parents:
diff changeset
  4170
	].
claus
parents:
diff changeset
  4171
	device setWindowBorderWidth:borderWidth in:drawableId.
claus
parents:
diff changeset
  4172
	self setBorderColor.
claus
parents:
diff changeset
  4173
    ]
claus
parents:
diff changeset
  4174
!
claus
parents:
diff changeset
  4175
claus
parents:
diff changeset
  4176
showActive
claus
parents:
diff changeset
  4177
    "redraw myself as active (i.e. busy).
151
claus
parents: 145
diff changeset
  4178
     Nothing done here, but redefined in some classes."
135
claus
parents:
diff changeset
  4179
claus
parents:
diff changeset
  4180
    ^ self
claus
parents:
diff changeset
  4181
!
claus
parents:
diff changeset
  4182
claus
parents:
diff changeset
  4183
showPassive
claus
parents:
diff changeset
  4184
    "redraw myself as inactive (i.e. nonbusy).
151
claus
parents: 145
diff changeset
  4185
     Nothing done here, but redefined in some classes."
135
claus
parents:
diff changeset
  4186
claus
parents:
diff changeset
  4187
    ^ self
claus
parents:
diff changeset
  4188
! !
claus
parents:
diff changeset
  4189
140
claus
parents: 138
diff changeset
  4190
!SimpleView methodsFor:'accessing-hierarchy'!
claus
parents: 138
diff changeset
  4191
claus
parents: 138
diff changeset
  4192
superView:aView
claus
parents: 138
diff changeset
  4193
    "set my superView to be aView"
claus
parents: 138
diff changeset
  4194
claus
parents: 138
diff changeset
  4195
    superView := aView
claus
parents: 138
diff changeset
  4196
!
claus
parents: 138
diff changeset
  4197
claus
parents: 138
diff changeset
  4198
superView
claus
parents: 138
diff changeset
  4199
    "return my superView"
claus
parents: 138
diff changeset
  4200
claus
parents: 138
diff changeset
  4201
    ^ superView
claus
parents: 138
diff changeset
  4202
!
claus
parents: 138
diff changeset
  4203
claus
parents: 138
diff changeset
  4204
subViews
claus
parents: 138
diff changeset
  4205
    "return the collection of subviews"
claus
parents: 138
diff changeset
  4206
claus
parents: 138
diff changeset
  4207
    ^ subViews
claus
parents: 138
diff changeset
  4208
!
claus
parents: 138
diff changeset
  4209
claus
parents: 138
diff changeset
  4210
topView
claus
parents: 138
diff changeset
  4211
    "return the topView - thats the one with no superview"
claus
parents: 138
diff changeset
  4212
claus
parents: 138
diff changeset
  4213
    |v|
claus
parents: 138
diff changeset
  4214
claus
parents: 138
diff changeset
  4215
    v := self.
claus
parents: 138
diff changeset
  4216
    [v notNil] whileTrue:[
claus
parents: 138
diff changeset
  4217
	v superView isNil ifTrue:[^ v].
claus
parents: 138
diff changeset
  4218
	v := v superView
claus
parents: 138
diff changeset
  4219
    ].
claus
parents: 138
diff changeset
  4220
claus
parents: 138
diff changeset
  4221
    ^ nil
claus
parents: 138
diff changeset
  4222
!
claus
parents: 138
diff changeset
  4223
claus
parents: 138
diff changeset
  4224
subViews:aListOfViews
claus
parents: 138
diff changeset
  4225
    "set the collection of subviews"
claus
parents: 138
diff changeset
  4226
claus
parents: 138
diff changeset
  4227
    subViews := aListOfViews.
claus
parents: 138
diff changeset
  4228
    subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  4229
	subViews do:[:view |
claus
parents: 138
diff changeset
  4230
	    view superView:self
claus
parents: 138
diff changeset
  4231
	]
claus
parents: 138
diff changeset
  4232
    ]
153
claus
parents: 151
diff changeset
  4233
!
claus
parents: 151
diff changeset
  4234
claus
parents: 151
diff changeset
  4235
raise
claus
parents: 151
diff changeset
  4236
    "bring to front"
claus
parents: 151
diff changeset
  4237
claus
parents: 151
diff changeset
  4238
    drawableId isNil ifTrue:[self create].
claus
parents: 151
diff changeset
  4239
    device raiseWindow:drawableId
claus
parents: 151
diff changeset
  4240
claus
parents: 151
diff changeset
  4241
    "
claus
parents: 151
diff changeset
  4242
     Transcript topView raise
claus
parents: 151
diff changeset
  4243
    "
claus
parents: 151
diff changeset
  4244
!
claus
parents: 151
diff changeset
  4245
claus
parents: 151
diff changeset
  4246
lower
claus
parents: 151
diff changeset
  4247
    "bring to back"
claus
parents: 151
diff changeset
  4248
claus
parents: 151
diff changeset
  4249
    drawableId isNil ifTrue:[self create].
claus
parents: 151
diff changeset
  4250
    device lowerWindow:drawableId
claus
parents: 151
diff changeset
  4251
claus
parents: 151
diff changeset
  4252
    "
claus
parents: 151
diff changeset
  4253
     Transcript topView lower
claus
parents: 151
diff changeset
  4254
    "
140
claus
parents: 138
diff changeset
  4255
! !
claus
parents: 138
diff changeset
  4256
claus
parents: 138
diff changeset
  4257
!SimpleView methodsFor:'initialization'!
claus
parents: 138
diff changeset
  4258
claus
parents: 138
diff changeset
  4259
initEvents
claus
parents: 138
diff changeset
  4260
    "will be sent by create - can be redefined by subclasses to enable
claus
parents: 138
diff changeset
  4261
     view events"
135
claus
parents:
diff changeset
  4262
claus
parents:
diff changeset
  4263
    ^ self
claus
parents:
diff changeset
  4264
!
claus
parents:
diff changeset
  4265
140
claus
parents: 138
diff changeset
  4266
defaultControllerClass
claus
parents: 138
diff changeset
  4267
    ^ nil "/ Controller
claus
parents: 138
diff changeset
  4268
!
claus
parents: 138
diff changeset
  4269
173
claus
parents: 162
diff changeset
  4270
initStyleSheet
claus
parents: 162
diff changeset
  4271
    "this method gets the styleSheet"
140
claus
parents: 138
diff changeset
  4272
claus
parents: 138
diff changeset
  4273
    "
claus
parents: 138
diff changeset
  4274
     when coming here the first time, we read the styleSheet
claus
parents: 138
diff changeset
  4275
     and keep the values in fast class variables
claus
parents: 138
diff changeset
  4276
    "
claus
parents: 138
diff changeset
  4277
    StyleSheet isNil ifTrue:[
claus
parents: 138
diff changeset
  4278
	self class updateStyleCache
135
claus
parents:
diff changeset
  4279
    ].
claus
parents:
diff changeset
  4280
151
claus
parents: 145
diff changeset
  4281
    styleSheet := StyleSheet.
173
claus
parents: 162
diff changeset
  4282
!
claus
parents: 162
diff changeset
  4283
claus
parents: 162
diff changeset
  4284
initStyle
claus
parents: 162
diff changeset
  4285
    "this method sets up all style dependent things"
claus
parents: 162
diff changeset
  4286
claus
parents: 162
diff changeset
  4287
    self initStyleSheet.
140
claus
parents: 138
diff changeset
  4288
claus
parents: 138
diff changeset
  4289
    borderWidth := DefaultBorderWidth.
claus
parents: 138
diff changeset
  4290
    borderWidth isNil ifTrue:[borderWidth := 1].
claus
parents: 138
diff changeset
  4291
151
claus
parents: 145
diff changeset
  4292
    viewBackground := DefaultViewBackgroundColor.
140
claus
parents: 138
diff changeset
  4293
claus
parents: 138
diff changeset
  4294
    DefaultLightColor notNil ifTrue:[
claus
parents: 138
diff changeset
  4295
	lightColor := DefaultLightColor.
claus
parents: 138
diff changeset
  4296
    ] ifFalse:[
claus
parents: 138
diff changeset
  4297
	device hasGreyscales ifTrue:[
claus
parents: 138
diff changeset
  4298
	    DefaultLightColor := lightColor := viewBackground lightened.
claus
parents: 138
diff changeset
  4299
	] ifFalse:[
135
claus
parents:
diff changeset
  4300
	    "
151
claus
parents: 145
diff changeset
  4301
	     this seems strange: on B&W screens, we create the light color 
claus
parents: 145
diff changeset
  4302
	     darker than normal viewBackground (White) -
claus
parents: 145
diff changeset
  4303
	     to make the boundary of the view visible
135
claus
parents:
diff changeset
  4304
	    "
140
claus
parents: 138
diff changeset
  4305
	    lightColor := Color grey:50
135
claus
parents:
diff changeset
  4306
	]
claus
parents:
diff changeset
  4307
    ].
140
claus
parents: 138
diff changeset
  4308
    DefaultShadowColor notNil ifTrue:[
claus
parents: 138
diff changeset
  4309
	shadowColor := DefaultShadowColor.
claus
parents: 138
diff changeset
  4310
    ] ifFalse:[
claus
parents: 138
diff changeset
  4311
	shadowColor := Black
135
claus
parents:
diff changeset
  4312
    ].
140
claus
parents: 138
diff changeset
  4313
151
claus
parents: 145
diff changeset
  4314
    lightColor := lightColor.
claus
parents: 145
diff changeset
  4315
    shadowColor := shadowColor.
claus
parents: 145
diff changeset
  4316
    borderColor := DefaultBorderColor.
claus
parents: 145
diff changeset
  4317
    font := DefaultFont.
140
claus
parents: 138
diff changeset
  4318
!
claus
parents: 138
diff changeset
  4319
claus
parents: 138
diff changeset
  4320
initialize
claus
parents: 138
diff changeset
  4321
    "initialize all state of the view - usually redefined in subclasses,
claus
parents: 138
diff changeset
  4322
     but always doing a 'super initialize'. Each class should setup its
claus
parents: 138
diff changeset
  4323
     locals - and not forget the others.
claus
parents: 138
diff changeset
  4324
     View setup is separated into two parts, the general setup done here
claus
parents: 138
diff changeset
  4325
     and the style specific setup in initStyle. Each view should be prepared
claus
parents: 138
diff changeset
  4326
     for a stylechange by being sent another initStyle with a new style value.
claus
parents: 138
diff changeset
  4327
     (in this case, it should set all of its style-dependent things, but
claus
parents: 138
diff changeset
  4328
      leave the state and contents as-is)"
claus
parents: 138
diff changeset
  4329
144
claus
parents: 142
diff changeset
  4330
    |ext myClass controllerClass|
140
claus
parents: 138
diff changeset
  4331
claus
parents: 138
diff changeset
  4332
    super initialize.
claus
parents: 138
diff changeset
  4333
claus
parents: 138
diff changeset
  4334
    font := DefaultFont.
claus
parents: 138
diff changeset
  4335
151
claus
parents: 145
diff changeset
  4336
    shown := hiddenOnRealize := realized := false.
140
claus
parents: 138
diff changeset
  4337
claus
parents: 138
diff changeset
  4338
    "fill in some defaults - some of them are usually redefined in subclasses
claus
parents: 138
diff changeset
  4339
     initialize methods"
claus
parents: 138
diff changeset
  4340
144
claus
parents: 142
diff changeset
  4341
    myClass := self class.
claus
parents: 142
diff changeset
  4342
    name := myClass name "asString" asLowercaseFirst.
claus
parents: 142
diff changeset
  4343
    ext := myClass defaultExtent.
claus
parents: 142
diff changeset
  4344
    resources := myClass classResources.
claus
parents: 142
diff changeset
  4345
claus
parents: 142
diff changeset
  4346
    level := margin := 0.
140
claus
parents: 138
diff changeset
  4347
    margin := 0.
claus
parents: 138
diff changeset
  4348
claus
parents: 138
diff changeset
  4349
    self initStyle.
claus
parents: 138
diff changeset
  4350
144
claus
parents: 142
diff changeset
  4351
    left := top := 0.
140
claus
parents: 138
diff changeset
  4352
    width := ext x.
claus
parents: 138
diff changeset
  4353
    height := ext y.
claus
parents: 138
diff changeset
  4354
claus
parents: 138
diff changeset
  4355
    originChanged := extentChanged := false.
claus
parents: 138
diff changeset
  4356
    bitGravity := nil.
claus
parents: 138
diff changeset
  4357
    viewGravity := nil.
claus
parents: 138
diff changeset
  4358
claus
parents: 138
diff changeset
  4359
    controllerClass := self defaultControllerClass.
claus
parents: 138
diff changeset
  4360
    controllerClass notNil ifTrue:[
claus
parents: 138
diff changeset
  4361
	controller := controllerClass new.
claus
parents: 138
diff changeset
  4362
	controller view:self.
135
claus
parents:
diff changeset
  4363
    ].
140
claus
parents: 138
diff changeset
  4364
!
claus
parents: 138
diff changeset
  4365
claus
parents: 138
diff changeset
  4366
prepareForReinit
claus
parents: 138
diff changeset
  4367
    super prepareForReinit.
claus
parents: 138
diff changeset
  4368
    windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  4369
	windowGroup reinitialize
135
claus
parents:
diff changeset
  4370
    ]
claus
parents:
diff changeset
  4371
!
claus
parents:
diff changeset
  4372
140
claus
parents: 138
diff changeset
  4373
reinitialize
claus
parents: 138
diff changeset
  4374
    "this is called right snapIn"
claus
parents: 138
diff changeset
  4375
claus
parents: 138
diff changeset
  4376
    |myController|
claus
parents: 138
diff changeset
  4377
claus
parents: 138
diff changeset
  4378
    "if I have already been reinited - return"
claus
parents: 138
diff changeset
  4379
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  4380
	^ self
135
claus
parents:
diff changeset
  4381
    ].
claus
parents:
diff changeset
  4382
140
claus
parents: 138
diff changeset
  4383
    "
claus
parents: 138
diff changeset
  4384
     superView must be there, first
claus
parents: 138
diff changeset
  4385
    "
claus
parents: 138
diff changeset
  4386
    superView notNil ifTrue:[
claus
parents: 138
diff changeset
  4387
	superView id isNil ifTrue:[
claus
parents: 138
diff changeset
  4388
	    superView reinitialize
135
claus
parents:
diff changeset
  4389
	]
claus
parents:
diff changeset
  4390
    ].
140
claus
parents: 138
diff changeset
  4391
claus
parents: 138
diff changeset
  4392
    myController := controller.
claus
parents: 138
diff changeset
  4393
    controller := nil.
claus
parents: 138
diff changeset
  4394
    self recreate.
claus
parents: 138
diff changeset
  4395
claus
parents: 138
diff changeset
  4396
    "if I was mapped, do it again"
claus
parents: 138
diff changeset
  4397
    realized ifTrue:[
claus
parents: 138
diff changeset
  4398
	"only remap if I have a superview - otherwise, I might be
claus
parents: 138
diff changeset
  4399
	 a hidden iconView or menu ..."
claus
parents: 138
diff changeset
  4400
	superView notNil ifTrue:[
claus
parents: 138
diff changeset
  4401
"/            shown ifTrue:[
claus
parents: 138
diff changeset
  4402
		device mapView:self id:drawableId iconified:false
claus
parents: 138
diff changeset
  4403
			   atX:left y:top width:width height:height
claus
parents: 138
diff changeset
  4404
"/            ].
claus
parents: 138
diff changeset
  4405
	].
135
claus
parents:
diff changeset
  4406
    ].
140
claus
parents: 138
diff changeset
  4407
claus
parents: 138
diff changeset
  4408
    "restore controller"
claus
parents: 138
diff changeset
  4409
    controller := myController
claus
parents: 138
diff changeset
  4410
!
claus
parents: 138
diff changeset
  4411
claus
parents: 138
diff changeset
  4412
reinitStyle
claus
parents: 138
diff changeset
  4413
    "this method is called for a style change"
claus
parents: 138
diff changeset
  4414
claus
parents: 138
diff changeset
  4415
    |t|
claus
parents: 138
diff changeset
  4416
claus
parents: 138
diff changeset
  4417
    self initStyle.
claus
parents: 138
diff changeset
  4418
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  4419
	"force a change"
claus
parents: 138
diff changeset
  4420
	t := borderWidth. borderWidth := nil. self borderWidth:t.
claus
parents: 138
diff changeset
  4421
	t := viewBackground. viewBackground := nil. self viewBackground:t.
claus
parents: 138
diff changeset
  4422
	self clear.
claus
parents: 138
diff changeset
  4423
	self redraw
135
claus
parents:
diff changeset
  4424
    ].
151
claus
parents: 145
diff changeset
  4425
!
claus
parents: 145
diff changeset
  4426
claus
parents: 145
diff changeset
  4427
initializeMiddleButtonMenu
claus
parents: 145
diff changeset
  4428
    "a place to initialize menu - this one is sent once when the view is
claus
parents: 145
diff changeset
  4429
     first created; usually redefined in subclasses; default here is no menu.
claus
parents: 145
diff changeset
  4430
     Notice, that static middleButtonmenus are a historic thing in ST/X;
claus
parents: 145
diff changeset
  4431
     you may prefer to create the menu dynamically (i.e. the ST-80 way)."
claus
parents: 145
diff changeset
  4432
claus
parents: 145
diff changeset
  4433
    ^ self
140
claus
parents: 138
diff changeset
  4434
! !
claus
parents: 138
diff changeset
  4435
claus
parents: 138
diff changeset
  4436
!SimpleView methodsFor:'accessing-bg & border'!
claus
parents: 138
diff changeset
  4437
claus
parents: 138
diff changeset
  4438
borderWidth
claus
parents: 138
diff changeset
  4439
    "return my borderWidth"
claus
parents: 138
diff changeset
  4440
claus
parents: 138
diff changeset
  4441
    ^ borderWidth
claus
parents: 138
diff changeset
  4442
!
claus
parents: 138
diff changeset
  4443
claus
parents: 138
diff changeset
  4444
level:aNumber
claus
parents: 138
diff changeset
  4445
    "set my level relative to superView (3D)"
claus
parents: 138
diff changeset
  4446
claus
parents: 138
diff changeset
  4447
    |oldMargin how|
claus
parents: 138
diff changeset
  4448
claus
parents: 138
diff changeset
  4449
    (aNumber ~~ level and:[aNumber notNil]) ifTrue:[
claus
parents: 138
diff changeset
  4450
	self is3D ifTrue:[
claus
parents: 138
diff changeset
  4451
	    level := aNumber.
claus
parents: 138
diff changeset
  4452
	    oldMargin := margin.
claus
parents: 138
diff changeset
  4453
	    margin := level abs.
claus
parents: 138
diff changeset
  4454
claus
parents: 138
diff changeset
  4455
	    realized ifTrue:[
claus
parents: 138
diff changeset
  4456
		margin ~~ oldMargin ifTrue:[
claus
parents: 138
diff changeset
  4457
		    (margin > oldMargin) ifTrue:[
claus
parents: 138
diff changeset
  4458
			how := #smaller
claus
parents: 138
diff changeset
  4459
		    ] ifFalse:[
claus
parents: 138
diff changeset
  4460
			how := #larger
claus
parents: 138
diff changeset
  4461
		    ].
claus
parents: 138
diff changeset
  4462
		    self sizeChanged:how.
claus
parents: 138
diff changeset
  4463
		    self setInnerClip.
claus
parents: 138
diff changeset
  4464
		].
claus
parents: 138
diff changeset
  4465
		shown ifTrue:[
claus
parents: 138
diff changeset
  4466
		    self redrawEdges
claus
parents: 138
diff changeset
  4467
		]
135
claus
parents:
diff changeset
  4468
	    ]
claus
parents:
diff changeset
  4469
	]
claus
parents:
diff changeset
  4470
    ]
claus
parents:
diff changeset
  4471
!
claus
parents:
diff changeset
  4472
140
claus
parents: 138
diff changeset
  4473
borderWidth:aNumber
claus
parents: 138
diff changeset
  4474
    "set my borderWidth"
claus
parents: 138
diff changeset
  4475
claus
parents: 138
diff changeset
  4476
    (aNumber ~~ borderWidth) ifTrue:[
claus
parents: 138
diff changeset
  4477
	borderWidth := aNumber.
claus
parents: 138
diff changeset
  4478
	drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  4479
	    device setWindowBorderWidth:aNumber in:drawableId
claus
parents: 138
diff changeset
  4480
	]
135
claus
parents:
diff changeset
  4481
    ]
claus
parents:
diff changeset
  4482
!
claus
parents:
diff changeset
  4483
140
claus
parents: 138
diff changeset
  4484
viewBackground:something
claus
parents: 138
diff changeset
  4485
    "set the viewBackground to something, a color, image or form.
claus
parents: 138
diff changeset
  4486
     If its a color and we run on a color display, also set shadow and light
claus
parents: 138
diff changeset
  4487
     colors - this means, that a red view will get light-red and dark-red
claus
parents: 138
diff changeset
  4488
     edges."
claus
parents: 138
diff changeset
  4489
claus
parents: 138
diff changeset
  4490
    something isColor ifTrue:[
claus
parents: 138
diff changeset
  4491
	device hasGreyscales ifTrue:[
claus
parents: 138
diff changeset
  4492
	    shadowColor := something darkened.
claus
parents: 138
diff changeset
  4493
	    lightColor := something lightened
claus
parents: 138
diff changeset
  4494
	]
claus
parents: 138
diff changeset
  4495
    ].
claus
parents: 138
diff changeset
  4496
    super viewBackground:something
claus
parents: 138
diff changeset
  4497
!
claus
parents: 138
diff changeset
  4498
claus
parents: 138
diff changeset
  4499
margin
claus
parents: 138
diff changeset
  4500
    "return my margin - this is usually the level,
claus
parents: 138
diff changeset
  4501
     but can be more for some views"
claus
parents: 138
diff changeset
  4502
claus
parents: 138
diff changeset
  4503
    ^ margin
claus
parents: 138
diff changeset
  4504
!
claus
parents: 138
diff changeset
  4505
claus
parents: 138
diff changeset
  4506
borderColor
claus
parents: 138
diff changeset
  4507
    "return my borderColor"
claus
parents: 138
diff changeset
  4508
claus
parents: 138
diff changeset
  4509
    ^ borderColor
claus
parents: 138
diff changeset
  4510
!
claus
parents: 138
diff changeset
  4511
claus
parents: 138
diff changeset
  4512
borderColor:aColor
claus
parents: 138
diff changeset
  4513
    "set my borderColor"
claus
parents: 138
diff changeset
  4514
claus
parents: 138
diff changeset
  4515
    (aColor ~~ borderColor) ifTrue:[
claus
parents: 138
diff changeset
  4516
	borderColor := aColor.
claus
parents: 138
diff changeset
  4517
	drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  4518
	    self setBorderColor
claus
parents: 138
diff changeset
  4519
	]
claus
parents: 138
diff changeset
  4520
    ]
claus
parents: 138
diff changeset
  4521
!
claus
parents: 138
diff changeset
  4522
claus
parents: 138
diff changeset
  4523
borderShape:aForm
claus
parents: 138
diff changeset
  4524
    "set the borderShape to aForm"
claus
parents: 138
diff changeset
  4525
claus
parents: 138
diff changeset
  4526
    borderShape := aForm.
135
claus
parents:
diff changeset
  4527
    drawableId notNil ifTrue:[
140
claus
parents: 138
diff changeset
  4528
	device setWindowBorderShape:(aForm id) in:drawableId
claus
parents: 138
diff changeset
  4529
    ]
claus
parents: 138
diff changeset
  4530
!
claus
parents: 138
diff changeset
  4531
claus
parents: 138
diff changeset
  4532
viewShape:aForm
claus
parents: 138
diff changeset
  4533
    "set the viewShape to aForm"
claus
parents: 138
diff changeset
  4534
claus
parents: 138
diff changeset
  4535
    viewShape := aForm.
claus
parents: 138
diff changeset
  4536
    drawableId notNil ifTrue:[
claus
parents: 138
diff changeset
  4537
	device setWindowShape:(aForm id) in:drawableId
135
claus
parents:
diff changeset
  4538
    ]
claus
parents:
diff changeset
  4539
!
claus
parents:
diff changeset
  4540
140
claus
parents: 138
diff changeset
  4541
level
claus
parents: 138
diff changeset
  4542
    "return my level relative to superView (3D)"
claus
parents: 138
diff changeset
  4543
claus
parents: 138
diff changeset
  4544
    ^ level
claus
parents: 138
diff changeset
  4545
!
claus
parents: 138
diff changeset
  4546
claus
parents: 138
diff changeset
  4547
lightColor:aColorOrImage
claus
parents: 138
diff changeset
  4548
    "set the color to be used for lighted edges (3D only)"
claus
parents: 138
diff changeset
  4549
claus
parents: 138
diff changeset
  4550
    lightColor := aColorOrImage
claus
parents: 138
diff changeset
  4551
!
claus
parents: 138
diff changeset
  4552
claus
parents: 138
diff changeset
  4553
shadowColor:aColorOrImage
claus
parents: 138
diff changeset
  4554
    "set the color to be used for shadowed edges (3D only)"
claus
parents: 138
diff changeset
  4555
claus
parents: 138
diff changeset
  4556
    shadowColor := aColorOrImage
claus
parents: 138
diff changeset
  4557
! !
claus
parents: 138
diff changeset
  4558
claus
parents: 138
diff changeset
  4559
!SimpleView methodsFor:'informing others of changes'!
claus
parents: 138
diff changeset
  4560
claus
parents: 138
diff changeset
  4561
contentsChanged
claus
parents: 138
diff changeset
  4562
    "this one is sent, whenever contents changes size -
claus
parents: 138
diff changeset
  4563
     tell dependents about the change (i.e. scrollers)."
claus
parents: 138
diff changeset
  4564
claus
parents: 138
diff changeset
  4565
    self changed:#sizeOfContents
claus
parents: 138
diff changeset
  4566
!
claus
parents: 138
diff changeset
  4567
claus
parents: 138
diff changeset
  4568
originChanged:delta
claus
parents: 138
diff changeset
  4569
    "this one is sent, after the origin of my contents has changed -
claus
parents: 138
diff changeset
  4570
     tell dependents (i.e. scrollers) about this"
claus
parents: 138
diff changeset
  4571
claus
parents: 138
diff changeset
  4572
    self changed:#originOfContents with:delta.
claus
parents: 138
diff changeset
  4573
"/   subViews notNil ifTrue:[
claus
parents: 138
diff changeset
  4574
"/        subViews do:[:aSubView |
claus
parents: 138
diff changeset
  4575
"/            aSubView pixelOrigin:((aSubView left @ aSubView top) - delta)
claus
parents: 138
diff changeset
  4576
"/        ]
claus
parents: 138
diff changeset
  4577
"/    ]
claus
parents: 138
diff changeset
  4578
!
claus
parents: 138
diff changeset
  4579
claus
parents: 138
diff changeset
  4580
originWillChange
claus
parents: 138
diff changeset
  4581
    "this one is sent, just before viewOrigin changes -
claus
parents: 138
diff changeset
  4582
     gives subclasses a chance to catch scrolls easily
claus
parents: 138
diff changeset
  4583
     (for example to hide cursor before scroll)"
claus
parents: 138
diff changeset
  4584
claus
parents: 138
diff changeset
  4585
    ^ self
135
claus
parents:
diff changeset
  4586
! !
claus
parents:
diff changeset
  4587
claus
parents:
diff changeset
  4588
!SimpleView methodsFor:'adding & removing components'!
claus
parents:
diff changeset
  4589
140
claus
parents: 138
diff changeset
  4590
addSubView:newView
claus
parents: 138
diff changeset
  4591
    "add a view to the collection of subviews"
claus
parents: 138
diff changeset
  4592
claus
parents: 138
diff changeset
  4593
    subViews isNil ifTrue:[
claus
parents: 138
diff changeset
  4594
	subViews := OrderedCollection with:newView
claus
parents: 138
diff changeset
  4595
    ] ifFalse:[
claus
parents: 138
diff changeset
  4596
	subViews add:newView.
claus
parents: 138
diff changeset
  4597
    ].
claus
parents: 138
diff changeset
  4598
    self setParentViewIn:newView.
claus
parents: 138
diff changeset
  4599
!
claus
parents: 138
diff changeset
  4600
135
claus
parents:
diff changeset
  4601
setParentViewIn:aView
claus
parents:
diff changeset
  4602
    "common code for addSubView* methods"
claus
parents:
diff changeset
  4603
claus
parents:
diff changeset
  4604
    aView superView:self.
claus
parents:
diff changeset
  4605
    (aView device ~~ device) ifTrue:[
145
claus
parents: 144
diff changeset
  4606
	'VIEW: warning subview (' errorPrint. aView class name errorPrint.
135
claus
parents:
diff changeset
  4607
	') has different device than me (' errorPrint.
145
claus
parents: 144
diff changeset
  4608
	self class name errorPrint. ').' errorPrintNL.
135
claus
parents:
diff changeset
  4609
	aView device:device
claus
parents:
diff changeset
  4610
    ]
claus
parents:
diff changeset
  4611
!
claus
parents:
diff changeset
  4612
claus
parents:
diff changeset
  4613
removeSubView:aView
claus
parents:
diff changeset
  4614
    "remove a view from the collection of subviews"
claus
parents:
diff changeset
  4615
claus
parents:
diff changeset
  4616
    subViews notNil ifTrue:[
claus
parents:
diff changeset
  4617
	subViews remove:aView ifAbsent:[nil].
claus
parents:
diff changeset
  4618
	(subViews size == 0) ifTrue:[
claus
parents:
diff changeset
  4619
	    subViews := nil
claus
parents:
diff changeset
  4620
	]
claus
parents:
diff changeset
  4621
    ]
claus
parents:
diff changeset
  4622
!
claus
parents:
diff changeset
  4623
140
claus
parents: 138
diff changeset
  4624
add:aComponent
claus
parents: 138
diff changeset
  4625
    "add a component (either a view or gadget) to the collection of
claus
parents: 138
diff changeset
  4626
     subComponents."
claus
parents: 138
diff changeset
  4627
claus
parents: 138
diff changeset
  4628
    self addComponent:aComponent
claus
parents: 138
diff changeset
  4629
!
claus
parents: 138
diff changeset
  4630
claus
parents: 138
diff changeset
  4631
addSubView:newView after:aView
claus
parents: 138
diff changeset
  4632
    "add a view to the collection of subviews after another view.
claus
parents: 138
diff changeset
  4633
     This makes sense, in Panels and other layout views, to enter a new
claus
parents: 138
diff changeset
  4634
     element at some defined place."
claus
parents: 138
diff changeset
  4635
claus
parents: 138
diff changeset
  4636
    subViews isNil ifTrue:[
claus
parents: 138
diff changeset
  4637
	subViews := OrderedCollection with:newView
claus
parents: 138
diff changeset
  4638
    ] ifFalse:[
claus
parents: 138
diff changeset
  4639
	aView isNil ifTrue:[
claus
parents: 138
diff changeset
  4640
	    subViews add:newView
claus
parents: 138
diff changeset
  4641
	] ifFalse:[
claus
parents: 138
diff changeset
  4642
	    subViews add:newView after:aView.
claus
parents: 138
diff changeset
  4643
	]
claus
parents: 138
diff changeset
  4644
    ].
claus
parents: 138
diff changeset
  4645
    self setParentViewIn:newView.
claus
parents: 138
diff changeset
  4646
!
claus
parents: 138
diff changeset
  4647
135
claus
parents:
diff changeset
  4648
addComponent:aComponent
claus
parents:
diff changeset
  4649
    "components (i.e. gadgets or lightweight views) are being prepared. 
claus
parents:
diff changeset
  4650
     Dont use this right now for non-views"
claus
parents:
diff changeset
  4651
claus
parents:
diff changeset
  4652
    aComponent isView ifTrue:[
claus
parents:
diff changeset
  4653
	self addSubView:aComponent
claus
parents:
diff changeset
  4654
    ] ifFalse:[
claus
parents:
diff changeset
  4655
	components isNil ifTrue:[
claus
parents:
diff changeset
  4656
	    components := OrderedCollection new
claus
parents:
diff changeset
  4657
	].
claus
parents:
diff changeset
  4658
	components add:aComponent.
claus
parents:
diff changeset
  4659
	aComponent setParentViewIn:self
claus
parents:
diff changeset
  4660
    ]
claus
parents:
diff changeset
  4661
!
claus
parents:
diff changeset
  4662
140
claus
parents: 138
diff changeset
  4663
add:aComponent in:aRectangleOrLayoutFrame 
claus
parents: 138
diff changeset
  4664
    "for ST-80 compatibility.
claus
parents: 138
diff changeset
  4665
     add a component in some frame; the argument may be either a rectangle
claus
parents: 138
diff changeset
  4666
     with relative coordinates, or an instance of LayoutFrame, specifying
claus
parents: 138
diff changeset
  4667
     both relative coordinates and the insets."
claus
parents: 138
diff changeset
  4668
151
claus
parents: 145
diff changeset
  4669
"/ old code:
154
claus
parents: 153
diff changeset
  4670
"/    |origin corner l|
claus
parents: 153
diff changeset
  4671
"/
151
claus
parents: 145
diff changeset
  4672
"/    origin := aRectangleOrLayoutFrame origin.
claus
parents: 145
diff changeset
  4673
"/    origin := origin x asFloat @ origin y asFloat.
claus
parents: 145
diff changeset
  4674
"/    corner := aRectangleOrLayoutFrame corner.
claus
parents: 145
diff changeset
  4675
"/    corner := corner x asFloat @ corner y asFloat.
claus
parents: 145
diff changeset
  4676
"/    aComponent origin:origin corner:corner.
claus
parents: 145
diff changeset
  4677
"/
claus
parents: 145
diff changeset
  4678
"/    (aRectangleOrLayoutFrame isMemberOf:Rectangle) ifFalse:[
claus
parents: 145
diff changeset
  4679
"/        aComponent leftInset:aRectangleOrLayoutFrame leftOffset.
claus
parents: 145
diff changeset
  4680
"/        aComponent rightInset:aRectangleOrLayoutFrame rightOffset negated.
claus
parents: 145
diff changeset
  4681
"/        aComponent topInset:aRectangleOrLayoutFrame topOffset.
claus
parents: 145
diff changeset
  4682
"/        aComponent bottomInset:aRectangleOrLayoutFrame bottomOffset negated.
claus
parents: 145
diff changeset
  4683
"/    ].
claus
parents: 145
diff changeset
  4684
claus
parents: 145
diff changeset
  4685
"/ new (being validated):
154
claus
parents: 153
diff changeset
  4686
claus
parents: 153
diff changeset
  4687
    |l|
claus
parents: 153
diff changeset
  4688
151
claus
parents: 145
diff changeset
  4689
    (aRectangleOrLayoutFrame isMemberOf:Rectangle) ifTrue:[
claus
parents: 145
diff changeset
  4690
	l := aRectangleOrLayoutFrame asLayout.
claus
parents: 145
diff changeset
  4691
    ] ifFalse:[
claus
parents: 145
diff changeset
  4692
	l := aRectangleOrLayoutFrame
140
claus
parents: 138
diff changeset
  4693
    ].
153
claus
parents: 151
diff changeset
  4694
claus
parents: 151
diff changeset
  4695
"/  will soon be replaced by:
claus
parents: 151
diff changeset
  4696
"/    aComponent layout:l.
154
claus
parents: 153
diff changeset
  4697
    aComponent geometryLayout:l.
claus
parents: 153
diff changeset
  4698
140
claus
parents: 138
diff changeset
  4699
    self addComponent:aComponent
claus
parents: 138
diff changeset
  4700
!
claus
parents: 138
diff changeset
  4701
claus
parents: 138
diff changeset
  4702
addSubView:newView before:aView
claus
parents: 138
diff changeset
  4703
    "add a view to the collection of subviews before another view.
claus
parents: 138
diff changeset
  4704
     This makes sense, in Panels and other layout views, to enter a new
claus
parents: 138
diff changeset
  4705
     element at some defined place."
claus
parents: 138
diff changeset
  4706
claus
parents: 138
diff changeset
  4707
    subViews isNil ifTrue:[
claus
parents: 138
diff changeset
  4708
	subViews := OrderedCollection with:newView
claus
parents: 138
diff changeset
  4709
    ] ifFalse:[
claus
parents: 138
diff changeset
  4710
	aView isNil ifTrue:[
claus
parents: 138
diff changeset
  4711
	    subViews addFirst:newView
claus
parents: 138
diff changeset
  4712
	] ifFalse:[
claus
parents: 138
diff changeset
  4713
	    subViews add:newView before:aView.
claus
parents: 138
diff changeset
  4714
	]
claus
parents: 138
diff changeset
  4715
    ].
claus
parents: 138
diff changeset
  4716
    self setParentViewIn:newView.
claus
parents: 138
diff changeset
  4717
!
claus
parents: 138
diff changeset
  4718
135
claus
parents:
diff changeset
  4719
component:aComponent
claus
parents:
diff changeset
  4720
    "components (i.e. gadgets or lightweight views) are being prepared. 
claus
parents:
diff changeset
  4721
     Dont use this right now for non-views"
claus
parents:
diff changeset
  4722
claus
parents:
diff changeset
  4723
    aComponent origin:0.0@0.0 corner:1.0@1.0.
claus
parents:
diff changeset
  4724
    aComponent isView ifTrue:[
claus
parents:
diff changeset
  4725
	self addSubView:aComponent
claus
parents:
diff changeset
  4726
    ] ifFalse:[
claus
parents:
diff changeset
  4727
	components := OrderedCollection with:aComponent.
claus
parents:
diff changeset
  4728
	aComponent setParentViewIn:self
claus
parents:
diff changeset
  4729
    ]
claus
parents:
diff changeset
  4730
!
claus
parents:
diff changeset
  4731
claus
parents:
diff changeset
  4732
removeComponent:aComponent
claus
parents:
diff changeset
  4733
    "components (i.e. gadgets or lightweight views) are being prepared. 
claus
parents:
diff changeset
  4734
     Dont use this right now for non-views"
claus
parents:
diff changeset
  4735
claus
parents:
diff changeset
  4736
    aComponent isView ifTrue:[
claus
parents:
diff changeset
  4737
	self removeSubView:aComponent
claus
parents:
diff changeset
  4738
    ] ifFalse:[
claus
parents:
diff changeset
  4739
	components isNil ifTrue:[^self].
claus
parents:
diff changeset
  4740
	components remove:aComponent ifAbsent:[].
claus
parents:
diff changeset
  4741
	aComponent parent:nil 
claus
parents:
diff changeset
  4742
    ]
claus
parents:
diff changeset
  4743
!
claus
parents:
diff changeset
  4744
claus
parents:
diff changeset
  4745
addSubView:aView in:bounds borderWidth:bw
claus
parents:
diff changeset
  4746
    "for ST-80 V2.x compatibility"
claus
parents:
diff changeset
  4747
claus
parents:
diff changeset
  4748
    aView borderWidth:bw.
claus
parents:
diff changeset
  4749
    self add:aView in:bounds.
claus
parents:
diff changeset
  4750
!
claus
parents:
diff changeset
  4751
claus
parents:
diff changeset
  4752
addSubView:aView viewport:aRectangle
claus
parents:
diff changeset
  4753
    "ST-80 V2.x compatibility:
claus
parents:
diff changeset
  4754
     Adds aView to the views list of subviews and uses the
claus
parents:
diff changeset
  4755
     existing subviews window and the new viewport to position it.
claus
parents:
diff changeset
  4756
     This method may be removed in future versions."
claus
parents:
diff changeset
  4757
claus
parents:
diff changeset
  4758
    self addSubView:aView.
claus
parents:
diff changeset
  4759
    aView viewport:aRectangle
claus
parents:
diff changeset
  4760
!
claus
parents:
diff changeset
  4761
claus
parents:
diff changeset
  4762
addSubView:aView window:aWindowRectangle viewport:aViewportRectangle
claus
parents:
diff changeset
  4763
    "ST-80 V2.x compatibility:
claus
parents:
diff changeset
  4764
     Adds aView to the views list of subviews and uses 
claus
parents:
diff changeset
  4765
     aWindowRectangle and aViewportRectangle to position it.
claus
parents:
diff changeset
  4766
     This method may be removed in future versions."
claus
parents:
diff changeset
  4767
claus
parents:
diff changeset
  4768
    self addSubView:aView.
claus
parents:
diff changeset
  4769
    aView window:aWindowRectangle viewport:aViewportRectangle
180
claus
parents: 176
diff changeset
  4770
!
claus
parents: 176
diff changeset
  4771
claus
parents: 176
diff changeset
  4772
destroySubViews
claus
parents: 176
diff changeset
  4773
    "remove all subviews"
claus
parents: 176
diff changeset
  4774
claus
parents: 176
diff changeset
  4775
    subViews notNil ifTrue:[
claus
parents: 176
diff changeset
  4776
	subViews copy do:[:aSubView |
claus
parents: 176
diff changeset
  4777
	    aSubView destroy.
claus
parents: 176
diff changeset
  4778
	]
claus
parents: 176
diff changeset
  4779
    ]
claus
parents: 176
diff changeset
  4780
claus
parents: 176
diff changeset
  4781
    "Modified: 5.9.1995 / 22:35:36 / claus"
135
claus
parents:
diff changeset
  4782
! !
claus
parents:
diff changeset
  4783
claus
parents:
diff changeset
  4784
!SimpleView methodsFor:'queries'!
claus
parents:
diff changeset
  4785
151
claus
parents: 145
diff changeset
  4786
preferredExtent
140
claus
parents: 138
diff changeset
  4787
    "return my preferred extent - this is the minimum size I would like to have.
claus
parents: 138
diff changeset
  4788
     The default here is the actual extent, the receiver currently has."
claus
parents: 138
diff changeset
  4789
claus
parents: 138
diff changeset
  4790
    "mhmh - if I have components, collect their
151
claus
parents: 145
diff changeset
  4791
     preferred bounds ..."
140
claus
parents: 138
diff changeset
  4792
claus
parents: 138
diff changeset
  4793
    |maxX maxY|
claus
parents: 138
diff changeset
  4794
claus
parents: 138
diff changeset
  4795
    subViews isNil ifTrue:[^ self extent].
claus
parents: 138
diff changeset
  4796
"/    ^ self extent.
claus
parents: 138
diff changeset
  4797
claus
parents: 138
diff changeset
  4798
    maxX := maxY := 0.
claus
parents: 138
diff changeset
  4799
    subViews notNil ifTrue:[
142
claus
parents: 140
diff changeset
  4800
	subViews do:[:aSubView |
claus
parents: 140
diff changeset
  4801
	    |org corn|
claus
parents: 140
diff changeset
  4802
claus
parents: 140
diff changeset
  4803
	    org := aSubView computeOrigin.
151
claus
parents: 145
diff changeset
  4804
	    corn := org + aSubView preferredExtent.
142
claus
parents: 140
diff changeset
  4805
	    maxX := maxX max:corn x.
claus
parents: 140
diff changeset
  4806
	    maxY := maxY max:corn y.
claus
parents: 140
diff changeset
  4807
	]
140
claus
parents: 138
diff changeset
  4808
    ].
claus
parents: 138
diff changeset
  4809
    ^ maxX @ maxY.
claus
parents: 138
diff changeset
  4810
!
claus
parents: 138
diff changeset
  4811
claus
parents: 138
diff changeset
  4812
buttonMotionEventPending
claus
parents: 138
diff changeset
  4813
    "return true, if a button motion event is pending.
claus
parents: 138
diff changeset
  4814
     Normally, you dont want to use this, since no polling is needed
claus
parents: 138
diff changeset
  4815
     (not even for mouse-tracking).
claus
parents: 138
diff changeset
  4816
     Dont use it, since it does not honor the windowGroup, but
claus
parents: 138
diff changeset
  4817
     goes directly to the device instead.
claus
parents: 138
diff changeset
  4818
     Actually, its a historical leftover"
claus
parents: 138
diff changeset
  4819
claus
parents: 138
diff changeset
  4820
    windowGroup notNil ifTrue:[
claus
parents: 138
diff changeset
  4821
	^ windowGroup sensor hasButtonMotionEventsFor:self
claus
parents: 138
diff changeset
  4822
    ].
claus
parents: 138
diff changeset
  4823
    ^ super buttonMotionEventPending
claus
parents: 138
diff changeset
  4824
!
claus
parents: 138
diff changeset
  4825
135
claus
parents:
diff changeset
  4826
isView
claus
parents:
diff changeset
  4827
    "return true, if the receiver is some kind of view;
claus
parents:
diff changeset
  4828
     true is returned here."
claus
parents:
diff changeset
  4829
claus
parents:
diff changeset
  4830
    ^ true
claus
parents:
diff changeset
  4831
!
claus
parents:
diff changeset
  4832
140
claus
parents: 138
diff changeset
  4833
hasFocus
142
claus
parents: 140
diff changeset
  4834
    "return true, if the receiver has the keyboard focus
claus
parents: 140
diff changeset
  4835
     (either via the focusView mechanism in the windowGroup,
claus
parents: 140
diff changeset
  4836
      or via delegation)"
claus
parents: 140
diff changeset
  4837
153
claus
parents: 151
diff changeset
  4838
    |focusView delegate|
claus
parents: 151
diff changeset
  4839
claus
parents: 151
diff changeset
  4840
    windowGroup isNil ifTrue:[^ false].
claus
parents: 151
diff changeset
  4841
claus
parents: 151
diff changeset
  4842
    (focusView := windowGroup focusView) == self ifTrue:[^ true].
142
claus
parents: 140
diff changeset
  4843
    focusView notNil ifTrue:[
claus
parents: 140
diff changeset
  4844
	"mhmh - is there a delegation to me ?"
153
claus
parents: 151
diff changeset
  4845
	(delegate := focusView delegate) notNil ifTrue:[
claus
parents: 151
diff changeset
  4846
	    delegate == self ifTrue:[^ true].
claus
parents: 151
diff changeset
  4847
	    ^ delegate delegatesTo:self
142
claus
parents: 140
diff changeset
  4848
	]
claus
parents: 140
diff changeset
  4849
    ].
claus
parents: 140
diff changeset
  4850
    ^ false
claus
parents: 140
diff changeset
  4851
!
claus
parents: 140
diff changeset
  4852
claus
parents: 140
diff changeset
  4853
delegatesTo:someone
claus
parents: 140
diff changeset
  4854
    "return true, if I delegate events to someone"
claus
parents: 140
diff changeset
  4855
claus
parents: 140
diff changeset
  4856
    delegate isNil ifTrue:[^ false].
claus
parents: 140
diff changeset
  4857
    ^ delegate delegatesTo:someone
140
claus
parents: 138
diff changeset
  4858
!
claus
parents: 138
diff changeset
  4859
claus
parents: 138
diff changeset
  4860
isSubViewOf:aView
claus
parents: 138
diff changeset
  4861
    "return true, if I am a subview of aView"
claus
parents: 138
diff changeset
  4862
claus
parents: 138
diff changeset
  4863
    aView == self isNil ifTrue:[^ true].
claus
parents: 138
diff changeset
  4864
    superView isNil ifTrue:[^ false].
claus
parents: 138
diff changeset
  4865
    superView == aView ifTrue:[^ true].
176
claus
parents: 175
diff changeset
  4866
    ^ superView isSubViewOf:aView
140
claus
parents: 138
diff changeset
  4867
!
claus
parents: 138
diff changeset
  4868
137
claus
parents: 136
diff changeset
  4869
canHandle:aKey from:aView
claus
parents: 136
diff changeset
  4870
    "return true, if I like to handle the key (from a keyPress event)
claus
parents: 136
diff changeset
  4871
     in aView.
claus
parents: 136
diff changeset
  4872
     OBSOLETE: do not use & depend on this method, it is a historic
claus
parents: 136
diff changeset
  4873
     leftOver and will be removed. Use the delegation mechanism for this."
claus
parents: 136
diff changeset
  4874
claus
parents: 136
diff changeset
  4875
    ^ self canHandle:aKey
claus
parents: 136
diff changeset
  4876
!
claus
parents: 136
diff changeset
  4877
135
claus
parents:
diff changeset
  4878
canHandle:aKey
137
claus
parents: 136
diff changeset
  4879
    "return true, if I like to handle the key (from a keyPress event).
claus
parents: 136
diff changeset
  4880
     OBSOLETE: do not use & depend on this method, it is a historic
claus
parents: 136
diff changeset
  4881
     leftOver and will be removed. Use the delegation mechanism for this."
claus
parents: 136
diff changeset
  4882
claus
parents: 136
diff changeset
  4883
    ^ false
135
claus
parents:
diff changeset
  4884
!
claus
parents:
diff changeset
  4885
claus
parents:
diff changeset
  4886
preferredBounds
claus
parents:
diff changeset
  4887
    "ST-80 compatibility."
claus
parents:
diff changeset
  4888
151
claus
parents: 145
diff changeset
  4889
    ^ 0@0 corner:self preferredExtent
140
claus
parents: 138
diff changeset
  4890
! !
claus
parents: 138
diff changeset
  4891
claus
parents: 138
diff changeset
  4892
!SimpleView methodsFor:'accessing-menus'!
claus
parents: 138
diff changeset
  4893
claus
parents: 138
diff changeset
  4894
yellowButtonMenu
claus
parents: 138
diff changeset
  4895
    "actually, this should be called 'middleButtonMenu'.
claus
parents: 138
diff changeset
  4896
     But for ST-80 compatibility ....
claus
parents: 138
diff changeset
  4897
     This method will vanish, once all views have controllers
claus
parents: 138
diff changeset
  4898
     associated with them; for now, dublicate some code also found in
claus
parents: 138
diff changeset
  4899
     controller."
claus
parents: 138
diff changeset
  4900
claus
parents: 138
diff changeset
  4901
    |sym menuHolder|
claus
parents: 138
diff changeset
  4902
claus
parents: 138
diff changeset
  4903
"/    middleButtonMenu notNil ifTrue:[
claus
parents: 138
diff changeset
  4904
"/        "/
claus
parents: 138
diff changeset
  4905
"/        "/ has been assigned a static middleButtonMenu
claus
parents: 138
diff changeset
  4906
"/        "/ (or a cached menu)
claus
parents: 138
diff changeset
  4907
"/        "/
claus
parents: 138
diff changeset
  4908
"/        ^ middleButtonMenu
claus
parents: 138
diff changeset
  4909
"/    ].
claus
parents: 138
diff changeset
  4910
claus
parents: 138
diff changeset
  4911
    menuHolder := self menuHolder.
claus
parents: 138
diff changeset
  4912
142
claus
parents: 140
diff changeset
  4913
    menuHolder notNil ifTrue:[
claus
parents: 140
diff changeset
  4914
	sym := self menuMessage.
claus
parents: 140
diff changeset
  4915
	sym notNil ifTrue:[
claus
parents: 140
diff changeset
  4916
	    "
claus
parents: 140
diff changeset
  4917
	     mhmh - for backward compatibility, try to ask
claus
parents: 140
diff changeset
  4918
	     the model first, then use the views menu.
claus
parents: 140
diff changeset
  4919
	    "
claus
parents: 140
diff changeset
  4920
	    (menuHolder respondsTo:sym) ifFalse:[
claus
parents: 140
diff changeset
  4921
		(self respondsTo:sym) ifTrue:[
claus
parents: 140
diff changeset
  4922
		    menuHolder := self
claus
parents: 140
diff changeset
  4923
		]
claus
parents: 140
diff changeset
  4924
	    ].
claus
parents: 140
diff changeset
  4925
	    "
claus
parents: 140
diff changeset
  4926
	     ask the menuHolder for the menu
claus
parents: 140
diff changeset
  4927
	    "
claus
parents: 140
diff changeset
  4928
	    ^ menuHolder perform:sym.
claus
parents: 140
diff changeset
  4929
	].
140
claus
parents: 138
diff changeset
  4930
    ].
142
claus
parents: 140
diff changeset
  4931
140
claus
parents: 138
diff changeset
  4932
    ^ nil
claus
parents: 138
diff changeset
  4933
!
claus
parents: 138
diff changeset
  4934
claus
parents: 138
diff changeset
  4935
menuHolder
claus
parents: 138
diff changeset
  4936
    "who has the menu ? 
claus
parents: 138
diff changeset
  4937
     By default, I have it."
claus
parents: 138
diff changeset
  4938
claus
parents: 138
diff changeset
  4939
    ^ self
claus
parents: 138
diff changeset
  4940
!
claus
parents: 138
diff changeset
  4941
claus
parents: 138
diff changeset
  4942
menuPerformer
claus
parents: 138
diff changeset
  4943
    "who should perform the menu actions ? 
claus
parents: 138
diff changeset
  4944
     By default, I do it."
claus
parents: 138
diff changeset
  4945
claus
parents: 138
diff changeset
  4946
    ^ self
claus
parents: 138
diff changeset
  4947
!
claus
parents: 138
diff changeset
  4948
claus
parents: 138
diff changeset
  4949
menuMessage
claus
parents: 138
diff changeset
  4950
    "Return the symbol sent to myself to aquire the menu"
claus
parents: 138
diff changeset
  4951
claus
parents: 138
diff changeset
  4952
    ^ #middleButtonMenu
claus
parents: 138
diff changeset
  4953
! !
claus
parents: 138
diff changeset
  4954
claus
parents: 138
diff changeset
  4955
!SimpleView methodsFor:'change & update'!
claus
parents: 138
diff changeset
  4956
claus
parents: 138
diff changeset
  4957
update:aspect with:aParameter from:changedObject
claus
parents: 138
diff changeset
  4958
    "an update request"
claus
parents: 138
diff changeset
  4959
claus
parents: 138
diff changeset
  4960
    aspect == #sizeOfView ifTrue:[
claus
parents: 138
diff changeset
  4961
	"one of the views we depend on changed its size"
claus
parents: 138
diff changeset
  4962
	^ self superViewChangedSize.
claus
parents: 138
diff changeset
  4963
    ].
claus
parents: 138
diff changeset
  4964
    ^super update:aspect with:aParameter from:changedObject
135
claus
parents:
diff changeset
  4965
! !
claus
parents:
diff changeset
  4966
claus
parents:
diff changeset
  4967
!SimpleView methodsFor:'enumerating subviews'!
claus
parents:
diff changeset
  4968
claus
parents:
diff changeset
  4969
allSubViewsDo:aBlock
claus
parents:
diff changeset
  4970
    "evaluate aBlock for all subviews (recursively)"
claus
parents:
diff changeset
  4971
claus
parents:
diff changeset
  4972
    (subViews isNil or:[subViews isEmpty]) ifFalse:[
claus
parents:
diff changeset
  4973
	subViews do:[:aSubview |
claus
parents:
diff changeset
  4974
	    aSubview withAllSubViewsDo:aBlock
claus
parents:
diff changeset
  4975
	]
claus
parents:
diff changeset
  4976
    ]
claus
parents:
diff changeset
  4977
!
claus
parents:
diff changeset
  4978
claus
parents:
diff changeset
  4979
withAllSubViewsDo:aBlock
claus
parents:
diff changeset
  4980
    "evaluate aBlock for the receiver and all subviews (recursively)"
claus
parents:
diff changeset
  4981
claus
parents:
diff changeset
  4982
    aBlock value:self.
claus
parents:
diff changeset
  4983
    self allSubViewsDo:aBlock
claus
parents:
diff changeset
  4984
! !
claus
parents:
diff changeset
  4985
claus
parents:
diff changeset
  4986
!SimpleView methodsFor:'scrolling-basic'!
claus
parents:
diff changeset
  4987
151
claus
parents: 145
diff changeset
  4988
scrollTo:newOrigin 
claus
parents: 145
diff changeset
  4989
    "change origin to have newOrigin be visible at the top-left.
claus
parents: 145
diff changeset
  4990
     The argument defines the integer device coordinates of the new top-left 
claus
parents: 145
diff changeset
  4991
     point."
claus
parents: 145
diff changeset
  4992
claus
parents: 145
diff changeset
  4993
    "due to historic reasons, the work is actually done by scrollUp/Down
claus
parents: 145
diff changeset
  4994
     scrollLeft/Right (those where implemented first).
claus
parents: 145
diff changeset
  4995
     This will be changed to do all work here, and call it from
claus
parents: 145
diff changeset
  4996
     the other scrolling methods."
claus
parents: 145
diff changeset
  4997
claus
parents: 145
diff changeset
  4998
    |dX   "{ Class:SmallInteger }"
claus
parents: 145
diff changeset
  4999
     dY   "{ Class:SmallInteger }"
claus
parents: 145
diff changeset
  5000
     m2   "{ Class:SmallInteger }"
claus
parents: 145
diff changeset
  5001
     orgX "{ Class:SmallInteger }"
claus
parents: 145
diff changeset
  5002
     orgY "{ Class:SmallInteger }" |
claus
parents: 145
diff changeset
  5003
claus
parents: 145
diff changeset
  5004
    transformation isNil ifTrue:[
claus
parents: 145
diff changeset
  5005
	orgY := orgX := 0
claus
parents: 145
diff changeset
  5006
    ] ifFalse:[
claus
parents: 145
diff changeset
  5007
	orgY := transformation translation y negated.
claus
parents: 145
diff changeset
  5008
	orgX := transformation translation x negated
claus
parents: 145
diff changeset
  5009
    ].
claus
parents: 145
diff changeset
  5010
    dX := newOrigin x - orgX.
claus
parents: 145
diff changeset
  5011
    dY := newOrigin y - orgY.
claus
parents: 145
diff changeset
  5012
    dX = 0 ifTrue:[
claus
parents: 145
diff changeset
  5013
	dY < 0 ifTrue:[
claus
parents: 145
diff changeset
  5014
	    ^ self scrollUp:(dY negated).
claus
parents: 145
diff changeset
  5015
	].
claus
parents: 145
diff changeset
  5016
	dY > 0 ifTrue:[
claus
parents: 145
diff changeset
  5017
	    ^ self scrollDown:dY.
claus
parents: 145
diff changeset
  5018
	].
claus
parents: 145
diff changeset
  5019
	^ self
claus
parents: 145
diff changeset
  5020
    ].
claus
parents: 145
diff changeset
  5021
    dY = 0 ifTrue:[
claus
parents: 145
diff changeset
  5022
	dX < 0 ifTrue:[
claus
parents: 145
diff changeset
  5023
	    ^ self scrollLeft:dX negated
claus
parents: 145
diff changeset
  5024
	].
claus
parents: 145
diff changeset
  5025
	dX > 0 ifTrue:[
claus
parents: 145
diff changeset
  5026
	    ^ self scrollRight:dX
claus
parents: 145
diff changeset
  5027
	].
claus
parents: 145
diff changeset
  5028
    ].
claus
parents: 145
diff changeset
  5029
claus
parents: 145
diff changeset
  5030
    self originWillChange.
claus
parents: 145
diff changeset
  5031
    self setViewOrigin:newOrigin.
claus
parents: 145
diff changeset
  5032
    shown ifTrue:[
claus
parents: 145
diff changeset
  5033
	m2 := margin * 2. "top & bottom margins"
claus
parents: 145
diff changeset
  5034
	self redrawDeviceX:margin y:margin
claus
parents: 145
diff changeset
  5035
		     width:(width - m2)
claus
parents: 145
diff changeset
  5036
		    height:(height - m2).
claus
parents: 145
diff changeset
  5037
    ].
claus
parents: 145
diff changeset
  5038
    self originChanged:(dX @ dY).
claus
parents: 145
diff changeset
  5039
!
claus
parents: 145
diff changeset
  5040
135
claus
parents:
diff changeset
  5041
scrollUp:nPixels
claus
parents:
diff changeset
  5042
    "change origin to scroll up (towards the origin) by some pixels"
claus
parents:
diff changeset
  5043
claus
parents:
diff changeset
  5044
    |count "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5045
     m2    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5046
     w     "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5047
     h     "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5048
     orgX
claus
parents:
diff changeset
  5049
     orgY  "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5050
     newOrigin|
claus
parents:
diff changeset
  5051
claus
parents:
diff changeset
  5052
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  5053
	orgY := orgX := 0
claus
parents:
diff changeset
  5054
    ] ifFalse:[
claus
parents:
diff changeset
  5055
	orgY := transformation translation y negated.
claus
parents:
diff changeset
  5056
	orgX := transformation translation x negated
claus
parents:
diff changeset
  5057
    ].
claus
parents:
diff changeset
  5058
claus
parents:
diff changeset
  5059
    count := nPixels.
claus
parents:
diff changeset
  5060
    (count > orgY) ifTrue:[
claus
parents:
diff changeset
  5061
	count := orgY
claus
parents:
diff changeset
  5062
    ].
claus
parents:
diff changeset
  5063
    (count <= 0) ifTrue:[^ self].
claus
parents:
diff changeset
  5064
claus
parents:
diff changeset
  5065
    self originWillChange.
claus
parents:
diff changeset
  5066
    newOrigin := orgX @ (orgY - count).
claus
parents:
diff changeset
  5067
claus
parents:
diff changeset
  5068
    shown ifFalse:[
claus
parents:
diff changeset
  5069
	self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5070
    ] ifTrue:[
claus
parents:
diff changeset
  5071
	m2 := margin * 2. "top & bottom margins"
claus
parents:
diff changeset
  5072
	(count >= self innerHeight) ifTrue:[
claus
parents:
diff changeset
  5073
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5074
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5075
			 width:(width - m2)
claus
parents:
diff changeset
  5076
			height:(height - m2).
claus
parents:
diff changeset
  5077
	] ifFalse:[
claus
parents:
diff changeset
  5078
	    h := height - m2 - count.
claus
parents:
diff changeset
  5079
	    w := width.
claus
parents:
diff changeset
  5080
	    self catchExpose.
claus
parents:
diff changeset
  5081
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5082
	    self copyFrom:self x:margin y:margin
claus
parents:
diff changeset
  5083
			     toX:margin y:(count + margin)
claus
parents:
diff changeset
  5084
			   width:w height:h.
claus
parents:
diff changeset
  5085
claus
parents:
diff changeset
  5086
	    self setInnerClip.
claus
parents:
diff changeset
  5087
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5088
			 width:(width - m2)
claus
parents:
diff changeset
  5089
			height:count.
claus
parents:
diff changeset
  5090
claus
parents:
diff changeset
  5091
	    self waitForExpose.
claus
parents:
diff changeset
  5092
	]
claus
parents:
diff changeset
  5093
    ].
claus
parents:
diff changeset
  5094
    self originChanged:(0 @ count negated).
claus
parents:
diff changeset
  5095
!
claus
parents:
diff changeset
  5096
claus
parents:
diff changeset
  5097
scrollDown:nPixels
claus
parents:
diff changeset
  5098
    "change origin to scroll down some pixels"
claus
parents:
diff changeset
  5099
claus
parents:
diff changeset
  5100
    |count "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5101
     m2    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5102
     w     "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5103
     h     "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5104
     hCont 
claus
parents:
diff changeset
  5105
     ih    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5106
     orgX  
claus
parents:
diff changeset
  5107
     orgY  "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5108
     newOrigin|
claus
parents:
diff changeset
  5109
claus
parents:
diff changeset
  5110
    hCont := self heightOfContents.
claus
parents:
diff changeset
  5111
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  5112
	orgY := orgX := 0
claus
parents:
diff changeset
  5113
    ] ifFalse:[
claus
parents:
diff changeset
  5114
	hCont := (transformation applyScaleY:hCont) rounded.
claus
parents:
diff changeset
  5115
	orgY := transformation translation y negated.
claus
parents:
diff changeset
  5116
	orgX := transformation translation x negated.
claus
parents:
diff changeset
  5117
    ].
claus
parents:
diff changeset
  5118
claus
parents:
diff changeset
  5119
    count := nPixels.
claus
parents:
diff changeset
  5120
    ih := self innerHeight.
claus
parents:
diff changeset
  5121
claus
parents:
diff changeset
  5122
    ((orgY + nPixels + ih) > hCont) ifTrue:[
claus
parents:
diff changeset
  5123
	count := hCont - orgY - ih
claus
parents:
diff changeset
  5124
    ].
claus
parents:
diff changeset
  5125
    (count <= 0) ifTrue:[^ self].
claus
parents:
diff changeset
  5126
claus
parents:
diff changeset
  5127
    self originWillChange.
claus
parents:
diff changeset
  5128
    newOrigin := orgX @ (orgY + count).
claus
parents:
diff changeset
  5129
    shown ifFalse:[
claus
parents:
diff changeset
  5130
	self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5131
    ] ifTrue:[
claus
parents:
diff changeset
  5132
	m2 := margin * 2.
claus
parents:
diff changeset
  5133
	(count >= ih) ifTrue:[
claus
parents:
diff changeset
  5134
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5135
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5136
			 width:(width - m2)
claus
parents:
diff changeset
  5137
			height:(height - m2).
claus
parents:
diff changeset
  5138
	] ifFalse:[
claus
parents:
diff changeset
  5139
	    h := height - m2 - count.
claus
parents:
diff changeset
  5140
	    w := self width.
claus
parents:
diff changeset
  5141
	    self catchExpose.
claus
parents:
diff changeset
  5142
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5143
	    self copyFrom:self x:margin y:(count + margin)
claus
parents:
diff changeset
  5144
			     toX:margin y:margin
claus
parents:
diff changeset
  5145
			   width:w 
claus
parents:
diff changeset
  5146
			  height:h.
claus
parents:
diff changeset
  5147
claus
parents:
diff changeset
  5148
	    self setInnerClip.
claus
parents:
diff changeset
  5149
	    self redrawDeviceX:margin y:(h + margin) 
claus
parents:
diff changeset
  5150
			 width:(width - m2) height:count.
claus
parents:
diff changeset
  5151
claus
parents:
diff changeset
  5152
	    self waitForExpose.
claus
parents:
diff changeset
  5153
	]
claus
parents:
diff changeset
  5154
    ].
claus
parents:
diff changeset
  5155
    self originChanged:(0 @ count).
claus
parents:
diff changeset
  5156
!
claus
parents:
diff changeset
  5157
claus
parents:
diff changeset
  5158
scrollLeft:nPixels
claus
parents:
diff changeset
  5159
    "change origin to scroll left some pixels"
claus
parents:
diff changeset
  5160
claus
parents:
diff changeset
  5161
    |count "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5162
     m2    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5163
     h     "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5164
     orgX orgY newOrigin|
claus
parents:
diff changeset
  5165
claus
parents:
diff changeset
  5166
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  5167
	orgY := orgX := 0
claus
parents:
diff changeset
  5168
    ] ifFalse:[
claus
parents:
diff changeset
  5169
	orgY := transformation translation y negated.
claus
parents:
diff changeset
  5170
	orgX := transformation translation x negated.
claus
parents:
diff changeset
  5171
    ].
claus
parents:
diff changeset
  5172
claus
parents:
diff changeset
  5173
    count := nPixels.
claus
parents:
diff changeset
  5174
    (count > orgX) ifTrue:[
claus
parents:
diff changeset
  5175
	count := orgX
claus
parents:
diff changeset
  5176
    ].
claus
parents:
diff changeset
  5177
    (count <= 0) ifTrue:[^ self].
claus
parents:
diff changeset
  5178
claus
parents:
diff changeset
  5179
    self originWillChange.
claus
parents:
diff changeset
  5180
    newOrigin := (orgX - count) @ orgY.
claus
parents:
diff changeset
  5181
claus
parents:
diff changeset
  5182
    shown ifFalse:[
claus
parents:
diff changeset
  5183
	self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5184
    ] ifTrue:[
claus
parents:
diff changeset
  5185
	m2 := margin * 2.
claus
parents:
diff changeset
  5186
	(count >= self innerWidth) ifTrue:[
claus
parents:
diff changeset
  5187
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5188
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5189
			 width:(width - m2)
claus
parents:
diff changeset
  5190
			height:(height - m2).
claus
parents:
diff changeset
  5191
	] ifFalse:[
claus
parents:
diff changeset
  5192
	    h := (height - m2).
claus
parents:
diff changeset
  5193
claus
parents:
diff changeset
  5194
	    self catchExpose.
claus
parents:
diff changeset
  5195
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5196
	    self copyFrom:self x:margin y:margin
claus
parents:
diff changeset
  5197
			     toX:(count + margin) y:margin
claus
parents:
diff changeset
  5198
			   width:(width - m2 - count) 
claus
parents:
diff changeset
  5199
			  height:h.
claus
parents:
diff changeset
  5200
claus
parents:
diff changeset
  5201
	    self setInnerClip.
claus
parents:
diff changeset
  5202
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5203
			 width:count height:(height - m2).
claus
parents:
diff changeset
  5204
claus
parents:
diff changeset
  5205
	    self waitForExpose.
claus
parents:
diff changeset
  5206
	]
claus
parents:
diff changeset
  5207
    ].
claus
parents:
diff changeset
  5208
    self originChanged:(count negated @ 0).
claus
parents:
diff changeset
  5209
!
claus
parents:
diff changeset
  5210
claus
parents:
diff changeset
  5211
scrollRight:nPixels
claus
parents:
diff changeset
  5212
    "change origin to scroll right some pixels"
claus
parents:
diff changeset
  5213
claus
parents:
diff changeset
  5214
    |count "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5215
     m2    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5216
     h     "{ Class:SmallInteger }" 
claus
parents:
diff changeset
  5217
     wCont 
claus
parents:
diff changeset
  5218
     iw    "{ Class:SmallInteger }"
claus
parents:
diff changeset
  5219
     orgX orgY newOrigin|
claus
parents:
diff changeset
  5220
claus
parents:
diff changeset
  5221
    wCont := self widthOfContents.
claus
parents:
diff changeset
  5222
    transformation isNil ifTrue:[
claus
parents:
diff changeset
  5223
	orgY := orgX := 0
claus
parents:
diff changeset
  5224
    ] ifFalse:[
claus
parents:
diff changeset
  5225
	wCont := (transformation applyScaleX:wCont) rounded.
claus
parents:
diff changeset
  5226
	orgY := transformation translation y negated.
claus
parents:
diff changeset
  5227
	orgX := transformation translation x negated.
claus
parents:
diff changeset
  5228
    ].
claus
parents:
diff changeset
  5229
claus
parents:
diff changeset
  5230
    count := nPixels.
claus
parents:
diff changeset
  5231
    iw := self innerWidth.
claus
parents:
diff changeset
  5232
claus
parents:
diff changeset
  5233
    ((orgX + nPixels + iw) > wCont) ifTrue:[
claus
parents:
diff changeset
  5234
	count := wCont - orgX - iw
claus
parents:
diff changeset
  5235
    ].
claus
parents:
diff changeset
  5236
    (count <= 0) ifTrue:[^ self].
claus
parents:
diff changeset
  5237
claus
parents:
diff changeset
  5238
    self originWillChange.
claus
parents:
diff changeset
  5239
    newOrigin := (orgX + count) @ orgY.
claus
parents:
diff changeset
  5240
claus
parents:
diff changeset
  5241
    shown ifFalse:[
claus
parents:
diff changeset
  5242
	self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5243
    ] ifTrue:[
claus
parents:
diff changeset
  5244
	m2 := margin * 2.
claus
parents:
diff changeset
  5245
	(count >= iw) ifTrue:[
claus
parents:
diff changeset
  5246
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5247
	    self redrawDeviceX:margin y:margin
claus
parents:
diff changeset
  5248
			 width:(width - m2)
claus
parents:
diff changeset
  5249
			height:(height - m2).
claus
parents:
diff changeset
  5250
	] ifFalse:[
claus
parents:
diff changeset
  5251
	    m2 := margin * 2.
claus
parents:
diff changeset
  5252
	    h := (height - m2).
claus
parents:
diff changeset
  5253
claus
parents:
diff changeset
  5254
	    self catchExpose.
claus
parents:
diff changeset
  5255
	    self setViewOrigin:newOrigin.
claus
parents:
diff changeset
  5256
	    self copyFrom:self x:(count + margin) y:margin
claus
parents:
diff changeset
  5257
			     toX:margin y:margin
claus
parents:
diff changeset
  5258
			   width:(width - m2 - count) 
claus
parents:
diff changeset
  5259
			  height:h.
claus
parents:
diff changeset
  5260
claus
parents:
diff changeset
  5261
	    self setInnerClip.
claus
parents:
diff changeset
  5262
	    self redrawDeviceX:(width - margin - count) y:margin 
claus
parents:
diff changeset
  5263
			 width:count height:(height - m2).
claus
parents:
diff changeset
  5264
claus
parents:
diff changeset
  5265
	    self waitForExpose.
claus
parents:
diff changeset
  5266
	].
claus
parents:
diff changeset
  5267
    ].
claus
parents:
diff changeset
  5268
    self originChanged:(count @ 0).
claus
parents:
diff changeset
  5269
! !
claus
parents:
diff changeset
  5270
claus
parents:
diff changeset
  5271
!SimpleView methodsFor:'scrolling'!
claus
parents:
diff changeset
  5272
claus
parents:
diff changeset
  5273
widthForScrollBetween:yStart and:yEnd 
claus
parents:
diff changeset
  5274
    "return the width in pixels for a scroll between yStart and yEnd
claus
parents:
diff changeset
  5275
     - return full width here since we do not know how wide contents is.
claus
parents:
diff changeset
  5276
     Views which only use part of their space (short lists, text) may redefine
claus
parents:
diff changeset
  5277
     this method and return the number of pixels that have to be scrolled.
claus
parents:
diff changeset
  5278
     On slow displays, this may make a difference; on fast ones you will probably
claus
parents:
diff changeset
  5279
     not notice any difference."
claus
parents:
diff changeset
  5280
claus
parents:
diff changeset
  5281
    ^ (width - margin - margin)
claus
parents:
diff changeset
  5282
!
claus
parents:
diff changeset
  5283
claus
parents:
diff changeset
  5284
verticalScrollStep
claus
parents:
diff changeset
  5285
    "return the amount to scroll when stepping up/down.
claus
parents:
diff changeset
  5286
     Subclasses may want to redefine this."
claus
parents:
diff changeset
  5287
claus
parents:
diff changeset
  5288
    ^ (device verticalPixelPerMillimeter * 20) asInteger
claus
parents:
diff changeset
  5289
!
claus
parents:
diff changeset
  5290
claus
parents:
diff changeset
  5291
scrollVerticalToPercent:percent
claus
parents:
diff changeset
  5292
    "scroll to a position given in percent of total"
claus
parents:
diff changeset
  5293
claus
parents:
diff changeset
  5294
    |hCont|
claus
parents:
diff changeset
  5295
claus
parents:
diff changeset
  5296
    hCont := self heightOfContents.
claus
parents:
diff changeset
  5297
    transformation notNil ifTrue:[
claus
parents:
diff changeset
  5298
	hCont := transformation applyScaleY:hCont.
claus
parents:
diff changeset
  5299
    ].
claus
parents:
diff changeset
  5300
    self scrollVerticalTo:
claus
parents:
diff changeset
  5301
	    ((((hCont * percent) / 100.0) + 0.5) asInteger)
claus
parents:
diff changeset
  5302
!
claus
parents:
diff changeset
  5303
claus
parents:
diff changeset
  5304
scrollVerticalTo:aPixelOffset
claus
parents:
diff changeset
  5305
    "change origin to make aPixelOffset be the top line"
claus
parents:
diff changeset
  5306
claus
parents:
diff changeset
  5307
    |orgY|
claus
parents:
diff changeset
  5308
claus
parents:
diff changeset
  5309
    orgY := self viewOrigin y.
claus
parents:
diff changeset
  5310
claus
parents:
diff changeset
  5311
    (aPixelOffset < orgY) ifTrue:[
claus
parents:
diff changeset
  5312
	self scrollUp:(orgY - aPixelOffset)
claus
parents:
diff changeset
  5313
    ] ifFalse:[
claus
parents:
diff changeset
  5314
	(aPixelOffset > orgY) ifTrue:[
claus
parents:
diff changeset
  5315
	    self scrollDown:(aPixelOffset - orgY)
claus
parents:
diff changeset
  5316
	]
claus
parents:
diff changeset
  5317
    ]
claus
parents:
diff changeset
  5318
!
claus
parents:
diff changeset
  5319
claus
parents:
diff changeset
  5320
scrollHorizontalToPercent:percent
claus
parents:
diff changeset
  5321
    "scroll to a position given in percent of total"
claus
parents:
diff changeset
  5322
claus
parents:
diff changeset
  5323
    |wCont|
claus
parents:
diff changeset
  5324
claus
parents:
diff changeset
  5325
    wCont := self widthOfContents.
claus
parents:
diff changeset
  5326
    transformation notNil ifTrue:[
claus
parents:
diff changeset
  5327
	wCont := transformation applyScaleX:wCont.
claus
parents:
diff changeset
  5328
    ].
claus
parents:
diff changeset
  5329
    self scrollHorizontalTo:
claus
parents:
diff changeset
  5330
	    ((((wCont * percent) / 100.0) + 0.5) asInteger)
claus
parents:
diff changeset
  5331
!
claus
parents:
diff changeset
  5332
140
claus
parents: 138
diff changeset
  5333
horizontalScrollStep
claus
parents: 138
diff changeset
  5334
    "return the amount to scroll when stepping left/right.
claus
parents: 138
diff changeset
  5335
     Subclasses may want to redefine this."
claus
parents: 138
diff changeset
  5336
claus
parents: 138
diff changeset
  5337
    ^ (device horizontalPixelPerMillimeter * 20) asInteger
claus
parents: 138
diff changeset
  5338
!
claus
parents: 138
diff changeset
  5339
135
claus
parents:
diff changeset
  5340
scrollHorizontalTo:aPixelOffset
claus
parents:
diff changeset
  5341
    "change origin to make aPixelOffset be the left col"
claus
parents:
diff changeset
  5342
claus
parents:
diff changeset
  5343
    |orgX|
claus
parents:
diff changeset
  5344
claus
parents:
diff changeset
  5345
    orgX := self viewOrigin x.
claus
parents:
diff changeset
  5346
claus
parents:
diff changeset
  5347
    (aPixelOffset < orgX) ifTrue:[
claus
parents:
diff changeset
  5348
	self scrollLeft:(orgX - aPixelOffset)
claus
parents:
diff changeset
  5349
    ] ifFalse:[
claus
parents:
diff changeset
  5350
	(aPixelOffset > orgX) ifTrue:[
claus
parents:
diff changeset
  5351
	    self scrollRight:(aPixelOffset - orgX)
claus
parents:
diff changeset
  5352
	]
claus
parents:
diff changeset
  5353
    ]
claus
parents:
diff changeset
  5354
!
claus
parents:
diff changeset
  5355
claus
parents:
diff changeset
  5356
scrollToTop
claus
parents:
diff changeset
  5357
    "move viewOrigin to top"
claus
parents:
diff changeset
  5358
claus
parents:
diff changeset
  5359
    self scrollVerticalTo:0
claus
parents:
diff changeset
  5360
!
claus
parents:
diff changeset
  5361
claus
parents:
diff changeset
  5362
scrollToTopLeft
claus
parents:
diff changeset
  5363
    "move viewOrigin to top/left"
claus
parents:
diff changeset
  5364
151
claus
parents: 145
diff changeset
  5365
    self scrollTo:(0 @ 0).
135
claus
parents:
diff changeset
  5366
!
claus
parents:
diff changeset
  5367
claus
parents:
diff changeset
  5368
scrollUp
claus
parents:
diff changeset
  5369
    "scroll up by some amount; this is called when the scrollbars
claus
parents:
diff changeset
  5370
     scroll-step up button is pressed."
claus
parents:
diff changeset
  5371
claus
parents:
diff changeset
  5372
    self scrollUp:(self verticalScrollStep)
claus
parents:
diff changeset
  5373
!
claus
parents:
diff changeset
  5374
claus
parents:
diff changeset
  5375
scrollDown
claus
parents:
diff changeset
  5376
    "scroll down by some amount; this is called when the scrollbars
claus
parents:
diff changeset
  5377
     scroll-step down button is pressed."
claus
parents:
diff changeset
  5378
claus
parents:
diff changeset
  5379
    self scrollDown:(self verticalScrollStep)
claus
parents:
diff changeset
  5380
!
claus
parents:
diff changeset
  5381
claus
parents:
diff changeset
  5382
scrollLeft
claus
parents:
diff changeset
  5383
    "scroll left by some amount; this is called when the scrollbars
claus
parents:
diff changeset
  5384
     scroll-step left button is pressed."
claus
parents:
diff changeset
  5385
claus
parents:
diff changeset
  5386
    self scrollLeft:(self horizontalScrollStep)
claus
parents:
diff changeset
  5387
!
claus
parents:
diff changeset
  5388
claus
parents:
diff changeset
  5389
scrollRight
claus
parents:
diff changeset
  5390
    "scroll right by some amount; this is called when the scrollbars
claus
parents:
diff changeset
  5391
     scroll-step right button is pressed."
claus
parents:
diff changeset
  5392
claus
parents:
diff changeset
  5393
    self scrollRight:(self horizontalScrollStep)
claus
parents:
diff changeset
  5394
! !
claus
parents:
diff changeset
  5395
claus
parents:
diff changeset
  5396
!SimpleView methodsFor:'user notification'!
claus
parents:
diff changeset
  5397
claus
parents:
diff changeset
  5398
warn:aString
claus
parents:
diff changeset
  5399
    "like Objects warn, but translates the string via the
claus
parents:
diff changeset
  5400
     resourcePack, thus giving a translated string automatically"
claus
parents:
diff changeset
  5401
151
claus
parents: 145
diff changeset
  5402
    super warn:(resources string:aString) withCRs
135
claus
parents:
diff changeset
  5403
!
claus
parents:
diff changeset
  5404
claus
parents:
diff changeset
  5405
warn:aString with:argument
claus
parents:
diff changeset
  5406
    "like Objects warn, but translates the string via the
claus
parents:
diff changeset
  5407
     resourcePack, thus giving a translated string automatically"
claus
parents:
diff changeset
  5408
151
claus
parents: 145
diff changeset
  5409
    super warn:(resources string:aString with:argument) withCRs
claus
parents: 145
diff changeset
  5410
!
claus
parents: 145
diff changeset
  5411
claus
parents: 145
diff changeset
  5412
warn:aString with:arg1 with:arg2
claus
parents: 145
diff changeset
  5413
    "like Objects warn, but translates the string via the
claus
parents: 145
diff changeset
  5414
     resourcePack, thus giving a translated string automatically"
claus
parents: 145
diff changeset
  5415
claus
parents: 145
diff changeset
  5416
    super warn:(resources string:aString with:arg1 with:arg2) withCRs
135
claus
parents:
diff changeset
  5417
! !
claus
parents:
diff changeset
  5418
claus
parents:
diff changeset
  5419
!SimpleView methodsFor:'cursor animation'!
claus
parents:
diff changeset
  5420
claus
parents:
diff changeset
  5421
showBusyWhile:aBlock
claus
parents:
diff changeset
  5422
    "evaluate some time consuming block, while doing this,
claus
parents:
diff changeset
  5423
     show a spinning wheel cursor"
claus
parents:
diff changeset
  5424
claus
parents:
diff changeset
  5425
    |ok bitmaps cursors mask process oldCursor|
claus
parents:
diff changeset
  5426
claus
parents:
diff changeset
  5427
    oldCursor := cursor.
claus
parents:
diff changeset
  5428
claus
parents:
diff changeset
  5429
    ok := true.
claus
parents:
diff changeset
  5430
    bitmaps := #('wheel1' 'wheel2' 'wheel3' 'wheel4') 
claus
parents:
diff changeset
  5431
	       collect:[:name |
claus
parents:
diff changeset
  5432
		   |f|
claus
parents:
diff changeset
  5433
claus
parents:
diff changeset
  5434
		   f := Form fromFile:(name , '.xbm').
claus
parents:
diff changeset
  5435
		   f isNil ifTrue:[
claus
parents:
diff changeset
  5436
			('no bitmap file: ' , name , '.xbm') errorPrintNL.
claus
parents:
diff changeset
  5437
			ok := false
claus
parents:
diff changeset
  5438
		   ].
claus
parents:
diff changeset
  5439
		   f
claus
parents:
diff changeset
  5440
	       ].
claus
parents:
diff changeset
  5441
claus
parents:
diff changeset
  5442
    mask := Form fromFile:'wheelm.xbm'.
claus
parents:
diff changeset
  5443
    mask isNil ifTrue:[
claus
parents:
diff changeset
  5444
	('no bitmap file: ' , mask , '.xbm') errorPrintNL.
claus
parents:
diff changeset
  5445
	ok := false
claus
parents:
diff changeset
  5446
    ].
claus
parents:
diff changeset
  5447
claus
parents:
diff changeset
  5448
    ok ifFalse:[
claus
parents:
diff changeset
  5449
	self cursor:Cursor wait.
claus
parents:
diff changeset
  5450
	aBlock valueNowOrOnUnwindDo:[
claus
parents:
diff changeset
  5451
	    self cursor:oldCursor
claus
parents:
diff changeset
  5452
	]
claus
parents:
diff changeset
  5453
    ] ifTrue:[
claus
parents:
diff changeset
  5454
	cursors := bitmaps collect:[:form | (Cursor sourceForm:form
claus
parents:
diff changeset
  5455
						      maskForm:mask
claus
parents:
diff changeset
  5456
							  hotX:8
claus
parents:
diff changeset
  5457
							  hotY:8) on:device].
claus
parents:
diff changeset
  5458
claus
parents:
diff changeset
  5459
	process := [
claus
parents:
diff changeset
  5460
		    (Delay forSeconds:0.25) wait.
claus
parents:
diff changeset
  5461
		    [true] whileTrue:[
claus
parents:
diff changeset
  5462
			cursors do:[:curs |
claus
parents:
diff changeset
  5463
			    self cursor:curs.
claus
parents:
diff changeset
  5464
			    (Delay forSeconds:0.05) wait
claus
parents:
diff changeset
  5465
			]
claus
parents:
diff changeset
  5466
		    ]
claus
parents:
diff changeset
  5467
		   ] fork.
claus
parents:
diff changeset
  5468
claus
parents:
diff changeset
  5469
	Processor activeProcess priority:7.
claus
parents:
diff changeset
  5470
	aBlock valueNowOrOnUnwindDo:[
claus
parents:
diff changeset
  5471
	    Processor activeProcess priority:8.
claus
parents:
diff changeset
  5472
	    process terminate.
claus
parents:
diff changeset
  5473
	    self cursor:oldCursor
claus
parents:
diff changeset
  5474
	]
claus
parents:
diff changeset
  5475
    ].
claus
parents:
diff changeset
  5476
claus
parents:
diff changeset
  5477
    "
claus
parents:
diff changeset
  5478
     View new realize showBusyWhile:[10 timesRepeat:[3000 factorial]]
claus
parents:
diff changeset
  5479
    "
claus
parents:
diff changeset
  5480
! !
claus
parents:
diff changeset
  5481
claus
parents:
diff changeset
  5482
SimpleView initialize!