Dota 2 Workshop Tools/Panorama/CSS Properties: Difference between revisions
| mNo edit summary | Thunder4ik (talk | contribs)  m (Unicodifying, replaced: </b> → ''' (93), <b> → ''' (93)) | ||
| Line 61: | Line 61: | ||
| === background-blur === | === background-blur === | ||
| Sets the amount of blur to apply to the contents behind this panel during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.<br><br> | Sets the amount of blur to apply to the contents behind this panel during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.<br><br>'''Examples:'''<pre>background-blur: gaussian( 2.5 ); | ||
| background-blur: gaussian( 6, 6, 1 );</pre> | background-blur: gaussian( 6, 6, 1 );</pre> | ||
| === background-color === | === background-color === | ||
| Sets the background fill color/gradient/combination for a panel.<br><br> | Sets the background fill color/gradient/combination for a panel.<br><br>'''Examples:'''<pre>background-color: #FFFFFFFF; | ||
| background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), to( #c0c0c0c0 ) ); | background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), to( #c0c0c0c0 ) ); | ||
| background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); | background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); | ||
| Line 74: | Line 74: | ||
| === background-color-opacity === | === background-color-opacity === | ||
| Sets the background color opacity for a panel (does nothing on its own, but when merged with a full background-color it overrides the opacity).<br><br> | Sets the background color opacity for a panel (does nothing on its own, but when merged with a full background-color it overrides the opacity).<br><br>'''Examples:'''<pre>background-color-opacity: 0.5; | ||
| </pre> | </pre> | ||
| === background-image === | === background-image === | ||
| Comma separated list of images or movies to draw in the background. Can specify "none" to not draw a background layer. Combined with background-position, background-size and background-repeat values.<br><br> | Comma separated list of images or movies to draw in the background. Can specify "none" to not draw a background layer. Combined with background-position, background-size and background-repeat values.<br><br>'''Example:'''<pre>background-image: url("file://{images}/default.tga"), url( "file://{movies}/Background1080p.webm" );</pre> | ||
| === background-img-opacity === | === background-img-opacity === | ||
| Sets the Opacity of background-image<br><br> | Sets the Opacity of background-image<br><br>'''Examples:'''<pre>background-img-opacity: 0.5;</pre> | ||
| === background-position === | === background-position === | ||
| Controls the horizontal and vertical placement of the background image, with the format: <left|center|right> <horizontal length> <top|center|bottom> <vertical length><br><br>If length is a percent, the specified location within the image is positioned over that same specified position in the background. If the length is pixels, the top left corner is placed relative to the provided alignment keywords (left, bottom, etc.). See examples for more details.<br><br>If 1 value is specified, the other value is assumed to be center. If 2 values are specified, the first value must be for horizontal placement and the second for vertical.<br><br> | Controls the horizontal and vertical placement of the background image, with the format: <left|center|right> <horizontal length> <top|center|bottom> <vertical length><br><br>If length is a percent, the specified location within the image is positioned over that same specified position in the background. If the length is pixels, the top left corner is placed relative to the provided alignment keywords (left, bottom, etc.). See examples for more details.<br><br>If 1 value is specified, the other value is assumed to be center. If 2 values are specified, the first value must be for horizontal placement and the second for vertical.<br><br>'''Examples:'''<pre>// aligns the top left corner of the image with the top left corner of the panel (default) | ||
| background-position: 0% 0%; | background-position: 0% 0%; | ||
| Line 101: | Line 101: | ||
| === background-repeat === | === background-repeat === | ||
| Controls if the background should be repeated in the horizontal and vertical directions.<br><br>Possible values per direction:<br>"repeat" - (default) Repeated in the specified direction until it fills the panel<br>"space" - Repeated as many times as required to fill the panel w/o being clipped. Space is added between images to to align first and last image with panel edges.<br>"round" - Repeated as many times as required to fill the panel w/o being clipped. The image is resized to align first and last image with panel edges.<br>"no-repeat" - Not repeated<br><br>Possible single values:<br>"repeat-x" - equals "repeat no-repeat"<br>"repeat-y" - equals "no-repeat repeat"<br><br> | Controls if the background should be repeated in the horizontal and vertical directions.<br><br>Possible values per direction:<br>"repeat" - (default) Repeated in the specified direction until it fills the panel<br>"space" - Repeated as many times as required to fill the panel w/o being clipped. Space is added between images to to align first and last image with panel edges.<br>"round" - Repeated as many times as required to fill the panel w/o being clipped. The image is resized to align first and last image with panel edges.<br>"no-repeat" - Not repeated<br><br>Possible single values:<br>"repeat-x" - equals "repeat no-repeat"<br>"repeat-y" - equals "no-repeat repeat"<br><br>'''Examples:'''<pre>background-repeat: repeat; // equals "repeat repeat" (default) | ||
| background-repeat: repeat space; // repeats horizontally, spaces vertically   | background-repeat: repeat space; // repeats horizontally, spaces vertically   | ||
| background-repeat: no-repeat round; // 1 column of images, scaled to fit evenly</pre> | background-repeat: no-repeat round; // 1 column of images, scaled to fit evenly</pre> | ||
| Line 107: | Line 107: | ||
| === background-size === | === background-size === | ||
| Sets the horizontal and vertical dimensions used to draw the background image. Can be set in pixels, percent, "contains" to size down to panel dimensions or "auto" preserves the image aspect ratio. By default, set to "auto" which preveres the image's original size.<br><br>Multiple background layers can be specified in a comma separated list, which are then combined with background-image, background-position, and background-repeat values.<br><br> | Sets the horizontal and vertical dimensions used to draw the background image. Can be set in pixels, percent, "contains" to size down to panel dimensions or "auto" preserves the image aspect ratio. By default, set to "auto" which preveres the image's original size.<br><br>Multiple background layers can be specified in a comma separated list, which are then combined with background-image, background-position, and background-repeat values.<br><br>'''Examples:'''<pre>background-size: auto; // same as "auto auto" (default)   | ||
| background-size: 100% 100%; // image fills the panel | background-size: 100% 100%; // image fills the panel | ||
| background-size: 50% 75%; // image fills 50% of the panel's width, and 75% of the panel's height | background-size: 50% 75%; // image fills 50% of the panel's width, and 75% of the panel's height | ||
| Line 114: | Line 114: | ||
| === blur === | === blur === | ||
| Sets the amount of blur to apply to the panel and all it's children during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.<br><br> | Sets the amount of blur to apply to the panel and all it's children during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.<br><br>'''Examples:'''<pre>blur: gaussian( 2.5 ); | ||
| blur: gaussian( 6, 6, 1 ); | blur: gaussian( 6, 6, 1 ); | ||
| </pre> | </pre> | ||
| Line 120: | Line 120: | ||
| === border === | === border === | ||
| Shorthand for setting panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br> | Shorthand for setting panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br>'''Examples:'''<pre>border: 2px solid #111111FF;</pre> | ||
| === border-bottom === | === border-bottom === | ||
| Shorthand for setting the bottom panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br> | Shorthand for setting the bottom panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br>'''Examples:'''<pre>border-bottom: 2px solid #111111FF;</pre> | ||
| === border-bottom-color === | === border-bottom-color === | ||
| Specifies border color for the bottom edge of the panel. <br><br> | Specifies border color for the bottom edge of the panel. <br><br>'''Examples:'''<pre>border-bottom-color: #111111FF;</pre> | ||
| === border-bottom-left-radius === | === border-bottom-left-radius === | ||
| Specifies border-radius for bottom-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br> | Specifies border-radius for bottom-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br>'''Examples:'''<pre>border-bottom-left-radius: 2px 2px; | ||
| border-bottom-left-radius: 5%;</pre> | border-bottom-left-radius: 5%;</pre> | ||
| === border-bottom-right-radius === | === border-bottom-right-radius === | ||
| Specifies border-radius for bottom-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br> | Specifies border-radius for bottom-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br>'''Examples:'''<pre>border-bottom-right-radius: 2px 2px; | ||
| border-bottom-right-radius: 5%;</pre> | border-bottom-right-radius: 5%;</pre> | ||
| === border-bottom-style === | === border-bottom-style === | ||
| Specifies border style for the bottom edge of the panel. <br><br> | Specifies border style for the bottom edge of the panel. <br><br>'''Examples:'''<pre>border-bottom-style: solid;</pre> | ||
| === border-bottom-width === | === border-bottom-width === | ||
| Specifies border width for the bottom edge of the panel. <br><br> | Specifies border width for the bottom edge of the panel. <br><br>'''Examples:'''<pre>border-bottom-width: 2px;</pre> | ||
| === border-brush === | === border-brush === | ||
| EXPERIMENTAL: Sets a more-complex brush for the entire border paint area (ignores normal border color).<br><br> | EXPERIMENTAL: Sets a more-complex brush for the entire border paint area (ignores normal border color).<br><br>'''Examples:'''<pre>border-brush: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), to( #c0c0c0c0 ) ); | ||
| border-brush: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); | border-brush: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); | ||
| border-brush: gradient( radial, 50% 50%, 0% 0%, 80% 80%, from( #00ff00ff ), to( #0000ffff ) ); | border-brush: gradient( radial, 50% 50%, 0% 0%, 80% 80%, from( #00ff00ff ), to( #0000ffff ) ); | ||
| Line 157: | Line 157: | ||
| === border-color === | === border-color === | ||
| Specifies border color for panel.  If a single color value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br> | Specifies border color for panel.  If a single color value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br>'''Examples:'''<pre>border-color: #111111FF; | ||
| border-color: #FF0000FF #00FF00FF #0000FFFF #00FFFFFF;</pre> | border-color: #FF0000FF #00FF00FF #0000FFFF #00FFFFFF;</pre> | ||
| === border-left === | === border-left === | ||
| Shorthand for setting the left panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br> | Shorthand for setting the left panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br>'''Examples:'''<pre>border-left: 2px solid #111111FF;</pre> | ||
| === border-left-color === | === border-left-color === | ||
| Specifies border color for the left edge of the panel. <br><br> | Specifies border color for the left edge of the panel. <br><br>'''Examples:'''<pre>border-left-color: #111111FF;</pre> | ||
| === border-left-style === | === border-left-style === | ||
| Specifies border style for the left edge of the panel. <br><br> | Specifies border style for the left edge of the panel. <br><br>'''Examples:'''<pre>border-left-style: solid;</pre> | ||
| === border-left-width === | === border-left-width === | ||
| Specifies border width for the left edge of the panel. <br><br> | Specifies border width for the left edge of the panel. <br><br>'''Examples:'''<pre>border-left-width: 2px;</pre> | ||
| === border-radius === | === border-radius === | ||
| Shorthand to set border radius for all corners at once.  Border radius rounds off corners of the panel, adjusting the border to smoothly round and also clipping background image/color and contents to the specified elliptical or circular values.  In this shorthand version you may specify a single value for all raddi, or horizontal / vertical separated by the '/' character.  For both horizontal and vertical you may specify 1 to 4 values in pixels or %, they will be taken in order as top-left, top-right, bottom-right, bottom-left radii values.<br><br> | Shorthand to set border radius for all corners at once.  Border radius rounds off corners of the panel, adjusting the border to smoothly round and also clipping background image/color and contents to the specified elliptical or circular values.  In this shorthand version you may specify a single value for all raddi, or horizontal / vertical separated by the '/' character.  For both horizontal and vertical you may specify 1 to 4 values in pixels or %, they will be taken in order as top-left, top-right, bottom-right, bottom-left radii values.<br><br>'''Examples:'''<pre>// 2 px circular corners on all sides | ||
| border-radius: 2px; | border-radius: 2px; | ||
| // Perfect circular or elliptical panel (circular if box was square) | // Perfect circular or elliptical panel (circular if box was square) | ||
| Line 189: | Line 189: | ||
| === border-right === | === border-right === | ||
| Shorthand for setting the right panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br> | Shorthand for setting the right panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br>'''Examples:'''<pre>border-right: 2px solid #111111FF;</pre> | ||
| === border-right-color === | === border-right-color === | ||
| Specifies border color for the right edge of the panel. <br><br> | Specifies border color for the right edge of the panel. <br><br>'''Examples:'''<pre>border-right-color: #111111FF;</pre> | ||
| === border-right-style === | === border-right-style === | ||
| Specifies border style for the right edge of the panel. <br><br> | Specifies border style for the right edge of the panel. <br><br>'''Examples:'''<pre>border-right-style: solid;</pre> | ||
| === border-right-width === | === border-right-width === | ||
| Specifies border width for the right edge of the panel. <br><br> | Specifies border width for the right edge of the panel. <br><br>'''Examples:'''<pre>border-right-width: 2px;</pre> | ||
| === border-style === | === border-style === | ||
| Specifies border style for panel.  If a single style value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br> | Specifies border style for panel.  If a single style value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br>'''Examples:'''<pre>border-style: solid; | ||
| border-style: solid none solid none;</pre> | border-style: solid none solid none;</pre> | ||
| === border-top === | === border-top === | ||
| Shorthand for setting the top panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br> | Shorthand for setting the top panel border. Specify width, style, and color.  Supported styles are: solid, none.<br><br>'''Examples:'''<pre>border-top: 2px solid #111111FF;</pre> | ||
| === border-top-color === | === border-top-color === | ||
| Specifies border color for the top edge of the panel. <br><br> | Specifies border color for the top edge of the panel. <br><br>'''Examples:'''<pre>border-top-color: #111111FF;</pre> | ||
| === border-top-left-radius === | === border-top-left-radius === | ||
| Specifies border-radius for top-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br> | Specifies border-radius for top-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br>'''Examples:'''<pre>border-top-left-radius: 2px 2px; | ||
| border-top-left-radius: 5%;</pre> | border-top-left-radius: 5%;</pre> | ||
| === border-top-right-radius === | === border-top-right-radius === | ||
| Specifies border-radius for top-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br> | Specifies border-radius for top-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.<br><br>'''Examples:'''<pre>border-top-right-radius: 2px 2px; | ||
| border-top-right-radius: 5%;</pre> | border-top-right-radius: 5%;</pre> | ||
| === border-top-style === | === border-top-style === | ||
| Specifies border style for the top edge of the panel. <br><br> | Specifies border style for the top edge of the panel. <br><br>'''Examples:'''<pre>border-top-style: solid;</pre> | ||
| === border-top-width === | === border-top-width === | ||
| Specifies border width for the top edge of the panel. <br><br> | Specifies border width for the top edge of the panel. <br><br>'''Examples:'''<pre>border-top-width: 2px;</pre> | ||
| === border-width === | === border-width === | ||
| Specifies border width for panel.  If a single width value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br> | Specifies border width for panel.  If a single width value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.<br><br>'''Examples:'''<pre>border-width: 1px;' | ||
| border-width: 20px 1px 20px 1px;</pre> | border-width: 20px 1px 20px 1px;</pre> | ||
| === box-shadow === | === box-shadow === | ||
| Specifies outer shadows for boxes, or inset shadows/glows.  The shadow shape will match the border box for the panel,so use border-radius to affect rounding.  Syntax takes optional 'inset', optional 'fill' then color, and then horizontal offset pixels, vertical offset pixels, blur radius pixels, and spread distance in pixels. Inset means the shadow is an inner shadow/glow, fill is valid only on outer shadows and means draw the shadow behind the entire box, not clipping it to outside the border area only. A negative blur radius will give a hard-edged look to the shadow, effectively a rounded outline of the same size as the blur.<br><br> | Specifies outer shadows for boxes, or inset shadows/glows.  The shadow shape will match the border box for the panel,so use border-radius to affect rounding.  Syntax takes optional 'inset', optional 'fill' then color, and then horizontal offset pixels, vertical offset pixels, blur radius pixels, and spread distance in pixels. Inset means the shadow is an inner shadow/glow, fill is valid only on outer shadows and means draw the shadow behind the entire box, not clipping it to outside the border area only. A negative blur radius will give a hard-edged look to the shadow, effectively a rounded outline of the same size as the blur.<br><br>'''Examples:'''<pre>box-shadow: #ffffff80 4px 4px 8px 0px; // outer | ||
| box-shadow: fill #ffffff80 4px 4px 8px 0px; // outer, filled | box-shadow: fill #ffffff80 4px 4px 8px 0px; // outer, filled | ||
| box-shadow: inset #333333b0 0px 0px 8px 12px; // inner</pre> | box-shadow: inset #333333b0 0px 0px 8px 12px; // inner</pre> | ||
| Line 247: | Line 247: | ||
| === brightness === | === brightness === | ||
| Sets the brightness that applies to the panel and all it's children during composition. The value is a multiplier on the HSB brightness value.<br><br> | Sets the brightness that applies to the panel and all it's children during composition. The value is a multiplier on the HSB brightness value.<br><br>'''Example:'''<pre>brightness: 1.5;</pre> | ||
| === clip === | === clip === | ||
| Specifies a clip region within the panel, where contents will be clipped at render time. This clipping has no impact on layout, and is fast and supported for transitions/animations. Radial clip mode takes a center point, start angle and angular width of the revealed sector.<br><br> | Specifies a clip region within the panel, where contents will be clipped at render time. This clipping has no impact on layout, and is fast and supported for transitions/animations. Radial clip mode takes a center point, start angle and angular width of the revealed sector.<br><br>'''Example:'''<pre>clip: rect( 10%, 90%, 90%, 10% );clip: radial( 50% %50, 0deg, 90deg );</pre> | ||
| === color === | === color === | ||
| Sets the foreground fill color/gradient/combination for a panel.  This color is the color used to render text within the panel.<br><br> | Sets the foreground fill color/gradient/combination for a panel.  This color is the color used to render text within the panel.<br><br>'''Examples:'''<pre>color: #FFFFFFFF; | ||
| color: gradient( linear, 0% 0%, 0% 100%, from( #cbcbcbff ), to( #a0a0a0a0 ) );</pre> | color: gradient( linear, 0% 0%, 0% 100%, from( #cbcbcbff ), to( #a0a0a0a0 ) );</pre> | ||
| === context-menu-arrow-position === | === context-menu-arrow-position === | ||
| Specifies where to point the arrow of a context menu at on this panel. The first value controls how the arrow is positioned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the context menu is to the left or right of the panel. Default is '50% 50%'.<br><br> | Specifies where to point the arrow of a context menu at on this panel. The first value controls how the arrow is positioned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the context menu is to the left or right of the panel. Default is '50% 50%'.<br><br>'''Example:'''<pre>context-menu-arrow-position: 25% 50%;</pre> | ||
| === context-menu-body-position === | === context-menu-body-position === | ||
| Specifies where to position the body of a context menu relative to this panel. The first value controls how the body is aligned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the context menu is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.<br><br> | Specifies where to position the body of a context menu relative to this panel. The first value controls how the body is aligned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the context menu is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.<br><br>'''Example:'''<pre>context-menu-body-position: 50% 100%;</pre> | ||
| === context-menu-position === | === context-menu-position === | ||
| Specifies where to position a context menu relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the context menu doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the context menu first tries the opposite of the specified position along the same axis before switching to the other axis.<br><br> | Specifies where to position a context menu relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the context menu doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the context menu first tries the opposite of the specified position along the same axis before switching to the other axis.<br><br>'''Examples:'''<pre>context-menu-position: bottom; | ||
| context-menu-position: left bottom;</pre> | context-menu-position: left bottom;</pre> | ||
| === contrast === | === contrast === | ||
| Sets the contrast that applies to the panel and all it's children during composition.<br><br> | Sets the contrast that applies to the panel and all it's children during composition.<br><br>'''Example:'''<pre>contrast: 1.5;</pre> | ||
| Line 285: | Line 285: | ||
| === font-family === | === font-family === | ||
| Specifies the font face to use.<br><br> | Specifies the font face to use.<br><br>'''Examples:'''<pre>font-family: Arial; | ||
| font-family: "Comic Sans MS";</pre> | font-family: "Comic Sans MS";</pre> | ||
| === font-size === | === font-size === | ||
| Specifies the target font face height in pixels.<br><br> | Specifies the target font face height in pixels.<br><br>'''Example:'''<pre>font-size: 12;</pre> | ||
| === font-stretch === | === font-stretch === | ||
| Specifies the font stretch to use. Supported values are normal, condensed, and expanded.<br><br> | Specifies the font stretch to use. Supported values are normal, condensed, and expanded.<br><br>'''Examples:'''<pre>font-stretch: normal; | ||
| font-stretch: condensed; | font-stretch: condensed; | ||
| font-stretch: expanded;</pre> | font-stretch: expanded;</pre> | ||
| Line 300: | Line 300: | ||
| === font-style === | === font-style === | ||
| Specifies the font style to use. Supported values are normal, and italic<br><br> | Specifies the font style to use. Supported values are normal, and italic<br><br>'''Example:'''<pre>font-style: normal;</pre> | ||
| === font-weight === | === font-weight === | ||
| Specifies the font weight to use. Supported values are light, thin, normal, medium, bold, and black.<br><br> | Specifies the font weight to use. Supported values are light, thin, normal, medium, bold, and black.<br><br>'''Examples:'''<pre>font-weight: normal; | ||
| font-weight: bold; | font-weight: bold; | ||
| font-weight: thin;</pre> | font-weight: thin;</pre> | ||
| Line 318: | Line 318: | ||
| === hue-rotation === | === hue-rotation === | ||
| Sets the hue rotation to apply to the panel and all it's children during composition. Default of 0.0 means no adjustment, domain is in degrees.<br><br> | Sets the hue rotation to apply to the panel and all it's children during composition. Default of 0.0 means no adjustment, domain is in degrees.<br><br>'''Example:'''<pre>hue-rotation: 180deg;</pre> | ||
| Line 326: | Line 326: | ||
| === img-shadow === | === img-shadow === | ||
| Specifies image shadows.  The shadow shape will match the image the panel can generate,and this is only meaningful for images.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.<br><br> | Specifies image shadows.  The shadow shape will match the image the panel can generate,and this is only meaningful for images.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.<br><br>'''Example:'''<pre>img-shadow: 2px 2px 8px 3.0 #333333b0;</pre> | ||
| === layout-position === | === layout-position === | ||
| Sets how the panel is positioned relative to its parent. "static" means position in the default way. "fixed" means position in the default way, but ignoring the parent's scroll offset.<br><br> | Sets how the panel is positioned relative to its parent. "static" means position in the default way. "fixed" means position in the default way, but ignoring the parent's scroll offset.<br><br>'''Example:'''<pre>layout-position: fixed;</pre> | ||
| Line 338: | Line 338: | ||
| === line-height === | === line-height === | ||
| Specifies the line height (distance between top edge of line above and line below) to use for text. By default this is 'normal' and a value that matches the font-size reasonably will be used automatically. Unlike the web, we don't have a weird CSS inheritence problem with the 120% vs 1.2 styles.<br><br> | Specifies the line height (distance between top edge of line above and line below) to use for text. By default this is 'normal' and a value that matches the font-size reasonably will be used automatically. Unlike the web, we don't have a weird CSS inheritence problem with the 120% vs 1.2 styles.<br><br>'''Example:'''<pre>line-height: normal;line-height: 20px;line-height: 1.2;line-height: 120%;</pre> | ||
| Line 378: | Line 378: | ||
| === opacity === | === opacity === | ||
| Sets the opacity or amount of transparency applied to the panel and all it's children during composition. Default of 1.0 means fully opaque, 0.0 means fully transparent.<br><br> | Sets the opacity or amount of transparency applied to the panel and all it's children during composition. Default of 1.0 means fully opaque, 0.0 means fully transparent.<br><br>'''Example:'''<pre>opacity: 0.8;</pre> | ||
| === opacity-brush === | === opacity-brush === | ||
| Sets an opacity brush to apply to the panel and all it's children during composition.<br><br> | Sets an opacity brush to apply to the panel and all it's children during composition.<br><br>'''Example:'''<pre>opacity-brush: gradient( linear, 0% 0%, 0% 100%, from( #ffffffff ), to( #ffffff00 ) );</pre> | ||
| === opacity-mask === | === opacity-mask === | ||
| Applies an image as an opacity mask that stretches to the panel bounds and fades out it's content based on the alpha channel. The second float value is an optional opacity value for the mask itself, the image won't interpolate/cross-fade, but you can animate the opacity to fade the mask in/out. The -scroll-up, -scroll-down, and -scroll-up-down varients override the mask and apply only when the various vertical scroll scenarios affect the panel based on the overflow property.<br><br> | Applies an image as an opacity mask that stretches to the panel bounds and fades out it's content based on the alpha channel. The second float value is an optional opacity value for the mask itself, the image won't interpolate/cross-fade, but you can animate the opacity to fade the mask in/out. The -scroll-up, -scroll-down, and -scroll-up-down varients override the mask and apply only when the various vertical scroll scenarios affect the panel based on the overflow property.<br><br>'''Examples:'''<pre>opacity-mask: url( "file://{images}/upper_row_mask.tga" ); | ||
| opacity-mask: url( "file://{images}/upper_row_mask.tga" ) 0.5; | opacity-mask: url( "file://{images}/upper_row_mask.tga" ) 0.5; | ||
| opacity-mask-scroll-up: url( "file://{images}/upper_row_mask_up.tga" ) 0.5; | opacity-mask-scroll-up: url( "file://{images}/upper_row_mask_up.tga" ) 0.5; | ||
| Line 406: | Line 406: | ||
| === overflow === | === overflow === | ||
| Specifies what to do with contents that overflow the available space for the panel. Possible values:<br>"squish" - Children are squished to fit within the panel's bounds if needed (default)<br>"clip" - Children maintain their desired size but their contents are clipped<br>"scroll" - Children maintain their desired size and a scrollbar is added to this panel<br><br>"noclip" - Children maintain their desired size and content is allowed to overflow this panel<br><br> | Specifies what to do with contents that overflow the available space for the panel. Possible values:<br>"squish" - Children are squished to fit within the panel's bounds if needed (default)<br>"clip" - Children maintain their desired size but their contents are clipped<br>"scroll" - Children maintain their desired size and a scrollbar is added to this panel<br><br>"noclip" - Children maintain their desired size and content is allowed to overflow this panel<br><br>'''Examples:'''<pre>overflow: squish squish; // squishes contents in horizontal and vertical directions | ||
| overflow: squish scroll; // scrolls contents in the Y direction</pre> | overflow: squish scroll; // scrolls contents in the Y direction</pre> | ||
| Line 431: | Line 431: | ||
| === perspective === | === perspective === | ||
| Sets the perspective depth space available for children of the panel.  Default of 1000 would mean that children at 1000px zpos are right at the viewers eye, -1000px are just out of view distance faded to nothing.<br><br> | Sets the perspective depth space available for children of the panel.  Default of 1000 would mean that children at 1000px zpos are right at the viewers eye, -1000px are just out of view distance faded to nothing.<br><br>'''Example:'''<pre>perspective: 1000;</pre> | ||
| === perspective-origin === | === perspective-origin === | ||
| Sets the perspective origin which will be used when transforming children of this panel.  This can be thought of as the camera x/y position relative to the panel.<br><br> | Sets the perspective origin which will be used when transforming children of this panel.  This can be thought of as the camera x/y position relative to the panel.<br><br>'''Example:'''<pre>perspective-origin: 50% 50%;</pre> | ||
| === position === | === position === | ||
| Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br> | Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br>'''Example:'''<pre>position: 3% 20px 0px;</pre> | ||
| === pre-transform-rotate2d === | === pre-transform-rotate2d === | ||
| Sets 2 dimensional rotation degrees that apply to the quad for this panel prior to 3 dimensional transforms. This rotation applies without perspective and leaves the panel centered at the same spot as it started.<br><br> | Sets 2 dimensional rotation degrees that apply to the quad for this panel prior to 3 dimensional transforms. This rotation applies without perspective and leaves the panel centered at the same spot as it started.<br><br>'''Example:'''<pre>pre-transform-rotate2d: 45deg;</pre> | ||
| === pre-transform-scale2d === | === pre-transform-scale2d === | ||
| Sets 2 dimensional X/Y scale factors that apply to the quad for this panel prior to 3 dimensional transforms. This scaling applies without perspective and leaves the panel centered at the same spot as it started. Default of 1.0 means no scaling, 0.5 would be half size.<br><br> | Sets 2 dimensional X/Y scale factors that apply to the quad for this panel prior to 3 dimensional transforms. This scaling applies without perspective and leaves the panel centered at the same spot as it started. Default of 1.0 means no scaling, 0.5 would be half size.<br><br>'''Examples:'''<pre>pre-transform-scale2d: 0.8 | ||
| pre-transform-scale2d: 0.4, 0.6</pre> | pre-transform-scale2d: 0.4, 0.6</pre> | ||
| === saturation === | === saturation === | ||
| Sets the amount of saturation to apply to the panel and all it's children during composition.  Default of 1.0 means no adjustment, 0.0 means fully desaturated to gray scale, greater than 1.0 means over-saturation.<br><br> | Sets the amount of saturation to apply to the panel and all it's children during composition.  Default of 1.0 means no adjustment, 0.0 means fully desaturated to gray scale, greater than 1.0 means over-saturation.<br><br>'''Example:'''<pre>saturation: 0.4;</pre> | ||
| === sound === | === sound === | ||
| Specifies a sound name to play when this selector is applied.<br><br> | Specifies a sound name to play when this selector is applied.<br><br>'''Example:'''<pre>sound: "whoosh_in";</pre> | ||
| === sound-out === | === sound-out === | ||
| Specifies a sound name to play when this selector is removed.<br><br> | Specifies a sound name to play when this selector is removed.<br><br>'''Example:'''<pre>sound-out: "whoosh_out";</pre> | ||
| === text-align === | === text-align === | ||
| Specifies the text alignment for text within this panel, defaults to left.<br><br> | Specifies the text alignment for text within this panel, defaults to left.<br><br>'''Examples:'''<pre>text-align: left; | ||
| text-align: right; | text-align: right; | ||
| text-align: center; | text-align: center; | ||
| Line 472: | Line 472: | ||
| === text-decoration === | === text-decoration === | ||
| Specifies the decoration for text within this panel, defaults to none. Possible values: none, underline, line-through.<br><br> | Specifies the decoration for text within this panel, defaults to none. Possible values: none, underline, line-through.<br><br>'''Example:'''<pre>text-decoration: underline;</pre> | ||
| === text-decoration-style === | === text-decoration-style === | ||
| Specifies the decoration style for text within this panel, defaults to none. Possible values: none, dashed, dotted, wavy.<br><br> | Specifies the decoration style for text within this panel, defaults to none. Possible values: none, dashed, dotted, wavy.<br><br>'''Example:'''<pre>text-decoration-style: dotted;</pre> | ||
| === text-overflow === | === text-overflow === | ||
| Controls truncation of text that doesn't fit in a panel.  "clip" means to simply truncate (on char boundaries), "ellipsis" means to end with '...', and "shrink" means lower the font size to fit.  "noclip" allows the text to overflow based on the "overflow" style. | Controls truncation of text that doesn't fit in a panel.  "clip" means to simply truncate (on char boundaries), "ellipsis" means to end with '...', and "shrink" means lower the font size to fit.  "noclip" allows the text to overflow based on the "overflow" style. | ||
| We default to ellipsis, which is contrary to the normal CSS spec.<br><br> | We default to ellipsis, which is contrary to the normal CSS spec.<br><br>'''Examples:'''<pre>text-overflow: ellipsis; | ||
| text-overflow: clip; | text-overflow: clip; | ||
| text-overflow: shrink; | text-overflow: shrink; | ||
| Line 489: | Line 489: | ||
| === text-shadow === | === text-shadow === | ||
| Specifies text shadows.  The shadow shape will match the text the panel can generate,and this is only meaningful for labels.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.<br><br> | Specifies text shadows.  The shadow shape will match the text the panel can generate,and this is only meaningful for labels.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.<br><br>'''Example:'''<pre>text-shadow: 2px 2px 8px 3.0 #333333b0;</pre> | ||
| === text-transform === | === text-transform === | ||
| Specifies the transform for text within this panel, defaults to none. Possible values: none, uppercase, lowercase.<br><br> | Specifies the transform for text within this panel, defaults to none. Possible values: none, uppercase, lowercase.<br><br>'''Example:'''<pre>text-transform: uppercase;</pre> | ||
| === texture-sampling === | === texture-sampling === | ||
| Controls texture sampling mode for the panel. Set to alpha-only to use the textures alpha data across all 3 color channels, or point for point sampling.<br><br> | Controls texture sampling mode for the panel. Set to alpha-only to use the textures alpha data across all 3 color channels, or point for point sampling.<br><br>'''Examples:'''<pre>texture-sampling: normal; | ||
| texture-sampling: alpha-only; | texture-sampling: alpha-only; | ||
| texture-sampling: point;</pre> | texture-sampling: point;</pre> | ||
| Line 503: | Line 503: | ||
| === tooltip-arrow-position === | === tooltip-arrow-position === | ||
| Specifies where to point the arrow of a tooltip at on this panel. The first value controls how the arrow is positioned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the tooltip is to the left or right of the panel. Default is '50% 50%'.<br><br> | Specifies where to point the arrow of a tooltip at on this panel. The first value controls how the arrow is positioned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the tooltip is to the left or right of the panel. Default is '50% 50%'.<br><br>'''Example:'''<pre>tooltip-arrow-position: 25% 50%;</pre> | ||
| === tooltip-body-position === | === tooltip-body-position === | ||
| Specifies where to position the body of a tooltip relative to this panel. The first value controls how the body is aligned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the tooltip is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.<br><br> | Specifies where to position the body of a tooltip relative to this panel. The first value controls how the body is aligned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the tooltip is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.<br><br>'''Example:'''<pre>tooltip-body-position: 50% 100%;</pre> | ||
| === tooltip-position === | === tooltip-position === | ||
| Specifies where to position a tooltip relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the tooltip doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the tooltip first tries the opposite of the specified position along the same axis before switching to the other axis.<br><br> | Specifies where to position a tooltip relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the tooltip doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the tooltip first tries the opposite of the specified position along the same axis before switching to the other axis.<br><br>'''Examples:'''<pre>tooltip-position: bottom; | ||
| tooltip-position: left bottom;</pre> | tooltip-position: left bottom;</pre> | ||
| === transform === | === transform === | ||
| Sets the transforms to apply to the panel in 2d or 3d space.  You can combine various transforms (comma separated) and they will be applied in order to create a 4x4 3d transform matrix.  The possible operations are: translate3d( x, y, z ), translatex( x ), translatey( y ), translatez( z ), scale3d( x, y, z), rotate3d( x, y, z ), rotatex( x ), rotatey( y ), rotatez( z ).<br><br> | Sets the transforms to apply to the panel in 2d or 3d space.  You can combine various transforms (comma separated) and they will be applied in order to create a 4x4 3d transform matrix.  The possible operations are: translate3d( x, y, z ), translatex( x ), translatey( y ), translatez( z ), scale3d( x, y, z), rotate3d( x, y, z ), rotatex( x ), rotatey( y ), rotatez( z ).<br><br>'''Examples:'''<pre>transform: translate3d( -100px, -100px, 0px ); | ||
| transform: rotateZ( -32deg ) rotateX( 30deg ) translate3d( 125px, 520px, 230px );</pre> | transform: rotateZ( -32deg ) rotateX( 30deg ) translate3d( 125px, 520px, 230px );</pre> | ||
| === transform-origin === | === transform-origin === | ||
| Sets the transform origin about which transforms will be applied.  Default is 50% 50% on the panel so a rotation/scale is centered.<br><br> | Sets the transform origin about which transforms will be applied.  Default is 50% 50% on the panel so a rotation/scale is centered.<br><br>'''Example:'''<pre>transform-origin: 50% 50%</pre> | ||
| === transition === | === transition === | ||
| Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.  Also specifies duration, timing function, and delay.  Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.<br><br> | Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.  Also specifies duration, timing function, and delay.  Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.<br><br>'''Example:'''<pre>transition: position 2.0s ease-in-out 0.0s, perspective-origin 1.2s ease-in-out 0.8s;</pre> | ||
| === transition-delay === | === transition-delay === | ||
| Specifies the delay in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.<br><br> | Specifies the delay in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.<br><br>'''Examples:'''<pre>transition-delay: 0.0s; | ||
| transition-delay: 0.0s, 1.2s;</pre> | transition-delay: 0.0s, 1.2s;</pre> | ||
| === transition-duration === | === transition-duration === | ||
| Specifies the durating in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.<br><br> | Specifies the durating in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.<br><br>'''Examples:'''<pre>transition-duration: 2.0s; | ||
| transition-duration: 2.0s, 1.2s, 1.2s, 4.0s, 2.0s;</pre> | transition-duration: 2.0s, 1.2s, 1.2s, 4.0s, 2.0s;</pre> | ||
| === transition-high-framerate === | === transition-high-framerate === | ||
| Specifies the desire for higher framerate during this transition, if we have control.<br><br> | Specifies the desire for higher framerate during this transition, if we have control.<br><br>'''Examples:'''<pre>transition-high-framerate: true; | ||
| transition-high-framerate: false, true, false;</pre> | transition-high-framerate: false, true, false;</pre> | ||
| === transition-property === | === transition-property === | ||
| Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.<br><br> | Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.<br><br>'''Examples:'''<pre>transition: position, transform, background-color;</pre> | ||
| === transition-timing-function === | === transition-timing-function === | ||
| Specifies the timing function to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property. Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.<br><br> | Specifies the timing function to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property. Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.<br><br>'''Examples:'''<pre>transition-timing-function: ease-in-out; | ||
| transition-timing-function: ease-in-out, linear; | transition-timing-function: ease-in-out, linear; | ||
| transition-timing-function: cubic-bezier( 0.785, 0.385, 0.555, 1.505 );</pre> | transition-timing-function: cubic-bezier( 0.785, 0.385, 0.555, 1.505 );</pre> | ||
| Line 554: | Line 554: | ||
| === ui-scale === | === ui-scale === | ||
| Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br> | Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br>'''Examples:'''<pre>ui-scale: 150%; // 150% scaling for X, Y, and Z. | ||
| ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ||
| === ui-scale-x === | === ui-scale-x === | ||
| Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br> | Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br>'''Examples:'''<pre>ui-scale: 150%; // 150% scaling for X, Y, and Z. | ||
| ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ||
| === ui-scale-y === | === ui-scale-y === | ||
| Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br> | Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br>'''Examples:'''<pre>ui-scale: 150%; // 150% scaling for X, Y, and Z. | ||
| ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ||
| === ui-scale-z === | === ui-scale-z === | ||
| Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br> | Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. <br><br>'''Examples:'''<pre>ui-scale: 150%; // 150% scaling for X, Y, and Z. | ||
| ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.</pre> | ||
| Line 582: | Line 582: | ||
| === wash-color === | === wash-color === | ||
| Specifies a 'wash' color, which means a color that will be blended over the panel and all it's children at composition time, tinting them.  The alpha value of the color determines the intensity of the tinting.<br><br> | Specifies a 'wash' color, which means a color that will be blended over the panel and all it's children at composition time, tinting them.  The alpha value of the color determines the intensity of the tinting.<br><br>'''Example:'''<pre>wash-color: #39b0d325;</pre> | ||
| === white-space === | === white-space === | ||
| Controls white-space wrapping on rendered text.  "normal" means wrap on whitespace, "nowrap" means do no wrapping at all.<br><br> | Controls white-space wrapping on rendered text.  "normal" means wrap on whitespace, "nowrap" means do no wrapping at all.<br><br>'''Examples:'''<pre>white-space: normal; | ||
| white-space: nowrap;</pre> | white-space: nowrap;</pre> | ||
| Line 595: | Line 595: | ||
| === world-blur === | === world-blur === | ||
| Sets the amount of blur to apply to the world / backbuffer before drawing.<br><br> | Sets the amount of blur to apply to the world / backbuffer before drawing.<br><br>'''Examples:'''<pre>world-blur: gaussian( 2.5 ); | ||
| world-blur: gaussian( 6, 6, 1 );world-blur: mipmapgaussian( 6, 6, 4 );  In this version each gaussian pass is preceded by a quarter area downsample.</pre> | world-blur: gaussian( 6, 6, 1 );world-blur: mipmapgaussian( 6, 6, 4 );  In this version each gaussian pass is preceded by a quarter area downsample.</pre> | ||
| === x === | === x === | ||
| Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br> | Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br>'''Example:'''<pre>position: 3% 20px 0px;</pre> | ||
| === y === | === y === | ||
| Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br> | Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br>'''Example:'''<pre>position: 3% 20px 0px;</pre> | ||
| === z === | === z === | ||
| Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br> | Sets the x, y, z position for a panel. Must not be in a flowing layout.<br><br>'''Example:'''<pre>position: 3% 20px 0px;</pre> | ||
| === z-index === | === z-index === | ||
| Sets the z-index for a panel, panels will be sorted and painted in order within a parent panel.  The sorting first sorts by the z-pos computed from position and transforms, then if panels have matching zpos zindex is used. z-index is different than z-pos in that it doesn't affect rendering perspective, just paint/hit-test ordering. The default z-index value is 0, and any floating point value is accepted.<br><br> | Sets the z-index for a panel, panels will be sorted and painted in order within a parent panel.  The sorting first sorts by the z-pos computed from position and transforms, then if panels have matching zpos zindex is used. z-index is different than z-pos in that it doesn't affect rendering perspective, just paint/hit-test ordering. The default z-index value is 0, and any floating point value is accepted.<br><br>'''Example:'''<pre>z-index: 1;</pre> | ||
| {{shortpagetitle}} | {{shortpagetitle}} | ||
| [[Category:Dota 2 Workshop Tools]] | [[Category:Dota 2 Workshop Tools]] | ||
| [[Category:Panorama]] | [[Category:Panorama]] | ||
Revision as of 08:53, 8 January 2024

 
Panorama supports a subset of the HTML5 CSS properties, and also adds a number of custom CSS properties. Panorama has tried to follow the W3C spec when possible: searching the web for a property by name is often a good resource.
The most up to date list of panorama properties can always be found by running the "dump_panorama_css_properties" command. That will print out the full list of properties including their documentation.
Supported pseudo-selectors
- :hover- mouse is over the panel
- :focus- panel has keyboard focus
- :active- panel is being actively used (mouse-down on the panel)
- :disabled- panel is disabled
- :enabled- panel is enabled
- :inspect- panel is being inspected by the debugger
- :selected- panel is selected (button checked)
- :descendantfocus- a descendant of the panel has keyboard focus
- :parentdisabled- a parent of this panel is disabled, thus implicitly disabling it
- :layoutloading- panel is in-progress loading it's layout file and thus may want to display specially
- :layoutfailed- panel failed to load requested layout file, and thus may want to display specially
- :activationdisabled- panel is disabled for activation, may still be enabled for focus (normal disabled disallows all input/focus)
Property List
Exported 2021-09-17 using dump_panorama_css_properties.
align
<Needs a description>
animation
<Needs a description>
animation-delay
<Needs a description>
animation-direction
<Needs a description>
animation-duration
<Needs a description>
animation-fill-mode
<Needs a description>
animation-iteration-count
<Needs a description>
animation-name
<Needs a description>
animation-timing-function
<Needs a description>
background-blur
Sets the amount of blur to apply to the contents behind this panel during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.
Examples:
background-blur: gaussian( 2.5 ); background-blur: gaussian( 6, 6, 1 );
background-color
Sets the background fill color/gradient/combination for a panel.
Examples:
background-color: #FFFFFFFF; background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), to( #c0c0c0c0 ) ); background-color: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); background-color: gradient( radial, 50% 50%, 0% 0%, 80% 80%, from( #00ff00ff ), to( #0000ffff ) ); background-color: #0d1c22ff, gradient( radial, 100% -0%, 100px -40px, 320% 270%, from( #3a464bff ), color-stop( 0.23, #0d1c22ff ), to( #0d1c22ff ) );
background-color-opacity
Sets the background color opacity for a panel (does nothing on its own, but when merged with a full background-color it overrides the opacity).
Examples:
background-color-opacity: 0.5;
background-image
Comma separated list of images or movies to draw in the background. Can specify "none" to not draw a background layer. Combined with background-position, background-size and background-repeat values.
Example:
background-image: url("file://{images}/default.tga"), url( "file://{movies}/Background1080p.webm" );
background-img-opacity
Sets the Opacity of background-image
Examples:
background-img-opacity: 0.5;
background-position
Controls the horizontal and vertical placement of the background image, with the format: <left|center|right> <horizontal length> <top|center|bottom> <vertical length>
If length is a percent, the specified location within the image is positioned over that same specified position in the background. If the length is pixels, the top left corner is placed relative to the provided alignment keywords (left, bottom, etc.). See examples for more details.
If 1 value is specified, the other value is assumed to be center. If 2 values are specified, the first value must be for horizontal placement and the second for vertical.
Examples:
// aligns the top left corner of the image with the top left corner of the panel (default) background-position: 0% 0%; // centers the image within the background (same as "center center") background-position: center; // aligns the bottom right corner of the image with the bottom right corner of the panel (same as "100% 100%") background-position: right bottom; // the top left corner of the image is placed 10px to the right of, 40px below the top left corner of the panel background-position: left 10px top 40px;
background-repeat
Controls if the background should be repeated in the horizontal and vertical directions.
Possible values per direction:
"repeat" - (default) Repeated in the specified direction until it fills the panel
"space" - Repeated as many times as required to fill the panel w/o being clipped. Space is added between images to to align first and last image with panel edges.
"round" - Repeated as many times as required to fill the panel w/o being clipped. The image is resized to align first and last image with panel edges.
"no-repeat" - Not repeated
Possible single values:
"repeat-x" - equals "repeat no-repeat"
"repeat-y" - equals "no-repeat repeat"
Examples:
background-repeat: repeat; // equals "repeat repeat" (default) background-repeat: repeat space; // repeats horizontally, spaces vertically background-repeat: no-repeat round; // 1 column of images, scaled to fit evenly
background-size
Sets the horizontal and vertical dimensions used to draw the background image. Can be set in pixels, percent, "contains" to size down to panel dimensions or "auto" preserves the image aspect ratio. By default, set to "auto" which preveres the image's original size.
Multiple background layers can be specified in a comma separated list, which are then combined with background-image, background-position, and background-repeat values.
Examples:
background-size: auto; // same as "auto auto" (default) background-size: 100% 100%; // image fills the panel background-size: 50% 75%; // image fills 50% of the panel's width, and 75% of the panel's height background-size: 300px 200px; // image is drawn 300px wide, 200px tall
blur
Sets the amount of blur to apply to the panel and all it's children during composition.  Default is no blur, for now Gaussian is the only blur type and takes a horizontal standard deviation, vertical standard deviation, and number of passes.  Good std deviation values are around 0-10, if 10 is still not intense enough consider more passes, but more than one pass is bad for perf.  As shorthand you can specify with just one value, which will be used for the standard deviation in both directions and 1 pass will be set.
Examples:
blur: gaussian( 2.5 ); blur: gaussian( 6, 6, 1 );
border
Shorthand for setting panel border. Specify width, style, and color.  Supported styles are: solid, none.
Examples:
border: 2px solid #111111FF;
border-bottom
Shorthand for setting the bottom panel border. Specify width, style, and color.  Supported styles are: solid, none.
Examples:
border-bottom: 2px solid #111111FF;
border-bottom-color
Specifies border color for the bottom edge of the panel. 
Examples:
border-bottom-color: #111111FF;
border-bottom-left-radius
Specifies border-radius for bottom-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.
Examples:
border-bottom-left-radius: 2px 2px; border-bottom-left-radius: 5%;
border-bottom-right-radius
Specifies border-radius for bottom-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.
Examples:
border-bottom-right-radius: 2px 2px; border-bottom-right-radius: 5%;
border-bottom-style
Specifies border style for the bottom edge of the panel. 
Examples:
border-bottom-style: solid;
border-bottom-width
Specifies border width for the bottom edge of the panel. 
Examples:
border-bottom-width: 2px;
border-brush
EXPERIMENTAL: Sets a more-complex brush for the entire border paint area (ignores normal border color).
Examples:
border-brush: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), to( #c0c0c0c0 ) ); border-brush: gradient( linear, 0% 0%, 0% 100%, from( #fbfbfbff ), color-stop( 0.3, #ebebebff ), to( #c0c0c0c0 ) ); border-brush: gradient( radial, 50% 50%, 0% 0%, 80% 80%, from( #00ff00ff ), to( #0000ffff ) );
border-color
Specifies border color for panel.  If a single color value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.
Examples:
border-color: #111111FF; border-color: #FF0000FF #00FF00FF #0000FFFF #00FFFFFF;
border-left
Shorthand for setting the left panel border. Specify width, style, and color.  Supported styles are: solid, none.
Examples:
border-left: 2px solid #111111FF;
border-left-color
Specifies border color for the left edge of the panel. 
Examples:
border-left-color: #111111FF;
border-left-style
Specifies border style for the left edge of the panel. 
Examples:
border-left-style: solid;
border-left-width
Specifies border width for the left edge of the panel. 
Examples:
border-left-width: 2px;
border-radius
Shorthand to set border radius for all corners at once.  Border radius rounds off corners of the panel, adjusting the border to smoothly round and also clipping background image/color and contents to the specified elliptical or circular values.  In this shorthand version you may specify a single value for all raddi, or horizontal / vertical separated by the '/' character.  For both horizontal and vertical you may specify 1 to 4 values in pixels or %, they will be taken in order as top-left, top-right, bottom-right, bottom-left radii values.
Examples:
// 2 px circular corners on all sides border-radius: 2px; // Perfect circular or elliptical panel (circular if box was square) border-radius: 50% / 50%; // 2 px horizontal radii 4px vertical elliptical corners on all sides border-radius: 2px / 4px; // All corners fully specified border-radius: 2px 3px 4px 2px / 2px 3px 3px 2px;
border-right
Shorthand for setting the right panel border. Specify width, style, and color.  Supported styles are: solid, none.
Examples:
border-right: 2px solid #111111FF;
border-right-color
Specifies border color for the right edge of the panel. 
Examples:
border-right-color: #111111FF;
border-right-style
Specifies border style for the right edge of the panel. 
Examples:
border-right-style: solid;
border-right-width
Specifies border width for the right edge of the panel. 
Examples:
border-right-width: 2px;
border-style
Specifies border style for panel.  If a single style value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.
Examples:
border-style: solid; border-style: solid none solid none;
border-top
Shorthand for setting the top panel border. Specify width, style, and color.  Supported styles are: solid, none.
Examples:
border-top: 2px solid #111111FF;
border-top-color
Specifies border color for the top edge of the panel. 
Examples:
border-top-color: #111111FF;
border-top-left-radius
Specifies border-radius for top-left corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.
Examples:
border-top-left-radius: 2px 2px; border-top-left-radius: 5%;
border-top-right-radius
Specifies border-radius for top-right corner which rounds off border and clips background/foreground content to rounded edge.  Takes 1 or 2 values in px or %, first value is horizontal radii for elliptical corner, second is vertical radii, if only one is specified then horizontal/vertical will both be set and corner will be circular.
Examples:
border-top-right-radius: 2px 2px; border-top-right-radius: 5%;
border-top-style
Specifies border style for the top edge of the panel. 
Examples:
border-top-style: solid;
border-top-width
Specifies border width for the top edge of the panel. 
Examples:
border-top-width: 2px;
border-width
Specifies border width for panel.  If a single width value is set it applies to all sides, if 2 are set the first is top/bottom and the second is left/right, if all four are set then they are top, right, bottom, left in order.
Examples:
border-width: 1px;' border-width: 20px 1px 20px 1px;
box-shadow
Specifies outer shadows for boxes, or inset shadows/glows.  The shadow shape will match the border box for the panel,so use border-radius to affect rounding.  Syntax takes optional 'inset', optional 'fill' then color, and then horizontal offset pixels, vertical offset pixels, blur radius pixels, and spread distance in pixels. Inset means the shadow is an inner shadow/glow, fill is valid only on outer shadows and means draw the shadow behind the entire box, not clipping it to outside the border area only. A negative blur radius will give a hard-edged look to the shadow, effectively a rounded outline of the same size as the blur.
Examples:
box-shadow: #ffffff80 4px 4px 8px 0px; // outer box-shadow: fill #ffffff80 4px 4px 8px 0px; // outer, filled box-shadow: inset #333333b0 0px 0px 8px 12px; // inner
brightness
Sets the brightness that applies to the panel and all it's children during composition. The value is a multiplier on the HSB brightness value.
Example:
brightness: 1.5;
clip
Specifies a clip region within the panel, where contents will be clipped at render time. This clipping has no impact on layout, and is fast and supported for transitions/animations. Radial clip mode takes a center point, start angle and angular width of the revealed sector.
Example:
clip: rect( 10%, 90%, 90%, 10% );clip: radial( 50% %50, 0deg, 90deg );
color
Sets the foreground fill color/gradient/combination for a panel.  This color is the color used to render text within the panel.
Examples:
color: #FFFFFFFF; color: gradient( linear, 0% 0%, 0% 100%, from( #cbcbcbff ), to( #a0a0a0a0 ) );
Specifies where to point the arrow of a context menu at on this panel. The first value controls how the arrow is positioned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the context menu is to the left or right of the panel. Default is '50% 50%'.
Example:
context-menu-arrow-position: 25% 50%;
Specifies where to position the body of a context menu relative to this panel. The first value controls how the body is aligned horizontally when the context menu is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the context menu is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.
Example:
context-menu-body-position: 50% 100%;
Specifies where to position a context menu relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the context menu doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the context menu first tries the opposite of the specified position along the same axis before switching to the other axis.
Examples:
context-menu-position: bottom; context-menu-position: left bottom;
contrast
Sets the contrast that applies to the panel and all it's children during composition.
Example:
contrast: 1.5;
flow-children
<Needs a description>
font
<Needs a description>
font-family
Specifies the font face to use.
Examples:
font-family: Arial; font-family: "Comic Sans MS";
font-size
Specifies the target font face height in pixels.
Example:
font-size: 12;
font-stretch
Specifies the font stretch to use. Supported values are normal, condensed, and expanded.
Examples:
font-stretch: normal; font-stretch: condensed; font-stretch: expanded;
font-style
Specifies the font style to use. Supported values are normal, and italic
Example:
font-style: normal;
font-weight
Specifies the font weight to use. Supported values are light, thin, normal, medium, bold, and black.
Examples:
font-weight: normal; font-weight: bold; font-weight: thin;
height
Sets the height for this panel. Possible values:
"fit-children" - Panel size is set to the required size of all children (default)
<pixels> - Any fixed pixel value (ex: "100px")
<percentage> - Percentage of parent height (ex: "100%")
"fill-parent-flow( <weight> )" - Fills to remaining parent width. If multiple children are set to this value, weight is used to determine final height. For example, if three children are set to fill-parent-flow of 1.0 and the parent is 300px tall, each child will be 100px tall. (ex: "fill-parent-flow( 1.0 )" )
"width-percentage( <percentage> )" - Percentage of the panel's width, which allows you to enforce a particular aspect ratio.  The width cannot also be height-percentage.
horizontal-align
<Needs a description>
hue-rotation
Sets the hue rotation to apply to the panel and all it's children during composition. Default of 0.0 means no adjustment, domain is in degrees.
Example:
hue-rotation: 180deg;
ignore-parent-flow
<Needs a description>
img-shadow
Specifies image shadows.  The shadow shape will match the image the panel can generate,and this is only meaningful for images.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.
Example:
img-shadow: 2px 2px 8px 3.0 #333333b0;
layout-position
Sets how the panel is positioned relative to its parent. "static" means position in the default way. "fixed" means position in the default way, but ignoring the parent's scroll offset.
Example:
layout-position: fixed;
letter-spacing
Sets letter-spacing for text in a string. Possible values:
normal - no manual spacing
<pixels> - Any fixed pixel value (ex: "1px")
line-height
Specifies the line height (distance between top edge of line above and line below) to use for text. By default this is 'normal' and a value that matches the font-size reasonably will be used automatically. Unlike the web, we don't have a weird CSS inheritence problem with the 120% vs 1.2 styles.
Example:
line-height: normal;line-height: 20px;line-height: 1.2;line-height: 120%;
margin
<Needs a description>
margin-bottom
<Needs a description>
margin-left
<Needs a description>
margin-right
<Needs a description>
margin-top
<Needs a description>
max-height
<Needs a description>
max-width
<Needs a description>
min-height
<Needs a description>
min-width
<Needs a description>
opacity
Sets the opacity or amount of transparency applied to the panel and all it's children during composition. Default of 1.0 means fully opaque, 0.0 means fully transparent.
Example:
opacity: 0.8;
opacity-brush
Sets an opacity brush to apply to the panel and all it's children during composition.
Example:
opacity-brush: gradient( linear, 0% 0%, 0% 100%, from( #ffffffff ), to( #ffffff00 ) );
opacity-mask
Applies an image as an opacity mask that stretches to the panel bounds and fades out it's content based on the alpha channel. The second float value is an optional opacity value for the mask itself, the image won't interpolate/cross-fade, but you can animate the opacity to fade the mask in/out. The -scroll-up, -scroll-down, and -scroll-up-down varients override the mask and apply only when the various vertical scroll scenarios affect the panel based on the overflow property.
Examples:
opacity-mask: url( "file://{images}/upper_row_mask.tga" );
opacity-mask: url( "file://{images}/upper_row_mask.tga" ) 0.5;
opacity-mask-scroll-up: url( "file://{images}/upper_row_mask_up.tga" ) 0.5;
opacity-mask-scroll-down: url( "file://{images}/upper_row_mask_down.tga" ) 0.5;
opacity-mask-scroll-up-down: url( "file://{images}/upper_row_mask_up_down.tga" ) 0.5;
opacity-mask-scroll-down
opacity-mask-scroll-up
opacity-mask-scroll-up-down
overflow
Specifies what to do with contents that overflow the available space for the panel. Possible values:
"squish" - Children are squished to fit within the panel's bounds if needed (default)
"clip" - Children maintain their desired size but their contents are clipped
"scroll" - Children maintain their desired size and a scrollbar is added to this panel
"noclip" - Children maintain their desired size and content is allowed to overflow this panel
Examples:
overflow: squish squish; // squishes contents in horizontal and vertical directions overflow: squish scroll; // scrolls contents in the Y direction
padding
<Needs a description>
padding-bottom
<Needs a description>
padding-left
<Needs a description>
padding-right
<Needs a description>
padding-top
<Needs a description>
perspective
Sets the perspective depth space available for children of the panel.  Default of 1000 would mean that children at 1000px zpos are right at the viewers eye, -1000px are just out of view distance faded to nothing.
Example:
perspective: 1000;
perspective-origin
Sets the perspective origin which will be used when transforming children of this panel.  This can be thought of as the camera x/y position relative to the panel.
Example:
perspective-origin: 50% 50%;
position
Sets the x, y, z position for a panel. Must not be in a flowing layout.
Example:
position: 3% 20px 0px;
pre-transform-rotate2d
Sets 2 dimensional rotation degrees that apply to the quad for this panel prior to 3 dimensional transforms. This rotation applies without perspective and leaves the panel centered at the same spot as it started.
Example:
pre-transform-rotate2d: 45deg;
pre-transform-scale2d
Sets 2 dimensional X/Y scale factors that apply to the quad for this panel prior to 3 dimensional transforms. This scaling applies without perspective and leaves the panel centered at the same spot as it started. Default of 1.0 means no scaling, 0.5 would be half size.
Examples:
pre-transform-scale2d: 0.8 pre-transform-scale2d: 0.4, 0.6
saturation
Sets the amount of saturation to apply to the panel and all it's children during composition.  Default of 1.0 means no adjustment, 0.0 means fully desaturated to gray scale, greater than 1.0 means over-saturation.
Example:
saturation: 0.4;
sound
Specifies a sound name to play when this selector is applied.
Example:
sound: "whoosh_in";
sound-out
Specifies a sound name to play when this selector is removed.
Example:
sound-out: "whoosh_out";
text-align
Specifies the text alignment for text within this panel, defaults to left.
Examples:
text-align: left; text-align: right; text-align: center; text-align: justify; text-align: justify-letter-spacing;
text-decoration
Specifies the decoration for text within this panel, defaults to none. Possible values: none, underline, line-through.
Example:
text-decoration: underline;
text-decoration-style
Specifies the decoration style for text within this panel, defaults to none. Possible values: none, dashed, dotted, wavy.
Example:
text-decoration-style: dotted;
text-overflow
Controls truncation of text that doesn't fit in a panel. "clip" means to simply truncate (on char boundaries), "ellipsis" means to end with '...', and "shrink" means lower the font size to fit. "noclip" allows the text to overflow based on the "overflow" style.
We default to ellipsis, which is contrary to the normal CSS spec.
Examples:
text-overflow: ellipsis; text-overflow: clip; text-overflow: shrink; text-overflow: noclip;
text-shadow
Specifies text shadows.  The shadow shape will match the text the panel can generate,and this is only meaningful for labels.  Syntax takes horizontal offset pixels, vertical offset pixels, blur radius pixels, strength, and then shadow color.
Example:
text-shadow: 2px 2px 8px 3.0 #333333b0;
text-transform
Specifies the transform for text within this panel, defaults to none. Possible values: none, uppercase, lowercase.
Example:
text-transform: uppercase;
texture-sampling
Controls texture sampling mode for the panel. Set to alpha-only to use the textures alpha data across all 3 color channels, or point for point sampling.
Examples:
texture-sampling: normal; texture-sampling: alpha-only; texture-sampling: point;
tooltip-arrow-position
Specifies where to point the arrow of a tooltip at on this panel. The first value controls how the arrow is positioned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the arrow is positioned vertically when the tooltip is to the left or right of the panel. Default is '50% 50%'.
Example:
tooltip-arrow-position: 25% 50%;
tooltip-body-position
Specifies where to position the body of a tooltip relative to this panel. The first value controls how the body is aligned horizontally when the tooltip is to the top or bottom of the panel, and the second value controls how the body is aligned vertically when the tooltip is to the left or right of the panel. 0% means left/top aligned, 50% means center/middle aligned, and 100% means right/bottom aligned. Default is '0% 0%'.
Example:
tooltip-body-position: 50% 100%;
tooltip-position
Specifies where to position a tooltip relative to this panel. Valid options include 'left', 'top', 'right', and 'bottom'. List up to 4 positions to determine the order that positions are tried if the tooltip doesn't fully fit on screen. Default is 'right left bottom top'. If less than 4 positions are specified, the tooltip first tries the opposite of the specified position along the same axis before switching to the other axis.
Examples:
tooltip-position: bottom; tooltip-position: left bottom;
transform
Sets the transforms to apply to the panel in 2d or 3d space.  You can combine various transforms (comma separated) and they will be applied in order to create a 4x4 3d transform matrix.  The possible operations are: translate3d( x, y, z ), translatex( x ), translatey( y ), translatez( z ), scale3d( x, y, z), rotate3d( x, y, z ), rotatex( x ), rotatey( y ), rotatez( z ).
Examples:
transform: translate3d( -100px, -100px, 0px ); transform: rotateZ( -32deg ) rotateX( 30deg ) translate3d( 125px, 520px, 230px );
transform-origin
Sets the transform origin about which transforms will be applied.  Default is 50% 50% on the panel so a rotation/scale is centered.
Example:
transform-origin: 50% 50%
transition
Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.  Also specifies duration, timing function, and delay.  Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.
Example:
transition: position 2.0s ease-in-out 0.0s, perspective-origin 1.2s ease-in-out 0.8s;
transition-delay
Specifies the delay in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.
Examples:
transition-delay: 0.0s; transition-delay: 0.0s, 1.2s;
transition-duration
Specifies the durating in seconds to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property.
Examples:
transition-duration: 2.0s; transition-duration: 2.0s, 1.2s, 1.2s, 4.0s, 2.0s;
transition-high-framerate
Specifies the desire for higher framerate during this transition, if we have control.
Examples:
transition-high-framerate: true; transition-high-framerate: false, true, false;
transition-property
Specifies which properties should transition smoothly to new values if a class/pseudo class changes the styles.
Examples:
transition: position, transform, background-color;
transition-timing-function
Specifies the timing function to use for transition properties on this panel, if more than one comma delimited value is specified then the values are applied to each property specified in 'transition-property' in order.  If only one value is specified then it applies to all the properties specified in transition-property. Valid timing functions are: ease, ease-in, ease-out, ease-in-out, linear.
Examples:
transition-timing-function: ease-in-out; transition-timing-function: ease-in-out, linear; transition-timing-function: cubic-bezier( 0.785, 0.385, 0.555, 1.505 );
ui-scale
Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. 
Examples:
ui-scale: 150%; // 150% scaling for X, Y, and Z. ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.
ui-scale-x
Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. 
Examples:
ui-scale: 150%; // 150% scaling for X, Y, and Z. ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.
ui-scale-y
Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. 
Examples:
ui-scale: 150%; // 150% scaling for X, Y, and Z. ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.
ui-scale-z
Specifies a scale to apply to this panel's layout and all descendants. This scale happens at the layout level ratherthan the bitmap level, so things like text will increase their font size rather than just bitmap scaling. 
Examples:
ui-scale: 150%; // 150% scaling for X, Y, and Z. ui-scale: 50% 100% 150%; // 50% scaling for X, 100% for Y. 150% for Z.
vertical-align
<Needs a description>
visibility
Controls if the panel is visible and is included in panel layout. Possible values:
"visible" - panel is visible and included in layout (default)
"collapse" - panel is invisible and not included in layout
wash-color
Specifies a 'wash' color, which means a color that will be blended over the panel and all it's children at composition time, tinting them.  The alpha value of the color determines the intensity of the tinting.
Example:
wash-color: #39b0d325;
white-space
Controls white-space wrapping on rendered text.  "normal" means wrap on whitespace, "nowrap" means do no wrapping at all.
Examples:
white-space: normal; white-space: nowrap;
width
Sets the width for this panel. Possible values:
"fit-children" - Panel size is set to the required size of all children (default)
<pixels> - Any fixed pixel value (ex: "100px")
<percentage> - Percentage of parent width (ex: "100%")
"fill-parent-flow( <weight> )" - Fills to remaining parent width. If multiple children are set to this value, weight is used to determine final width. For example, if three children are set to fill-parent-flow of 1.0 and the parent is 300px wide, each child will be 100px wide. (ex: "fill-parent-flow( 1.0 )" )
"height-percentage( <percentage> )" - Percentage of the panel's height, which allows you to enforce a particular aspect ratio.  The height cannot also be width-percentage.
world-blur
Sets the amount of blur to apply to the world / backbuffer before drawing.
Examples:
world-blur: gaussian( 2.5 ); world-blur: gaussian( 6, 6, 1 );world-blur: mipmapgaussian( 6, 6, 4 ); In this version each gaussian pass is preceded by a quarter area downsample.
x
Sets the x, y, z position for a panel. Must not be in a flowing layout.
Example:
position: 3% 20px 0px;
y
Sets the x, y, z position for a panel. Must not be in a flowing layout.
Example:
position: 3% 20px 0px;
z
Sets the x, y, z position for a panel. Must not be in a flowing layout.
Example:
position: 3% 20px 0px;
z-index
Sets the z-index for a panel, panels will be sorted and painted in order within a parent panel.  The sorting first sorts by the z-pos computed from position and transforms, then if panels have matching zpos zindex is used. z-index is different than z-pos in that it doesn't affect rendering perspective, just paint/hit-test ordering. The default z-index value is 0, and any floating point value is accepted.
Example:
z-index: 1;


























