/onchain-image-renderers

A collection of Solidity contracts that render pixel art directly from EVM blockchains

Primary LanguageSolidity

Onchain Image Renderers

This project is a collection of Solidity contracts that allow users to generate art on-chain.

BitmapRendererV1

BitmapRendererV1 allows callers to generate bitmap images onchain. Images can be generated in two formats: 8-bit and 24-bit. The 8-bit images are generated using a palette and an array of indices, while the 24-bit images are generated using an array of RGB values.

Generally, the 8-bit images are more gas efficient than the 24-bit images, but the 24-bit images provide more flexibility in terms of color selection.

Both 8-bit and 24-bit images can be generated as raw bitmap data or as base64 encoded strings. The function signature for generating base64 encoded images is the same as the function signature for generating raw bitmap data, with the only difference being the return type.

Addresses

8-bit image creation

  • create8bitBMPData(...) external pure returns (bytes memory)
  • createBase64Encoded8bitBMP(...) pure returns (string memory)

Note: Both functions take the same arguments. For the sake of simplicity, we'll only look at the create8bitBMPData function below.

function create8bitBMPData(
    uint8 width,
    uint8 height,
    uint256[] memory palette,
    uint8[] memory data
) external pure returns (bytes memory);

In order to generate an 8-bit image, the caller must provide the width and height of the image, a palette of colors, and an array of numbers that indicate the index of the color to use for that pixel.

The palette is colors to be used in the image, represented as an array of uint256. Each uint256 should represent an RGB color value in hex format. E.g. pure red would be 0xFF0000, pure green would be 0x00FF00, and pure blue would be 0x0000FF.

The data array is an array of numbers where each number represents the index of the color in the palette to use for that pixel. Pixels are written top left to bottom right.

For example, to generate a 3 by 3 image where the colors are as follows:

red,green,blue
white,black,white
blue,green,red

The caller would do the following:

bytes memory result = IBitmapRendererV1(contractAddress).create8bitBMPData(
    3,
    3,
    [
        0xFF0000, // 0: red
        0x00FF00, // 1: green
        0x0000FF, // 2: blue
        0xFFFFFF, // 3: white
        0x000000  // 4: black
    ],
    [
        0, 1, 2,
        3, 4, 3,
        2, 1, 0
    ]
);

24-bit image creation

  • create24bitBMPData(...) external pure returns (bytes memory)
  • createBase64Encoded24bitBMP(...) pure returns (string memory)

Note: Both functions take the same arguments. For the sake of simplicity, we'll only look at the create24bitBMPData function below.

function create24bitBMPData(
    uint8 width,
    uint8 height,
    uint8[] memory data
) external pure returns (bytes memory);

In order to generate a 24-bit image, the caller must provide the width and height of the image, and an array of RGB values.

The data array is an array of numbers where each number represents the RGB value of the pixel. Pixels are written top left to bottom right.

For example, to generate a 3 by 3 image where the colors are as follows:

red,green,blue
white,black,white
blue,green,red

The caller would do the following:

bytes memory result = IBitmapRendererV1(contractAddress).create24bitBMPData(
    3,
    3,
    [
        0xFF0000, 0x00FF00, 0x0000FF,
        0xFFFFFF, 0x000000, 0xFFFFFF,
        0x0000FF, 0x00FF00, 0xFF0000
    ]
);

SVGRendererV1

...todo...