Ruler.st
author claus
Fri, 05 Aug 1994 03:24:10 +0200
changeset 11 793044d4bc90
parent 7 19b36b78ee01
child 24 6704fad5eb7d
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
     1
"
4
claus
parents: 2
diff changeset
     2
 COPYRIGHT (c) 1991 by Claus Gittinger
0
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:'
4
claus
parents: 2
diff changeset
    21
COPYRIGHT (c) 1991 by Claus Gittinger
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    22
              All Rights Reserved
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    23
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    24
a Ruler for page layout.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    25
11
793044d4bc90 *** empty log message ***
claus
parents: 7
diff changeset
    26
$Header: /cvs/stx/stx/libwidg2/Ruler.st,v 1.6 1994-08-05 01:24:05 claus Exp $
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    27
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    28
written oct 91 by claus
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    29
'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    30
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    31
!Ruler methodsFor:'accessing'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    32
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    33
metric:aSymbol
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    34
    "set the metric"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    35
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    36
    metric := aSymbol.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    37
    shown ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    38
        self redraw
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    39
    ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    40
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    41
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    42
!Ruler methodsFor:'redrawing'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    43
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    44
redraw
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    45
    "redraw scale"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    46
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    47
    |x pixelPerMM pixelPerInch mod pos shortLen veryShortLen longLen charY
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    48
     top paperWidthMM paperWidthPixel xOrigin labelRight marg|
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    49
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    50
    self fill:viewBackground.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    51
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    52
    xOrigin := viewOrigin x.
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    53
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    54
    paperWidthPixel := (self inchToPixel:paperWidth) rounded.
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    55
    (xOrigin + width > paperWidthPixel) ifTrue:[
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    56
        self paint:(Color darkGrey).
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    57
        self fillRectangleX:paperWidthPixel - xOrigin y:0
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    58
                      width:(width - (paperWidthPixel - xOrigin)) height:height.
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    59
        self paint:fgColor.
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    60
        self displayLineFromX:paperWidthPixel - xOrigin y:0
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    61
                          toX:paperWidthPixel - xOrigin y:height
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    62
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    63
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    64
    self paint:fgColor.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    65
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    66
    top := height - font height - font ascent.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    67
    longLen := font height.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    68
    shortLen := longLen // 2.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    69
    charY := top + (font ascent) + shortLen.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    70
    mod := 1.
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    71
    marg := 3. "character shift"
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    72
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    73
    (metric == #mm) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    74
        "centimeter - long blibs every centimeter; short ones every half"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    75
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    76
        paperWidthMM := self inchToMillimeter:paperWidth.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    77
        pixelPerMM := self millimeterToPixel:1.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    78
        pos := 5.
7
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
    79
        labelRight := marg + (font widthOf:'cm').
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    80
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    81
        x := (pixelPerMM * pos - xOrigin) rounded.
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    82
        [(x < width) and:[pos <= paperWidthMM]] whileTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    83
            (mod == 1) ifTrue:[
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 + shortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    86
            ] ifFalse:[
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    87
                x < labelRight ifFalse:[
7
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
    88
                    self displayLineFromX:x y:top
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
    89
                                      toX:x y:(top + longLen).
11
793044d4bc90 *** empty log message ***
claus
parents: 7
diff changeset
    90
                    self displayString:(pos // 10) printString
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    91
                                     x:(x + marg)
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    92
                                     y:charY
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    93
                ]
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    94
            ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    95
            mod := (mod + 1) \\ 2.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
    96
            pos := pos + 5.
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    97
            x := (pixelPerMM * pos - xOrigin) rounded 
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    98
        ].
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
    99
        self displayString:'cm ' x:marg y:charY.
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   100
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   101
    (metric == #inch) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   102
        "inches - long blibs every inch; short ones every half; very
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   103
         short ones every quarter"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   104
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   105
        pixelPerInch := self inchToPixel:1.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   106
        pos := 0.25.
7
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
   107
        labelRight := marg + (font widthOf:'inch').
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   108
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   109
        x := (pixelPerInch * pos - xOrigin) rounded.
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   110
        veryShortLen := longLen // 4.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   111
        [(x < width) and:[pos <= paperWidth]] whileTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   112
            (mod == 0) ifTrue:[
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   113
                x < labelRight ifFalse:[
7
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
   114
                    self displayLineFromX:x y:top
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
   115
                                      toX:x y:(top + longLen).
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   116
                    self displayString:pos asInteger printString
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   117
                                     x:(x + marg)
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   118
                                     y:charY
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   119
                ]
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   120
            ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   121
                (mod == 2) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   122
                    self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   123
                                      toX:x y:(top + shortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   124
                ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   125
                    self displayLineFromX:x y:top
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   126
                                      toX:x y:(top + veryShortLen)
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   127
                ]
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   128
            ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   129
            mod := (mod + 1) \\ 4.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   130
            pos := pos + 0.25.
6
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   131
            x := (pixelPerInch * pos - xOrigin) rounded
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   132
        ].
ff95fd6d4e96 *** empty log message ***
claus
parents: 4
diff changeset
   133
        self displayString:'inch ' x:marg y:charY.
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   134
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   135
    self redrawEdges
7
19b36b78ee01 *** empty log message ***
claus
parents: 6
diff changeset
   136
0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   137
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   138
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   139
!Ruler methodsFor:'initialization'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   140
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   141
initialize
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   142
    super initialize.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   143
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   144
    fgColor := Black.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   145
    self height:(font height + font descent + font descent). 
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   146
    (Language == #english) ifTrue:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   147
        metric := #inch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   148
    ] ifFalse:[
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   149
        metric := #mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   150
    ].
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   151
    paperWidth := 8.5.
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   152
    paperHeight := 11
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   153
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   154
    "Ruler new realize"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   155
! !
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   156
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   157
!Ruler methodsFor:'metric conversions'!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   158
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   159
inchToMillimeter:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   160
    "convert inches to mm"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   161
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   162
    ^ inches * 25.4
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   163
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   164
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   165
inchToPixel:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   166
    "convert inches to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   167
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   168
    ^ inches * self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   169
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   170
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   171
inchToTwip:inches
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   172
    "convert inches to twips"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   173
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   174
    ^ inches * 1440
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   175
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   176
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   177
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   178
millimeterToPixel:mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   179
    "convert mms to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   180
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   181
    ^ mm * self horizontalPixelPerMillimeter
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   182
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   183
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   184
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   185
millimeterToInch:mm
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   186
    "convert mm to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   187
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   188
    ^ mm / 25.4
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   189
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   190
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   191
pointToTwip:points
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   192
    "convert points to twips"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   193
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   194
    ^ points * 20
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   195
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   196
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   197
twipToInch:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   198
    "convert twips to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   199
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   200
    ^ twips / 1440.0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   201
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   202
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   203
pixelToInch:pixels
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   204
    "convert pixels to inches"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   205
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   206
    ^ pixels / self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   207
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   208
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   209
twipToPixel:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   210
    "convert twips to screen pixels"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   211
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   212
    ^ (twips / 1440.0) * self horizontalPixelPerInch
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   213
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   214
!
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   215
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   216
twipToPoint:twips
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   217
    "convert twips to points"
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   218
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   219
    ^ twips / 20.0
0fd7841626f6 Initial revision
claus
parents:
diff changeset
   220
! !