Color.st
author claus
Fri, 16 Jul 1993 11:42:20 +0200
changeset 0 48194c26a46c
child 2 b35336ab0de3
permissions -rw-r--r--
Initial revision
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     1
"
48194c26a46c Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1992-93 by Claus Gittinger
48194c26a46c Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
48194c26a46c Initial revision
claus
parents:
diff changeset
     4
48194c26a46c Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
48194c26a46c Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
48194c26a46c Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
48194c26a46c Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
48194c26a46c Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
48194c26a46c Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
48194c26a46c Initial revision
claus
parents:
diff changeset
    11
"
48194c26a46c Initial revision
claus
parents:
diff changeset
    12
48194c26a46c Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Color
48194c26a46c Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'redVal greenVal blueVal device colorId ditherForm'
48194c26a46c Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:'lobby
48194c26a46c Initial revision
claus
parents:
diff changeset
    16
                           Black White LightGrey Grey DarkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
    17
                           Pseudo0 Pseudo1 PseudoAll
48194c26a46c Initial revision
claus
parents:
diff changeset
    18
                           Red Green Blue DitherColors'
48194c26a46c Initial revision
claus
parents:
diff changeset
    19
       poolDictionaries:''
48194c26a46c Initial revision
claus
parents:
diff changeset
    20
       category:'Graphics-Support'
48194c26a46c Initial revision
claus
parents:
diff changeset
    21
!
48194c26a46c Initial revision
claus
parents:
diff changeset
    22
48194c26a46c Initial revision
claus
parents:
diff changeset
    23
Color comment:'
48194c26a46c Initial revision
claus
parents:
diff changeset
    24
48194c26a46c Initial revision
claus
parents:
diff changeset
    25
COPYRIGHT (c) 1992-93 by Claus Gittinger
48194c26a46c Initial revision
claus
parents:
diff changeset
    26
              All Rights Reserved
48194c26a46c Initial revision
claus
parents:
diff changeset
    27
48194c26a46c Initial revision
claus
parents:
diff changeset
    28
see Color documentation for more info
48194c26a46c Initial revision
claus
parents:
diff changeset
    29
48194c26a46c Initial revision
claus
parents:
diff changeset
    30
%W% %E%
48194c26a46c Initial revision
claus
parents:
diff changeset
    31
totally rewritten summer 92 by claus (from XColor)
48194c26a46c Initial revision
claus
parents:
diff changeset
    32
'!
48194c26a46c Initial revision
claus
parents:
diff changeset
    33
48194c26a46c Initial revision
claus
parents:
diff changeset
    34
!Color class methodsFor:'documentation'!
48194c26a46c Initial revision
claus
parents:
diff changeset
    35
48194c26a46c Initial revision
claus
parents:
diff changeset
    36
documentation
48194c26a46c Initial revision
claus
parents:
diff changeset
    37
    "
48194c26a46c Initial revision
claus
parents:
diff changeset
    38
Color represents colors in a device independent manner, main info I keep about
48194c26a46c Initial revision
claus
parents:
diff changeset
    39
mySelf are the red, green and blue components in percent (0 .. 100).
48194c26a46c Initial revision
claus
parents:
diff changeset
    40
The device specific color can be aquired by sending a color the 'on:aDevice' message,
48194c26a46c Initial revision
claus
parents:
diff changeset
    41
which will return a color with the same rgb values as the receiver but specific
48194c26a46c Initial revision
claus
parents:
diff changeset
    42
for that device.
48194c26a46c Initial revision
claus
parents:
diff changeset
    43
48194c26a46c Initial revision
claus
parents:
diff changeset
    44
Colors can be pure or dithered, depending on the capabilities of the device. 
48194c26a46c Initial revision
claus
parents:
diff changeset
    45
For plain colors, the colorId-instvar is a handle (usually lookup-table entry) for that
48194c26a46c Initial revision
claus
parents:
diff changeset
    46
device. For dithered colors, the colorId is nil and ditherForm specifies the form
48194c26a46c Initial revision
claus
parents:
diff changeset
    47
used to dither that color (which can have a colormap and need 2 or more plain colors).
48194c26a46c Initial revision
claus
parents:
diff changeset
    48
48194c26a46c Initial revision
claus
parents:
diff changeset
    49
Instance variables:
48194c26a46c Initial revision
claus
parents:
diff changeset
    50
48194c26a46c Initial revision
claus
parents:
diff changeset
    51
redVal          <Number>        the red component (0..100)
48194c26a46c Initial revision
claus
parents:
diff changeset
    52
greenVal        <Number>        the green component (0..100)
48194c26a46c Initial revision
claus
parents:
diff changeset
    53
blueVal         <Number>        the blue component (0..100)
48194c26a46c Initial revision
claus
parents:
diff changeset
    54
device          <aDevice>       the device I am on, or nil
48194c26a46c Initial revision
claus
parents:
diff changeset
    55
colorId         <anObject>      some device dependent identifier (or nil if dithered)
48194c26a46c Initial revision
claus
parents:
diff changeset
    56
ditherForm      <aForm>         the Form to dither this color (if non-nil)
48194c26a46c Initial revision
claus
parents:
diff changeset
    57
48194c26a46c Initial revision
claus
parents:
diff changeset
    58
Class variables:
48194c26a46c Initial revision
claus
parents:
diff changeset
    59
48194c26a46c Initial revision
claus
parents:
diff changeset
    60
lobby           <Registry>      keeps track of dead colors
48194c26a46c Initial revision
claus
parents:
diff changeset
    61
48194c26a46c Initial revision
claus
parents:
diff changeset
    62
Black           <Color>         for fast return of black
48194c26a46c Initial revision
claus
parents:
diff changeset
    63
White           <Color>         for fast return of white
48194c26a46c Initial revision
claus
parents:
diff changeset
    64
Grey            <Color>         for fast return of grey
48194c26a46c Initial revision
claus
parents:
diff changeset
    65
LightGrey       <Color>         for fast return of lightGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
    66
DarkGrey        <Color>         for fast return of darkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
    67
48194c26a46c Initial revision
claus
parents:
diff changeset
    68
Pseudo0         <Color>         a color with 0 as handle (for forms and bitblit)
48194c26a46c Initial revision
claus
parents:
diff changeset
    69
Pseudo1         <Color>         a color with 1 as handle (for forms)
48194c26a46c Initial revision
claus
parents:
diff changeset
    70
PseudoAll       <Color>         a color with allPlanes as handle (for bitblit)
48194c26a46c Initial revision
claus
parents:
diff changeset
    71
48194c26a46c Initial revision
claus
parents:
diff changeset
    72
Red             <Color>         red, needed for dithering
48194c26a46c Initial revision
claus
parents:
diff changeset
    73
Green           <Color>         green, for dithering
48194c26a46c Initial revision
claus
parents:
diff changeset
    74
Blue            <Color>         blue, for dithering
48194c26a46c Initial revision
claus
parents:
diff changeset
    75
48194c26a46c Initial revision
claus
parents:
diff changeset
    76
DitherColors    <Collection>    some preallocated colors for dithering
48194c26a46c Initial revision
claus
parents:
diff changeset
    77
                                (kept, so they are available when needed)
48194c26a46c Initial revision
claus
parents:
diff changeset
    78
48194c26a46c Initial revision
claus
parents:
diff changeset
    79
%W% %E%
48194c26a46c Initial revision
claus
parents:
diff changeset
    80
totally rewritten summer 92 by claus (from XColor)
48194c26a46c Initial revision
claus
parents:
diff changeset
    81
    "
48194c26a46c Initial revision
claus
parents:
diff changeset
    82
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
    83
48194c26a46c Initial revision
claus
parents:
diff changeset
    84
!Color class methodsFor:'initialization'!
48194c26a46c Initial revision
claus
parents:
diff changeset
    85
48194c26a46c Initial revision
claus
parents:
diff changeset
    86
initialize
48194c26a46c Initial revision
claus
parents:
diff changeset
    87
    "setup tracker of known colors and initialize classvars with
48194c26a46c Initial revision
claus
parents:
diff changeset
    88
     heavily used colors"
48194c26a46c Initial revision
claus
parents:
diff changeset
    89
48194c26a46c Initial revision
claus
parents:
diff changeset
    90
    lobby isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
    91
        lobby := Registry new.
48194c26a46c Initial revision
claus
parents:
diff changeset
    92
48194c26a46c Initial revision
claus
parents:
diff changeset
    93
        self getPrimaryColors.
48194c26a46c Initial revision
claus
parents:
diff changeset
    94
48194c26a46c Initial revision
claus
parents:
diff changeset
    95
        "want to be informed when returning from snapshot"
48194c26a46c Initial revision
claus
parents:
diff changeset
    96
        ObjectMemory addDependent:self.
48194c26a46c Initial revision
claus
parents:
diff changeset
    97
48194c26a46c Initial revision
claus
parents:
diff changeset
    98
        Smalltalk at:#ColorValue put:self "for ST-80 compatibility"
48194c26a46c Initial revision
claus
parents:
diff changeset
    99
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   100
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   101
48194c26a46c Initial revision
claus
parents:
diff changeset
   102
getPrimaryColors
48194c26a46c Initial revision
claus
parents:
diff changeset
   103
    White := (self red:100 green:100 blue:100) exactOn:Display.
48194c26a46c Initial revision
claus
parents:
diff changeset
   104
    Black := (self red:0 green:0 blue:0) exactOn:Display.
48194c26a46c Initial revision
claus
parents:
diff changeset
   105
48194c26a46c Initial revision
claus
parents:
diff changeset
   106
    Display hasColors ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   107
        Red := (self red:100 green:0 blue:0) exactOn:Display.
48194c26a46c Initial revision
claus
parents:
diff changeset
   108
        Green := (self red:0 green:100 blue:0) exactOn:Display.
48194c26a46c Initial revision
claus
parents:
diff changeset
   109
        Blue := (self red:0 green:0 blue:100) exactOn:Display.
48194c26a46c Initial revision
claus
parents:
diff changeset
   110
48194c26a46c Initial revision
claus
parents:
diff changeset
   111
        Display ncells < 256 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   112
             "on low-color resolution displays, allocate some colors
48194c26a46c Initial revision
claus
parents:
diff changeset
   113
              for dithering - otherwise, they may not be available when
48194c26a46c Initial revision
claus
parents:
diff changeset
   114
              we need them ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
   115
48194c26a46c Initial revision
claus
parents:
diff changeset
   116
             DitherColors := OrderedCollection new.
48194c26a46c Initial revision
claus
parents:
diff changeset
   117
             DitherColors add:((self red:100 green:100 blue:0) exactOn:Display).
48194c26a46c Initial revision
claus
parents:
diff changeset
   118
             DitherColors add:((self red:100 green:0 blue:100) exactOn:Display).
48194c26a46c Initial revision
claus
parents:
diff changeset
   119
             DitherColors add:((self red:0 green:100 blue:100) exactOn:Display).
48194c26a46c Initial revision
claus
parents:
diff changeset
   120
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   121
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   122
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   123
48194c26a46c Initial revision
claus
parents:
diff changeset
   124
flushDeviceColors
48194c26a46c Initial revision
claus
parents:
diff changeset
   125
    "unassign all colors from their device"
48194c26a46c Initial revision
claus
parents:
diff changeset
   126
48194c26a46c Initial revision
claus
parents:
diff changeset
   127
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   128
        aColor resetDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
   129
        lobby changed:aColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   130
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   131
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   132
48194c26a46c Initial revision
claus
parents:
diff changeset
   133
update:something
48194c26a46c Initial revision
claus
parents:
diff changeset
   134
    (something == #restarted) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   135
        self flushDeviceColors
48194c26a46c Initial revision
claus
parents:
diff changeset
   136
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   137
    (something == #returnFromSnapshot) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   138
        self getPrimaryColors
48194c26a46c Initial revision
claus
parents:
diff changeset
   139
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   140
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   141
48194c26a46c Initial revision
claus
parents:
diff changeset
   142
!Color class methodsFor:'instance creation'!
48194c26a46c Initial revision
claus
parents:
diff changeset
   143
48194c26a46c Initial revision
claus
parents:
diff changeset
   144
white
48194c26a46c Initial revision
claus
parents:
diff changeset
   145
    "return the white-color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   146
48194c26a46c Initial revision
claus
parents:
diff changeset
   147
    White isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   148
        White := (self red:100 green:100 blue:100) exactOn:Display
48194c26a46c Initial revision
claus
parents:
diff changeset
   149
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   150
    ^ White
48194c26a46c Initial revision
claus
parents:
diff changeset
   151
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   152
48194c26a46c Initial revision
claus
parents:
diff changeset
   153
black
48194c26a46c Initial revision
claus
parents:
diff changeset
   154
    "return the black-color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   155
48194c26a46c Initial revision
claus
parents:
diff changeset
   156
    Black isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   157
        Black := (self red:0 green:0 blue:0) exactOn:Display
48194c26a46c Initial revision
claus
parents:
diff changeset
   158
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   159
    ^ Black
48194c26a46c Initial revision
claus
parents:
diff changeset
   160
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   161
48194c26a46c Initial revision
claus
parents:
diff changeset
   162
mediumGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   163
    "return medium-grey color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   164
48194c26a46c Initial revision
claus
parents:
diff changeset
   165
    ^ self grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   166
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   167
48194c26a46c Initial revision
claus
parents:
diff changeset
   168
veryLightGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   169
    ^ self grey:87
48194c26a46c Initial revision
claus
parents:
diff changeset
   170
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   171
48194c26a46c Initial revision
claus
parents:
diff changeset
   172
lightGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   173
    "return light-grey color -
48194c26a46c Initial revision
claus
parents:
diff changeset
   174
     take value from resource file - 67% is very dark on some, very light
48194c26a46c Initial revision
claus
parents:
diff changeset
   175
     on other displays ... sigh"
48194c26a46c Initial revision
claus
parents:
diff changeset
   176
48194c26a46c Initial revision
claus
parents:
diff changeset
   177
    LightGrey isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   178
        LightGrey := self grey:(Resource name:'COLOR_LIGHTGREY_VALUE'
48194c26a46c Initial revision
claus
parents:
diff changeset
   179
                                      default:67 
48194c26a46c Initial revision
claus
parents:
diff changeset
   180
                                     fromFile:'Smalltalk.rs')
48194c26a46c Initial revision
claus
parents:
diff changeset
   181
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   182
    ^ LightGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   183
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   184
48194c26a46c Initial revision
claus
parents:
diff changeset
   185
darkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   186
    "return dark-grey color -
48194c26a46c Initial revision
claus
parents:
diff changeset
   187
     take value from resource file - 33% is very dark on some, very light
48194c26a46c Initial revision
claus
parents:
diff changeset
   188
     on other displays ... sigh"
48194c26a46c Initial revision
claus
parents:
diff changeset
   189
48194c26a46c Initial revision
claus
parents:
diff changeset
   190
    DarkGrey isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   191
        DarkGrey := self grey:(Resource name:'COLOR_DARKGREY_VALUE'
48194c26a46c Initial revision
claus
parents:
diff changeset
   192
                                     default:33
48194c26a46c Initial revision
claus
parents:
diff changeset
   193
                                    fromFile:'Smalltalk.rs')
48194c26a46c Initial revision
claus
parents:
diff changeset
   194
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   195
    ^ DarkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   196
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   197
48194c26a46c Initial revision
claus
parents:
diff changeset
   198
veryDarkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   199
    ^ self grey:13
48194c26a46c Initial revision
claus
parents:
diff changeset
   200
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   201
48194c26a46c Initial revision
claus
parents:
diff changeset
   202
grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   203
    "return a medium grey color -
48194c26a46c Initial revision
claus
parents:
diff changeset
   204
     take value from resource file - 50% is very dark on some, very light
48194c26a46c Initial revision
claus
parents:
diff changeset
   205
     on other displays ... sigh"
48194c26a46c Initial revision
claus
parents:
diff changeset
   206
48194c26a46c Initial revision
claus
parents:
diff changeset
   207
    Grey isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   208
        Grey := self grey:(Resource name:'COLOR_GREY_VALUE' 
48194c26a46c Initial revision
claus
parents:
diff changeset
   209
                                 default:50
48194c26a46c Initial revision
claus
parents:
diff changeset
   210
                                fromFile:'Smalltalk.rs')
48194c26a46c Initial revision
claus
parents:
diff changeset
   211
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   212
    ^ Grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   213
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   214
48194c26a46c Initial revision
claus
parents:
diff changeset
   215
grey:grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   216
    "return a grey color. The argument, grey is interpreted as
48194c26a46c Initial revision
claus
parents:
diff changeset
   217
     percent (0..100)."
48194c26a46c Initial revision
claus
parents:
diff changeset
   218
48194c26a46c Initial revision
claus
parents:
diff changeset
   219
    ^ self red:grey green:grey blue:grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   220
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   221
48194c26a46c Initial revision
claus
parents:
diff changeset
   222
gray
48194c26a46c Initial revision
claus
parents:
diff changeset
   223
    "return grey"
48194c26a46c Initial revision
claus
parents:
diff changeset
   224
48194c26a46c Initial revision
claus
parents:
diff changeset
   225
    ^ self grey
48194c26a46c Initial revision
claus
parents:
diff changeset
   226
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   227
48194c26a46c Initial revision
claus
parents:
diff changeset
   228
lightGray
48194c26a46c Initial revision
claus
parents:
diff changeset
   229
    "return lightGrey"
48194c26a46c Initial revision
claus
parents:
diff changeset
   230
48194c26a46c Initial revision
claus
parents:
diff changeset
   231
    ^ self lightGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   232
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   233
48194c26a46c Initial revision
claus
parents:
diff changeset
   234
darkGray
48194c26a46c Initial revision
claus
parents:
diff changeset
   235
    "return darkGrey"
48194c26a46c Initial revision
claus
parents:
diff changeset
   236
48194c26a46c Initial revision
claus
parents:
diff changeset
   237
    ^ self darkGrey
48194c26a46c Initial revision
claus
parents:
diff changeset
   238
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   239
48194c26a46c Initial revision
claus
parents:
diff changeset
   240
red
48194c26a46c Initial revision
claus
parents:
diff changeset
   241
    "return red"
48194c26a46c Initial revision
claus
parents:
diff changeset
   242
48194c26a46c Initial revision
claus
parents:
diff changeset
   243
    Red isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   244
        Red := self red:100 green:0 blue:0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   245
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   246
    ^ Red
48194c26a46c Initial revision
claus
parents:
diff changeset
   247
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   248
48194c26a46c Initial revision
claus
parents:
diff changeset
   249
green
48194c26a46c Initial revision
claus
parents:
diff changeset
   250
    "return green"
48194c26a46c Initial revision
claus
parents:
diff changeset
   251
48194c26a46c Initial revision
claus
parents:
diff changeset
   252
    Green isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   253
        Green := self red:0 green:100 blue:0
48194c26a46c Initial revision
claus
parents:
diff changeset
   254
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   255
    ^ Green
48194c26a46c Initial revision
claus
parents:
diff changeset
   256
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   257
48194c26a46c Initial revision
claus
parents:
diff changeset
   258
blue
48194c26a46c Initial revision
claus
parents:
diff changeset
   259
    "return blue"
48194c26a46c Initial revision
claus
parents:
diff changeset
   260
48194c26a46c Initial revision
claus
parents:
diff changeset
   261
    Blue isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   262
        Blue := self red:0 green:0 blue:100
48194c26a46c Initial revision
claus
parents:
diff changeset
   263
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   264
    ^ Blue
48194c26a46c Initial revision
claus
parents:
diff changeset
   265
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   266
48194c26a46c Initial revision
claus
parents:
diff changeset
   267
red:r green:g blue:b
48194c26a46c Initial revision
claus
parents:
diff changeset
   268
    "return a color from red, green and blue values;
48194c26a46c Initial revision
claus
parents:
diff changeset
   269
     the arguments, r, g and b are interpreted as percent (0..100)"
48194c26a46c Initial revision
claus
parents:
diff changeset
   270
48194c26a46c Initial revision
claus
parents:
diff changeset
   271
    |newColor rr rg rb|
48194c26a46c Initial revision
claus
parents:
diff changeset
   272
48194c26a46c Initial revision
claus
parents:
diff changeset
   273
    "round to 1/300 i.e. to about 0.33%"
48194c26a46c Initial revision
claus
parents:
diff changeset
   274
48194c26a46c Initial revision
claus
parents:
diff changeset
   275
    rr := (r * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   276
    rg := (g * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   277
    rb := (b * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   278
48194c26a46c Initial revision
claus
parents:
diff changeset
   279
    "look if already known"
48194c26a46c Initial revision
claus
parents:
diff changeset
   280
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   281
        (rr = aColor red) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   282
            (rg = aColor green) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   283
                (rb = aColor blue) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   284
                    ^ aColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   285
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   286
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   287
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   288
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   289
    newColor := self basicNew setRed:rr green:rg blue:rb device:nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   290
    lobby register:newColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   291
    ^ newColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   292
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   293
48194c26a46c Initial revision
claus
parents:
diff changeset
   294
name:aString
48194c26a46c Initial revision
claus
parents:
diff changeset
   295
    "return a named color - or try do do as good as possible"
48194c26a46c Initial revision
claus
parents:
diff changeset
   296
48194c26a46c Initial revision
claus
parents:
diff changeset
   297
    ^ self nameOrDither:aString
48194c26a46c Initial revision
claus
parents:
diff changeset
   298
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   299
48194c26a46c Initial revision
claus
parents:
diff changeset
   300
nameOrDither:aString
48194c26a46c Initial revision
claus
parents:
diff changeset
   301
    "return a named color - if the exact color is not available,
48194c26a46c Initial revision
claus
parents:
diff changeset
   302
     return a dithered color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   303
48194c26a46c Initial revision
claus
parents:
diff changeset
   304
    Display getRGBFromName:aString into:[:r :g :b |
48194c26a46c Initial revision
claus
parents:
diff changeset
   305
        r notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   306
            ^ self red:r green:g blue:b
48194c26a46c Initial revision
claus
parents:
diff changeset
   307
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   308
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   309
    self error:'no color named ' , aString.
48194c26a46c Initial revision
claus
parents:
diff changeset
   310
    ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   311
48194c26a46c Initial revision
claus
parents:
diff changeset
   312
    "Color nameOrDither:'Brown'"
48194c26a46c Initial revision
claus
parents:
diff changeset
   313
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   314
48194c26a46c Initial revision
claus
parents:
diff changeset
   315
nameOrNearest:aString
48194c26a46c Initial revision
claus
parents:
diff changeset
   316
    "return a named color - or its nearest match"
48194c26a46c Initial revision
claus
parents:
diff changeset
   317
48194c26a46c Initial revision
claus
parents:
diff changeset
   318
    |id newColor|
48194c26a46c Initial revision
claus
parents:
diff changeset
   319
48194c26a46c Initial revision
claus
parents:
diff changeset
   320
    id := Display colorNamed:aString.
48194c26a46c Initial revision
claus
parents:
diff changeset
   321
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   322
        ObjectMemory scavenge.
48194c26a46c Initial revision
claus
parents:
diff changeset
   323
        id := Display colorNamed:aString.
48194c26a46c Initial revision
claus
parents:
diff changeset
   324
        id isNil ifTrue:[^ nil].
48194c26a46c Initial revision
claus
parents:
diff changeset
   325
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   326
    newColor := self basicNew.
48194c26a46c Initial revision
claus
parents:
diff changeset
   327
    Display getRGBFrom:id into:[:r :g :b |
48194c26a46c Initial revision
claus
parents:
diff changeset
   328
        newColor setRed:r green:g blue:b device:Display
48194c26a46c Initial revision
claus
parents:
diff changeset
   329
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   330
    newColor colorId:id.
48194c26a46c Initial revision
claus
parents:
diff changeset
   331
    lobby register:newColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   332
    ^ newColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   333
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   334
48194c26a46c Initial revision
claus
parents:
diff changeset
   335
nearestColorRed:r green:g blue:b error:error on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   336
    "return a device color on aDevice with rgb values
48194c26a46c Initial revision
claus
parents:
diff changeset
   337
     same or near r/g/b, if there is one, nil otherwise.
48194c26a46c Initial revision
claus
parents:
diff changeset
   338
     Near is defined as having an error less than the argument
48194c26a46c Initial revision
claus
parents:
diff changeset
   339
     error (in percent). The error is computed by the color
48194c26a46c Initial revision
claus
parents:
diff changeset
   340
     vector distance (which is not the best possible solution)."
48194c26a46c Initial revision
claus
parents:
diff changeset
   341
48194c26a46c Initial revision
claus
parents:
diff changeset
   342
    "first try exact color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   343
48194c26a46c Initial revision
claus
parents:
diff changeset
   344
    |delta minDelta bestSoFar rr rg rb|
48194c26a46c Initial revision
claus
parents:
diff changeset
   345
48194c26a46c Initial revision
claus
parents:
diff changeset
   346
    "round to 1/300 i.e. to about 0.3%"
48194c26a46c Initial revision
claus
parents:
diff changeset
   347
48194c26a46c Initial revision
claus
parents:
diff changeset
   348
    rr := (r * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   349
    rg := (g * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   350
    rb := (b * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   351
48194c26a46c Initial revision
claus
parents:
diff changeset
   352
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   353
        (aColor device == aDevice) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   354
            (aColor colorId notNil) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   355
                (rr = aColor red) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   356
                    (rg = aColor green) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   357
                        (rb = aColor blue) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   358
                            ^ aColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   359
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   360
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   361
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   362
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   363
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   364
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   365
48194c26a46c Initial revision
claus
parents:
diff changeset
   366
    "exact color was not available, search for the one with the
48194c26a46c Initial revision
claus
parents:
diff changeset
   367
     smallest delta"
48194c26a46c Initial revision
claus
parents:
diff changeset
   368
48194c26a46c Initial revision
claus
parents:
diff changeset
   369
    minDelta := 999999.
48194c26a46c Initial revision
claus
parents:
diff changeset
   370
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   371
        (aColor device == aDevice) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   372
            (aColor colorId notNil) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   373
                delta := ((rr - aColor red) squared * 0.3)
48194c26a46c Initial revision
claus
parents:
diff changeset
   374
                         + ((rg - aColor green) squared * 0.6)
48194c26a46c Initial revision
claus
parents:
diff changeset
   375
                         + ((rb - aColor blue) squared * 0.1).
48194c26a46c Initial revision
claus
parents:
diff changeset
   376
48194c26a46c Initial revision
claus
parents:
diff changeset
   377
                delta < minDelta ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   378
                    bestSoFar := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   379
                    minDelta := delta
48194c26a46c Initial revision
claus
parents:
diff changeset
   380
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   381
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   382
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   383
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   384
48194c26a46c Initial revision
claus
parents:
diff changeset
   385
    minDelta < error squared ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   386
        ^ bestSoFar
48194c26a46c Initial revision
claus
parents:
diff changeset
   387
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   388
48194c26a46c Initial revision
claus
parents:
diff changeset
   389
    ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   390
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   391
48194c26a46c Initial revision
claus
parents:
diff changeset
   392
hue:h light:l saturation:s
48194c26a46c Initial revision
claus
parents:
diff changeset
   393
    "return a color from hue, light and saturation values"
48194c26a46c Initial revision
claus
parents:
diff changeset
   394
48194c26a46c Initial revision
claus
parents:
diff changeset
   395
    self withRGBFromHue:h light:l saturation:s do:[:r :g :b |
48194c26a46c Initial revision
claus
parents:
diff changeset
   396
        ^ self red:r green:g blue:b
48194c26a46c Initial revision
claus
parents:
diff changeset
   397
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   398
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   399
48194c26a46c Initial revision
claus
parents:
diff changeset
   400
noColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   401
    "return a special color which, when used for bit-blitting will
48194c26a46c Initial revision
claus
parents:
diff changeset
   402
     behave like a 0-color (i.e. have a device-pixel value of all-0s)"
48194c26a46c Initial revision
claus
parents:
diff changeset
   403
48194c26a46c Initial revision
claus
parents:
diff changeset
   404
    ^ self basicNew colorId:0
48194c26a46c Initial revision
claus
parents:
diff changeset
   405
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   406
48194c26a46c Initial revision
claus
parents:
diff changeset
   407
allColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   408
    "return a special color which, when used for bit-blitting will
48194c26a46c Initial revision
claus
parents:
diff changeset
   409
     behave like a all-1-color (i.e. have a device-pixel value of all-1s)"
48194c26a46c Initial revision
claus
parents:
diff changeset
   410
48194c26a46c Initial revision
claus
parents:
diff changeset
   411
    ^ self basicNew colorId:-1
48194c26a46c Initial revision
claus
parents:
diff changeset
   412
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   413
48194c26a46c Initial revision
claus
parents:
diff changeset
   414
colorId:id
48194c26a46c Initial revision
claus
parents:
diff changeset
   415
    "return a color for a specific colorid without associating it to a
48194c26a46c Initial revision
claus
parents:
diff changeset
   416
     specific device. Use this only for bitmaps which want 0- or 1-color,
48194c26a46c Initial revision
claus
parents:
diff changeset
   417
     or for bitblits if you want to manipulate a specific colorplane."
48194c26a46c Initial revision
claus
parents:
diff changeset
   418
48194c26a46c Initial revision
claus
parents:
diff changeset
   419
    id == 0 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   420
        Pseudo0 isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   421
            Pseudo0 := self basicNew colorId:0
48194c26a46c Initial revision
claus
parents:
diff changeset
   422
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   423
        ^ Pseudo0
48194c26a46c Initial revision
claus
parents:
diff changeset
   424
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   425
    id == 1 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   426
        Pseudo1 isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   427
            Pseudo1 := self basicNew colorId:1
48194c26a46c Initial revision
claus
parents:
diff changeset
   428
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   429
        ^ Pseudo1
48194c26a46c Initial revision
claus
parents:
diff changeset
   430
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   431
    id == -1 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   432
        PseudoAll isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   433
            PseudoAll := self basicNew colorId:-1
48194c26a46c Initial revision
claus
parents:
diff changeset
   434
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   435
        ^ PseudoAll
48194c26a46c Initial revision
claus
parents:
diff changeset
   436
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   437
    ^ self basicNew colorId:id
48194c26a46c Initial revision
claus
parents:
diff changeset
   438
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   439
48194c26a46c Initial revision
claus
parents:
diff changeset
   440
!Color class methodsFor:'private'!
48194c26a46c Initial revision
claus
parents:
diff changeset
   441
48194c26a46c Initial revision
claus
parents:
diff changeset
   442
existingColorRed:r green:g blue:b on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   443
    "return a device color on aDevice with rgb values
48194c26a46c Initial revision
claus
parents:
diff changeset
   444
     if there is one, nil otherwise."
48194c26a46c Initial revision
claus
parents:
diff changeset
   445
48194c26a46c Initial revision
claus
parents:
diff changeset
   446
    |rr rg rb|
48194c26a46c Initial revision
claus
parents:
diff changeset
   447
48194c26a46c Initial revision
claus
parents:
diff changeset
   448
    rr := (r * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   449
    rg := (g * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   450
    rb := (b * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   451
48194c26a46c Initial revision
claus
parents:
diff changeset
   452
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   453
        (aColor device == aDevice) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   454
            aColor colorId notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   455
                (rr = aColor red) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   456
                    (rg = aColor green) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   457
                        (rb = aColor blue) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   458
                            ^ aColor
48194c26a46c Initial revision
claus
parents:
diff changeset
   459
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   460
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   461
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   462
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   463
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   464
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   465
    ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   466
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   467
48194c26a46c Initial revision
claus
parents:
diff changeset
   468
colorNearRed:r green:g blue:b on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   469
    "return a device color on aDevice with rgb values
48194c26a46c Initial revision
claus
parents:
diff changeset
   470
     almost matching. If there is one, nil otherwise.
48194c26a46c Initial revision
claus
parents:
diff changeset
   471
     This is tried as a last chance before dithering.
48194c26a46c Initial revision
claus
parents:
diff changeset
   472
     The algorithm needs rework, the color components
48194c26a46c Initial revision
claus
parents:
diff changeset
   473
     should be weighted according some theory :-)"
48194c26a46c Initial revision
claus
parents:
diff changeset
   474
48194c26a46c Initial revision
claus
parents:
diff changeset
   475
    |bestColor minDelta diff rr rg rb|
48194c26a46c Initial revision
claus
parents:
diff changeset
   476
48194c26a46c Initial revision
claus
parents:
diff changeset
   477
    rr := (r * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   478
    rg := (g * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   479
    rb := (b * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   480
48194c26a46c Initial revision
claus
parents:
diff changeset
   481
    minDelta := 100*100*100.
48194c26a46c Initial revision
claus
parents:
diff changeset
   482
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   483
        (aColor device == aDevice) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   484
            (aColor colorId notNil) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   485
                diff := (rr - aColor red) asInteger squared
48194c26a46c Initial revision
claus
parents:
diff changeset
   486
                        + (rg - aColor green) asInteger squared
48194c26a46c Initial revision
claus
parents:
diff changeset
   487
                        + (rb - aColor blue) asInteger squared.
48194c26a46c Initial revision
claus
parents:
diff changeset
   488
                diff < minDelta ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   489
                    bestColor := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   490
                    minDelta := diff
48194c26a46c Initial revision
claus
parents:
diff changeset
   491
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   492
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   493
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   494
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   495
48194c26a46c Initial revision
claus
parents:
diff changeset
   496
    "allow an error of 10% per component"
48194c26a46c Initial revision
claus
parents:
diff changeset
   497
    minDelta < (100+100+100) ifTrue:[ ^ bestColor ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   498
    ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   499
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   500
48194c26a46c Initial revision
claus
parents:
diff changeset
   501
!Color class methodsFor:'color space conversions'!
48194c26a46c Initial revision
claus
parents:
diff changeset
   502
48194c26a46c Initial revision
claus
parents:
diff changeset
   503
withRGBFromHue:h light:l saturation:s do:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   504
    "compute rgb form hls, evaluate aBlock with r,g and b as arguments"
48194c26a46c Initial revision
claus
parents:
diff changeset
   505
48194c26a46c Initial revision
claus
parents:
diff changeset
   506
    |valueFunc s1 l1 r g b m1 m2|
48194c26a46c Initial revision
claus
parents:
diff changeset
   507
48194c26a46c Initial revision
claus
parents:
diff changeset
   508
    valueFunc := [:n1 :n2 :hIn |
48194c26a46c Initial revision
claus
parents:
diff changeset
   509
        |hue|
48194c26a46c Initial revision
claus
parents:
diff changeset
   510
48194c26a46c Initial revision
claus
parents:
diff changeset
   511
        hue := hIn.
48194c26a46c Initial revision
claus
parents:
diff changeset
   512
        hue > 360 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   513
            hue := hue - 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   514
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   515
            hue < 0 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   516
                hue := hue + 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   517
            ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   518
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   519
        hue < 60 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   520
            n1 + ((n2 - n1) * hue / 60)
48194c26a46c Initial revision
claus
parents:
diff changeset
   521
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   522
            hue < 180 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   523
                n2
48194c26a46c Initial revision
claus
parents:
diff changeset
   524
            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   525
                hue < 240 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   526
                    n1 + ((n2 - n1) * (240 - hue) / 60)
48194c26a46c Initial revision
claus
parents:
diff changeset
   527
                ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   528
                    n1
48194c26a46c Initial revision
claus
parents:
diff changeset
   529
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   530
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   531
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   532
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   533
48194c26a46c Initial revision
claus
parents:
diff changeset
   534
    "compute hls; h in 0..360; l 0..100; s 0..100"
48194c26a46c Initial revision
claus
parents:
diff changeset
   535
48194c26a46c Initial revision
claus
parents:
diff changeset
   536
    s1 := s / 100.0.   "scale to  0..1"
48194c26a46c Initial revision
claus
parents:
diff changeset
   537
    l1 := l / 100.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   538
48194c26a46c Initial revision
claus
parents:
diff changeset
   539
    l1 <= 0.5 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   540
        m2 := l1 * (1 + s1)
48194c26a46c Initial revision
claus
parents:
diff changeset
   541
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   542
        m2 := l1 + s1 - (l1 * s1)
48194c26a46c Initial revision
claus
parents:
diff changeset
   543
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   544
48194c26a46c Initial revision
claus
parents:
diff changeset
   545
    m1 := 2 * l1 - m2.
48194c26a46c Initial revision
claus
parents:
diff changeset
   546
48194c26a46c Initial revision
claus
parents:
diff changeset
   547
    s1 = 0 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   548
        "achromatic, ignore hue"
48194c26a46c Initial revision
claus
parents:
diff changeset
   549
        r := g := b := l1
48194c26a46c Initial revision
claus
parents:
diff changeset
   550
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   551
        r := valueFunc value:m1 value:m2 value:h + 120.
48194c26a46c Initial revision
claus
parents:
diff changeset
   552
        g := valueFunc value:m1 value:m2 value:h.
48194c26a46c Initial revision
claus
parents:
diff changeset
   553
        b := valueFunc value:m1 value:m2 value:h - 120.
48194c26a46c Initial revision
claus
parents:
diff changeset
   554
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   555
    aBlock value:r*100 value:g*100 value:b*100
48194c26a46c Initial revision
claus
parents:
diff changeset
   556
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   557
48194c26a46c Initial revision
claus
parents:
diff changeset
   558
withHLSFromRed:r green:g blue:b do:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   559
    "compute hls form rgb, evaluate aBlock with h,l and s as arguments"
48194c26a46c Initial revision
claus
parents:
diff changeset
   560
48194c26a46c Initial revision
claus
parents:
diff changeset
   561
    |max min r1 g1 b1 delta h l s|
48194c26a46c Initial revision
claus
parents:
diff changeset
   562
48194c26a46c Initial revision
claus
parents:
diff changeset
   563
    "compute hls; h in 0..360; l 0..100; s 0..100"
48194c26a46c Initial revision
claus
parents:
diff changeset
   564
48194c26a46c Initial revision
claus
parents:
diff changeset
   565
    r1 := r / 100.   "scale to  0..1"
48194c26a46c Initial revision
claus
parents:
diff changeset
   566
    g1 := g / 100.
48194c26a46c Initial revision
claus
parents:
diff changeset
   567
    b1 := b / 100.
48194c26a46c Initial revision
claus
parents:
diff changeset
   568
48194c26a46c Initial revision
claus
parents:
diff changeset
   569
    max := (r1 max:g1) max:b1.
48194c26a46c Initial revision
claus
parents:
diff changeset
   570
    min := (r1 min:g1) min:b1.
48194c26a46c Initial revision
claus
parents:
diff changeset
   571
    l := (max + min) / 2.
48194c26a46c Initial revision
claus
parents:
diff changeset
   572
48194c26a46c Initial revision
claus
parents:
diff changeset
   573
    max = min ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   574
        "achromatic, r=g=b"
48194c26a46c Initial revision
claus
parents:
diff changeset
   575
48194c26a46c Initial revision
claus
parents:
diff changeset
   576
        s := 0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   577
        h := nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   578
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   579
        l < 0.5 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   580
            s := (max - min) / (max + min)
48194c26a46c Initial revision
claus
parents:
diff changeset
   581
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   582
            s := (max - min) / (2 - max - min)
48194c26a46c Initial revision
claus
parents:
diff changeset
   583
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   584
48194c26a46c Initial revision
claus
parents:
diff changeset
   585
        "calc hue"
48194c26a46c Initial revision
claus
parents:
diff changeset
   586
48194c26a46c Initial revision
claus
parents:
diff changeset
   587
        delta := max - min.
48194c26a46c Initial revision
claus
parents:
diff changeset
   588
        r1 = max ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   589
            h := (g1 - b1) / delta
48194c26a46c Initial revision
claus
parents:
diff changeset
   590
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   591
            g1 = max ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   592
                h := 2 + ((b1 - r1) / delta)
48194c26a46c Initial revision
claus
parents:
diff changeset
   593
            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   594
                h := 4 + ((r1 - g1) / delta)
48194c26a46c Initial revision
claus
parents:
diff changeset
   595
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   596
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   597
        h := h * 60.
48194c26a46c Initial revision
claus
parents:
diff changeset
   598
        h < 0 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   599
            h := h + 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   600
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   601
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   602
    aBlock value:h value:l * 100 value:s * 100
48194c26a46c Initial revision
claus
parents:
diff changeset
   603
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   604
48194c26a46c Initial revision
claus
parents:
diff changeset
   605
!Color methodsFor:'instance release'!
48194c26a46c Initial revision
claus
parents:
diff changeset
   606
48194c26a46c Initial revision
claus
parents:
diff changeset
   607
disposed
48194c26a46c Initial revision
claus
parents:
diff changeset
   608
    "a color died - free the device color"
48194c26a46c Initial revision
claus
parents:
diff changeset
   609
48194c26a46c Initial revision
claus
parents:
diff changeset
   610
    colorId notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   611
        device freeColor:colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
   612
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   613
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
   614
48194c26a46c Initial revision
claus
parents:
diff changeset
   615
!Color methodsFor:'private'!
48194c26a46c Initial revision
claus
parents:
diff changeset
   616
48194c26a46c Initial revision
claus
parents:
diff changeset
   617
resetDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   618
    "private: color has been restored (either from snapin or binary store);
48194c26a46c Initial revision
claus
parents:
diff changeset
   619
     flush device stuff"
48194c26a46c Initial revision
claus
parents:
diff changeset
   620
48194c26a46c Initial revision
claus
parents:
diff changeset
   621
    ditherForm := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   622
    device := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   623
    colorId := nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   624
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   625
48194c26a46c Initial revision
claus
parents:
diff changeset
   626
setRed:r green:g blue:b device:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   627
    "private: set the components"
48194c26a46c Initial revision
claus
parents:
diff changeset
   628
48194c26a46c Initial revision
claus
parents:
diff changeset
   629
    redVal notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   630
        "oops cannot change (you want to make red be green - or what)"
48194c26a46c Initial revision
claus
parents:
diff changeset
   631
        self error:'Colors cannot change their components'.
48194c26a46c Initial revision
claus
parents:
diff changeset
   632
        ^ self
48194c26a46c Initial revision
claus
parents:
diff changeset
   633
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   634
    redVal := r.
48194c26a46c Initial revision
claus
parents:
diff changeset
   635
    greenVal := g.
48194c26a46c Initial revision
claus
parents:
diff changeset
   636
    blueVal := b.
48194c26a46c Initial revision
claus
parents:
diff changeset
   637
    device := aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   638
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   639
48194c26a46c Initial revision
claus
parents:
diff changeset
   640
colorId:anId
48194c26a46c Initial revision
claus
parents:
diff changeset
   641
    "private: set the deviceId"
48194c26a46c Initial revision
claus
parents:
diff changeset
   642
48194c26a46c Initial revision
claus
parents:
diff changeset
   643
    colorId := anId
48194c26a46c Initial revision
claus
parents:
diff changeset
   644
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   645
48194c26a46c Initial revision
claus
parents:
diff changeset
   646
ditherForm:aForm
48194c26a46c Initial revision
claus
parents:
diff changeset
   647
    "private: set the ditherForm"
48194c26a46c Initial revision
claus
parents:
diff changeset
   648
48194c26a46c Initial revision
claus
parents:
diff changeset
   649
    ditherForm := aForm
48194c26a46c Initial revision
claus
parents:
diff changeset
   650
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   651
48194c26a46c Initial revision
claus
parents:
diff changeset
   652
device:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   653
    "private: set the device"
48194c26a46c Initial revision
claus
parents:
diff changeset
   654
48194c26a46c Initial revision
claus
parents:
diff changeset
   655
    device := aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   656
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   657
48194c26a46c Initial revision
claus
parents:
diff changeset
   658
ditherRed:redVal green:greenVal blue:blueVal on:aDevice into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   659
    "get a dither form or colorId for an rgb value.
48194c26a46c Initial revision
claus
parents:
diff changeset
   660
     Returns 2 values (either color or ditherForm) through
48194c26a46c Initial revision
claus
parents:
diff changeset
   661
     aBlock.
48194c26a46c Initial revision
claus
parents:
diff changeset
   662
     This code is just a minimum of what is really needed,
48194c26a46c Initial revision
claus
parents:
diff changeset
   663
     and needs much more work. Currently only some special cases
48194c26a46c Initial revision
claus
parents:
diff changeset
   664
     are handled"
48194c26a46c Initial revision
claus
parents:
diff changeset
   665
48194c26a46c Initial revision
claus
parents:
diff changeset
   666
    |full none rest primary val gr values primaries sum
48194c26a46c Initial revision
claus
parents:
diff changeset
   667
     rr rg rb rh rl rs color1 color2 
48194c26a46c Initial revision
claus
parents:
diff changeset
   668
     lowL hiL lowValL hiValL lowS hiS lowValS hiValS lowH hiH lowValH hiValH d|
48194c26a46c Initial revision
claus
parents:
diff changeset
   669
48194c26a46c Initial revision
claus
parents:
diff changeset
   670
    "get hls (since we dither anyway, round them a bit"
48194c26a46c Initial revision
claus
parents:
diff changeset
   671
48194c26a46c Initial revision
claus
parents:
diff changeset
   672
    Color withHLSFromRed:redVal green:greenVal blue:blueVal do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
   673
        h notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   674
            rh := (h * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   675
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   676
        rl := (l * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   677
        rs := (s * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   678
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   679
48194c26a46c Initial revision
claus
parents:
diff changeset
   680
    rh isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   681
        "achromatic,  dither between achromatic colors"
48194c26a46c Initial revision
claus
parents:
diff changeset
   682
48194c26a46c Initial revision
claus
parents:
diff changeset
   683
        lowL := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   684
        hiL := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   685
48194c26a46c Initial revision
claus
parents:
diff changeset
   686
        "find the 2 bounding colors"
48194c26a46c Initial revision
claus
parents:
diff changeset
   687
        lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   688
            aColor colorId notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   689
                Color withHLSFromRed:aColor red green:aColor green blue:aColor blue do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
   690
                    | cl |
48194c26a46c Initial revision
claus
parents:
diff changeset
   691
48194c26a46c Initial revision
claus
parents:
diff changeset
   692
                    h isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   693
                        cl := (l * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   694
48194c26a46c Initial revision
claus
parents:
diff changeset
   695
                        cl > rl ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   696
                            hiL isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   697
                                hiL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   698
                                hiValL := cl.
48194c26a46c Initial revision
claus
parents:
diff changeset
   699
                            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   700
                                cl < hiValL ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   701
                                    hiL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   702
                                    hiValL := cl.
48194c26a46c Initial revision
claus
parents:
diff changeset
   703
                                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   704
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   705
                        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   706
                            lowL isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   707
                                lowL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   708
                                lowValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   709
                            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   710
                                cl > lowValL ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   711
                                    lowL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   712
                                    lowValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   713
                                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   714
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   715
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   716
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   717
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   718
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   719
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   720
48194c26a46c Initial revision
claus
parents:
diff changeset
   721
        (lowL notNil and:[hiL notNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   722
            ^ self monoDitherFor:100 / ((hiValL - lowValL)/(rl - lowValL))
48194c26a46c Initial revision
claus
parents:
diff changeset
   723
                         between:lowL
48194c26a46c Initial revision
claus
parents:
diff changeset
   724
                             and:hiL 
48194c26a46c Initial revision
claus
parents:
diff changeset
   725
                              on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   726
                            into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   727
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   728
        "cannot happen, should always find at least black and white"
48194c26a46c Initial revision
claus
parents:
diff changeset
   729
        self error:'cannot happen'.
48194c26a46c Initial revision
claus
parents:
diff changeset
   730
        ^ aBlock value:nil value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   731
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   732
48194c26a46c Initial revision
claus
parents:
diff changeset
   733
    "chromatic case"
48194c26a46c Initial revision
claus
parents:
diff changeset
   734
48194c26a46c Initial revision
claus
parents:
diff changeset
   735
    aDevice hasColors ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   736
        "no chance, return nil values"
48194c26a46c Initial revision
claus
parents:
diff changeset
   737
        ^ aBlock value:nil value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   738
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   739
    (Red isNil or:[Green isNil or:[Blue isNil]]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   740
        "if we where not able to get primary colors: no chance"
48194c26a46c Initial revision
claus
parents:
diff changeset
   741
        ^ aBlock value:nil value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   742
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   743
48194c26a46c Initial revision
claus
parents:
diff changeset
   744
    "try to find two bounding colors with same hue and saturation;
48194c26a46c Initial revision
claus
parents:
diff changeset
   745
     dither on light between those"
48194c26a46c Initial revision
claus
parents:
diff changeset
   746
48194c26a46c Initial revision
claus
parents:
diff changeset
   747
    lowL := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   748
    hiL := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   749
    lowS := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   750
    hiS := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   751
    lowH := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   752
    hiH := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   753
48194c26a46c Initial revision
claus
parents:
diff changeset
   754
    lobby contentsDo:[:aColor |
48194c26a46c Initial revision
claus
parents:
diff changeset
   755
48194c26a46c Initial revision
claus
parents:
diff changeset
   756
        aColor colorId notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   757
            Color withHLSFromRed:aColor red green:aColor green blue:aColor blue do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
   758
                | cl ch cs|
48194c26a46c Initial revision
claus
parents:
diff changeset
   759
48194c26a46c Initial revision
claus
parents:
diff changeset
   760
                h notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   761
                   ch := (h * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   762
                ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   763
                   ch := nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   764
                ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   765
                cl := (l * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   766
                cs := (s * 3) rounded / 3.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
   767
48194c26a46c Initial revision
claus
parents:
diff changeset
   768
                ((ch = rh) and:[cs = rs]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   769
                    "found a color with same saturation and same hue, keep for light"
48194c26a46c Initial revision
claus
parents:
diff changeset
   770
48194c26a46c Initial revision
claus
parents:
diff changeset
   771
                    cl > rl ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   772
                        hiL isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   773
                            hiL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   774
                            hiValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   775
                        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   776
                            cl < hiValL ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   777
                                hiL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   778
                                hiValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   779
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   780
                        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   781
                    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   782
                        lowL isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   783
                            lowL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   784
                            lowValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   785
                        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   786
                            cl > lowValL ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   787
                                lowL := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   788
                                lowValL := cl
48194c26a46c Initial revision
claus
parents:
diff changeset
   789
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   790
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   791
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   792
                ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   793
48194c26a46c Initial revision
claus
parents:
diff changeset
   794
                (((ch = rh) or:[ch == nil]) and:[cl = rl]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   795
                    "found a color with same light and same hue, keep for saturation"
48194c26a46c Initial revision
claus
parents:
diff changeset
   796
48194c26a46c Initial revision
claus
parents:
diff changeset
   797
                    cs > rs ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   798
                        hiS isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   799
                            hiS := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   800
                            hiValS := cs
48194c26a46c Initial revision
claus
parents:
diff changeset
   801
                        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   802
                            cs < hiValS ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   803
                                hiS := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   804
                                hiValS := cs
48194c26a46c Initial revision
claus
parents:
diff changeset
   805
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   806
                        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   807
                    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   808
                        lowS isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   809
                            lowS := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   810
                            lowValS := cs
48194c26a46c Initial revision
claus
parents:
diff changeset
   811
                        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   812
                            cs > lowValS ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   813
                                lowS := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   814
                                lowValS := cs
48194c26a46c Initial revision
claus
parents:
diff changeset
   815
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   816
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   817
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   818
                ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   819
48194c26a46c Initial revision
claus
parents:
diff changeset
   820
                rh notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   821
                    cl = rl ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   822
                        cs = rs ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   823
                            ch notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   824
                                d := (ch - rh) abs.
48194c26a46c Initial revision
claus
parents:
diff changeset
   825
                                d > 300 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   826
                                    rh > 180 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   827
                                        ch := ch + 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   828
                                    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   829
                                        ch := ch - 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   830
                                    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   831
                                ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   832
                                ch > rh ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   833
                                    hiH isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   834
                                        hiH := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   835
                                        hiValH := ch
48194c26a46c Initial revision
claus
parents:
diff changeset
   836
                                    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   837
                                        ch < hiValH ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   838
                                            hiH := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   839
                                            hiValH := ch
48194c26a46c Initial revision
claus
parents:
diff changeset
   840
                                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   841
                                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   842
                                ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   843
                                    lowH isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   844
                                        lowH := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   845
                                        lowValH := ch
48194c26a46c Initial revision
claus
parents:
diff changeset
   846
                                    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   847
                                        ch > lowValH ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   848
                                            lowH := aColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
   849
                                            lowValH := ch
48194c26a46c Initial revision
claus
parents:
diff changeset
   850
                                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   851
                                    ] 
48194c26a46c Initial revision
claus
parents:
diff changeset
   852
                                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   853
                            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   854
                        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   855
                    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   856
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   857
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   858
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   859
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   860
48194c26a46c Initial revision
claus
parents:
diff changeset
   861
    "found bounds for light ?"
48194c26a46c Initial revision
claus
parents:
diff changeset
   862
48194c26a46c Initial revision
claus
parents:
diff changeset
   863
    (lowL notNil and:[hiL notNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   864
	rl = lowValL ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   865
	    ^ aBlock value:lowL value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   866
	].
48194c26a46c Initial revision
claus
parents:
diff changeset
   867
        ^ self monoDitherFor:100 / ((hiValL - lowValL)/(rl - lowValL))
48194c26a46c Initial revision
claus
parents:
diff changeset
   868
                     between:lowL
48194c26a46c Initial revision
claus
parents:
diff changeset
   869
                         and:hiL 
48194c26a46c Initial revision
claus
parents:
diff changeset
   870
                          on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   871
                        into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   872
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   873
48194c26a46c Initial revision
claus
parents:
diff changeset
   874
    "found bounds for saturation?"
48194c26a46c Initial revision
claus
parents:
diff changeset
   875
48194c26a46c Initial revision
claus
parents:
diff changeset
   876
    (lowS notNil and:[hiS notNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   877
        'saturation dither' printNewline.
48194c26a46c Initial revision
claus
parents:
diff changeset
   878
48194c26a46c Initial revision
claus
parents:
diff changeset
   879
        ^ self monoDitherFor:100 / ((hiValS - lowValS)/(rs - lowValS))
48194c26a46c Initial revision
claus
parents:
diff changeset
   880
                     between:lowS
48194c26a46c Initial revision
claus
parents:
diff changeset
   881
                         and:hiS
48194c26a46c Initial revision
claus
parents:
diff changeset
   882
                          on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   883
                        into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   884
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   885
48194c26a46c Initial revision
claus
parents:
diff changeset
   886
    "found one for light, dither with black or white"
48194c26a46c Initial revision
claus
parents:
diff changeset
   887
48194c26a46c Initial revision
claus
parents:
diff changeset
   888
    lowL notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   889
        ^ self monoDitherFor:100 / ((100 - lowValL)/(rl - lowValL))
48194c26a46c Initial revision
claus
parents:
diff changeset
   890
                     between:lowL
48194c26a46c Initial revision
claus
parents:
diff changeset
   891
                         and:White 
48194c26a46c Initial revision
claus
parents:
diff changeset
   892
                          on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   893
                        into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   894
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   895
48194c26a46c Initial revision
claus
parents:
diff changeset
   896
    hiL notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   897
        ^ self monoDitherFor:100 / ((hiValL - 0)/(rl - 0))
48194c26a46c Initial revision
claus
parents:
diff changeset
   898
                     between:Black
48194c26a46c Initial revision
claus
parents:
diff changeset
   899
                         and:hiL 
48194c26a46c Initial revision
claus
parents:
diff changeset
   900
                          on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   901
                        into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   902
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   903
48194c26a46c Initial revision
claus
parents:
diff changeset
   904
    "found bounds for hue ?"
48194c26a46c Initial revision
claus
parents:
diff changeset
   905
48194c26a46c Initial revision
claus
parents:
diff changeset
   906
    (lowH notNil and:[hiH notNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   907
        'hue dither' printNewline.
48194c26a46c Initial revision
claus
parents:
diff changeset
   908
        hiValH < lowValH ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   909
            hiValH := hiValH + 360
48194c26a46c Initial revision
claus
parents:
diff changeset
   910
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   911
48194c26a46c Initial revision
claus
parents:
diff changeset
   912
        d := hiValH - lowValH.
48194c26a46c Initial revision
claus
parents:
diff changeset
   913
48194c26a46c Initial revision
claus
parents:
diff changeset
   914
        ^ self monoDitherFor:100 / (d / (rh - lowValH))
48194c26a46c Initial revision
claus
parents:
diff changeset
   915
                     between:lowH
48194c26a46c Initial revision
claus
parents:
diff changeset
   916
                         and:hiH 
48194c26a46c Initial revision
claus
parents:
diff changeset
   917
                          on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   918
                        into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   919
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   920
48194c26a46c Initial revision
claus
parents:
diff changeset
   921
    ^ aBlock value:nil value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
   922
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   923
48194c26a46c Initial revision
claus
parents:
diff changeset
   924
monoDitherFor:grey on:aDevice into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   925
    "get a dither form or colorId for a grey color.
48194c26a46c Initial revision
claus
parents:
diff changeset
   926
     Returns 2 values (either color or ditherForm) through
48194c26a46c Initial revision
claus
parents:
diff changeset
   927
     aBlock."
48194c26a46c Initial revision
claus
parents:
diff changeset
   928
48194c26a46c Initial revision
claus
parents:
diff changeset
   929
    ^ self monoDitherFor:grey 
48194c26a46c Initial revision
claus
parents:
diff changeset
   930
                 between:Black and:White
48194c26a46c Initial revision
claus
parents:
diff changeset
   931
                      on:aDevice into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   932
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   933
48194c26a46c Initial revision
claus
parents:
diff changeset
   934
monoDitherFor:grey between:color1 and:color2 on:aDevice into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   935
    "get a dither form or colorId for a grey color.
48194c26a46c Initial revision
claus
parents:
diff changeset
   936
     Returns 2 values (either color or ditherForm) through
48194c26a46c Initial revision
claus
parents:
diff changeset
   937
     aBlock."
48194c26a46c Initial revision
claus
parents:
diff changeset
   938
48194c26a46c Initial revision
claus
parents:
diff changeset
   939
    |form bits color clr1 clr2
48194c26a46c Initial revision
claus
parents:
diff changeset
   940
     gr index|
48194c26a46c Initial revision
claus
parents:
diff changeset
   941
48194c26a46c Initial revision
claus
parents:
diff changeset
   942
    "having forms with: [1 .. 31] of 64 pixels,
48194c26a46c Initial revision
claus
parents:
diff changeset
   943
     we get dithers for: 0, 1/64, 2/64, ... 32/64"
48194c26a46c Initial revision
claus
parents:
diff changeset
   944
48194c26a46c Initial revision
claus
parents:
diff changeset
   945
    grey <= 50 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   946
        clr1 := color1.
48194c26a46c Initial revision
claus
parents:
diff changeset
   947
        clr2 := color2.
48194c26a46c Initial revision
claus
parents:
diff changeset
   948
        gr := grey.
48194c26a46c Initial revision
claus
parents:
diff changeset
   949
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   950
        clr1 := color2.
48194c26a46c Initial revision
claus
parents:
diff changeset
   951
        clr2 := color1.
48194c26a46c Initial revision
claus
parents:
diff changeset
   952
        gr := 100 - grey.
48194c26a46c Initial revision
claus
parents:
diff changeset
   953
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   954
48194c26a46c Initial revision
claus
parents:
diff changeset
   955
    gr := gr * 64.
48194c26a46c Initial revision
claus
parents:
diff changeset
   956
    index := (gr // 100) asInteger.
48194c26a46c Initial revision
claus
parents:
diff changeset
   957
    index < 1 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   958
        color := color1 exactOn:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
   959
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   960
        index > 63 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   961
            color := color2 exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   962
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   963
            bits := Form ditherBitsForXin64:index
48194c26a46c Initial revision
claus
parents:
diff changeset
   964
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   965
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   966
    bits notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   967
        form := Form width:8 height:8 fromArray:bits on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
   968
        form colorMap:(Array with:(clr1 exactOn:aDevice)
48194c26a46c Initial revision
claus
parents:
diff changeset
   969
                             with:(clr2 exactOn:aDevice))
48194c26a46c Initial revision
claus
parents:
diff changeset
   970
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   971
    ^ aBlock value:color value:form
48194c26a46c Initial revision
claus
parents:
diff changeset
   972
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   973
 
48194c26a46c Initial revision
claus
parents:
diff changeset
   974
dither2PlaneFor:grey on:aDevice into:aBlock
48194c26a46c Initial revision
claus
parents:
diff changeset
   975
    "get a dither form or colorId for a grey color.
48194c26a46c Initial revision
claus
parents:
diff changeset
   976
     Returns 2 values (either color or ditherForm) through
48194c26a46c Initial revision
claus
parents:
diff changeset
   977
     aBlock.
48194c26a46c Initial revision
claus
parents:
diff changeset
   978
     This code optimized for 2-plane displays (NeXT),
48194c26a46c Initial revision
claus
parents:
diff changeset
   979
     - must be generalized for any number of planes."
48194c26a46c Initial revision
claus
parents:
diff changeset
   980
48194c26a46c Initial revision
claus
parents:
diff changeset
   981
    |form color
48194c26a46c Initial revision
claus
parents:
diff changeset
   982
     gr "{ Class:SmallInteger }"
48194c26a46c Initial revision
claus
parents:
diff changeset
   983
     color1 color2 low high scaled|
48194c26a46c Initial revision
claus
parents:
diff changeset
   984
48194c26a46c Initial revision
claus
parents:
diff changeset
   985
    gr := grey asInteger.
48194c26a46c Initial revision
claus
parents:
diff changeset
   986
48194c26a46c Initial revision
claus
parents:
diff changeset
   987
    gr <= 1 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   988
        color := Black exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   989
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   990
        (gr between:32 and:34) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   991
            color := (Color grey:33) exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   992
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   993
            (gr between:66 and:68) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   994
                color := (Color grey:67) exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   995
            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   996
                gr >= 99 ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
   997
                    color := White exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
   998
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
   999
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1000
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1001
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1002
48194c26a46c Initial revision
claus
parents:
diff changeset
  1003
    color notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1004
        ^ aBlock value:color value:nil
48194c26a46c Initial revision
claus
parents:
diff changeset
  1005
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1006
48194c26a46c Initial revision
claus
parents:
diff changeset
  1007
    (gr between:0 and:33) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1008
        color1 := Black on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1009
        color2 := (Color grey:33) on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1010
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1011
        (gr between:34 and:66) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1012
            color1 := (Color grey:33) on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1013
            color2 := (Color grey:67) on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1014
        ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1015
            color1 := (Color grey:67) on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1016
            color2 := White on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1017
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1018
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1019
    low := color1 red.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1020
    high := color2 red.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1021
48194c26a46c Initial revision
claus
parents:
diff changeset
  1022
    "scale gr in between low..high"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1023
    scaled := ((gr - low) * 100 / (high - low)) rounded.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1024
48194c26a46c Initial revision
claus
parents:
diff changeset
  1025
    ^ self monoDitherFor:scaled
48194c26a46c Initial revision
claus
parents:
diff changeset
  1026
                 between:color1
48194c26a46c Initial revision
claus
parents:
diff changeset
  1027
                     and:color2
48194c26a46c Initial revision
claus
parents:
diff changeset
  1028
                      on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
  1029
                    into:aBlock.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1030
! ! 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1031
48194c26a46c Initial revision
claus
parents:
diff changeset
  1032
!Color methodsFor:'getting a device color'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1033
48194c26a46c Initial revision
claus
parents:
diff changeset
  1034
on:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
  1035
    "create a new Color representing the same color as
48194c26a46c Initial revision
claus
parents:
diff changeset
  1036
     myself on aDevice; if one already exists, return the one"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1037
48194c26a46c Initial revision
claus
parents:
diff changeset
  1038
    |newColor index id grey form sav|
48194c26a46c Initial revision
claus
parents:
diff changeset
  1039
48194c26a46c Initial revision
claus
parents:
diff changeset
  1040
    "if Iam already assigned to that device ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1041
    (device == aDevice) ifTrue:[^ self].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1042
48194c26a46c Initial revision
claus
parents:
diff changeset
  1043
    "the is a special case for pseudo-colors (0 and 1 in bitmaps)"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1044
    (redVal isNil and:[colorId notNil]) ifTrue:[^ self].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1045
48194c26a46c Initial revision
claus
parents:
diff changeset
  1046
    "want to release color ?"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1047
    (aDevice isNil and:[device notNil and:[colorId notNil]]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1048
        (device notNil and:[colorId notNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1049
            device freeColor:colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1050
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1051
        device := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1052
        colorId := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1053
48194c26a46c Initial revision
claus
parents:
diff changeset
  1054
        "have to tell lobby - otherwise it keeps old info around"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1055
        lobby changed:self.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1056
        ^ self
48194c26a46c Initial revision
claus
parents:
diff changeset
  1057
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1058
48194c26a46c Initial revision
claus
parents:
diff changeset
  1059
    newColor := Color existingColorRed:redVal green:greenVal blue:blueVal on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1060
    newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1061
48194c26a46c Initial revision
claus
parents:
diff changeset
  1062
    aDevice hasColors ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1063
        "ask that device for the exact color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1064
48194c26a46c Initial revision
claus
parents:
diff changeset
  1065
        id := aDevice colorRed:redVal green:greenVal blue:blueVal.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1066
        id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1067
            "this is a kludge: scavenge to free unused colors
48194c26a46c Initial revision
claus
parents:
diff changeset
  1068
             and try again ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1069
            ObjectMemory scavenge.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1070
            id := aDevice colorRed:redVal green:greenVal blue:blueVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1071
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1072
        id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1073
            "no such color, look for a near-by one"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1074
48194c26a46c Initial revision
claus
parents:
diff changeset
  1075
"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1076
            newColor := Color colorNearRed:redVal green:greenVal blue:blueVal on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1077
            newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1078
"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1079
48194c26a46c Initial revision
claus
parents:
diff changeset
  1080
            "no such color - try color dithers"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1081
            self ditherRed:redVal green:greenVal blue:blueVal on:aDevice 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1082
                      into:[:c :f | newColor := c. form := f].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1083
            newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1084
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1085
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1086
48194c26a46c Initial revision
claus
parents:
diff changeset
  1087
    (id isNil and:[form isNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1088
        "still no result - try greying"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1089
48194c26a46c Initial revision
claus
parents:
diff changeset
  1090
        grey := (0.3 * redVal) + (0.6 * greenVal) + (0.1 * blueVal).
48194c26a46c Initial revision
claus
parents:
diff changeset
  1091
        "avoid things like 100.00000001"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1092
        grey := ((grey * 100) rounded) / 100.0.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1093
48194c26a46c Initial revision
claus
parents:
diff changeset
  1094
        ((grey = 0) or:[(grey = 100) or:[aDevice hasGreyscales]]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1095
            "kludge for 2-plane display - dither using 4 grey levels"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1096
48194c26a46c Initial revision
claus
parents:
diff changeset
  1097
            (aDevice depth == 2) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1098
                grey := grey rounded.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1099
                self dither2PlaneFor:grey on:aDevice 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1100
                                into:[:c :f | newColor := c. form := f].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1101
                newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1102
            ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1103
                id := aDevice colorRed:grey green:grey blue:grey.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1104
                id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1105
                    ObjectMemory scavenge.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1106
                    id := aDevice colorRed:redVal green:greenVal blue:blueVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1107
                ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1108
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1109
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1110
48194c26a46c Initial revision
claus
parents:
diff changeset
  1111
        "now we have either a form (2-plane dithering) 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1112
         or an id (a real color).
48194c26a46c Initial revision
claus
parents:
diff changeset
  1113
         if both are nil, fall back to very simple dithering"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1114
48194c26a46c Initial revision
claus
parents:
diff changeset
  1115
        (form isNil and:[id isNil]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1116
            self monoDitherFor:grey on:aDevice 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1117
                          into:[:c :f | newColor := c. form := f].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1118
            newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1119
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1120
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1121
48194c26a46c Initial revision
claus
parents:
diff changeset
  1122
    device isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1123
        "receiver was not associated - do it now"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1124
        device := aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1125
        id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1126
            ditherForm := form
48194c26a46c Initial revision
claus
parents:
diff changeset
  1127
        ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1128
        colorId := id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1129
48194c26a46c Initial revision
claus
parents:
diff changeset
  1130
        "have to tell lobby - otherwise it keeps old info around"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1131
        lobby changed:self.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1132
        ^ self
48194c26a46c Initial revision
claus
parents:
diff changeset
  1133
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1134
48194c26a46c Initial revision
claus
parents:
diff changeset
  1135
    "receiver was already associated to another device - need a new color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1136
    newColor := (self class basicNew) setRed:redVal green:greenVal blue:blueVal device:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1137
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1138
        newColor ditherForm:form
48194c26a46c Initial revision
claus
parents:
diff changeset
  1139
    ] ifFalse:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1140
        newColor colorId:id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1141
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1142
    lobby register:newColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1143
    ^ newColor
48194c26a46c Initial revision
claus
parents:
diff changeset
  1144
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1145
48194c26a46c Initial revision
claus
parents:
diff changeset
  1146
exactOn:aDevice
48194c26a46c Initial revision
claus
parents:
diff changeset
  1147
    "create a new Color representing the same color as
48194c26a46c Initial revision
claus
parents:
diff changeset
  1148
     myself on aDevice; if one already exists, return the one.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1149
     Do not dither or otherwise approximate the color, but return
48194c26a46c Initial revision
claus
parents:
diff changeset
  1150
     nil, if the exact color is not available. 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1151
     Used to aquire primary colors for dithering, during startup."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1152
48194c26a46c Initial revision
claus
parents:
diff changeset
  1153
    |newColor index id|
48194c26a46c Initial revision
claus
parents:
diff changeset
  1154
48194c26a46c Initial revision
claus
parents:
diff changeset
  1155
    "if Iam already assigned to that device ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1156
    (device == aDevice) ifTrue:[^ self].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1157
48194c26a46c Initial revision
claus
parents:
diff changeset
  1158
    "first look if not already there"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1159
    newColor := Color existingColorRed:redVal green:greenVal blue:blueVal on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1160
    newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1161
48194c26a46c Initial revision
claus
parents:
diff changeset
  1162
    "ask that device for the color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1163
    id := aDevice colorRed:redVal green:greenVal blue:blueVal.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1164
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1165
        "this is a kludge: scavenge to free unused colors
48194c26a46c Initial revision
claus
parents:
diff changeset
  1166
         and try again ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1167
        ObjectMemory scavenge.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1168
        id := aDevice colorRed:redVal green:greenVal blue:blueVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1169
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1170
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1171
        "no such color - fail"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1172
48194c26a46c Initial revision
claus
parents:
diff changeset
  1173
        ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
  1174
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1175
48194c26a46c Initial revision
claus
parents:
diff changeset
  1176
    "receiver was not associated - do it now"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1177
    device isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1178
        device := aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1179
        colorId := id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1180
48194c26a46c Initial revision
claus
parents:
diff changeset
  1181
        "have to tell lobby - otherwise it keeps old info around"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1182
        lobby changed:self.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1183
        ^ self
48194c26a46c Initial revision
claus
parents:
diff changeset
  1184
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1185
48194c26a46c Initial revision
claus
parents:
diff changeset
  1186
    "receiver was already associated to another device - need a new color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1187
    newColor := (self class basicNew) setRed:redVal green:greenVal blue:blueVal device:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1188
    newColor colorId:id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1189
    lobby register:newColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1190
    ^ newColor
48194c26a46c Initial revision
claus
parents:
diff changeset
  1191
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1192
48194c26a46c Initial revision
claus
parents:
diff changeset
  1193
nearestOn:aDevice error:error
48194c26a46c Initial revision
claus
parents:
diff changeset
  1194
    "create a new Color representing the same color as myself on aDevice; 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1195
     if one already exists, return the one. If no exact match is found,
48194c26a46c Initial revision
claus
parents:
diff changeset
  1196
     search for one with an error less than the argument error (in percent)."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1197
48194c26a46c Initial revision
claus
parents:
diff changeset
  1198
    |newColor index id|
48194c26a46c Initial revision
claus
parents:
diff changeset
  1199
48194c26a46c Initial revision
claus
parents:
diff changeset
  1200
    "if Iam already assigned to that device ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1201
    (device == aDevice) ifTrue:[^ self].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1202
48194c26a46c Initial revision
claus
parents:
diff changeset
  1203
    "first look if not already there"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1204
    newColor := Color nearestColorRed:redVal green:greenVal blue:blueVal 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1205
                                error:error on:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1206
    newColor notNil ifTrue:[^ newColor].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1207
48194c26a46c Initial revision
claus
parents:
diff changeset
  1208
    "ask that device for the color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1209
    id := aDevice colorRed:redVal green:greenVal blue:blueVal.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1210
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1211
        "this is a kludge: scavenge to free unused colors
48194c26a46c Initial revision
claus
parents:
diff changeset
  1212
         and try again ..."
48194c26a46c Initial revision
claus
parents:
diff changeset
  1213
        ObjectMemory scavenge.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1214
        id := aDevice colorRed:redVal green:greenVal blue:blueVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1215
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1216
    id isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1217
        "no color - fail"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1218
48194c26a46c Initial revision
claus
parents:
diff changeset
  1219
        ^ nil
48194c26a46c Initial revision
claus
parents:
diff changeset
  1220
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1221
48194c26a46c Initial revision
claus
parents:
diff changeset
  1222
    "receiver was not associated - do it now"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1223
    device isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1224
        device := aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1225
        colorId := id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1226
48194c26a46c Initial revision
claus
parents:
diff changeset
  1227
        "have to tell lobby - otherwise it keeps old info around"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1228
        lobby changed:self.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1229
        ^ self
48194c26a46c Initial revision
claus
parents:
diff changeset
  1230
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1231
48194c26a46c Initial revision
claus
parents:
diff changeset
  1232
    "receiver was already associated to another device - need a new color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1233
    newColor := (self class basicNew) setRed:redVal green:greenVal blue:blueVal device:aDevice.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1234
    newColor colorId:id.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1235
    lobby register:newColor.
48194c26a46c Initial revision
claus
parents:
diff changeset
  1236
    ^ newColor
48194c26a46c Initial revision
claus
parents:
diff changeset
  1237
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
  1238
48194c26a46c Initial revision
claus
parents:
diff changeset
  1239
!Color methodsFor:'comparing'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1240
48194c26a46c Initial revision
claus
parents:
diff changeset
  1241
= aColor
48194c26a46c Initial revision
claus
parents:
diff changeset
  1242
    "two colors are considered equal, if the color components are;
48194c26a46c Initial revision
claus
parents:
diff changeset
  1243
     independent of the device, the color is on"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1244
48194c26a46c Initial revision
claus
parents:
diff changeset
  1245
    (aColor isKindOf:Color) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1246
        (redVal = aColor red) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1247
            (greenVal = aColor green) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1248
                (blueVal = aColor blue) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1249
                    ^ true
48194c26a46c Initial revision
claus
parents:
diff changeset
  1250
                ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1251
            ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1252
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1253
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1254
    ^ false
48194c26a46c Initial revision
claus
parents:
diff changeset
  1255
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
  1256
48194c26a46c Initial revision
claus
parents:
diff changeset
  1257
!Color methodsFor:'instance creation'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1258
48194c26a46c Initial revision
claus
parents:
diff changeset
  1259
darkened
48194c26a46c Initial revision
claus
parents:
diff changeset
  1260
    "return a new color, which is slightly darker than the receiver"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1261
48194c26a46c Initial revision
claus
parents:
diff changeset
  1262
    ^ Color red:(redVal / 2) green:(greenVal / 2) blue:(blueVal / 2)
48194c26a46c Initial revision
claus
parents:
diff changeset
  1263
48194c26a46c Initial revision
claus
parents:
diff changeset
  1264
    "(Color red) darkened"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1265
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1266
48194c26a46c Initial revision
claus
parents:
diff changeset
  1267
lightened
48194c26a46c Initial revision
claus
parents:
diff changeset
  1268
    "return a new color, which is slightly lighter than the receiver"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1269
48194c26a46c Initial revision
claus
parents:
diff changeset
  1270
    ^ Color red:((100 - redVal) / 2 + redVal)
48194c26a46c Initial revision
claus
parents:
diff changeset
  1271
          green:((100 - greenVal) / 2 + greenVal)
48194c26a46c Initial revision
claus
parents:
diff changeset
  1272
           blue:((100 - blueVal) / 2 + blueVal)
48194c26a46c Initial revision
claus
parents:
diff changeset
  1273
48194c26a46c Initial revision
claus
parents:
diff changeset
  1274
    "(Color red) lightened"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1275
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
  1276
48194c26a46c Initial revision
claus
parents:
diff changeset
  1277
!Color methodsFor:'queries'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1278
48194c26a46c Initial revision
claus
parents:
diff changeset
  1279
isGreyColor
48194c26a46c Initial revision
claus
parents:
diff changeset
  1280
    "return true, if this color is a grey one -
48194c26a46c Initial revision
claus
parents:
diff changeset
  1281
     i.e. red = green = blue"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1282
48194c26a46c Initial revision
claus
parents:
diff changeset
  1283
    ^ (redVal = greenVal) and:[redVal = blueVal]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1284
48194c26a46c Initial revision
claus
parents:
diff changeset
  1285
    "(Color grey:50) isGreyColor"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1286
    "(Color red) isGreyColor"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1287
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
  1288
48194c26a46c Initial revision
claus
parents:
diff changeset
  1289
!Color methodsFor:'accessing'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1290
48194c26a46c Initial revision
claus
parents:
diff changeset
  1291
red
48194c26a46c Initial revision
claus
parents:
diff changeset
  1292
    "return the red component in percent"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1293
48194c26a46c Initial revision
claus
parents:
diff changeset
  1294
    ^ redVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1295
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1296
48194c26a46c Initial revision
claus
parents:
diff changeset
  1297
green
48194c26a46c Initial revision
claus
parents:
diff changeset
  1298
    "return the green component in percent"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1299
48194c26a46c Initial revision
claus
parents:
diff changeset
  1300
    ^ greenVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1301
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1302
48194c26a46c Initial revision
claus
parents:
diff changeset
  1303
blue
48194c26a46c Initial revision
claus
parents:
diff changeset
  1304
    "return the blue component in percent"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1305
48194c26a46c Initial revision
claus
parents:
diff changeset
  1306
    ^ blueVal
48194c26a46c Initial revision
claus
parents:
diff changeset
  1307
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1308
48194c26a46c Initial revision
claus
parents:
diff changeset
  1309
greyIntensity
48194c26a46c Initial revision
claus
parents:
diff changeset
  1310
    "return the grey intensity in percent"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1311
48194c26a46c Initial revision
claus
parents:
diff changeset
  1312
    ^ (0.3 * redVal) + (0.6 * greenVal) + (0.1 * blueVal)
48194c26a46c Initial revision
claus
parents:
diff changeset
  1313
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1314
48194c26a46c Initial revision
claus
parents:
diff changeset
  1315
hue
48194c26a46c Initial revision
claus
parents:
diff changeset
  1316
    "return the hue"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1317
48194c26a46c Initial revision
claus
parents:
diff changeset
  1318
    self class withHLSFromRed:redVal green:greenVal blue:blueVal do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
  1319
        ^ h
48194c26a46c Initial revision
claus
parents:
diff changeset
  1320
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1321
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1322
48194c26a46c Initial revision
claus
parents:
diff changeset
  1323
light 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1324
    "return the hue"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1325
48194c26a46c Initial revision
claus
parents:
diff changeset
  1326
    self class withHLSFromRed:redVal green:greenVal blue:blueVal do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
  1327
        ^ l
48194c26a46c Initial revision
claus
parents:
diff changeset
  1328
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1329
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1330
48194c26a46c Initial revision
claus
parents:
diff changeset
  1331
saturation 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1332
    "return the hue"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1333
48194c26a46c Initial revision
claus
parents:
diff changeset
  1334
    self class withHLSFromRed:redVal green:greenVal blue:blueVal do:[:h :l :s |
48194c26a46c Initial revision
claus
parents:
diff changeset
  1335
        ^ s
48194c26a46c Initial revision
claus
parents:
diff changeset
  1336
    ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1337
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1338
48194c26a46c Initial revision
claus
parents:
diff changeset
  1339
colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1340
    "return the device-dependent color-id"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1341
48194c26a46c Initial revision
claus
parents:
diff changeset
  1342
    ^ colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1343
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1344
48194c26a46c Initial revision
claus
parents:
diff changeset
  1345
ditherForm
48194c26a46c Initial revision
claus
parents:
diff changeset
  1346
    "return the form to dither the color"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1347
48194c26a46c Initial revision
claus
parents:
diff changeset
  1348
    ^ ditherForm
48194c26a46c Initial revision
claus
parents:
diff changeset
  1349
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1350
48194c26a46c Initial revision
claus
parents:
diff changeset
  1351
device
48194c26a46c Initial revision
claus
parents:
diff changeset
  1352
    "return the device I am on"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1353
48194c26a46c Initial revision
claus
parents:
diff changeset
  1354
    ^ device
48194c26a46c Initial revision
claus
parents:
diff changeset
  1355
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1356
48194c26a46c Initial revision
claus
parents:
diff changeset
  1357
deviceRedValue
48194c26a46c Initial revision
claus
parents:
diff changeset
  1358
    "return the value of the red component in device metrics"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1359
48194c26a46c Initial revision
claus
parents:
diff changeset
  1360
    ^ device redComponentOfColor:colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1361
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1362
48194c26a46c Initial revision
claus
parents:
diff changeset
  1363
deviceGreenValue
48194c26a46c Initial revision
claus
parents:
diff changeset
  1364
    "return the value of the green component in device metrics"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1365
48194c26a46c Initial revision
claus
parents:
diff changeset
  1366
    ^ device greenComponentOfColor:colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1367
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1368
48194c26a46c Initial revision
claus
parents:
diff changeset
  1369
deviceBlueValue
48194c26a46c Initial revision
claus
parents:
diff changeset
  1370
    "return the value of the blue component in device metrics"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1371
48194c26a46c Initial revision
claus
parents:
diff changeset
  1372
    ^ device blueComponentOfColor:colorId
48194c26a46c Initial revision
claus
parents:
diff changeset
  1373
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1374
48194c26a46c Initial revision
claus
parents:
diff changeset
  1375
deviceRedValue:r deviceGreenValue:g deviceBlueValue:b
48194c26a46c Initial revision
claus
parents:
diff changeset
  1376
    "set r/g/b components in device metrics"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1377
48194c26a46c Initial revision
claus
parents:
diff changeset
  1378
    device setColor:colorId red:r green:g blue:b
48194c26a46c Initial revision
claus
parents:
diff changeset
  1379
! !
48194c26a46c Initial revision
claus
parents:
diff changeset
  1380
48194c26a46c Initial revision
claus
parents:
diff changeset
  1381
!Color methodsFor:'printing & storing'!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1382
48194c26a46c Initial revision
claus
parents:
diff changeset
  1383
printString
48194c26a46c Initial revision
claus
parents:
diff changeset
  1384
    "return a string representing the receiver"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1385
48194c26a46c Initial revision
claus
parents:
diff changeset
  1386
    ^ self storeString
48194c26a46c Initial revision
claus
parents:
diff changeset
  1387
!
48194c26a46c Initial revision
claus
parents:
diff changeset
  1388
48194c26a46c Initial revision
claus
parents:
diff changeset
  1389
storeString
48194c26a46c Initial revision
claus
parents:
diff changeset
  1390
    "return a string representing an expression to reconstruct the receiver"
48194c26a46c Initial revision
claus
parents:
diff changeset
  1391
48194c26a46c Initial revision
claus
parents:
diff changeset
  1392
    redVal isNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1393
        colorId notNil ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1394
            ^ 'Color colorId:' , colorId storeString 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1395
        ]
48194c26a46c Initial revision
claus
parents:
diff changeset
  1396
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1397
    (redVal = greenVal and:[redVal = blueVal]) ifTrue:[
48194c26a46c Initial revision
claus
parents:
diff changeset
  1398
        ^ 'Color grey:' , redVal storeString
48194c26a46c Initial revision
claus
parents:
diff changeset
  1399
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
  1400
    ^ 'Color red:' , redVal storeString , 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1401
         ' green:' , greenVal storeString , 
48194c26a46c Initial revision
claus
parents:
diff changeset
  1402
          ' blue:' , blueVal storeString
48194c26a46c Initial revision
claus
parents:
diff changeset
  1403
! !