Ruler.st
author claus
Fri, 16 Jul 1993 11:44:30 +0200
changeset 0 0fd7841626f6
child 2 ab6002adaee1
permissions -rw-r--r--
Initial revision
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     1
"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1991-93 by Claus Gittinger
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     4
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    11
"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    12
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    13
View subclass:#Ruler
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    14
         instanceVariableNames:'fgColor metric paperWidth paperHeight'
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    15
         classVariableNames:''
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    16
         poolDictionaries:''
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    17
         category:'Views-Interactors'
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    18
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    19
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    20
Ruler comment:'
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    21
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    22
COPYRIGHT (c) 1991-93 by Claus Gittinger
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    24
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    25
a Ruler for page layout.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    26
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    27
%W% %E%
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    28
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    29
written oct 91 by claus
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    30
'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    31
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    32
!Ruler methodsFor:'accessing'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    33
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    34
metric:aSymbol
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    35
    "set the metric"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    36
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    37
    metric := aSymbol.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    38
    shown ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    39
        self redraw
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    40
    ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    41
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    42
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    43
!Ruler methodsFor:'redrawing'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    44
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    45
redraw
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    46
    "redraw scale"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    47
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    48
    |x pixelPerMM pixelPerInch mod pos shortLen veryShortLen longLen charY
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    49
     top paperWidthMM paperWidthPixel|
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    50
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    51
    self fill:viewBackground.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    52
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    53
    paperWidthPixel := (self inchToPixel:paperWidth) rounded.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    54
    (width > paperWidthPixel) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    55
        self paint:(Color darkGrey).
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    56
        self fillRectangleX:paperWidthPixel y:0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    57
                      width:(width - paperWidthPixel) height:height.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    58
        self paint:fgColor.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    59
        self displayLineFromX:paperWidthPixel y:0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    60
                          toX:paperWidthPixel y:height
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    61
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    62
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    63
    self paint:fgColor.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    64
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    65
    top := height - font height - font ascent.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    66
    longLen := font height.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    67
    shortLen := longLen // 2.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    68
    charY := top + (font ascent) + shortLen.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    69
    mod := 1.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    70
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    71
    (metric == #mm) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    72
        "centimeter - long blibs every centimeter; short ones every half"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    73
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    74
        paperWidthMM := self inchToMillimeter:paperWidth.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    75
        pixelPerMM := self millimeterToPixel:1.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    76
        pos := 5.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    77
        x := (pixelPerMM * pos) rounded.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    78
        self displayString:'cm' x:3 y:charY.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    79
        [(x < width) and:[pos <= paperWidthMM]] whileTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    80
            (mod == 1) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    81
                self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    82
                                  toX:x y:(top + shortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    83
            ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    84
                self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    85
                                  toX:x y:(top + longLen).
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    86
                self displayString:(pos // 10) asInteger printString
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    87
                                 x:(x + 3)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    88
                                 y:charY
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    89
            ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    90
            mod := (mod + 1) \\ 2.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    91
            pos := pos + 5.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    92
            x := (pixelPerMM * pos) rounded 
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    93
        ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    94
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    95
    (metric == #inch) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    96
        "inches - long blibs every inch; short ones every half; very
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    97
         short ones every quarter"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    98
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    99
        pixelPerInch := self inchToPixel:1.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   100
        pos := 0.25.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   101
        x := (pixelPerInch * pos) rounded.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   102
        veryShortLen := longLen // 4.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   103
        self displayString:'inch' x:3 y:charY.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   104
        [(x < width) and:[pos <= paperWidth]] whileTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   105
            (mod == 0) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   106
                self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   107
                                  toX:x y:(top + longLen).
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   108
                self displayString:pos asInteger printString
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   109
                                 x:(x + 3)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   110
                                 y:charY
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   111
            ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   112
                (mod == 2) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   113
                    self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   114
                                      toX:x y:(top + shortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   115
                ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   116
                    self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   117
                                      toX:x y:(top + veryShortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   118
                ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   119
            ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   120
            mod := (mod + 1) \\ 4.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   121
            pos := pos + 0.25.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   122
            x := (pixelPerInch * pos) rounded
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   123
        ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   124
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   125
    self redrawEdges
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   126
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   127
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   128
!Ruler methodsFor:'initialization'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   129
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   130
initialize
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   131
    super initialize.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   132
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   133
    fgColor := Black.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   134
    self height:(font height + font descent + font descent). 
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   135
    (Language == #english) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   136
        metric := #inch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   137
    ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   138
        metric := #mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   139
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   140
    paperWidth := 8.5.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   141
    paperHeight := 11
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   142
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   143
    "Ruler new realize"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   144
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   145
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   146
!Ruler methodsFor:'metric conversions'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   147
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   148
inchToMillimeter:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   149
    "convert inches to mm"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   150
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   151
    ^ inches * 25.4
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   152
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   153
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   154
inchToPixel:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   155
    "convert inches to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   156
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   157
    ^ inches * self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   158
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   159
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   160
inchToTwip:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   161
    "convert inches to twips"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   162
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   163
    ^ inches * 1440
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   164
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   165
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   166
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   167
millimeterToPixel:mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   168
    "convert mms to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   169
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   170
    ^ mm * self horizontalPixelPerMillimeter
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   171
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   172
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   173
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   174
millimeterToInch:mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   175
    "convert mm to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   176
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   177
    ^ mm / 25.4
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   178
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   179
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   180
pointToTwip:points
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   181
    "convert points to twips"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   182
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   183
    ^ points * 20
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   184
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   185
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   186
twipToInch:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   187
    "convert twips to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   188
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   189
    ^ twips / 1440.0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   190
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   191
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   192
pixelToInch:pixels
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   193
    "convert pixels to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   194
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   195
    ^ pixels / self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   196
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   197
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   198
twipToPixel:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   199
    "convert twips to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   200
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   201
    ^ (twips / 1440.0) * self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   202
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   203
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   204
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   205
twipToPoint:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   206
    "convert twips to points"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   207
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   208
    ^ twips / 20.0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   209
! !