Summary
RetinaImg wraps the DOM's standard <img
> tag and implements a UIImage
style
interface. Rather than specifying an image src
, RetinaImg allows you to provide
an image name. Like UIImage on iOS, it automatically finds the best image for the current
display based on pixel density. Given image.png
, on a Retina screen, it looks for
image@2x.png
, image.png
, image@1x.png
in that order. It uses a lookup table and caches
image names, so images generally resolve immediately.
RetinaImg also introduces the concept of image modes
. Specifying an image mode
is important for theming: it describes the content of your image, allowing theme
developers to properly adjust it. The four modes are described below:
- ContentPreserve: Your image contains color or should not be adjusted by any theme.
- ContentLight: Your image is a grayscale image with light colors, intended to be shown
against a dark background. If a theme developer changes the background to be light, they
can safely apply CSS filters to invert or darken this image. This mode adds the
content-light
CSS class to the image. - ContentDark: Your image is a grayscale image with dark colors, intended to be shown
against a light background. If a theme developer changes the background to be dark, they
can safely apply CSS filters to invert or brighten this image. This mode adds the
content-dark
CSS class to the image. - ContentIsMask: This image provides alpha information only, and color should
be based on the
background-color
of the RetinaImg. This mode adds thecontent-mask
CSS class to the image, and leverages-webkit-mask-image
. Example: Icons displayed within buttons specify ContentIsMask, and their color is declared via CSS to be the same as the button text color. Changing@text-color-subtle
in a theme changes both button text and button icons!.btn-icon { color: @text-color-subtle; img.content-mask { background-color:@text-color-subtle; } }
Class Properties
propTypes
React props
supported by RetinaImg:
mode |
(required) One of the RetinaImg.Mode constants. See above for details. |
name |
Optional
A String image name to display. |
url |
Optional
A String url of an image to display. May be an http, https, or |
fallback |
Optional
A String image name to use when |
selected |
Optional
Appends "-selected" to the end of the image name when when true |
active |
Optional
Appends "-active" to the end of the image name when when true |
style |
Optional
An Object with additional styles to apply to the image. |
resourcePath |
(options) Changes the default lookup location used to find the images. |