8 releases

0.1.1 Aug 18, 2023
0.1.0 Aug 10, 2023
0.0.1-alpha.5 Aug 7, 2023
0.0.1-alpha.3 Jul 29, 2023

#263 in Images


Used in 2 crates (via paperdoll-tar)

MIT license

36KB
682 lines

paperdoll

Latest version Documentation MIT

2D pixel-based stationary paper doll model.

  • It's 2D.
  • It's pixel-based. Vector images and basic shapes are not supported in the current version.
  • It's stationary. Animations and transformations are not supported in the current version.

Latest version: 1.

Design

The model consists of three parts: doll, slot, and fragment.

Doll

Dolls are the fundamental parts of your model. Normally, they represent faces, bodies, or any other assembled objects in your projects. A doll contains multiple slots.

Slot

Slots are where your paper doll can have alternative styles. For example, in a doll that represents a human's face, they could be eyes, mouth, nose, and so on.

A slot can be placed in different positions inside the doll (eg. slot of eyes). Not all slots need to have images to be shown, they can be empty. For instance, an empty 'hair' slot means that the person is bald.

Each slot has several alternative images to display. they're called 'candidates'. And those candidates are all defined as fragments.

Fragment

Fragments are image assets that you can put into a slot as candidates. In paperdoll, all fragments are raster images. One fragment can be used in multiple slots.

There are two ways slots and their fragment candidates are connected.

  • Constrainted. The fragment acts like the background of the slot. It will fill the whole space of the slot and resizes if needed.

  • Non-constrainted. Slots and fragments are connected like mortises and tenons. There is an anchor point inside a slot. When a fragment is placed into a slot, the pivot point of that fragment will be placed in the same position as the anchor point. The fragment remains its original size and resizing will never happen.

core-concept

Container format

ppd

ppd is a tar archive container for paperdoll. Read more.

Tools

Editor for paperdoll.

ppd-editor

Viewer for paperdoll.

ppd-viewer

Dependencies

~0.5–1.2MB
~26K SLoC