ScaleTransform.st
author Claus Gittinger <cg@exept.de>
Thu, 20 Feb 2020 10:52:26 +0100
changeset 8995 a54112003192
parent 8713 9d5e054e16db
permissions -rw-r--r--
#DOCUMENTATION by exept class: SimpleView comment/format in: #waitUntilVisible
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8713
9d5e054e16db #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7950
diff changeset
     1
"{ Encoding: utf8 }"
9d5e054e16db #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7950
diff changeset
     2
7950
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     3
"
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     4
 COPYRIGHT (c) 1992 by Claus Gittinger
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     5
              All Rights Reserved
7057
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
     6
7950
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     7
 This software is furnished under a license and may be used
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     8
 only in accordance with the terms of that license and with the
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    10
 be provided or otherwise made available to, or used by, any
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    11
 other person.  No title to or ownership of the software is
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    12
 hereby transferred.
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    13
"
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ Package: 'stx:libview' }"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
6747
352ff5d5ada8 bugfix: missing return
az
parents: 6695
diff changeset
    16
"{ NameSpace: Smalltalk }"
352ff5d5ada8 bugfix: missing return
az
parents: 6695
diff changeset
    17
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
DisplayTransform variableFloatSubclass:#ScaleTransform
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	instanceVariableNames:'scale'
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	classVariableNames:''
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
	poolDictionaries:''
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	category:'Graphics-Transformations'
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
!ScaleTransform class methodsFor:'documentation'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
7950
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    27
copyright
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    28
"
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    29
 COPYRIGHT (c) 1992 by Claus Gittinger
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    30
              All Rights Reserved
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    31
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    32
 This software is furnished under a license and may be used
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    33
 only in accordance with the terms of that license and with the
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    35
 be provided or otherwise made available to, or used by, any
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    36
 other person.  No title to or ownership of the software is
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    37
 hereby transferred.
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    38
"
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    39
!
6319458fdf4e #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7415
diff changeset
    40
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
documentation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    instances of ScaleTransform can be used to scale other objects in 2D space.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    This one is used, if only a scale is applied, but no translation.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    All 2-D objects are supposed to be able to be transformed using instances of me.  
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    Multiple instances of me can also be combined to form a single composite transformation.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    [Instance variables:]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
        scale           <Number> or <Point> representing a linear scaling factor.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
                        nil is interpreted as 1@1
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    [author:]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
        Claus Gittinger
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
examples
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    example :
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
                                                                        [exBegin]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
     |v|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
     v := View new extent:200@200; openAndWait.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
     v paint:Color green.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
     v fillRectangle:(10@10 corner:40@40).
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
     v displayLineFrom:50@50 to:75@100. 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
     v transformation:(ScaleTransform withScale:2).
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
     v paint:Color red.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
     v fillRectangle:(10@10 corner:40@40).
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
     v displayLineFrom:50@50 to:75@100. 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
                                                                        [exEnd]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
!ScaleTransform class methodsFor:'instance creation'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
scale:scaleFactor
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    ^ self new scale:scaleFactor
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
withScale:scaleFactor
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    ^ self new scale:scaleFactor
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
!ScaleTransform methodsFor:'accessing'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
inverseTransformation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    "Return the inverse transformation of the receiver"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
    ^ ScaleTransform withScale:(1 / scale)
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
scale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
    "return a copy of the Point that represents the
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
     current scale of the receiver."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    scale isNil ifTrue:[^ Point x:1 y:1 ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    ^ scale copy
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
scale:aScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
    "Set the receiver's scale to aScale, a Point or Number."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    aScale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
        scale := aScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
    ] ifFalse:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
        aScale = 1 ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
            scale := nil
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
        ] ifFalse:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
            scale := aScale asPoint.
6749
fcc5b03b21b7 class: ScaleTransform
Claus Gittinger <cg@exept.de>
parents: 6747
diff changeset
   114
            (scale x = 1 and:[scale y = 1]) ifTrue:[
fcc5b03b21b7 class: ScaleTransform
Claus Gittinger <cg@exept.de>
parents: 6747
diff changeset
   115
                scale := nil
fcc5b03b21b7 class: ScaleTransform
Claus Gittinger <cg@exept.de>
parents: 6747
diff changeset
   116
            ].
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
        ]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
    ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    "Modified: / 13.6.1998 / 14:04:51 / cg"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
scaleOfOne
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
    "Set the scale of the receiver to the identity scale"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
    scale := nil
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
scaleX
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    "return the current x-scale of the receiver."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    scale isNil ifTrue:[^ 1].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
    ^ scale x
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
    "Created: 21.5.1996 / 21:13:49 / cg"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
scaleY
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
    "return the current x-scale of the receiver."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
    scale isNil ifTrue:[^ 1].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    ^ scale y
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    "Created: 21.5.1996 / 21:13:59 / cg"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
translation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
    "return a copy of the receiver's translation."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    ^ Point x:0 y:0
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
translationX
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    "return the x part of the receiver's translation."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    ^ 0 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
translationY
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
    "return the y part of the receiver's translation."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
    ^ 0 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
!ScaleTransform methodsFor:'applying transform'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
applyInverseScaleX:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
    "apply the scale only (if widths are to be transformed)"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
    scale isNil ifTrue:[^ aNumber].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    ^ aNumber / scale x
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
applyInverseScaleY:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    "apply the scale only (if heights are to be transformed)"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
    scale isNil ifTrue:[^ aNumber].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
    ^ aNumber / scale y
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
applyInverseTo:anObject 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
    "Apply the inverse of the receiver to anObject
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
     and return the result. This can be used to map back from logical
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
     to physical coordinates, for example."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
    scale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
        ^ anObject
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
    ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    ^ anObject scaledBy:self inverseScale 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
applyInverseToX:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
    "Apply the receiver to a number representing an x-coordinate
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
     and return the result."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
    |s|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale x].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    ^ aNumber / s
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
applyInverseToY:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
    "Apply the receiver to a number representing an y-coordinate
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
     and return the result."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
    |s|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
    scale isNil ifTrue:[s := 1] ifFalse:[s := scale y].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
    ^ aNumber / s
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
applyScaleX:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
    "apply the scale only (if widths are to be transformed)"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
    scale isNil ifTrue:[^ aNumber].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
    ^ aNumber * scale x
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
applyScaleY:aNumber
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
    "apply the scale only (if heights are to be transformed)"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    scale isNil ifTrue:[^ aNumber].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
    ^ aNumber * scale y
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
transformPoint:p 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
    "Apply the receiver to a point, returning a new point."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
    scale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
        ^ p
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
    ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    ^ p * scale
7057
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   233
!
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   234
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   235
transformRectangle:aRectangle 
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   236
    "Apply the receiver to a rectangle, returning a new rectangle."
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   237
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   238
    scale isNil ifTrue:[
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   239
        ^ aRectangle.
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   240
    ].
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   241
    ^ aRectangle scaledBy:scale.
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
!ScaleTransform methodsFor:'printing & storing'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
printOn:aStream
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
    "append a user printed representation of the receiver to aStream.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
     The format is suitable for a human - not meant to be read back."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
8713
9d5e054e16db #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7950
diff changeset
   250
    aStream nextPutAll:self className.
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
    aStream nextPutAll:' scale: '.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
    scale printOn:aStream.
8713
9d5e054e16db #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7950
diff changeset
   253
9d5e054e16db #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 7950
diff changeset
   254
    "Modified: / 28-06-2019 / 09:15:51 / Claus Gittinger"
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
!ScaleTransform methodsFor:'private'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
checkScale:aScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
    "Converts aScale to the internal format of a floating-point Point."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
    |checkedScale|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
    checkedScale := aScale asPoint.
6747
352ff5d5ada8 bugfix: missing return
az
parents: 6695
diff changeset
   265
    ^ (checkedScale x asFloat) @ (checkedScale y asFloat)
352ff5d5ada8 bugfix: missing return
az
parents: 6695
diff changeset
   266
352ff5d5ada8 bugfix: missing return
az
parents: 6695
diff changeset
   267
    "Modified: / 22-01-2015 / 14:21:11 / az"
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
inverseScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
    "return with a Point representing the inverse of my
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
     scale."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
    |newScale|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
    newScale := self checkScale:scale.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
    ^ (1.0 / newScale x) @ (1.0 / newScale y)
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
!ScaleTransform methodsFor:'testing'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
7415
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   282
isIdentityTransformation
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   283
    "return true if this is an identity transformation;
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   284
     return false, otherwise."
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   285
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   286
    ^ scale isNil or:[scale x = 1 and:[scale y = 1]]
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   287
!
9a5397d090bf #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 7057
diff changeset
   288
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
isNoScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
    "return true if the identity scale is in effect (i.e. saleFactor is 1);
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
     return false, otherwise."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
    scale isNil ifTrue:[^ true].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
    ^ scale x = 1 and:[scale y = 1]
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
!ScaleTransform methodsFor:'transformations'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
scaleBy:aScale 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
    "scale the receiver.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
     This is a destructive operation, modifying the transformation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
     represented by the receiver"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
    |newScale|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
    aScale isNil ifTrue:[^ self].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
    scale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
        newScale := aScale asPoint
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
    ] ifFalse:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
        newScale := scale * aScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
    ].
6749
fcc5b03b21b7 class: ScaleTransform
Claus Gittinger <cg@exept.de>
parents: 6747
diff changeset
   313
    self scale:newScale.
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
scaledBy:aScale 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
    "return a new WindowingTransformation with the scale and translation of 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
     the receiver both scaled by aScale."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
    |checkedScale newScale|
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
    aScale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
        newScale := scale.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
    ] ifFalse:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
        checkedScale := self checkScale:aScale.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
        scale isNil ifTrue:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
            newScale := checkedScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
        ] ifFalse:[
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
            newScale := scale * checkedScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
        ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
    ].
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
    ^ (self class) withScale:newScale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
translateBy:aTranslation 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
    "translate the receiver.
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
     This is a destructive operation, modifying the transformation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
     represented by the receiver"
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
    self error:'not allowed'
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
translatedBy:aPoint 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
    "return a new WindowingTransformation with the same scale and 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
     rotations as the receiver and with a translation of the current 
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
     translation plus aPoint."
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
    ^ WindowingTransformation
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
          scale:scale
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
          translation:aPoint
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
!ScaleTransform class methodsFor:'documentation'!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
version
7057
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   356
    ^ '$Header$'
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
!
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
version_CVS
7057
336206a77c6e #FEATURE
Stefan Vogel <sv@exept.de>
parents: 6749
diff changeset
   360
    ^ '$Header$'
6695
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
! !
a864ecedd754 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362