A 
style-delta% object encapsulates a style change. The changes expressible
by a delta include:
- changing the font family 
- changing the font face 
- changing the font size to a new value 
- enlarging the font by an additive amount 
- enlarging the font by a multiplicative amount, etc. 
- changing the font style (normal, italic, or slant) 
- toggling the font style 
- changing the font to italic if it is currently slant, etc. 
- changing the font weight, etc. 
- changing the underline, etc. 
- changing the vertical alignment, etc. 
- changing the foreground color 
- dimming or brightening the foreground color, etc. 
- changing the background color, etc. 
- changing text backing transparency 
The set-delta method is convenient for most
style delta settings; it takes a high-level delta specification and
sets the internal delta information.
To take full advantage of a style delta, it is necessary to understand
the internal on/off settings that can be manipulated through methods
such as set-weight-on. For example, the font
weight change is specified through the weight-on and
weight-off internal settings. Roughly, weight-on
turns on a weight setting when it is not present and
weight-off turns off a weight setting when it is
present. These two interact precisely in the following way:
- If both weight-on and weight-off are set to 'base,
then the font weight is not changed. 
- If weight-on is not 'base, then the weight is set to
weight-on. 
- If weight-off is not 'base, then the weight will be set back
to 'normal when the base style has the weight weight-off. 
- If both weight-on and weight-off are set to the same
value, then the weight is toggled with respect to that value: if
the base style has the weight weight-on, then weight is changed to
'normal; if the base style has a different weight, it is changed to
weight-on. 
- If both weight-on and weight-off are set, but to
different values, then the weight is changed to weight-on
only when the base style has the weight weight-off. 
Font styles, smoothing, underlining, and alignment work in an analogous manner.
The possible values for alignment-on and alignment-off are:
The possible values for style-on and style-off are:
- 'base 
- 'normal 
- 'italic 
- 'slant 
The possible values for smoothing-on and smoothing-off are:
- 'base 
- 'default 
- 'partly-smoothed 
- 'smoothed 
- 'unsmoothed 
The possible values for underlined-on and underlined-off are:
The possible values for size-in-pixels-on and size-in-pixels-off are:
The possible values for transparent-text-backing-on and
transparent-text-backing-off are:
The possible values for weight-on and weight-off are:
The family and face settings in a style delta are interdependent:
- When a delta’s face is #f and its family is
'base, then neither the face nor family are modified by
the delta. 
- When a delta’s face is a string and its family is
'base, then only face is modified by the delta. 
- When a delta’s family is not 'base, then both the face
and family are modified by the delta. If the delta’s face is
#f, then applying the delta sets a style’s face to
#f, so that the family setting prevails in choosing a
font. 
The initialization arguments are passed on to
 
set-delta.
Tries to collapse into a single delta the changes that would be made
 by applying this delta after a given delta. If the return value is
 #f, then it is impossible to perform the
 collapse. Otherwise, the return value is #t and this delta
 will contain the collapsed change specification.
Copies the given style delta’s settings into this one.
Returns #t if the given delta is equivalent to this one in
 all contexts or #f otherwise.
Gets the object additive color shift for the background (applied after
 the multiplicative factor). Call this 
add-color<%> object’s
 methods to change the style delta’s additive background color shift.
Gets the multiplicative color shift for the background (applied before
 the additive factor). Call this 
mult-color<%> object’s
 methods to change the style delta’s multiplicative background color
 shift.
Gets the delta’s font face string. If this string is 
#f and the
 family is 
'base when the delta is applied to a style,
 the style’s face and family are not changed. However, if the face
 string is 
#f and the family is not 
'base, then
 the style’s face is changed to 
#f.
See also get-family.
| (send a-style-delta get-family) | 
| |  | → |  | | (or/c 'base 'default 'decorative 'roman 'script |  | 'swiss 'modern 'symbol 'system) | 
 | 
 | 
Returns the delta’s font family. The possible values are
See also
get-face.
Gets the additive color shift for the foreground (applied after the
 multiplicative factor). Call this 
add-color<%> object’s
 methods to change the style delta’s additive foreground color shift.
Gets the multiplicative color shift for the foreground (applied before
 the additive factor). Call this 
mult-color<%> object’s
 methods to change the style delta’s multiplicative foreground color
 shift.
Gets the additive font size shift (applied after the multiplicative factor).
Gets the multiplicative font size shift (applied before the additive factor).
| (send a-style-delta set-delta [change-command]) | 
| → (is-a?/c style-delta%) | 
| |  | change-command |  | : |  | | (or/c 'change-nothing |  | 'change-normal |  | 'change-toggle-underline |  | 'change-toggle-size-in-pixels |  | 'change-normal-color |  | 'change-bold) | 
 |  |  |  |  | = |  | 'change-nothing | 
 | 
|  | 
| → (is-a?/c style-delta%) | 
| |  | change-command |  | : |  | | (or/c 'change-family |  | 'change-style |  | 'change-toggle-style |  | 'change-weight |  | 'change-toggle-weight |  | 'change-smoothing |  | 'change-toggle-smoothing |  | 'change-alignment) | 
 | 
 | 
| param : symbol | 
|  | 
| → (is-a?/c style-delta%) | 
| |  | change-command |  | : |  | | (or/c 'change-size |  | 'change-bigger |  | 'change-smaller) | 
 | 
 | 
| param : (integer-in 0 255) | 
|  | 
| → (is-a?/c style-delta%) | 
| |  | change-command |  | : |  | | (or/c 'change-underline |  | 'change-size-in-pixels) | 
 | 
 | 
| on? : any/c | 
Configures the delta with high-level specifications.  The return value
 is the delta itself.
Except for 'change-nothing and
 'change-normal, the command only changes part of the
 delta. Thus, applying 'change-bold and then
 'change-italic sets the delta for both the style and
 weight change.
The change-command argument specifies how the delta is changed;
the possible values are:
- 'change-nothing  –  reset all changes 
- 'change-normal  –  turn off all styles and resizings 
- 'change-toggle-underline  –  underline regions that are currently not underlined, and vice versa 
- 'change-toggle-size-in-pixels  –  interpret sizes in pixels for regions that are currently interpreted in points, and vice versa 
- 'change-normal-color  –  change the foreground and background to black and white, respectively 
- 'change-italic  –  change the style of the font to italic 
- 'change-bold  –  change the weight of the font to bold 
- 'change-family  –  change the font family (param is a family; see
font%); see also
get-family 
- 'change-style  –  change the style of the font (param is a style; see
font%) 
- 'change-toggle-style  –  toggle the style of the font (param is a style; see
font%) 
- 'change-weight  –  change the weight of the font (param is a weight; see
font%) 
- 'change-toggle-weight  –  toggle the weight of the font (param is a weight; see
font%) 
- 'change-smoothing  –  change the smoothing of the font (param is a smoothing; see
font%) 
- 'change-toggle-smoothing  –  toggle the smoothing of the font (param is a smoothing; see
font%) 
- 'change-alignment  –  change the alignment (param is an alignment; see
style-delta%) 
- 'change-size  –  change the size to an absolute value (param is a size) 
- 'change-bigger  –  make the text larger (param is an additive amount) 
- 'change-smaller  –  make the text smaller (param is an additive amount) 
- 'change-underline  –  set the underline status to either underlined or plain 
- 'change-size-in-pixels  –  set the size interpretation to pixels or points 
Makes the delta encode a background color change to match the absolute
 color given; that is, it sets the multiplicative factors to
 
0.0 in the result of 
get-background-mult, and it sets the additive values in the result
 of 
get-background-add to the specified color’s
 values.  In addition, it also disables transparent text backing by
 setting 
transparent-text-backing-on to 
#f and
 
transparent-text-backing-off to 
#t.
 The return value of the method is the delta itself.
For the case that a string color name is supplied, see
 color-database<%>.
Like 
set-face, but sets the family at the same
 time.
The return value is a-style-delta.
Makes the delta encode a foreground color change to match the absolute
 color given; that is, it sets the multiplicative factors to
 
0.0 in the result of 
get-foreground-mult, and it sets the additive values in the result
 of 
get-foreground-add to the specified color’s
 values.  The return value of the method is the delta itself.
For the case that a string color name is supplied, see
 color-database<%>.
| (send a-style-delta set-family v) → void? | 
| |  | v |  | : |  | | (or/c 'base 'default 'decorative 'roman 'script |  | 'swiss 'modern 'symbol 'system) | 
 | 
 | 
Sets the additive font size shift (applied
after the multiplicative factor).
Sets the multiplicative font size shift (applied
before the additive factor).