Rectangle.st
author claus
Sat, 22 Jul 1995 21:25:26 +0200
changeset 362 4131e87e79ec
parent 360 90c3608b92a3
child 379 5b5a130ccd09
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
356
claus
parents: 329
diff changeset
    13
Geometric subclass:#Rectangle
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'left top width height'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    17
       category:'Graphics-Geometry'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
Rectangle comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    22
	      All Rights Reserved
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    23
362
claus
parents: 360
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/Rectangle.st,v 1.23 1995-07-22 19:24:16 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    27
!Rectangle class methodsFor:'documentation'!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    28
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    29
copyright
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    30
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    32
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    33
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    34
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    35
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    37
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    38
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    39
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    41
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    42
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    43
version
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    44
"
362
claus
parents: 360
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/Rectangle.st,v 1.23 1995-07-22 19:24:16 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    46
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    47
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    48
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    49
documentation
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    50
"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    51
    Rectangles represent a rectangular area in 2D space.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    52
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    53
    notice, my implementation does not use origin/corner as instance objects
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    54
    but left/top/width/height to save space and allocations. This means, that my
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    55
    Rectangles cannot be used to represent Rectangles in a higher than 2D
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    56
    space. (i.e. only valid if origin/corner are 2D Points)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    57
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    58
    (aside from that, you will not see any difference from the outside)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    59
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    60
    Instance variables:
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    61
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    62
	left           <Number>        the left coordinate (i.e origin x)
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    63
	top            <Number>        the top coordinate (i.e origin y)
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    64
	width          <Number>        the width of the rectangle
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    65
	height         <Number>        the height of the rectangle
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    66
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    67
    I am not certain, if implementing Rectangle different was a good idea - 
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    68
    subclasses may expect things to be different ...
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    69
    Therefore, this may change.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    70
"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    71
! !
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
    72
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
!Rectangle class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
origin:origin corner:corner
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
    "create and return a new Rectangle giving top-left and bottom-right points"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
    ^ (self basicNew) origin:origin corner:corner
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
origin:origin extent:extent
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
    "create and return a new Rectangle giving top-left point and extent point"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
%{  /* NOCONTEXT */
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
    85
    REGISTER OBJ newRect;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
    extern OBJ Point;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
    87
    OBJ t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
    88
    int spc;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
    /* short cut - rectangles are created so often ... */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
    if (_CanDoQuickNew(OHDR_SIZE + 4*sizeof(OBJ))) {
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    92
	if (self == Rectangle) {
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    93
	    if (__isPoint(origin) && __isPoint(extent)) {
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    94
		_qCheckedAlignedNew(newRect, OHDR_SIZE + 4*sizeof(OBJ));
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
    95
		_InstPtr(newRect)->o_class = Rectangle;
325
claus
parents: 308
diff changeset
    96
		spc = __qSpace(newRect);
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
    97
325
claus
parents: 308
diff changeset
    98
		t = _PointInstPtr(origin)->p_x;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
    99
		_InstPtr(newRect)->i_instvars[0] = t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   100
		__STORE_SPC(newRect, t, spc);
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   101
325
claus
parents: 308
diff changeset
   102
		t = _PointInstPtr(origin)->p_y;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   103
		_InstPtr(newRect)->i_instvars[1] = t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   104
		__STORE_SPC(newRect, t, spc);
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   105
325
claus
parents: 308
diff changeset
   106
		t = _PointInstPtr(extent)->p_x;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   107
		_InstPtr(newRect)->i_instvars[2] = t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   108
		__STORE_SPC(newRect, t, spc);
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   109
325
claus
parents: 308
diff changeset
   110
		t = _PointInstPtr(extent)->p_y;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   111
		_InstPtr(newRect)->i_instvars[3] = t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   112
		__STORE_SPC(newRect, t, spc);
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   113
		RETURN ( newRect );
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   114
	    }
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   115
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
    ^ (self basicNew) origin:origin extent:extent
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
left:left top:top width:w height:h
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
    "create and return a new Rectangle giving left and top coordinates
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
     and width, height"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
%{  /* NOCONTEXT */
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   127
    REGISTER OBJ newRect;
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   128
    OBJ t;
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   129
    int spc;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
    if (_CanDoQuickNew(OHDR_SIZE + 4*sizeof(OBJ))) {
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   132
	if (self == Rectangle) {
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   133
	/* short cut - rectangles are created so often ... */
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   134
	    _qCheckedAlignedNew(newRect, OHDR_SIZE + 4*sizeof(OBJ));
293
31df3850e98c *** empty log message ***
claus
parents: 259
diff changeset
   135
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   136
	    _InstPtr(newRect)->o_class = Rectangle;
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   137
	    _InstPtr(newRect)->i_instvars[0] = left;
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   138
	    _InstPtr(newRect)->i_instvars[1] = top;
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   139
	    _InstPtr(newRect)->i_instvars[2] = w;
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   140
	    _InstPtr(newRect)->i_instvars[3] = h;
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   141
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   142
	    if (! (__bothSmallInteger(left, top) && 
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   143
		   __bothSmallInteger(w, h))) {
325
claus
parents: 308
diff changeset
   144
		spc = __qSpace(newRect);
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   145
		__STORE_SPC(newRect, left, spc);
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   146
		__STORE_SPC(newRect, top, spc);
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   147
		__STORE_SPC(newRect, w, spc);
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   148
		__STORE_SPC(newRect, h, spc);
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   149
	    }
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   150
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   151
	    RETURN ( newRect );
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   152
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   156
    ^ (self basicNew) left:left top:top width:w height:h
a27a279701f8 Initial revision
claus
parents:
diff changeset
   157
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
left:left right:right top:top bottom:bottom
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
    "create and return a new Rectangle giving left, top, right and bottom coordinates"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
    ^ (self basicNew) left:left right:right top:top bottom:bottom
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
left:left top:top right:right bottom:bottom
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
    "create and return a new Rectangle giving left, top, right and bottom coordinates"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
    ^ (self basicNew) left:left top:top right:right bottom:bottom
32
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   169
!
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   170
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   171
fromUser
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   172
    "let user specify a rectangle on the screen, return it"
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   173
359
claus
parents: 356
diff changeset
   174
    ^ Screen current rectangleFromUser
32
ee1a621c696c *** empty log message ***
claus
parents: 13
diff changeset
   175
356
claus
parents: 329
diff changeset
   176
    "
claus
parents: 329
diff changeset
   177
     Rectangle fromUser     
claus
parents: 329
diff changeset
   178
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
!Rectangle methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
left:newLeft right:right top:newTop bottom:bottom
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   184
    "set the rectangle given left, top, right and bottom coordinates."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
    left := newLeft.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
    top := newTop.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
    width := right - left.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    height := bottom - top
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
left:newLeft top:newTop right:right bottom:bottom
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
    "set the rectangle given left, top, right and bottom coordinates"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
    left := newLeft.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
    top := newTop.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    width := right - left.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
    height := bottom - top
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
left:newLeft top:newTop width:newWidth height:newHeight
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
    "set the rectangle given left, top coordinates and width, height"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
    left := newLeft.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
    top := newTop.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
    width := newWidth.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
    height := newHeight
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
origin:aPoint
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   211
    "set the top-left origin. The corner remains unchanged."
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   212
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   213
    |newTop newLeft|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   215
    newTop := aPoint y.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   216
    newLeft := aPoint x.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   217
    height := height + (top - newTop).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   218
    width := width + (left - newLeft).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   219
    left := newLeft.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   220
    top := newTop
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
corner:aPoint
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
    "set the bottom-right corner"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
    width := aPoint x - left.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
    height := aPoint y - top
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
top:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
    "set the top edge"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    height := height + (top - aNumber).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
    top := aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
bottom:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
    "set the bottom edge"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
    height := aNumber - top
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   243
left:aNumber
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   244
    "set the left edge"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   245
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   246
    width := width + (left - aNumber).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   247
    left := aNumber
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   248
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   249
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   250
right:aNumber
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   251
    "set the right edge"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   252
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   253
    width := aNumber - left
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   254
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   255
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   256
topLeft:aPoint
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   257
    "Set the top and left edges.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   258
     The bottom right remains unchanged."
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   259
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   260
    |newTop|
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   261
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   262
    newTop := aPoint y.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   263
    height := height + (top - newTop).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   264
    top := newTop.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   265
    width := aPoint x - left
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   266
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   267
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   268
topRight:aPoint
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   269
    "Set the top and right edges. 
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   270
     The bottom left remains unchanged."
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   271
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   272
    |newTop|
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   273
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   274
    newTop := aPoint y.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   275
    height := height + (top - newTop).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   276
    top := newTop.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   277
    width := aPoint x - left
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   278
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   279
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
origin:origin corner:corner
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
    "set both origin and corner"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
    left := origin x.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
    top := origin y.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    width := corner x - left.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
    height := corner y - top
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
extent:aPoint
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
    "set the extent from the argument, aPoint with width taken from aPoint x
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
     and height taken from aPoint y"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
    width := aPoint x.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
    height := aPoint y
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
origin:origin extent:extent
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
    "set both origin and extent"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
    left := origin x.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
    top := origin y.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
    width := extent x.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
    height := extent y
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
origin
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
    "return the origin"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   309
    ^ left @ top
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
corner
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
    "return the corner"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   315
    ^ (left + width) @ (top + height)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   316
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   317
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   318
width
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   319
    "return the width of the rectangle"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   320
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   321
    ^ width
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   322
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   323
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   324
height
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   325
    "return the height of the rectangle"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   326
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   327
    ^ height
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
extent
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
    "return the extent"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   333
    ^ width @ height
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   334
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   335
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   336
left
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   337
    "return the x-coordinate of the top-left origin"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   338
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   339
    ^ left
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   340
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   341
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   342
leftCenter
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   343
    "return the left center point"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   344
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   345
    ^ left @ (top + (height // 2))
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   346
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   347
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   348
top
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   349
    "return the y-coordinate of the top-left"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   350
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   351
    ^ top
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
topLeft
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   355
    "return the top-left point - the same as origin"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   357
    ^ left @ top
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
topRight
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
    "return the top-right point"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   363
    ^ (left + width) @ top
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   365
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   366
topCenter
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   367
    "return the top center point"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   369
    ^ (left + (width // 2)) @ top
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
bottom
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
    "return the y coordinate of the bottom"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
    ^ (top + height)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   378
bottomLeft
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   379
    "return the bottom-left point"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   380
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   381
    ^ left @ (top + height)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   382
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   383
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   384
bottomRight
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   385
    "return the bottom-right point"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   386
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   387
    ^ (left + width) @ (top + height)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   388
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   389
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   390
bottomCenter
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   391
    "return the bottom center point"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   392
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   393
    ^ (left + (width // 2)) @ (top + height)
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   394
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   395
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
right
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
    "return the x coordinate of the right"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
    ^ (left + width)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   402
rightCenter
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   403
    "return the right center point"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   404
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   405
    ^ (left + width) @ (top + (height // 2))
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   406
!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   407
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
center
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
    "return the point in the center of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   411
    ^ (left + (width // 2)) @ (top + (height // 2))
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
area
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   415
    "return the area 
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   416
     - for screen Rectangles this is the number of pixels"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
    ^ width * height
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
!Rectangle methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
= aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
    "return true, if the argument aRectangle represents the same
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
     rectangle as the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
%{  /* NOCONTEXT */
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   428
    /*
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   429
     * handle the common case quickly
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   430
     */
329
claus
parents: 326
diff changeset
   431
    if (__isNonNilObject(aRectangle) 
claus
parents: 326
diff changeset
   432
     && __qClass(aRectangle) == Rectangle) {
325
claus
parents: 308
diff changeset
   433
	if ((_InstPtr(self)->i_instvars[0] == _InstPtr(aRectangle)->i_instvars[0])
claus
parents: 308
diff changeset
   434
	 && (_InstPtr(self)->i_instvars[1] == _InstPtr(aRectangle)->i_instvars[1])
claus
parents: 308
diff changeset
   435
	 && (_InstPtr(self)->i_instvars[2] == _InstPtr(aRectangle)->i_instvars[2])
claus
parents: 308
diff changeset
   436
	 && (_InstPtr(self)->i_instvars[3] == _InstPtr(aRectangle)->i_instvars[3])) {
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   437
	    RETURN ( true );
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   438
	}
325
claus
parents: 308
diff changeset
   439
	if (__bothSmallInteger(_InstPtr(self)->i_instvars[0], _InstPtr(aRectangle)->i_instvars[0])
claus
parents: 308
diff changeset
   440
	 && __bothSmallInteger(_InstPtr(self)->i_instvars[1], _InstPtr(aRectangle)->i_instvars[1])
claus
parents: 308
diff changeset
   441
	 && __bothSmallInteger(_InstPtr(self)->i_instvars[2], _InstPtr(aRectangle)->i_instvars[2])
claus
parents: 308
diff changeset
   442
	 && __bothSmallInteger(_InstPtr(self)->i_instvars[3], _InstPtr(aRectangle)->i_instvars[3])) {
claus
parents: 308
diff changeset
   443
	    RETURN ( false );
claus
parents: 308
diff changeset
   444
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
.
259
   448
    (aRectangle species ~~ self species) ifTrue:[^ false].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
    left = aRectangle left ifFalse:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
    top = aRectangle top ifFalse:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
    width = aRectangle width ifFalse:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
    height = aRectangle height ifFalse:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
    ^ true
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   455
!
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   456
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   457
hash
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   458
    "return an integer useful for hashing -
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   459
     redefined since = is redefined here"
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   460
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   461
    ^ ((left hash bitShift:16) bitXor:(top hash bitShift:16))
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   462
      + ((width hash) bitXor:(height hash))
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
356
claus
parents: 329
diff changeset
   465
!Rectangle methodsFor:'converting'!
claus
parents: 329
diff changeset
   466
claus
parents: 329
diff changeset
   467
asFractionalLayout
claus
parents: 329
diff changeset
   468
    "return a layoutFrame in which fractions (top, left, bottom, right)
claus
parents: 329
diff changeset
   469
     are taken from corresponding edges of the receiver.
claus
parents: 329
diff changeset
   470
     You have to make certain that those are in 0..1."
claus
parents: 329
diff changeset
   471
claus
parents: 329
diff changeset
   472
    |l|
claus
parents: 329
diff changeset
   473
claus
parents: 329
diff changeset
   474
    l := LayoutFrame new.
claus
parents: 329
diff changeset
   475
    l
claus
parents: 329
diff changeset
   476
	leftFraction:(self left);
claus
parents: 329
diff changeset
   477
	rightFraction:(self right);
claus
parents: 329
diff changeset
   478
	topFraction:(self top);
claus
parents: 329
diff changeset
   479
	bottomFraction:(self bottom).
claus
parents: 329
diff changeset
   480
    ^ l
claus
parents: 329
diff changeset
   481
claus
parents: 329
diff changeset
   482
    "
claus
parents: 329
diff changeset
   483
     (0.5@0.5 corner:0.75@0.75) asFractionalLayout 
claus
parents: 329
diff changeset
   484
     (0.5@0.5 corner:0.75@0.75) asOffsetLayout      
claus
parents: 329
diff changeset
   485
     (0.5@0.5 corner:0.75@0.75) asLayout        
claus
parents: 329
diff changeset
   486
    "
claus
parents: 329
diff changeset
   487
!
claus
parents: 329
diff changeset
   488
claus
parents: 329
diff changeset
   489
asOffsetLayout
claus
parents: 329
diff changeset
   490
    "return a layoutFrame in which offsets (top, left, bottom, right)
claus
parents: 329
diff changeset
   491
     are taken from corresponding edges of the receiver.
claus
parents: 329
diff changeset
   492
     You have to make certain that those are in 0..1."
claus
parents: 329
diff changeset
   493
claus
parents: 329
diff changeset
   494
    |l|
claus
parents: 329
diff changeset
   495
claus
parents: 329
diff changeset
   496
    l := LayoutFrame new.
claus
parents: 329
diff changeset
   497
    l
claus
parents: 329
diff changeset
   498
	leftOffset:(self left);
claus
parents: 329
diff changeset
   499
	rightFraction:0 offset:(self right);
claus
parents: 329
diff changeset
   500
	topOffset:(self top);
claus
parents: 329
diff changeset
   501
	bottomFraction:0 offset:(self bottom).
claus
parents: 329
diff changeset
   502
    ^ l
claus
parents: 329
diff changeset
   503
claus
parents: 329
diff changeset
   504
    "
claus
parents: 329
diff changeset
   505
     (0.5@0.5 corner:0.75@0.75) asFractionalLayout 
claus
parents: 329
diff changeset
   506
     (0.5@0.5 corner:0.75@0.75) asOffsetLayout      
claus
parents: 329
diff changeset
   507
     (0.5@0.5 corner:0.75@0.75) asLayout        
claus
parents: 329
diff changeset
   508
claus
parents: 329
diff changeset
   509
     (10@10 corner:20@20) asFractionalLayout 
claus
parents: 329
diff changeset
   510
     (10@10 corner:20@20) asOffsetLayout     
claus
parents: 329
diff changeset
   511
     (10@10 corner:20@20) asLayout             
claus
parents: 329
diff changeset
   512
    "
claus
parents: 329
diff changeset
   513
claus
parents: 329
diff changeset
   514
!
claus
parents: 329
diff changeset
   515
claus
parents: 329
diff changeset
   516
asLayout
claus
parents: 329
diff changeset
   517
    "return a layoutFrame in which offsets (top, left, bottom, right)
claus
parents: 329
diff changeset
   518
     are taken from corresponding edges of the receiver.
claus
parents: 329
diff changeset
   519
     If all values are between 0..1, a fractionalLayout is created,
claus
parents: 329
diff changeset
   520
     otherwise, an offsetLayout"
claus
parents: 329
diff changeset
   521
claus
parents: 329
diff changeset
   522
    |l left right top bot|
claus
parents: 329
diff changeset
   523
claus
parents: 329
diff changeset
   524
    l := LayoutFrame new.
claus
parents: 329
diff changeset
   525
    left := (self left).
claus
parents: 329
diff changeset
   526
    right := (self right).
claus
parents: 329
diff changeset
   527
    top := (self top).
claus
parents: 329
diff changeset
   528
    bot := (self bottom).
claus
parents: 329
diff changeset
   529
    ((left between:0 and:1)
claus
parents: 329
diff changeset
   530
    and:[(right between:0 and:1)
claus
parents: 329
diff changeset
   531
    and:[(top between:0 and:1)
claus
parents: 329
diff changeset
   532
    and:[(bot between:0 and:1)]]]) ifTrue:[
claus
parents: 329
diff changeset
   533
	l
claus
parents: 329
diff changeset
   534
	    leftFraction:left;
claus
parents: 329
diff changeset
   535
	    rightFraction:right;
claus
parents: 329
diff changeset
   536
	    topFraction:top;
claus
parents: 329
diff changeset
   537
	    bottomFraction:bot.
claus
parents: 329
diff changeset
   538
    ] ifFalse:[
claus
parents: 329
diff changeset
   539
	l
claus
parents: 329
diff changeset
   540
	    leftOffset:left;
claus
parents: 329
diff changeset
   541
	    rightFraction:0 offset:right;
claus
parents: 329
diff changeset
   542
	    topOffset:top;
claus
parents: 329
diff changeset
   543
	    bottomFraction:0 offset:bot.
claus
parents: 329
diff changeset
   544
    ].
claus
parents: 329
diff changeset
   545
    ^ l
claus
parents: 329
diff changeset
   546
claus
parents: 329
diff changeset
   547
    "
claus
parents: 329
diff changeset
   548
     (0.5@0.5 corner:0.75@0.75) asFractionalLayout  
claus
parents: 329
diff changeset
   549
     (0.5@0.5 corner:0.75@0.75) asOffsetLayout       
claus
parents: 329
diff changeset
   550
     (0.5@0.5 corner:0.75@0.75) asLayout              
claus
parents: 329
diff changeset
   551
     (0@0 corner:1@1) asLayout                      
claus
parents: 329
diff changeset
   552
     (0@0 corner:1@1) asFractionalLayout             
claus
parents: 329
diff changeset
   553
     (0@0 corner:1@1) asOffsetLayout                 
claus
parents: 329
diff changeset
   554
    "
claus
parents: 329
diff changeset
   555
!
claus
parents: 329
diff changeset
   556
claus
parents: 329
diff changeset
   557
asPointArray
claus
parents: 329
diff changeset
   558
    "return an array containing my corners (clockwise) and
claus
parents: 329
diff changeset
   559
     the origin again as 5th element. Can be used to convert
claus
parents: 329
diff changeset
   560
     a rectangle into a polygon."
claus
parents: 329
diff changeset
   561
claus
parents: 329
diff changeset
   562
    |org|
claus
parents: 329
diff changeset
   563
claus
parents: 329
diff changeset
   564
    ^ Array with:(org := self origin)
claus
parents: 329
diff changeset
   565
	    with:self topRight
claus
parents: 329
diff changeset
   566
	    with:self corner
claus
parents: 329
diff changeset
   567
	    with:self bottomLeft
claus
parents: 329
diff changeset
   568
	    with:org 
claus
parents: 329
diff changeset
   569
claus
parents: 329
diff changeset
   570
    "
claus
parents: 329
diff changeset
   571
     (10@10 corner:100@100) asPointArray 
claus
parents: 329
diff changeset
   572
    "
claus
parents: 329
diff changeset
   573
!
claus
parents: 329
diff changeset
   574
claus
parents: 329
diff changeset
   575
rectangleRelativeTo:aRectangle preferred:prefRect
claus
parents: 329
diff changeset
   576
    "compute a displayRectangle, treating the receiver like a
claus
parents: 329
diff changeset
   577
     layoutorigin. This allows point to be used interchangable with
claus
parents: 329
diff changeset
   578
     LayoutOrigins."
claus
parents: 329
diff changeset
   579
claus
parents: 329
diff changeset
   580
    ^ (self asLayout) rectangleRelativeTo:aRectangle preferred:prefRect
claus
parents: 329
diff changeset
   581
claus
parents: 329
diff changeset
   582
    "
claus
parents: 329
diff changeset
   583
     (10@20 corner:20@30) rectangleRelativeTo:(0@0 corner:100@100) preferred:(0@0 corner:50@50) 
claus
parents: 329
diff changeset
   584
claus
parents: 329
diff changeset
   585
     (0.5@0.5) rectangleRelativeTo:(0@0 corner:100@100) preferred:(0@0 corner:50@50) 
claus
parents: 329
diff changeset
   586
    "
claus
parents: 329
diff changeset
   587
! !
claus
parents: 329
diff changeset
   588
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   589
!Rectangle methodsFor:'queries'!
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   590
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   591
isRectangle
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   592
    "return true, if the receiver is some kind of rectangle"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   593
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   594
    ^ true
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   595
! !
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   596
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
!Rectangle methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   598
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
containsPoint:aPoint
a27a279701f8 Initial revision
claus
parents:
diff changeset
   600
    "return true, if the argument, aPoint is contained in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   601
a27a279701f8 Initial revision
claus
parents:
diff changeset
   602
    |px py|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   603
a27a279701f8 Initial revision
claus
parents:
diff changeset
   604
    px := aPoint x.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   605
    (px < left)           ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
    (px > (left + width)) ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
    py := aPoint y.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
    (py < top)            ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
    (py > (top + height)) ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
208
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   613
containsPointX:x y:y
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   614
    "return true, if the point defined by x@y is contained in the receiver.
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   615
     This is the same as containsPoint:, but can be used if the coordinates
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   616
     are already available as separate numbers to avoid useless creation of a
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   617
     temporary point."
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   618
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   619
    (x < left)           ifTrue:[^ false].
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   620
    (x > (left + width)) ifTrue:[^ false].
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   621
    (y < top)            ifTrue:[^ false].
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   622
    (y > (top + height)) ifTrue:[^ false].
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   623
    ^ true
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   624
!
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   625
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
intersects:aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
    "return true, if the intersection between the argument, aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
     and the receiver is not empty"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
    |b r|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
a27a279701f8 Initial revision
claus
parents:
diff changeset
   632
    (aRectangle right)  < left ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   633
    (aRectangle bottom) < top  ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
    r := left + width.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
    (aRectangle left)   > r    ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   636
    b := top + height.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   637
    (aRectangle top)    > b    ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
contains:aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    "return true, if the argument, aRectangle is equal to or
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
     is contained fully within the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
    (left <= aRectangle left) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
      ((left + width) >= aRectangle right) ifTrue:[
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   647
	(top <= aRectangle top) ifTrue:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   648
	  ((top + height) >= aRectangle bottom) ifTrue:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   649
	    ^ true
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   650
	  ]
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   651
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
      ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
isContainedIn:aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
    "return true, if the receiver is fully contained within 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
     the argument, aRectangle"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
    (aRectangle left <= left) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   662
      (aRectangle right >= (left + width)) ifTrue:[
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   663
	(aRectangle top <= top) ifTrue:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   664
	  (aRectangle bottom >= (top + height)) ifTrue:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   665
	    ^ true
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   666
	  ]
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   667
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
      ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   672
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   673
!Rectangle methodsFor:'destructive rectangle operations'!
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   674
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   675
translateBy:amount
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   676
    "translate (i.e. move) the receiver rectangle 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   677
     by amount, a Point or Number.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   678
     This is destructive (modifies the receiver, not a copy) and 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   679
     should only be used if you know, that you are the exclusive owner 
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   680
     of the receiver. (use translatedBy if in doubt)"
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   681
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   682
    |amountPoint|
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   683
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   684
    (amount isMemberOf:Point) ifTrue:[  "type hint to stc"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   685
	left := left + amount x.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   686
	top := top + amount y
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   687
    ] ifFalse:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   688
	amountPoint := amount asPoint.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   689
	left := left + amountPoint x.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   690
	top := top + amountPoint y
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   691
    ]
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   692
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   693
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   694
     (Rectangle origin:10@10 corner:50@50) translateBy:10
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   695
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   696
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   697
    "its destructive:"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   698
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   699
     |r1 r2|
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   700
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   701
     r1 := Rectangle origin:10@10 corner:50@50.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   702
     r2 := r1 translateBy:10.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   703
     r1 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   704
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   705
!
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   706
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   707
scaleBy:scale
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   708
    "scale the receiver rectangle by scale (a Number or Point).
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   709
     This is destructive (modifies the receiver, not a copy) and 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   710
     should only be used if you know, that you are the exclusive owner 
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   711
     of the receiver. (use scaledBy if in doubt)"
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   712
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   713
    |scalePoint sx sy|
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   714
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   715
    (scale isMemberOf:Point) ifTrue:[  "type hint to stc"
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   716
	sx := scale x.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   717
	sy := scale y
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   718
    ] ifFalse:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   719
	scalePoint := scale asPoint.
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   720
	sx := scalePoint x.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   721
	sy := scalePoint y
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   722
    ].
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   723
    width := width * sx.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   724
    height := height * sy.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   725
    left := left * sx.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   726
    top := top * sy
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   727
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   728
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   729
     (Rectangle origin:10@10 corner:50@50) scaleBy:2 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   730
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   731
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   732
    "its destructive:"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   733
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   734
     |r1 r2|
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   735
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   736
     r1 := Rectangle origin:10@10 corner:50@50.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   737
     r2 := r1 scaleBy:2.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   738
     r1 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   739
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   740
!
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   741
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   742
moveTo:aPoint
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   743
    "destructively translate the rectangle to have its origin at aPoint."
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   744
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   745
    |diff|
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   746
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   747
    diff := aPoint - self origin.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   748
    self origin:aPoint corner:self corner + diff
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   749
!
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   750
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   751
moveBy:aPoint
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   752
    "destructively translate the rectangle by some distance.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   753
     sorry for the name inconsistency - but GNU-ST named it that way"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   754
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   755
    left := left + aPoint x.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   756
    top := top + aPoint y
356
claus
parents: 329
diff changeset
   757
!
claus
parents: 329
diff changeset
   758
claus
parents: 329
diff changeset
   759
expandBy:delta
claus
parents: 329
diff changeset
   760
    "destructively expanded the receiver in all directions
claus
parents: 329
diff changeset
   761
     by amount, a Point, Rectangle or Number.
claus
parents: 329
diff changeset
   762
     Warning: this is a destructive operation, modifying the receiver
claus
parents: 329
diff changeset
   763
     NOT returning a copy. You have to be certain to be the exclusive
claus
parents: 329
diff changeset
   764
     owner of the receiver to avoid side effects. See also: #expandedBy:"
claus
parents: 329
diff changeset
   765
claus
parents: 329
diff changeset
   766
    |amountPoint deltaLeft deltaTop deltaWidth deltaHeight|
claus
parents: 329
diff changeset
   767
claus
parents: 329
diff changeset
   768
    delta isNumber ifTrue:[
claus
parents: 329
diff changeset
   769
	deltaLeft := deltaTop := delta.
claus
parents: 329
diff changeset
   770
	deltaWidth := deltaHeight := delta * 2.
claus
parents: 329
diff changeset
   771
    ] ifFalse:[
claus
parents: 329
diff changeset
   772
	delta isRectangle ifTrue:[
claus
parents: 329
diff changeset
   773
	    deltaLeft := delta left.
claus
parents: 329
diff changeset
   774
	    deltaTop := delta top.
claus
parents: 329
diff changeset
   775
	    deltaWidth := deltaLeft + delta right.
claus
parents: 329
diff changeset
   776
	    deltaHeight := deltaTop + delta bottom
claus
parents: 329
diff changeset
   777
	] ifFalse:[
claus
parents: 329
diff changeset
   778
	    amountPoint := delta asPoint.
claus
parents: 329
diff changeset
   779
	    deltaLeft := amountPoint x.
claus
parents: 329
diff changeset
   780
	    deltaTop := amountPoint y.
claus
parents: 329
diff changeset
   781
	    deltaWidth := deltaLeft * 2.
claus
parents: 329
diff changeset
   782
	    deltaHeight := deltaTop * 2.
claus
parents: 329
diff changeset
   783
	]
claus
parents: 329
diff changeset
   784
    ].
claus
parents: 329
diff changeset
   785
claus
parents: 329
diff changeset
   786
    left := (left - deltaLeft).
claus
parents: 329
diff changeset
   787
    top := (top - deltaTop).
claus
parents: 329
diff changeset
   788
    width := (width + deltaWidth).
claus
parents: 329
diff changeset
   789
    height := (height + deltaHeight).
claus
parents: 329
diff changeset
   790
claus
parents: 329
diff changeset
   791
    "
claus
parents: 329
diff changeset
   792
     |r|
claus
parents: 329
diff changeset
   793
     r := Rectangle origin:10@10 corner:100@100.
claus
parents: 329
diff changeset
   794
     r expandBy:5.
claus
parents: 329
diff changeset
   795
claus
parents: 329
diff changeset
   796
     r := Rectangle origin:10@10 corner:100@100.
claus
parents: 329
diff changeset
   797
     r expandBy:(5 @ 0).
claus
parents: 329
diff changeset
   798
claus
parents: 329
diff changeset
   799
     r := Rectangle origin:10@10 corner:100@100.
claus
parents: 329
diff changeset
   800
     r expandBy:(10 @ 10).
claus
parents: 329
diff changeset
   801
claus
parents: 329
diff changeset
   802
     r := Rectangle origin:10@10 corner:100@100.
claus
parents: 329
diff changeset
   803
     r expandBy:( 10@10 corner:20@20 )
claus
parents: 329
diff changeset
   804
    "
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   805
! !
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   806
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   807
!Rectangle methodsFor:'rectangle operations'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   808
a27a279701f8 Initial revision
claus
parents:
diff changeset
   809
intersect:aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   810
    "return a new rectangle covering the intersection of the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   811
     and the argument, aRectangle.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   812
     the rectangles must intersect for a valid return"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   813
a27a279701f8 Initial revision
claus
parents:
diff changeset
   814
    ^ Rectangle left:(left max:(aRectangle left))
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   815
	       right:((left + width) min:(aRectangle right))
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   816
		 top:(top max:(aRectangle top))
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   817
	      bottom:((top + height) min:(aRectangle bottom))
208
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   818
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   819
    "
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   820
     |r1 r2|
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   821
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   822
     r1 := Rectangle origin:10@10 corner:100@100.
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   823
     r2 := Rectangle origin:50@50 corner:150@75.
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   824
     r1 intersect:r2
43741b9068a0 added containspoint
claus
parents: 186
diff changeset
   825
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   826
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   827
a27a279701f8 Initial revision
claus
parents:
diff changeset
   828
merge:aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
   829
    "return a new rectangle covering both the receiver 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   830
     and the argument, aRectangle"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   831
a27a279701f8 Initial revision
claus
parents:
diff changeset
   832
    ^ Rectangle left:(left min:(aRectangle left))
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   833
	       right:((left + width) max:(aRectangle right))
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   834
		 top:(top min:(aRectangle top))
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   835
	      bottom:((top + height) max:(aRectangle bottom))
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   836
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   837
a27a279701f8 Initial revision
claus
parents:
diff changeset
   838
+ aPoint
356
claus
parents: 329
diff changeset
   839
    "return a new rectangle with same extent as receiver but
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   840
     origin translated by the argument, aPoint"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   841
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   842
    |amountPoint|
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   843
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   844
    amountPoint := aPoint asPoint.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   845
    ^ Rectangle left:(left + amountPoint x)
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   846
		 top:(top + amountPoint y)
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   847
	       width:width
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   848
	      height:height
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   849
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   850
a27a279701f8 Initial revision
claus
parents:
diff changeset
   851
rounded
356
claus
parents: 329
diff changeset
   852
    "return a copy of the receiver with rounded coordinates"
claus
parents: 329
diff changeset
   853
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   854
    ^ Rectangle left:(left rounded) 
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   855
		 top:(top rounded)
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   856
	       width:(width rounded) 
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   857
	      height:(height rounded)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   858
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   859
356
claus
parents: 329
diff changeset
   860
expandedBy:delta
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   861
    "return a new rectangle which is expanded in all directions
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   862
     by amount, a Point, Rectangle or Number"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   863
356
claus
parents: 329
diff changeset
   864
    ^ self copy expandBy:delta
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   865
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   866
    "
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   867
     |r|
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   868
     r := Rectangle origin:10@10 corner:100@100.
356
claus
parents: 329
diff changeset
   869
     r expandedBy:5.   
claus
parents: 329
diff changeset
   870
     r expandedBy:(5 @ 0).  
claus
parents: 329
diff changeset
   871
     r expandedBy:(10 @ 10).  
claus
parents: 329
diff changeset
   872
     r expandedBy:( 10@10 corner:20@20 )  
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   873
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   875
a27a279701f8 Initial revision
claus
parents:
diff changeset
   876
insetBy: delta
a27a279701f8 Initial revision
claus
parents:
diff changeset
   877
    "return a new rectangle which is inset in all directions
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   878
     by delta, a Point, Rectangle or Number"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   879
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   880
    |amountPoint deltaLeft deltaTop deltaWidth deltaHeight|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   881
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   882
    delta isNumber ifTrue:[
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   883
	deltaLeft := deltaTop := delta.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   884
	deltaWidth := deltaHeight := delta * 2.
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   885
    ] ifFalse:[
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   886
	delta isRectangle ifTrue:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   887
	    deltaLeft := delta left.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   888
	    deltaTop := delta top.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   889
	    deltaWidth := deltaLeft + delta right.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   890
	    deltaHeight := deltaTop + delta bottom
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   891
	] ifFalse:[
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   892
	    amountPoint := delta asPoint.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   893
	    deltaLeft := amountPoint x.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   894
	    deltaTop := amountPoint y.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   895
	    deltaWidth := deltaLeft * 2.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   896
	    deltaHeight := deltaTop * 2.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   897
	]
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   898
    ].
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   899
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   900
    ^ Rectangle left:(left + deltaLeft)
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   901
		 top:(top + deltaTop)
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   902
	       width:(width - deltaWidth)
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   903
	      height:(height - deltaHeight)
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   904
    "
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   905
     |r|
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   906
     r := Rectangle origin:10@10 corner:100@100.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   907
     r insetBy:5.
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   908
     r insetBy:(5 @ 0).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   909
     r insetBy:(10 @ 10).
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   910
     r insetBy:( 10@10 corner:20@20 )
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
   911
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   912
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   913
362
claus
parents: 360
diff changeset
   914
insetOriginBy:originDelta cornerBy:cornerDelta
claus
parents: 360
diff changeset
   915
    "return a new rectangle which is inset by originDelta 
claus
parents: 360
diff changeset
   916
     and cornerDelta; both may be instances of Point or Number"
claus
parents: 360
diff changeset
   917
claus
parents: 360
diff changeset
   918
    |amountPoint deltaLeft deltaTop deltaWidth deltaHeight|
claus
parents: 360
diff changeset
   919
claus
parents: 360
diff changeset
   920
    ^ Rectangle
claus
parents: 360
diff changeset
   921
	origin:(left @ top) + originDelta asPoint
claus
parents: 360
diff changeset
   922
	corner:(self corner - cornerDelta asPoint)
claus
parents: 360
diff changeset
   923
    "
claus
parents: 360
diff changeset
   924
     |r|
claus
parents: 360
diff changeset
   925
     r := Rectangle origin:10@10 corner:100@100.
claus
parents: 360
diff changeset
   926
     r insetOriginBy:5 cornerBy:10. 
claus
parents: 360
diff changeset
   927
     r insetOriginBy:10@5 cornerBy:10.
claus
parents: 360
diff changeset
   928
     r insetOriginBy:10 cornerBy:10@5. 
claus
parents: 360
diff changeset
   929
     r insetOriginBy:10@10 cornerBy:20@20.
claus
parents: 360
diff changeset
   930
    "
claus
parents: 360
diff changeset
   931
!
claus
parents: 360
diff changeset
   932
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   933
translatedBy:amount
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   934
    "return a new rectangle which is translated (i.e. moved)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   935
     by amount, aPoint or Number"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   936
a27a279701f8 Initial revision
claus
parents:
diff changeset
   937
    |amountPoint|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   938
a27a279701f8 Initial revision
claus
parents:
diff changeset
   939
    amountPoint := amount asPoint.
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
   940
    ^ Rectangle left:(left + amountPoint x) 
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   941
		 top:(top + amountPoint y)
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   942
	       width:width
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   943
	      height:height
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   944
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   945
     (Rectangle origin:10@10 corner:50@50) translatedBy:10
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   946
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   947
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   948
    "its NOT destructive:"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   949
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   950
     |r1 r2|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   951
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   952
     r1 := Rectangle origin:10@10 corner:50@50.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   953
     r2 := r1 translatedBy:10.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   954
     r1 
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   955
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   956
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   957
a27a279701f8 Initial revision
claus
parents:
diff changeset
   958
scaledBy:scale
a27a279701f8 Initial revision
claus
parents:
diff changeset
   959
    "return a new rectangle which is the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   960
     scaled by scale"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   961
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   962
    |scalePoint sx sy|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   963
a27a279701f8 Initial revision
claus
parents:
diff changeset
   964
    scalePoint := scale asPoint.
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   965
    sx := scalePoint x.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   966
    sy := scalePoint y.
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   967
    ^ Rectangle left:left * sx
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   968
		 top:top * sy
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   969
	       width:(width * sx)
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   970
	      height:(height * sy)
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   971
    "
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   972
     (Rectangle origin:10@10 corner:50@50) scaledBy:2   
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   973
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   974
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   975
    "its NOT destructive:"
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   976
    "
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   977
     |r1 r2|
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   978
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   979
     r1 := Rectangle origin:10@10 corner:50@50.
217
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   980
     r2 := r1 scaledBy:2.    
a0400fdbc933 *** empty log message ***
claus
parents: 208
diff changeset
   981
     r1  
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
   982
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   983
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   984
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   985
align:offset with:someCoordinate
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   986
    "return a new rectangle which is translated (i.e. moved)
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   987
     such that the point offset in mySelf is placed on someCoordinate."
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   988
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   989
    ^ Rectangle origin:(someCoordinate - offset + self origin)
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   990
		extent:(self extent)
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   991
    "
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   992
     |r|
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   993
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   994
     r := Rectangle origin:10@10 corner:50@50.
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   995
     r align:(r center) with:100@100.
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   996
    "
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   997
!
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   998
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   999
amountToTranslateWithin: aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1000
    "for GNU-ST compatibility"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1001
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1002
    ^(aRectangle origin) - self origin
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1003
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1004
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1005
areasOutside: aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1006
    "----------------------------------------------------------------
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1007
    | added for GNU-ST compatibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1008
    |
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1009
    | author: Doug McCallum <uunet!!ico.isc.com!!dougm>
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1010
    |
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1011
    |areasOutside: aRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1012
    | most complicated of the Rectangle primitives
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1013
    | The basic methodology is to first determine that there is an 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1014
    | intersection by finding the overlapping rectangle.  From the
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1015
    | overlapping rectangle, first determine if it runs along an edge.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1016
    | If it doesn't, extend the rectangle up to the top edge and add
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1017
    | the new rectangle to the collection and start the rest of the
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1018
    | process.  If the left edge does not touch the left edge of self,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1019
    | extend it to the edge saving the new rectangle.  Then do the 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1020
    | same to the right edge.  Then check top and bottom edges.  Most
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1021
    | of the time only 2 or 3 rectangles get formed, occasionally 4.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1022
    | It should be possible to never get more than 3 but requires more
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1023
    | work.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1024
     ----------------------------------------------------------------"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1025
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1026
    | collect iRect tmp |
360
claus
parents: 359
diff changeset
  1027
    iRect := self intersect: aRectangle.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1028
    (iRect = nil) ifTrue: [^nil]. "case of no intersection"
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1029
				"the collect collection gathers Rectangles"
360
claus
parents: 359
diff changeset
  1030
    collect := OrderedCollection new: 4.
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1031
				"is it floating or on the edge?"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1032
    (((((iRect top) ~= self top) 
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1033
	 and: [ (iRect bottom) ~= self bottom ])
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1034
	 and: [ (iRect left) ~= self left ])
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1035
	 and: [ (iRect right) ~= self right ] )
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1036
	ifTrue: "entirely in the center."
360
claus
parents: 359
diff changeset
  1037
	    [tmp := Rectangle origin: (Point x: iRect left y: self top)
claus
parents: 359
diff changeset
  1038
			      corner: iRect bottomRight.
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1039
	     collect add: tmp.
360
claus
parents: 359
diff changeset
  1040
	     iRect := iRect merge: tmp].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1041
    ((iRect left) ~= self left)
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1042
	ifTrue:                 "doesn't touch left edge so make it touch"
360
claus
parents: 359
diff changeset
  1043
	    [tmp := Rectangle origin: (Point x: self left y: iRect top)
claus
parents: 359
diff changeset
  1044
			      corner: iRect bottomLeft.
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1045
		 collect add: tmp.
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1046
				"merge new (tmp) with overlap to keep track"
360
claus
parents: 359
diff changeset
  1047
		 iRect := iRect merge: tmp].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1048
    ((iRect right) ~= self right)
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1049
	ifTrue:                 "doesn't touch right edge so extend it"
360
claus
parents: 359
diff changeset
  1050
	    [tmp := Rectangle origin: iRect topRight
claus
parents: 359
diff changeset
  1051
			      corner: (Point x: self right y: iRect bottom).
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1052
		 collect add: tmp.
360
claus
parents: 359
diff changeset
  1053
		 iRect := iRect merge: tmp].
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1054
    (((iRect left) ~= self left) or: [(iRect top) ~= self top])
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1055
	ifTrue:                 "whole top part can be taken now"
360
claus
parents: 359
diff changeset
  1056
	    [tmp := Rectangle origin: self origin corner: iRect topRight.
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1057
		 collect add: tmp].
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1058
    (((iRect right) ~= self right) or: [(iRect bottom) ~= self bottom])
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1059
	ifTrue:                 "whole bottom open and can be taken"
360
claus
parents: 359
diff changeset
  1060
	    [tmp := Rectangle origin: iRect bottomLeft corner: self corner.
186
a4c3032fc825 *** empty log message ***
claus
parents: 93
diff changeset
  1061
		 collect add: tmp].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1062
    ^collect
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1063
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1064
77
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1065
nonIntersections:aRectangle
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1066
    "this is the same as areasOutside: - for ST/V compatibility only"
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1067
6c38ca59927f *** empty log message ***
claus
parents: 59
diff changeset
  1068
    ^ self areasOutside:aRectangle
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1069
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1070
356
claus
parents: 329
diff changeset
  1071
!Rectangle methodsFor:'displaying'!
claus
parents: 329
diff changeset
  1072
claus
parents: 329
diff changeset
  1073
displayStrokedOn:aGC
claus
parents: 329
diff changeset
  1074
    aGC displayRectangleX:left y:top width:width height:height
claus
parents: 329
diff changeset
  1075
claus
parents: 329
diff changeset
  1076
    "
claus
parents: 329
diff changeset
  1077
     |v|
claus
parents: 329
diff changeset
  1078
claus
parents: 329
diff changeset
  1079
     v := View new open.
claus
parents: 329
diff changeset
  1080
     [v shown] whileFalse:[Processor yield].
claus
parents: 329
diff changeset
  1081
claus
parents: 329
diff changeset
  1082
     (Rectangle origin:10@10 corner:50@50) displayStrokedOn:v
claus
parents: 329
diff changeset
  1083
    "
claus
parents: 329
diff changeset
  1084
!
claus
parents: 329
diff changeset
  1085
claus
parents: 329
diff changeset
  1086
displayFilledOn:aGC
claus
parents: 329
diff changeset
  1087
    aGC fillRectangleX:left y:top width:width height:height
claus
parents: 329
diff changeset
  1088
claus
parents: 329
diff changeset
  1089
    "
claus
parents: 329
diff changeset
  1090
     |v|
claus
parents: 329
diff changeset
  1091
claus
parents: 329
diff changeset
  1092
     v := View new open.
claus
parents: 329
diff changeset
  1093
     [v shown] whileFalse:[Processor yield].
claus
parents: 329
diff changeset
  1094
claus
parents: 329
diff changeset
  1095
     (Rectangle origin:10@10 corner:50@50) displayFilledOn:v
claus
parents: 329
diff changeset
  1096
    "
claus
parents: 329
diff changeset
  1097
! !
claus
parents: 329
diff changeset
  1098
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  1099
!Rectangle methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1100
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1101
printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1102
    "print the receiver on aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1103
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1104
    aStream nextPutAll:(self class name).
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1105
    aStream nextPutAll:' origin:'.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1106
    (self origin) printOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1107
    aStream nextPutAll:' corner:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1108
    (self corner) printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1109
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1110
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1111
storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1112
    "store the receiver on aStream; i.e. print an expression which will
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1113
     reconstruct the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1114
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1115
    aStream nextPut:$(.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1116
    aStream nextPutAll:(self class name).
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1117
    aStream nextPutAll:' origin:'.
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1118
    (self origin) storeOn:aStream.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1119
    aStream nextPutAll:' corner:'.
59
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1120
    (self corner) storeOn:aStream.
4a86aad06603 *** empty log message ***
claus
parents: 32
diff changeset
  1121
    aStream nextPut:$)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1122
! !