AlignOrg.st
author claus
Thu, 10 Aug 1995 20:44:27 +0200
changeset 88 f8a41aa4b34b
parent 83 97fd04d167c8
child 93 f2389560b8eb
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
88
claus
parents: 83
diff changeset
     1
"
claus
parents: 83
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 83
diff changeset
     3
              All Rights Reserved
claus
parents: 83
diff changeset
     4
claus
parents: 83
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents: 83
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents: 83
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents: 83
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents: 83
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents: 83
diff changeset
    10
 hereby transferred.
claus
parents: 83
diff changeset
    11
"
claus
parents: 83
diff changeset
    12
83
claus
parents:
diff changeset
    13
LayoutOrigin subclass:#AlignmentOrigin
claus
parents:
diff changeset
    14
	 instanceVariableNames:'leftAlignmentFraction topAlignmentFraction'
claus
parents:
diff changeset
    15
	 classVariableNames:''
claus
parents:
diff changeset
    16
	 poolDictionaries:''
claus
parents:
diff changeset
    17
	 category:'Graphics-Geometry'
claus
parents:
diff changeset
    18
!
claus
parents:
diff changeset
    19
88
claus
parents: 83
diff changeset
    20
!AlignmentOrigin class methodsFor:'documentation'!
claus
parents: 83
diff changeset
    21
claus
parents: 83
diff changeset
    22
copyright
claus
parents: 83
diff changeset
    23
"
claus
parents: 83
diff changeset
    24
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 83
diff changeset
    25
              All Rights Reserved
claus
parents: 83
diff changeset
    26
claus
parents: 83
diff changeset
    27
 This software is furnished under a license and may be used
claus
parents: 83
diff changeset
    28
 only in accordance with the terms of that license and with the
claus
parents: 83
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
claus
parents: 83
diff changeset
    30
 be provided or otherwise made available to, or used by, any
claus
parents: 83
diff changeset
    31
 other person.  No title to or ownership of the software is
claus
parents: 83
diff changeset
    32
 hereby transferred.
claus
parents: 83
diff changeset
    33
"
claus
parents: 83
diff changeset
    34
!
claus
parents: 83
diff changeset
    35
claus
parents: 83
diff changeset
    36
version
claus
parents: 83
diff changeset
    37
"
claus
parents: 83
diff changeset
    38
$Header: /cvs/stx/stx/libview2/Attic/AlignOrg.st,v 1.2 1995-08-10 18:43:06 claus Exp $
claus
parents: 83
diff changeset
    39
"
claus
parents: 83
diff changeset
    40
! !
claus
parents: 83
diff changeset
    41
83
claus
parents:
diff changeset
    42
!AlignmentOrigin methodsFor:'accessing'!
claus
parents:
diff changeset
    43
claus
parents:
diff changeset
    44
leftAlignmentFraction:something
claus
parents:
diff changeset
    45
    "set leftAlignmentFraction"
claus
parents:
diff changeset
    46
claus
parents:
diff changeset
    47
    leftAlignmentFraction := something.
claus
parents:
diff changeset
    48
!
claus
parents:
diff changeset
    49
claus
parents:
diff changeset
    50
leftAlignmentFraction
claus
parents:
diff changeset
    51
    "return leftAlignmentFraction"
claus
parents:
diff changeset
    52
claus
parents:
diff changeset
    53
    ^ leftAlignmentFraction
claus
parents:
diff changeset
    54
!
claus
parents:
diff changeset
    55
claus
parents:
diff changeset
    56
topAlignmentFraction:something
claus
parents:
diff changeset
    57
    "set topAlignmentFraction"
claus
parents:
diff changeset
    58
claus
parents:
diff changeset
    59
    topAlignmentFraction := something.
claus
parents:
diff changeset
    60
!
claus
parents:
diff changeset
    61
claus
parents:
diff changeset
    62
topAlignmentFraction
claus
parents:
diff changeset
    63
    "return topAlignmentFraction"
claus
parents:
diff changeset
    64
claus
parents:
diff changeset
    65
    ^ topFraction
claus
parents:
diff changeset
    66
! !
claus
parents:
diff changeset
    67
claus
parents:
diff changeset
    68
!AlignmentOrigin methodsFor:'printing & storing'!
claus
parents:
diff changeset
    69
claus
parents:
diff changeset
    70
displayString
claus
parents:
diff changeset
    71
    ^ 'LayoutOrigin(' 
claus
parents:
diff changeset
    72
	, 'l: ' , leftFraction displayString
claus
parents:
diff changeset
    73
	, '+' , leftOffset displayString
claus
parents:
diff changeset
    74
	, ' t: ' , topFraction displayString
claus
parents:
diff changeset
    75
	, '+' , topOffset displayString
claus
parents:
diff changeset
    76
	, ' a: ' , leftAlignmentFraction displayString
claus
parents:
diff changeset
    77
	, '@' , topAlignmentFraction displayString
claus
parents:
diff changeset
    78
	, ')'
claus
parents:
diff changeset
    79
! !
claus
parents:
diff changeset
    80
claus
parents:
diff changeset
    81
claus
parents:
diff changeset
    82
!AlignmentOrigin methodsFor:'queries'!
claus
parents:
diff changeset
    83
claus
parents:
diff changeset
    84
rectangleRelativeTo:superRectangle preferred:prefRect
claus
parents:
diff changeset
    85
    |x y|
claus
parents:
diff changeset
    86
claus
parents:
diff changeset
    87
    leftOffset isNil ifTrue:[
claus
parents:
diff changeset
    88
	x := 0
claus
parents:
diff changeset
    89
    ] ifFalse:[
claus
parents:
diff changeset
    90
	x := leftOffset
claus
parents:
diff changeset
    91
    ].
claus
parents:
diff changeset
    92
    topOffset isNil ifTrue:[
claus
parents:
diff changeset
    93
	y := 0
claus
parents:
diff changeset
    94
    ] ifFalse:[
claus
parents:
diff changeset
    95
	y := topOffset
claus
parents:
diff changeset
    96
    ].
claus
parents:
diff changeset
    97
    leftFraction notNil ifTrue:[
claus
parents:
diff changeset
    98
	x := x + (superRectangle width * leftFraction)
claus
parents:
diff changeset
    99
    ].
claus
parents:
diff changeset
   100
    topFraction notNil ifTrue:[
claus
parents:
diff changeset
   101
	y := y + (superRectangle height * topFraction)
claus
parents:
diff changeset
   102
    ].
claus
parents:
diff changeset
   103
    leftAlignmentFraction ~~ 0 ifTrue:[
claus
parents:
diff changeset
   104
	x := x - (prefRect width * leftAlignmentFraction)
claus
parents:
diff changeset
   105
    ].
claus
parents:
diff changeset
   106
    topAlignmentFraction ~~ 0 ifTrue:[
claus
parents:
diff changeset
   107
	y := y - (prefRect height * topAlignmentFraction)
claus
parents:
diff changeset
   108
    ].
claus
parents:
diff changeset
   109
    ^ Rectangle origin:x@y extent:prefRect extent
claus
parents:
diff changeset
   110
claus
parents:
diff changeset
   111
    "
claus
parents:
diff changeset
   112
     |superRect aO|
claus
parents:
diff changeset
   113
claus
parents:
diff changeset
   114
     superRect := 0@0 corner:100@100.
claus
parents:
diff changeset
   115
     aO := (AlignmentOrigin new).
claus
parents:
diff changeset
   116
     aO leftFraction:0.5;
claus
parents:
diff changeset
   117
	topFraction:0.5;
claus
parents:
diff changeset
   118
	leftAlignmentFraction:0.5;
claus
parents:
diff changeset
   119
	topAlignmentFraction:0.5.
claus
parents:
diff changeset
   120
     aO rectangleRelativeTo:superRect preferred:(0@0 corner:30@30) 
claus
parents:
diff changeset
   121
    "
claus
parents:
diff changeset
   122
! !
claus
parents:
diff changeset
   123
claus
parents:
diff changeset
   124
!AlignmentOrigin methodsFor:'initialization'!
claus
parents:
diff changeset
   125
claus
parents:
diff changeset
   126
initialize
claus
parents:
diff changeset
   127
    super initialize.
claus
parents:
diff changeset
   128
    leftAlignmentFraction := topAlignmentFraction := 0.
claus
parents:
diff changeset
   129
! !