Try   HackMD

VRM to Spritesheet

Sprites can help with optimization, like generating imposters that improve concurrent user count with assets that look like the original custom avatar.

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →

Character Studio Pipeline

using character studio to generate the sprites, example animation / manifest file

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →
Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →

It works with different sized models as well

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →


r3f-sprite-animator

{"frames": {

"Celebration_000":
{
	"frame": {"x":1,"y":1,"w":560,"h":440},
	"rotated": false,
	"trimmed": false,
	"spriteSourceSize": {"x":0,"y":0,"w":560,"h":440},
	"sourceSize": {"w":560,"h":440}
},
"Celebration_001":
{
	"frame": {"x":1,"y":443,"w":560,"h":440},
	"rotated": false,
	"trimmed": false,
	"spriteSourceSize": {"x":0,"y":0,"w":560,"h":440},
	"sourceSize": {"w":560,"h":440}
},
"Celebration_002":
{
	"frame": {"x":1,"y":885,"w":560,"h":440},
	"rotated": false,
	"trimmed": false,
	"spriteSourceSize": {"x":0,"y":0,"w":560,"h":440},
	"sourceSize": {"w":560,"h":440}
},
"Celebration_003":
{
	"frame": {"x":1,"y":1327,"w":560,"h":440},
	"rotated": false,
	"trimmed": false,
	"spriteSourceSize": {"x":0,"y":0,"w":560,"h":440},
	"sourceSize": {"w":560,"h":440}
},

https://twitter.com/antpb/status/1752868882291790262

The biggest thing we need is a list of standard animations. My current implementation is

  • idle
  • idleBackward
  • walk
  • walkBackward

For jumps you could use the walk animation clamped to a frame where the leg is forward. These are all very old problems though so I’m sure there’s some very standard way that is a one file sheet. The names matter most because the implementations could just not care what the animations do and play on the state associated like walk


Notes

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →

{
    "Apple": {
        "frame": {"x":292,"y":304,"w":60,"h":61},
        "rotated": false,
        "trimmed": true,
        "spriteSourceSize": {"x":23,"y":29,"w":60,"h":61},
        "sourceSize": {"w":90,"h":90},
        "pivot": {"x":0.5,"y":0.5}
    },
    ...
}

snippet from Eidur in Webgamedev discord

I'm implementing vanilla three and threlte components and utilities at the same time.

export type SpritesheetFormat = {
  frames: [x: number, y: number, w: number, h: number][];
  animations: Record<string, [frameId: number, duration: number][]>;
  sheetSize: [w: number, h: number];
  animationLengths: number[];
};

glTF extension notes

rough sketch by lasershark

{
  "extensionsUsed": ["m3_spritesheet_animations"],
  "images": [
    {
      "uri": "..."
    }
  ],
  "extensions": {
    "m3_spritesheet_animations": {
      "spritesheets": [
        {
          "image": 0,
          "name": "Sprite Animations",
          "dimensions": { "width": 1024, "height": 1024, "framesH": 4, "framesV": 4 },
          "frameRate": 12,
          "animations": [
            { "name": "walking", "startFrame": 0, "endFrame": 3, "loop": true },
            { "name": "jumping", "startFrame": 4, "endFrame": 7, "loop": false }
          ]
        }
      ]
    }
  }
}