mirror of https://github.com/anoshenko/rui.git
Added mix-blend-mode and background-blend-mode
This commit is contained in:
parent
9fe570ec22
commit
e5842180ef
|
@ -1,3 +1,10 @@
|
|||
# v.11.0
|
||||
|
||||
* Added "order", "background-blend-mode", and "mix-blend-mode" properties
|
||||
* Added GetOrder, GetBackgroundBlendMode, and GetMixBlendMode functions
|
||||
* ClientItem, SetClientItem, and RemoveAllClientItems method added to Session interface
|
||||
* PropertyWithTag method of DataObject interface renamed to PropertyByTag
|
||||
|
||||
# v.10.0
|
||||
|
||||
* The Canvas.TextWidth method replaced by Canvas.TextMetrics
|
||||
|
|
|
@ -674,4 +674,20 @@ const (
|
|||
// The "Order" int property sets the order to layout an item in a ListLayout or GridLayout container.
|
||||
// Items in a container are sorted by ascending order value and then by their source code order.
|
||||
Order = "Order"
|
||||
|
||||
// BackgroundBlendMode is the constant for the "background-blend-mode" property tag.
|
||||
// The "background-blend-mode" int property sets how an element's background images should blend
|
||||
// with each other and with the element's background color.
|
||||
// Valid values are "normal" (0), "multiply" (1), "screen" (2), "overlay" (3), "darken" (4), "lighten" (5),
|
||||
// "color-dodge" (6), "color-burn" (7), "hard-light" (8), "soft-light" (9), "difference" (10),
|
||||
// "exclusion" (11), "hue" (12), "saturation" (13), "color" (14), "luminosity" (15).
|
||||
BackgroundBlendMode = "background-blend-mode"
|
||||
|
||||
// MixBlendMode is the constant for the "mix-blend-mode" property tag.
|
||||
// The "mix-blend-mode" int property sets how a view's content should blend
|
||||
// with the content of the view's parent and the view's background.
|
||||
// Valid values are "normal" (0), "multiply" (1), "screen" (2), "overlay" (3), "darken" (4), "lighten" (5),
|
||||
// "color-dodge" (6), "color-burn" (7), "hard-light" (8), "soft-light" (9), "difference" (10),
|
||||
// "exclusion" (11), "hue" (12), "saturation" (13), "color" (14), "luminosity" (15).
|
||||
MixBlendMode = "mix-blend-mode"
|
||||
)
|
||||
|
|
|
@ -448,6 +448,16 @@ var enumProperties = map[string]struct {
|
|||
"",
|
||||
[]string{"none", "top", "right", "bottom", "left"},
|
||||
},
|
||||
MixBlendMode: {
|
||||
[]string{"normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"},
|
||||
MixBlendMode,
|
||||
[]string{"normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"},
|
||||
},
|
||||
BackgroundBlendMode: {
|
||||
[]string{"normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"},
|
||||
BackgroundBlendMode,
|
||||
[]string{"normal", "multiply", "screen", "overlay", "darken", "lighten", "color-dodge", "color-burn", "hard-light", "soft-light", "difference", "exclusion", "hue", "saturation", "color", "luminosity"},
|
||||
},
|
||||
}
|
||||
|
||||
func notCompatibleType(tag string, value any) {
|
||||
|
|
|
@ -307,4 +307,85 @@ const (
|
|||
// "dense" packing algorithm attempts to fill in holes earlier in the grid, if smaller items come up later.
|
||||
// This may cause views to appear out-of-order, when doing so would fill in holes left by larger views.
|
||||
ColumnDenseAutoFlow = 3
|
||||
|
||||
// BlendNormal - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the top color, regardless of what the bottom color is.
|
||||
// The effect is like two opaque pieces of paper overlapping.
|
||||
BlendNormal = 0
|
||||
|
||||
// BlendMultiply - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of multiplying the top and bottom colors.
|
||||
// A black layer leads to a black final layer, and a white layer leads to no change.
|
||||
// The effect is like two images printed on transparent film overlapping.
|
||||
BlendMultiply = 1
|
||||
|
||||
// BlendScreen - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of inverting the colors, multiplying them, and inverting that value.
|
||||
// A black layer leads to no change, and a white layer leads to a white final layer.
|
||||
// The effect is like two images shone onto a projection screen.
|
||||
BlendScreen = 2
|
||||
|
||||
// BlendOverlay - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of multiply if the bottom color is darker, or screen if the bottom color is lighter.
|
||||
// This blend mode is equivalent to hard-light but with the layers swapped.
|
||||
BlendOverlay = 3
|
||||
|
||||
// BlendDarken - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is composed of the darkest values of each color channel.
|
||||
BlendDarken = 4
|
||||
|
||||
// BlendLighten - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is composed of the lightest values of each color channel.
|
||||
BlendLighten = 5
|
||||
|
||||
// BlendColorDodge - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of dividing the bottom color by the inverse of the top color.
|
||||
// A black foreground leads to no change. A foreground with the inverse color of the backdrop leads to a fully lit color.
|
||||
// This blend mode is similar to screen, but the foreground need only be as light as the inverse of the backdrop to create a fully lit color.
|
||||
BlendColorDodge = 6
|
||||
|
||||
// BlendColorBurn - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of inverting the bottom color, dividing the value by the top color, and inverting that value.
|
||||
// A white foreground leads to no change. A foreground with the inverse color of the backdrop leads to a black final image.
|
||||
// This blend mode is similar to multiply, but the foreground need only be as dark as the inverse of the backdrop to make the final image black.
|
||||
BlendColorBurn = 7
|
||||
|
||||
// BlendHardLight - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of multiply if the top color is darker, or screen if the top color is lighter.
|
||||
// This blend mode is equivalent to overlay but with the layers swapped. The effect is similar to shining a harsh spotlight on the backdrop.
|
||||
BlendHardLight = 8
|
||||
|
||||
// BlendSoftLight - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is similar to hard-light, but softer. This blend mode behaves similar to hard-light.
|
||||
// The effect is similar to shining a diffused spotlight on the backdrop*.*
|
||||
BlendSoftLight = 9
|
||||
|
||||
// BlendDifference - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is the result of subtracting the darker of the two colors from the lighter one.
|
||||
// A black layer has no effect, while a white layer inverts the other layer's color.
|
||||
BlendDifference = 10
|
||||
|
||||
// BlendExclusion - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color is similar to difference, but with less contrast.
|
||||
// As with difference, a black layer has no effect, while a white layer inverts the other layer's color.
|
||||
BlendExclusion = 11
|
||||
|
||||
// BlendHue - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color has the hue of the top color, while using the saturation and luminosity of the bottom color.
|
||||
BlendHue = 12
|
||||
|
||||
// BlendSaturation - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color has the saturation of the top color, while using the hue and luminosity of the bottom color.
|
||||
// A pure gray backdrop, having no saturation, will have no effect.
|
||||
BlendSaturation = 13
|
||||
|
||||
// BlendColor - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color has the hue and saturation of the top color, while using the luminosity of the bottom color.
|
||||
// The effect preserves gray levels and can be used to colorize the foreground.
|
||||
BlendColor = 14
|
||||
|
||||
// BlendLuminosity - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||||
// The final color has the luminosity of the top color, while using the hue and saturation of the bottom color.
|
||||
// This blend mode is equivalent to BlendColor, but with the layers swapped.
|
||||
BlendLuminosity = 15
|
||||
)
|
||||
|
|
|
@ -252,7 +252,7 @@ func (style *viewStyle) cssViewStyle(builder cssBuilder, session Session) {
|
|||
for _, tag := range []string{
|
||||
Overflow, TextAlign, TextTransform, TextWeight, TextLineStyle, WritingMode, TextDirection,
|
||||
VerticalTextOrientation, CellVerticalAlign, CellHorizontalAlign, GridAutoFlow, Cursor,
|
||||
WhiteSpace, WordBreak, TextOverflow, Float, TableVerticalAlign, Resize} {
|
||||
WhiteSpace, WordBreak, TextOverflow, Float, TableVerticalAlign, Resize, MixBlendMode, BackgroundBlendMode} {
|
||||
|
||||
if data, ok := enumProperties[tag]; ok {
|
||||
if tag != VerticalTextOrientation || (writingMode != VerticalLeftToRight && writingMode != VerticalRightToLeft) {
|
||||
|
|
24
viewUtils.go
24
viewUtils.go
|
@ -896,3 +896,27 @@ func isUserSelect(view View) (bool, bool) {
|
|||
|
||||
return false, false
|
||||
}
|
||||
|
||||
// GetMixBlendMode returns a "mix-blend-mode" of the subview. Returns one of next values:
|
||||
//
|
||||
// BlendNormal (0), BlendMultiply (1), BlendScreen (2), BlendOverlay (3), BlendDarken (4),
|
||||
// BlendLighten (5), BlendColorDodge (6), BlendColorBurn (7), BlendHardLight (8),
|
||||
// BlendSoftLight (9), BlendDifference (10), BlendExclusion (11), BlendHue (12),
|
||||
// BlendSaturation (13), BlendColor (14), BlendLuminosity (15)
|
||||
//
|
||||
// If the second argument (subviewID) is not specified or it is "" then a value from the first argument (view) is returned.
|
||||
func GetMixBlendMode(view View, subviewID ...string) int {
|
||||
return enumStyledProperty(view, subviewID, MixBlendMode, BlendNormal, true)
|
||||
}
|
||||
|
||||
// GetBackgroundBlendMode returns a "background-blend-mode" of the subview. Returns one of next values:
|
||||
//
|
||||
// BlendNormal (0), BlendMultiply (1), BlendScreen (2), BlendOverlay (3), BlendDarken (4),
|
||||
// BlendLighten (5), BlendColorDodge (6), BlendColorBurn (7), BlendHardLight (8),
|
||||
// BlendSoftLight (9), BlendDifference (10), BlendExclusion (11), BlendHue (12),
|
||||
// BlendSaturation (13), BlendColor (14), BlendLuminosity (15)
|
||||
//
|
||||
// If the second argument (subviewID) is not specified or it is "" then a value from the first argument (view) is returned.
|
||||
func GetBackgroundBlendMode(view View, subviewID ...string) int {
|
||||
return enumStyledProperty(view, subviewID, BackgroundBlendMode, BlendNormal, true)
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue