WindowingTransformation.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 16:54:10 +0100
changeset 219 9ff0660f447f
parent 137 523edf3204e4
child 601 2c4c1e797909
permissions -rw-r--r--
uff - version methods changed to return stings
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     1
"
48194c26a46c Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1992 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
     3
	      All Rights Reserved
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     4
48194c26a46c Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
48194c26a46c Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
48194c26a46c Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
48194c26a46c Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
48194c26a46c Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
48194c26a46c Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
48194c26a46c Initial revision
claus
parents:
diff changeset
    11
"
48194c26a46c Initial revision
claus
parents:
diff changeset
    12
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    13
'From Smalltalk/X, Version:2.10.3 on 20-sep-1994 at 0:15:56'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    14
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    15
Object subclass:#WindowingTransformation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    16
	 instanceVariableNames:'scale translation'
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    17
	 classVariableNames:''
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    18
	 poolDictionaries:''
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    19
	 category:'Graphics-Support'
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    20
!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    21
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    22
!WindowingTransformation class methodsFor:'documentation '!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    23
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    24
copyright
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    25
"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    26
 COPYRIGHT (c) 1992 by Claus Gittinger
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    27
	      All Rights Reserved
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    28
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    29
 This software is furnished under a license and may be used
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    30
 only in accordance with the terms of that license and with the
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    32
 be provided or otherwise made available to, or used by, any
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    33
 other person.  No title to or ownership of the software is
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    34
 hereby transferred.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    35
"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    36
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    37
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    38
version
219
9ff0660f447f uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 137
diff changeset
    39
    ^ '$Header: /cvs/stx/stx/libview/WindowingTransformation.st,v 1.10 1995-11-11 15:53:42 cg Exp $'
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    40
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    41
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    42
documentation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    43
"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    44
    instances of WindowingTransformation can be used to scale, translate or
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    45
    generally transform other objects in 2D space. 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    46
    They can also be set as the translation in a graphic context, 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    47
    which will then apply this to all of its drawing operations 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    48
    (see GraphicContext>>transformation:).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    49
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    50
    All 2-D objects are supposed to be able to be transformed using
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    51
    instances of me.  Multiple instances of me can also be combined to form a
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    52
    single composite transformation.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    53
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    54
    Instance variables are:
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    55
	scale           <Number> or <Point> representing a linear scaling factor.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    56
			nil is interpreted as 1@1
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    57
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    58
	translation     <Number> or <Point> representing a translation in 2-D.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    59
			nil is interpreted as 0@0
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    60
81
4ba554473294 *** empty log message ***
claus
parents: 78
diff changeset
    61
"
4ba554473294 *** empty log message ***
claus
parents: 78
diff changeset
    62
!
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    63
81
4ba554473294 *** empty log message ***
claus
parents: 78
diff changeset
    64
examples
4ba554473294 *** empty log message ***
claus
parents: 78
diff changeset
    65
"
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    66
    example (drawing in inches):
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    67
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    68
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    69
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    70
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    71
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    72
     v transformation:(WindowingTransformation unit:#inch on:Display).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    73
     'now, we can think of drawing in inches ...'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    74
     v displayLineFrom:0.5@0.5 to:1@1 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    75
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    76
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    77
    example (drawing in millimeters):
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    79
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    80
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    81
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    82
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    83
     v transformation:(WindowingTransformation unit:#mm on:Display).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    84
     'now, we can think of drawing in millimeters ...'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    85
     v displayLineFrom:5@5 to:20@5 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    86
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    87
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    88
    example (drawing magnified):
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    89
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    90
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    91
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    92
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    93
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    94
     v transformation:(WindowingTransformation scale:2 translation:0).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    95
     'now, everything is magnfied by 2'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    96
     v displayLineFrom:10@10 to:30@30 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    97
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    98
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
    99
    example (drawing shrunk):
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   100
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   101
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   102
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   103
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   104
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   105
     v transformation:(WindowingTransformation scale:0.5 translation:0).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   106
     'now, everything is shrunk by 2'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   107
     v displayLineFrom:10@10 to:30@30 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   108
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   109
"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   110
! !
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   111
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   112
!WindowingTransformation class methodsFor:'instance creation'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   113
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   114
unit:unitSymbol on:device 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   115
    "returns a windowing transformation with scaling 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   116
     for unitSymbol and no translation (0@0).
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   117
     With such a transformation, you can draw in your preferred 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   118
     units.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   119
     UnitSymbol may be #mm, #cm, #inch, #point, #twip or #pixel (default).
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   120
     Twip is 1/20th of a point, point is 1/72th of an inch
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   121
     (i.e. the print-unit which is also used for font sizes etc.) 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   122
     - not to confuse with device pixels."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   123
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   124
    |pixelPerUnitV pixelPerUnitH|
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   125
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   126
    unitSymbol == #mm ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   127
	pixelPerUnitV := device verticalPixelPerMillimeter.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   128
	pixelPerUnitH := device horizontalPixelPerMillimeter 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   129
    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   130
	unitSymbol == #cm ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   131
	    pixelPerUnitV := device verticalPixelPerMillimeter * 10.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   132
	    pixelPerUnitH := device horizontalPixelPerMillimeter * 10 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   133
	] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   134
	    unitSymbol == #twip ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   135
		pixelPerUnitV := device verticalPixelPerInch / 1440.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   136
		pixelPerUnitH := device horizontalPixelPerInch / 1440 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   137
	    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   138
		unitSymbol == #point ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   139
		    pixelPerUnitV := device verticalPixelPerInch / 72.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   140
		    pixelPerUnitH := device horizontalPixelPerInch / 72 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   141
		] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   142
		    unitSymbol == #inch ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   143
			pixelPerUnitV := device verticalPixelPerInch.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   144
			pixelPerUnitH := device horizontalPixelPerInch 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   145
		    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   146
			"sorry: unknown unit is taken as pixel"
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   147
			^ self new scale:nil translation:nil
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   148
		    ]
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   149
		]
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   150
	    ]
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   151
	]
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   152
    ].
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   153
    ^ self basicNew scale:(pixelPerUnitH @ pixelPerUnitV) translation:nil
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   154
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   155
    "
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   156
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   157
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   158
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   159
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   160
     v transformation:(WindowingTransformation unit:#inch on:Display).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   161
     'now, we can think of drawing in inches ...'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   162
     v displayLineFrom:0.5@0.5 to:1@1 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   163
    "
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   164
!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   165
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   166
scale:aScale translation:aTranslation 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   167
    "returns a windowing transformation with a scale factor of  
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   168
     aScale and a translation offset of aTranslation."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   169
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   170
    ^ self basicNew scale:aScale translation:aTranslation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   171
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   172
    "
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   173
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   174
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   175
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   176
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   177
     v transformation:(WindowingTransformation scale:2 translation:0).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   178
     'now, everything is magnfied by 2'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   179
     v displayLineFrom:10@10 to:30@30 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   180
    "
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   181
    "
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   182
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   183
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   184
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   185
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   186
     v transformation:(WindowingTransformation scale:0.5 translation:0).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   187
     'now, everything is shrunk by 2'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   188
     v displayLineFrom:10@10 to:30@30 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   189
    "
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   190
!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   191
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   192
window:sourceRectangle viewport:destinationRectangle 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   193
    "returns a windowing transformation with a scale and
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   194
     translation computed from sourceRectangle and destinationRectangle.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   195
     The scale and transformation are computed such that sourceRectangle
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   196
     is transformed to destinationRectangle. Typically sourceRectangle
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   197
     represents the logical coordinateSpace while destinationRectangle 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   198
     represents the device coordinateSpace."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   199
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   200
    |sX sY tX tY newScale newTranslation|
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   201
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   202
    sX := destinationRectangle width / sourceRectangle width.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   203
    sY := destinationRectangle height / sourceRectangle height.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   204
    tX := destinationRectangle left - sourceRectangle left.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   205
    tY := destinationRectangle top - sourceRectangle top.
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   206
    ((tX = 1.0) and:[tY = 1.0]) ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   207
	newTranslation := nil
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   208
    ] ifFalse:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   209
	newTranslation := tX @ tY
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   210
    ].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   211
    ((sX = 1.0) and:[sY = 1.0]) ifTrue:[
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   212
	newScale := nil
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   213
    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   214
	newScale := sX @ sY
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   215
    ].
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   216
    ^ self basicNew scale:newScale translation:newTranslation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   217
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   218
    "
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   219
     |v|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   220
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   221
     v := View new realize.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   222
     (Delay forSeconds:3) wait.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   223
     v transformation:(WindowingTransformation 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   224
				window:(0@0 corner:1@1)
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   225
				viewport:(0@0 corner:100@100)).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   226
     'now, we can think of drawing in 0..1/0..1 coordinates'.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   227
     v displayLineFrom:0.1@0.1 to:0.9@0.9 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   228
    "
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   229
!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   230
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   231
identity
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   232
    "returns a windowing transformation with no scaling (1@1) 
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   233
     and no translation (0@0)."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   234
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   235
    ^ self basicNew scale:nil translation:nil 
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
   236
! !
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   237
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   238
!WindowingTransformation methodsFor:'applying transform'!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   239
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   240
applyToX:aNumber
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   241
    "Apply the receiver to a number representing an x-coordinate
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   242
     and return the result."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   243
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   244
    |t s|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   245
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   246
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale x].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   247
    translation isNil ifTrue:[t := 0] ifFalse:[t := translation x].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   248
    ^ aNumber * s + t
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   249
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   250
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   251
applyToY:aNumber
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   252
    "Apply the receiver to a number representing an y-coordinate
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   253
     and return the result."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   254
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   255
    |t s|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   256
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   257
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale y].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   258
    translation isNil ifTrue:[t := 0] ifFalse:[t := translation y].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   259
    ^ aNumber * s + t
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   260
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   261
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   262
applyScaleX:aNumber
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   263
    "apply the scale only (if widths are to be transformed)"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   264
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   265
    scale isNil ifTrue:[^ aNumber].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   266
    ^ aNumber * scale x
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   267
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   268
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   269
applyScaleY:aNumber
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   270
    "apply the scale only (if heights are to be transformed)"
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   271
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   272
    scale isNil ifTrue:[^ aNumber].
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   273
    ^ aNumber * scale y
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   274
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   275
48194c26a46c Initial revision
claus
parents:
diff changeset
   276
applyTo:anObject 
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   277
    "Apply the receiver to anObject and return the result."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   278
48194c26a46c Initial revision
claus
parents:
diff changeset
   279
    |transformedObject|
48194c26a46c Initial revision
claus
parents:
diff changeset
   280
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   281
    scale isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   282
	translation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   283
	    ^ anObject
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   284
	].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   285
	^ anObject translatedBy:translation 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   286
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   287
    transformedObject := anObject scaledBy:scale.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   288
    translation notNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   289
	transformedObject translateBy:translation.
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   290
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   291
    ^ transformedObject
48194c26a46c Initial revision
claus
parents:
diff changeset
   292
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   293
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   294
applyInverseToX:aNumber
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   295
    "Apply the receiver to a number representing an x-coordinate
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   296
     and return the result."
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   297
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   298
    |t s|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   299
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   300
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale x].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   301
    translation isNil ifTrue:[t := 0] ifFalse:[t := translation x].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   302
    ^ (aNumber - t) / s
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   303
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   304
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   305
applyInverseToY:aNumber
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   306
    "Apply the receiver to a number representing an y-coordinate
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   307
     and return the result."
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   308
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   309
    |t s|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   310
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   311
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale y].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   312
    translation isNil ifTrue:[t := 0] ifFalse:[t := translation y].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   313
    ^ (aNumber - t) / s
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   314
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   315
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   316
applyInverseScaleX:aNumber
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   317
    "apply the scale only (if widths are to be transformed)"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   318
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   319
    scale isNil ifTrue:[^ aNumber].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   320
    ^ aNumber / scale x
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   321
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   322
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   323
applyInverseScaleY:aNumber
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   324
    "apply the scale only (if heights are to be transformed)"
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   325
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   326
    scale isNil ifTrue:[^ aNumber].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   327
    ^ aNumber / scale y
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   328
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   329
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   330
applyInverseTo:anObject 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   331
    "Apply the inverse of the receiver to anObject
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   332
     and return the result. This can be used to map back from logical
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   333
     to physical coordinates, for example."
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   334
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   335
    |transformedObject|
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   336
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   337
    translation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   338
	scale isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   339
	    ^ anObject
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   340
	].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   341
	^ anObject scaledBy:self inverseScale 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   342
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   343
    transformedObject := anObject translatedBy:(self inverseTranslation).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   344
    scale notNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   345
	transformedObject scaleBy:(self inverseScale).
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   346
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   347
    ^ transformedObject
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   348
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   349
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   350
transformPoint:p 
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   351
    "Apply the receiver to a point.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   352
     This is destructive in that the point is being modified,
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   353
     not a copy."
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   354
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   355
    scale isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   356
	translation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   357
	    ^ p
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   358
	].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   359
	^ p + translation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   360
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   361
    translation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   362
	^ p * scale
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   363
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   364
    ^ (p * scale + translation)
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   365
!
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   366
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   367
compose:aTransformation 
48194c26a46c Initial revision
claus
parents:
diff changeset
   368
    "return a new WindowingTransformation that is the
48194c26a46c Initial revision
claus
parents:
diff changeset
   369
     composition of the receiver and aTransformation.
48194c26a46c Initial revision
claus
parents:
diff changeset
   370
     The effect of applying the resulting WindowingTransformation
48194c26a46c Initial revision
claus
parents:
diff changeset
   371
     to an object is the same as that of first applying
48194c26a46c Initial revision
claus
parents:
diff changeset
   372
     aTransformation to the object and then applying the 
48194c26a46c Initial revision
claus
parents:
diff changeset
   373
     receiver to its result."
48194c26a46c Initial revision
claus
parents:
diff changeset
   374
48194c26a46c Initial revision
claus
parents:
diff changeset
   375
    |aTransformationScale newScale newTranslation|
48194c26a46c Initial revision
claus
parents:
diff changeset
   376
48194c26a46c Initial revision
claus
parents:
diff changeset
   377
    aTransformationScale := aTransformation scale.
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   378
    scale isNil ifTrue:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   379
	aTransformation noScale ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   380
	    newScale := nil
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   381
	] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   382
	    newScale := aTransformationScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   383
	].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   384
	newTranslation := translation + aTransformation translation
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   385
    ] ifFalse:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   386
	aTransformation noScale ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   387
	    newScale := scale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   388
	] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   389
	    newScale := scale * aTransformationScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   390
	].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   391
	newTranslation := translation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   392
			  + (scale * aTransformation translation)
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   393
    ].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   394
    ^ (self class) 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   395
	  scale:newScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   396
	  translation:newTranslation
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   397
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   398
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   399
!WindowingTransformation methodsFor:'transforming'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   400
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   401
scaleBy:aScale 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   402
    "scale the receiver.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   403
     This is a destructive operation, modifying the transformation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   404
     represented by the receiver"
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   405
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   406
    |newScale|
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   407
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   408
    aScale isNil ifTrue:[^ self].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   409
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   410
    scale isNil ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   411
	newScale := aScale asPoint
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   412
    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   413
	newScale := scale * aScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   414
    ].
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   415
    translation notNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   416
	translation := translation * aScale.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   417
    ].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   418
    scale := newScale.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   419
!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   420
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   421
translateBy:aTranslation 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   422
    "translate the receiver.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   423
     This is a destructive operation, modifying the transformation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   424
     represented by the receiver"
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   425
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   426
    aTranslation isNil ifTrue:[^ self].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   427
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   428
    translation isNil ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   429
	translation := 0@0
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   430
    ].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   431
    scale isNil ifTrue:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   432
	translation := translation + aTranslation asPoint
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   433
    ] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   434
	translation := translation + (scale * aTranslation)
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   435
    ].
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   436
!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   437
2
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
   438
scaledBy:aScale 
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   439
    "return a new WindowingTransformation with the scale and translation of 
48194c26a46c Initial revision
claus
parents:
diff changeset
   440
     the receiver both scaled by aScale."
48194c26a46c Initial revision
claus
parents:
diff changeset
   441
48194c26a46c Initial revision
claus
parents:
diff changeset
   442
    |checkedScale newScale newTranslation|
48194c26a46c Initial revision
claus
parents:
diff changeset
   443
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   444
    aScale isNil ifTrue:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   445
	newScale := scale.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   446
	newTranslation := translation
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   447
    ] ifFalse:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   448
	checkedScale := self checkScale:aScale.
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   449
	scale isNil ifTrue:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   450
	    newScale := checkedScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   451
	] ifFalse:[
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   452
	    newScale := scale * checkedScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   453
	].
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   454
	translation notNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   455
	    newTranslation := checkedScale * translation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   456
	]
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   457
    ].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   458
    ^ (self class) 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   459
	  scale:newScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   460
	  translation:newTranslation
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   461
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   462
2
b35336ab0de3 *** empty log message ***
claus
parents: 0
diff changeset
   463
translatedBy:aPoint 
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   464
    "return a new WindowingTransformation with the same scale and 
48194c26a46c Initial revision
claus
parents:
diff changeset
   465
     rotations as the receiver and with a translation of the current 
48194c26a46c Initial revision
claus
parents:
diff changeset
   466
     translation plus aPoint."
48194c26a46c Initial revision
claus
parents:
diff changeset
   467
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   468
    ^ (self class) 
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   469
	  scale:scale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   470
	  translation:(translation + aPoint)
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   471
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   472
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   473
!WindowingTransformation methodsFor:'private'!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   474
48194c26a46c Initial revision
claus
parents:
diff changeset
   475
checkScale:aScale
48194c26a46c Initial revision
claus
parents:
diff changeset
   476
    "Converts aScale to the internal format of a floating-point Point."
48194c26a46c Initial revision
claus
parents:
diff changeset
   477
48194c26a46c Initial revision
claus
parents:
diff changeset
   478
    |checkedScale|
48194c26a46c Initial revision
claus
parents:
diff changeset
   479
48194c26a46c Initial revision
claus
parents:
diff changeset
   480
    checkedScale := aScale asPoint.
48194c26a46c Initial revision
claus
parents:
diff changeset
   481
    ^ Point x:checkedScale x asFloat
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   482
	    y:checkedScale y asFloat
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   483
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   484
48194c26a46c Initial revision
claus
parents:
diff changeset
   485
inverseScale
48194c26a46c Initial revision
claus
parents:
diff changeset
   486
    "return with a Point representing the inverse of my
48194c26a46c Initial revision
claus
parents:
diff changeset
   487
     scale."
48194c26a46c Initial revision
claus
parents:
diff changeset
   488
48194c26a46c Initial revision
claus
parents:
diff changeset
   489
    |newScale|
48194c26a46c Initial revision
claus
parents:
diff changeset
   490
48194c26a46c Initial revision
claus
parents:
diff changeset
   491
    newScale := self checkScale:scale.
48194c26a46c Initial revision
claus
parents:
diff changeset
   492
    ^ Point x:(1.0 / newScale x)
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   493
	    y:(1.0 / newScale y)
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   494
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   495
48194c26a46c Initial revision
claus
parents:
diff changeset
   496
inverseTranslation
48194c26a46c Initial revision
claus
parents:
diff changeset
   497
    "return with a Point representing the inverse of my
48194c26a46c Initial revision
claus
parents:
diff changeset
   498
     translation."
48194c26a46c Initial revision
claus
parents:
diff changeset
   499
48194c26a46c Initial revision
claus
parents:
diff changeset
   500
    |trans|
48194c26a46c Initial revision
claus
parents:
diff changeset
   501
48194c26a46c Initial revision
claus
parents:
diff changeset
   502
    trans := translation asPoint.
48194c26a46c Initial revision
claus
parents:
diff changeset
   503
    ^ Point x:trans x negated
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   504
	    y:trans y negated
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   505
! !
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   506
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   507
!WindowingTransformation methodsFor:'accessing'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   508
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   509
scale:aScale translation:aTranslation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   510
    "sets the scale to aScale and the translation to aTranslation."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   511
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   512
    aScale isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   513
	scale := aScale
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   514
    ] ifFalse:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   515
	scale := aScale asPoint.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   516
    ].
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   517
    aTranslation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   518
	translation := aTranslation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   519
    ] ifFalse:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   520
	translation := aTranslation asPoint
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   521
    ]
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   522
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   523
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   524
translation:aTranslation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   525
    "Set the receiver's translation to aTranslation, a Point or Number."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   526
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   527
    aTranslation isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   528
	translation := aTranslation
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   529
    ] ifFalse:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   530
	translation := aTranslation asPoint
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   531
    ]
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   532
!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   533
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   534
scale:aScale
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   535
    "Set the receiver's scale to aScale, a Point or Number."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   536
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   537
    aScale isNil ifTrue:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   538
	scale := aScale
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   539
    ] ifFalse:[
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   540
	scale := aScale asPoint.
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   541
    ].
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   542
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   543
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   544
scale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   545
    "return a copy of the Point that represents the
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   546
     current scale of the receiver."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   547
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   548
    scale isNil ifTrue:[^ (1@1) copy].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   549
    ^ scale copy
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   550
!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   551
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   552
translation
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   553
    "return a copy of the receiver's translation."
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   554
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   555
    translation isNil ifTrue:[^ (0@0) copy].
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   556
    ^ translation copy
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   557
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   558
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   559
scaleOfOne
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   560
    "Set the scale of the receiver to the identity scale"
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   561
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   562
    scale := nil
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   563
! !
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   564
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   565
!WindowingTransformation methodsFor:'testing'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   566
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   567
noScale
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   568
    "return true if the identity scale is in effect;
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   569
     return false, otherwise."
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   570
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   571
    ^ scale == nil
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   572
! !
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   573
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   574
!WindowingTransformation methodsFor:'printing'!
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   575
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   576
printOn:aStream
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   577
    aStream nextPutAll:self class name.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   578
    aStream nextPutAll:' scale: '.
78
1c9c22df3251 *** empty log message ***
claus
parents: 72
diff changeset
   579
    scale printOn:aStream.
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   580
    aStream nextPutAll:' translation: '.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   581
    translation printOn:aStream
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   582
! !
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   583