VerticalRuler.st
author claus
Mon, 21 Nov 1994 17:49:32 +0100
changeset 28 ca403f4c5b86
parent 27 12e5a38bf0a8
child 33 3e68e4c73db3
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     1
"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1994 by Claus Gittinger
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     3
	      All Rights Reserved
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     4
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    11
"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    12
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    13
Ruler subclass:#VerticalRuler
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    14
	 instanceVariableNames:''
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    15
	 classVariableNames:''
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    16
	 poolDictionaries:''
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    17
	 category:'Views-Misc'
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    18
!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    19
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    20
VerticalRuler comment:'
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    21
COPYRIGHT (c) 1991 by Claus Gittinger
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    22
	      All Rights Reserved
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    23
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    24
a VerticalRuler for page layout.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    25
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
    26
$Header: /cvs/stx/stx/libwidg2/VerticalRuler.st,v 1.2 1994-11-21 16:48:22 claus Exp $
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    28
written oct 91 by claus
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    29
'!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    30
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    31
!VerticalRuler methodsFor:'accessing'!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    32
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    33
paperHeightInch:inches
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    34
    "set the width of the document"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    35
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    36
    paperHeight := inches.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    37
    shown ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    38
	self redraw
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    39
    ]
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    40
!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    41
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    42
paperHeightMM:millis
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    43
    "set the width of the document"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    44
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    45
    paperHeight := self millimeterToInch:millis.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    46
    shown ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    47
	self redraw
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    48
    ]
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    49
! !
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    50
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    51
!VerticalRuler methodsFor:'redrawing'!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    52
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    53
redraw
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
    54
    "redraw the scale"
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    55
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    56
    |y pixelPerMM pixelPerInch mod pos shortLen veryShortLen longLen charX
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    57
     left paperHeightMM paperHeightPixel yOrigin labelBot marg fontHeight|
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    58
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    59
    shown ifFalse:[^ self].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    60
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    61
    self clear.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    62
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    63
    yOrigin := self viewOrigin y.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    64
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    65
    paperHeightPixel := ((self inchToPixel:paperHeight) * scale) rounded.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    66
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    67
    (yOrigin + height > paperHeightPixel) ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    68
	self paint:(Color darkGrey).
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    69
	self fillRectangleX:0 y:paperHeightPixel - yOrigin
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    70
		      width:width
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    71
		      height:(height - (paperHeightPixel - yOrigin)).
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    72
	self paint:fgColor.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    73
	self displayLineFromX:0 y:paperHeightPixel - yOrigin
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    74
			  toX:width y:paperHeightPixel - yOrigin
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    75
    ].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    76
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    77
    self paint:fgColor.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    78
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    79
    left := 0. "width - (font widthOf:'WW')"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    80
    longLen := font widthOf:'WW'.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    81
    shortLen := longLen // 2.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    82
    charX := left + shortLen.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    83
    mod := 1.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    84
    marg := 3. "character shift"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    85
    fontHeight := font height.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    86
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    87
    (metric == #mm) ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    88
	"centimeter - long blibs every centimeter; short ones every half"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    89
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    90
	paperHeightMM := self inchToMillimeter:paperHeight.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    91
	pixelPerMM := (self millimeterToPixel:1) * scale.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    92
	pos := 5.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    93
	labelBot := marg + font height + font ascent.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    94
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    95
	y := (pixelPerMM * pos - yOrigin) rounded.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
    96
	[(y < height) and:[pos <= paperHeightMM]] whileTrue:[
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
    97
	    |l|
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
    98
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
    99
	    l := shortLen.
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   100
	    (mod ~~ 1) ifTrue:[
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   101
		y < labelBot ifFalse:[
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   102
		    l := longLen
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   103
		]
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   104
	    ].
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   105
	    self displayLineFromX:left y:y toX:(left + l) y:y.
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   106
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   107
	    (mod ~~ 1 and:[y >= labelBot]) ifTrue:[
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   108
		self displayString:(pos // 10) printString
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   109
				 x:charX
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   110
				 y:(y + marg + fontHeight)
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   111
	    ].
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   112
	    mod := (mod + 1) \\ 2.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   113
	    pos := pos + 5.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   114
	    y := (pixelPerMM * pos - yOrigin) rounded 
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   115
	].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   116
	self displayString:'cm ' x:charX y:marg + fontHeight.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   117
    ].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   118
    (metric == #inch) ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   119
	"inches - long blibs every inch; short ones every half; very
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   120
	 short ones every quarter"
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   121
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   122
	pixelPerInch := (self inchToPixel:1) * scale.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   123
	pos := 0.25.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   124
	labelBot := marg + (font height + font ascent).
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   125
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   126
	y := (pixelPerInch * pos - yOrigin) rounded.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   127
	veryShortLen := longLen // 4.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   128
	[(y < height) and:[pos <= paperHeight]] whileTrue:[
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   129
	    |l|
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   130
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   131
	    l := shortLen.
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   132
	    (mod == 0) ifTrue:[
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   133
		y < labelBot ifFalse:[
28
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   134
		    l := longLen.
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   135
		]
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   136
	    ] ifFalse:[
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   137
		(mod == 2) ifFalse:[
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   138
		    l := veryShortLen
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   139
		]
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   140
	    ].
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   141
	    self displayLineFromX:left y:y toX:(left + l) y:y.
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   142
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   143
	    (mod == 0) ifTrue:[
ca403f4c5b86 *** empty log message ***
claus
parents: 27
diff changeset
   144
		y < labelBot ifFalse:[
27
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   145
		    self displayString:pos asInteger printString
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   146
				     x:charX
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   147
				     y:(y + marg + fontHeight)
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   148
		]
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   149
	    ].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   150
	    mod := (mod + 1) \\ 4.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   151
	    pos := pos + 0.25.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   152
	    y := (pixelPerInch * pos - yOrigin) rounded
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   153
	].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   154
	self displayString:'inch ' x:charX y:marg + fontHeight.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   155
    ].
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   156
    self redrawEdges
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   157
! !
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   158
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   159
!VerticalRuler methodsFor:'initialization'!
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   160
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   161
initialize
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   162
    super initialize.
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   163
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   164
    self width:(font widthOf:'inch').
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   165
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   166
    "
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   167
     VerticalRuler new open
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   168
    "
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   169
! !
12e5a38bf0a8 Initial revision
claus
parents:
diff changeset
   170