| animations | ||
| cmd/cory-bin | ||
| render_test | ||
| renderer | ||
| utils | ||
| .gitignore | ||
| animation.go | ||
| compress.nri | ||
| const.go | ||
| decode.go | ||
| frame.go | ||
| gawi.go | ||
| go.mod | ||
| go.sum | ||
| image.go | ||
| Makefile | ||
| mon1033.nri | ||
| nori.go | ||
| palette.go | ||
| plane.go | ||
| reader.go | ||
| readme.md | ||
| render_test.go | ||
| render.go | ||
| server.Dockerfile | ||
nri file reader
about
common/nori provides structs and decoders for nori file
usage:
import (
"log"
"git.tuxpa.in/a/nori"
)
func main() {
n, err := nori.FromFile(filename)
if err != nil {
log.Panicln("decode: %s", err)
}
// uses apng encoder/decoder from https://gitlab.com/gfxlabs/gfximg
animations, err := n.RenderAnimationsApng(n)
if err != nil {
log.Panicln("render: %s", err)
}
// each animation has slice of frames
// each frame contains an image.Image, if another format is needed
// internally they are stored as &image.NRGBA64{}
log.Println(animations[0].Frames[])
}
cory
cmd/cory is command line util for working with nori files
get a zip file of animations from a nori file
usage: ./cory -d -f=filename.nri -o=output.zip
optionally, use webserver
start: ./cory -serve
example with curl: curl -X POST --data-binary "@filename.nri" localhost:3333/animations --output output.zip
building cory
make cory
docker
oh yeah there's also a docker image for cory lol
make docker
and to run server
make server-run