eInk Radiator - #2: Basic Image Sources
The three basic image sources for the eInk Radiator project: Blank, image, and text
The first few image sources for the eInk Radiator project are going to be very simple. A single color, some text, an image. These will be the building blocks for other image generators later. These are the test-beds for the source repository structure, the testing methodology, and are composable for the rest of the image sources.
After building these first few image sources, I settled on some patterns. All image sources behave the same:
- They are simple CLIs with few or no external dependencies
- They take a config file that says what kind of image to make
- They take the height and width as arguments
The most basic image source: a single color
I call it, the "eInk Radiator Image Source Blank". Ok, I'm an engineer, not a... pretty words naming guy. I wanted this one because:
- It's very useful to start with a simple project.
- It's very useful to spend time early on building the inputs and outputs of an image source.
- It will be useful for other image sources. For example, need a background color? Import this image source and use this.
data:image/s3,"s3://crabby-images/feb43/feb43ad62425314826fa2e5a782edb4b96b4ee16" alt="A plain rectangle of orange"
This beautiful image was created with:
blank generate --config config.json --height 300 --width 400
Where the config file is simply: {"color": "orange"}
The next image source: images
This one's name is even worse: "eInk Radiator Image Source Image". Obviously, displaying images will be important. The previous post showed a few images and how they'd be rendered on the eInk hardware. The display utility requires the image to be the right resolution, so the most important part for this image source is all about resizing.
There are three methods for resizing, loosely based on the background-size
property in CSS:
- Resize: Simply scale both in height and width to smoosh or stretch the image to fit the desired resolution. This is simple, but will distort the image.
- Cover: Scale the image so that it covers the entire desired resolution. This will likely result in parts of the original image being cropped out.
- Contain: Scale the image so that the whole original image fits in the desired resolution. This will likely not fill the whole frame, so a background color can be set to fill what the resized image did not.
data:image/s3,"s3://crabby-images/62296/62296791fa68a746f78668281ccd9cde3b308654" alt="A happy dog, jumping in a grassy field, with a solid green border above and below the image."
This image was generated by running:
image generate --config config.json --height 300 --width 300
Where the config file is:
{
"source": "https://github.com/petewall/eink-radiator-image-source-image/raw/main/test/dog2.jpg",
"scale": "contain",
"background": {
"color": "green"
}
}
The wordy image source: text
The last image source I've aptly named "eInk Radiator Image Source Text". The simple idea is to render text onto an image. Simple enough, but the complexity comes in with the ability to set the font, the color, the size, and how to wrap text.
With a simple config file like this:
text: One Two Three Four Five Six Seven Eight Nine Ten
The image source will format the text so it's all on one line, resized to be as large as possible:
data:image/s3,"s3://crabby-images/1c051/1c05112ab004e054b254d29821e119bcd1fd6db8" alt="An image with only the text "One Two Three Four Five Six Seven Eight Nine Ten""
While a config like this:
text: |-
Shields up!
Rrrrrred Alert!
color: red
background:
color: black
font: UbuntuMono
size: 48
Will result in an image like this:
data:image/s3,"s3://crabby-images/bb08e/bb08e2bee2162792d199288a99b97ba9776e9044" alt="An image with the text "Shield up!" on one line, and "Rrrrrred Alert!" on the second line. The text is red on a black background."
While these image sources are not the most interesting, they're the start of a system that can be composed together. More to come!