Author: Gerald Bauer (Punk's Not Dead, Learn Pixel Art, etc)
Let's deploy a new 10 000 d.i.y. punk (pixel head) collection in 8 seconds ;-) - yes, you can. Example:
{
"p": "orc-721",
"op": "deploy",
"slug": "diypunks",
"name": "D.I.Y. Punks",
"max": 10000,
"dim": "24x24",
"generative": "<spritesheet/art layers inscription id here>"
}
That's it. Ready to mint the first d.i.y. punk with the (generative) specs - [0]
:
{
"p":"orc-721",
"op":"mint",
"s":"diypunks",
"g":[0]
}
and the second with the (generative) specs - [0,38]
:
{
"p":"orc-721",
"op":"mint",
"s":"diypunks",
"g":[0,38]
}
and the third with the (generative specs) - [59,0,38]
:
{
"p":"orc-721",
"op":"mint",
"s":"diypunks",
"g":[59,0,38]
}
and so on.
Where's the catch? Step 0: To make it work you can (re)use existing inscribed spritesheets / art layers or inscribe your very own. Read on.
To inscribe your spritesheet(s) / art layers you have three format options:
- binary image - ultra-compact (less bytes, saving sats!)
- tabular text / dataset (.csv) - compact (less bytes, saving sats!)
- structured text / dataset (.json) - classic
Let's use the d.i.y (ordinal) punks as an example.
Inscribe the spritesheet / art layers as a single binary image file (image/png).
Example - spritesheet.png (~4kb):
Note: To make it work all sprites or attributes MUST be of the same image dimension (e.g. 24x24) and get referenced by number (starting with 0) counting left-to-right and top-to-bottom.
Thus, for example [59,0,38]
from the mint starter examples:
{
"p":"orc-721",
"op":"mint",
"s":"diypunks",
"g":[59,0,38]
}
references the sprites / attributes no. 59 - , no. 0 - , no. 38- and the sprites / attributes get merged / stacked / pasted-on-top-of-each-other in the order listed resulting in .
Aside - Pasted On Top Of Each Other?!
Yes, the (generative) magic is the transparent background / color! If you merge a solid / fully opaque image (let's say all black) on-top-of another image, than it gets completly overwritten - to make the (generative) magic work - use the transparent color in your sprite / art layers.
Using the tabular (text) format in the comma-separated values (.csv) format lets you add "on-chain" metadata such as names, categories, and more.
Example - spritesheet.csv:
name, category, base64
Blue, Background,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEVkhZa3PARZAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
Bitcoin Orange, Background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEX3kh03gNzOAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
Purple, Background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEWOb7aMtmqBAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
Antenna, Accessories, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAKUlEQVRYCe3BsQ0AIADDsOT/o8sJLEgssSHJhTpg4oDxmzKSJEmS5KEDUlIFA6L+DvwAAAAASUVORK5CYII=
Rainbow, Accessories, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAu0lEQVRYw+2OsQ5EQBCG12ucjhegpaFdPa/GG3BoeDMamv1vZ5bG1XvJJfMlX2ZGJPspJQiCIAiCIAiWI0tx5imOLMHvH88T4K2sAU8OYROcNojuk/fUTxzGAGYvgb2w02pDzKisLoh2kHb3EmC2EtVUQ88NT3OHbIWLonnpJUBPDcLWsK8O0BRzBem5RkXyXfsJoEeHaMEQr+yrcyFk2IJvF2f8BAzxgufdsytL923/+LeP1q9vgvB3fABOiLQ6WjY8vQAAAABJRU5ErkJggg==
...
Note: The name (or names) or the category columns are optional - only the base64-encoded image is required - and, yes you can add more columns as you please.
Aside - What's base64?
Images are binary blobs - using the base64 encoding you can convert (or encode) the binary blob into an ascii-7bit (& utf-8)-safe text snippet that you can copy-n-paste into any text file.
Using the structured (text) format in the javascript object notation (.json) format lets you add "on-chain" metadata such as names, categories, and more.
Example - spritesheet.json:
[{ "name": "Blue",
"category": "Background",
"base64": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEVkhZa3PARZAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=" },
{ "name": "Bitcoin Orange",
"category": "Background",
"base64": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEX3kh03gNzOAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=" },
{ "name": "Purple",
"category": "Background",
"base64": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEWOb7aMtmqBAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=" },
{ "name": "Antenna",
"category": "Accessories",
"base64": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAKUlEQVRYCe3BsQ0AIADDsOT/o8sJLEgssSHJhTpg4oDxmzKSJEmS5KEDUlIFA6L+DvwAAAAASUVORK5CYII=" },
{ "name": "Rainbow",
"category": "Accessories",
"base64": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAu0lEQVRYw+2OsQ5EQBCG12ucjhegpaFdPa/GG3BoeDMamv1vZ5bG1XvJJfMlX2ZGJPspJQiCIAiCIAiWI0tx5imOLMHvH88T4K2sAU8OYROcNojuk/fUTxzGAGYvgb2w02pDzKisLoh2kHb3EmC2EtVUQ88NT3OHbIWLonnpJUBPDcLWsK8O0BRzBem5RkXyXfsJoEeHaMEQr+yrcyFk2IJvF2f8BAzxgufdsytL923/+LeP1q9vgvB3fABOiLQ6WjY8vQAAAABJRU5ErkJggg=="},
...
]
Note: The name (or names) or the category keys are optional - only the base64-encoded image is required - and, yes you can add more keys as you please.
Format Option 1) Binary Image - Ultra-Compact
Example - no1/spritesheet.png (~4kb):
Format Option 2) Tabular Text (.csv) - Compact
Example - no1/spritesheet.csv:
name, category, base64
...
and the deploy inscription:
{
"p": "orc-721",
"op": "deploy",
"slug": "diypunks",
"name": "D.I.Y. Punks",
"max": 100,
"dim": "24x24",
"generative": "<spritesheet/art layers inscription id here>"
}
and the mint inscriptions...
Format Option 1) Binary Image - Ultra-Compact
Example - no2/spritesheet.png (~??kb):
Format Option 2) Tabular Text (.csv) - Compact
Example - no2/spritesheet.csv:
name, category, base64
...
and the deploy inscription:
{
"p": "orc-721",
"op": "deploy",
"slug": "diywiener",
"name": "D.I.Y. Wiener",
"max": 100,
"dim": "32x32",
"generative": "<spritesheet/art layers inscription id here>"
}
and the mint inscriptions...
What's different compared to Generative BRC-721 (by Jerry Fanelli)? Let's compare the Ordibots (BRC-721) and D.I.Y. Ordibots (ORC-721) inscriptions!
Format Option 1) Binary Image - Ultra-Compact
Example - no3/spritesheet.png (~3kb):
Format Option 2) Tabular Text (.csv) - Compact
Example - no3/spritesheet.csv:
name, category, base64
blue, background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEVkhZa3PARZAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
bitcoin-orange, background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEX3kh03gNzOAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
brown, background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEWUVU4LyOhwAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
purple, background, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgAQMAAABJtOi3AAAAA1BMVEWOb7aMtmqBAAAAC0lEQVR4AWMY5AAAAKAAAVQqnscAAAAASUVORK5CYII=
antenna, accessories, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAKUlEQVRYCe3BsQ0AIADDsOT/o8sJLEgssSHJhTpg4oDxmzKSJEmS5KEDUlIFA6L+DvwAAAAASUVORK5CYII=
none, accessories, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAGklEQVRYR+3BAQEAAACCIP+vbkhAAQAAAO8GECAAAcFgLJ8AAAAASUVORK5CYII=
rainbow, accessories, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAu0lEQVRYw+2OsQ5EQBCG12ucjhegpaFdPa/GG3BoeDMamv1vZ5bG1XvJJfMlX2ZGJPspJQiCIAiCIAiWI0tx5imOLMHvH88T4K2sAU8OYROcNojuk/fUTxzGAGYvgb2w02pDzKisLoh2kHb3EmC2EtVUQ88NT3OHbIWLonnpJUBPDcLWsK8O0BRzBem5RkXyXfsJoEeHaMEQr+yrcyFk2IJvF2f8BAzxgufdsytL923/+LeP1q9vgvB3fABOiLQ6WjY8vQAAAABJRU5ErkJggg==
...
and the deploy inscription:
{
"p": "orc-721",
"op": "deploy",
"slug": "diyordibots",
"name": "D.I.Y. Ordibots",
"max": 1000,
"dim": "32x32",
"generative": "<spritesheet/art layers inscription id here>"
}
and the mint inscriptions:
ordibot no. 0 specs:
- background: 2 - brown
- accessories: 5 - none
- body: 16 - standard-oval
- belly: 23 - empty
- face: 9 - surprised
{
"p":"orc-721",
"op":"mint",
"s":"diyordibots",
"g": [2,5,16,23,9]
}
ordibot no. 1 specs:
- background: 0 - blue
- accessories: 4 - antenna
- body: 16 - standard-oval
- belly: 23 - empty
- face: 8 - neutral
{
"p":"orc-721",
"op":"mint",
"s":"diyordibots",
"g": [0,4,16,23,8]
}
and so on.
Compare to Gen-BRC-721
The deploy inscription (no. 8 326 719) on May 21, 2023 by Jerry Fanelli
{
"p": "gen-brc-721",
"op": "deploy",
"slug": "ordibots",
"name": "OrdiBots",
"supply": 1000,
"trait_types": [
"background",
"accessories",
"body",
"belly",
"face"
],
"traits": {
...
}
}
The 1000 mint inscriptions
{
"p":"gen-brc-721",
"op":"mint",
"s":"ordibots",
"t_ins":["b7205d40f3b1b1486567f0d6e53ff2812983db4c03ad7d3606812cd150c64802i0"],
"h":"2b936881d34e7be726d6ad3f23edbdaf84ae5974e33c987505d4d70a144859d5",
"id":"0",
"a":[[0,"brown"],
[0,"none"],
[0,"standard-oval"],
[0,"empty"],
[0,"surprised"]]
}
{
"p":"gen-brc-721",
"op":"mint",
"s":"ordibots",
"t_ins":["b7205d40f3b1b1486567f0d6e53ff2812983db4c03ad7d3606812cd150c64802i0"],
"h":"ad82a097c19a5d349ab99db3ad9102caf624486702d9a147f4d3003162b90222",
"id":"1",
"a":[[0,"blue"],
[0,"antenna"],
[0,"standard-oval"],
[0,"empty"],
[0,"neutral"]]
}
and so on.
What's different compared to Generative BRC-721 (by Jerry Fanelli)?
Three main ideas:
- Make it (even) easier
- Use less bytes (and, thus, save on inscription fees)
- Many more options (and less restrictions / requirements)
- Keep all keys unique, that is, MUST start with a different letter,
thus,
- d is the same as dim
- g is the same as generative
- n is the same as name
- m is the same as max
- s is the same as slug
- etc.
Birth of Ordinals
Birth of BRC-20 Tokens
May 23rd, 2023 - Birth of Generative BRC-721
May 27th, 2023 - Hearing first and reading-up on the Generative BRC-721 docu / write-up by Jerry Fanelli and the 1000 Ordibots collection
May 28th, 2023 - Birthday!
The Generative ORC-721 protcol, sample scripts & collections are dedicated to the public domain. Use it as you please with no restrictions whatsoever.
Post them over at the Help & Support page. Thanks.