Fork of Pixie for nimskull and with extra features
Go to file
Ryan Oldenburg 6fd7df9b23 shortcut
2021-02-08 21:44:17 -06:00
.github/workflows
examples updated examples 2021-01-29 14:21:48 -06:00
experiments add trapezoid experiment. 2021-01-29 22:42:49 -08:00
src shortcut 2021-02-08 21:44:17 -06:00
tests mask applyOpacity 10x faster 2021-02-08 21:12:28 -06:00
tools Better readme. 2020-12-04 09:41:28 -08:00
.gitignore ignore dll 2020-12-09 23:49:00 -06:00
LICENSE
pixie.nimble nimsimd dep 2021-01-27 02:07:21 -06:00
README.md updated examples 2021-01-29 14:21:48 -06:00

Pixie - A full-featured 2D graphics library for Nim

⚠️ WARNING: This library is still in heavy development. ⚠️

Pixie is a 2D graphics library similar to Cairo and Skia written (almost) entirely in Nim.

Features include:

  • Drawing paths, shapes and curves
  • Complex masking
  • Shadows, glows and effects
  • Loading image file formats (PNG, BMP, JPG, SVG + more in development)

This library is being actively developed and is not yet ready for use. Since you've managed to stumble onto it, give it a star and check back soon!

Testing

nimble test

Examples

Blur

examples/blur.nim

var p: Path
p.polygon(100, 100, 70, sides=6)
p.closePath()

let mask = newImage(200, 200)
mask.fillPath(p, rgba(255, 255, 255, 255))

blur.blur(20)
blur.draw(mask, blendMode = bmMask)

image.draw(trees)
image.draw(blur)

example output

Rounded rectangle

examples/rounded_rectangle.nim

let
  x = 50.0
  y = 50.0
  w = 100.0
  h = 100.0
  r = 25.0

var path: Path
path.moveTo(x+r, y)
path.arcTo(x+w, y,   x+w, y+h, r)
path.arcTo(x+w, y+h, x,   y+h, r)
path.arcTo(x,   y+h, x,   y,   r)
path.arcTo(x,   y,   x+w, y,   r)
path.closePath()

image.fillPath(path, rgba(255, 0, 0, 255))

example output

Square

examples/square.nim

var p: Path
p.moveTo(50, 50)
p.lineTo(50, 150)
p.lineTo(150, 150)
p.lineTo(150, 50)
p.closePath()

image.fillPath(p, rgba(255, 0, 0, 255))

example output

Tiger

examples/tiger.nim

let tiger = readImage("examples/data/tiger.svg")

image.draw(
  tiger,
  translate(vec2(100, 100)) *
  scale(vec2(0.2, 0.2)) *
  translate(vec2(-450, -450))
)

example output