72 lines
1.1 KiB
Nim
72 lines
1.1 KiB
Nim
import benchy, pixie
|
|
|
|
block:
|
|
let mask = newMask(2560, 1440)
|
|
|
|
proc reset() =
|
|
mask.fill(63)
|
|
|
|
reset()
|
|
|
|
timeIt "minifyBy2":
|
|
let minified = mask.minifyBy2()
|
|
doAssert minified[0, 0] == 63
|
|
|
|
reset()
|
|
|
|
timeIt "magnifyBy2":
|
|
let magnified = mask.magnifyBy2()
|
|
doAssert magnified[0, 0] == 63
|
|
|
|
reset()
|
|
|
|
timeIt "invert":
|
|
mask.invert()
|
|
|
|
reset()
|
|
|
|
timeIt "applyOpacity":
|
|
reset()
|
|
mask.applyOpacity(0.5)
|
|
|
|
reset()
|
|
|
|
timeIt "ceil":
|
|
mask.ceil()
|
|
|
|
block:
|
|
let mask = newMask(400, 400)
|
|
mask.fill(63)
|
|
|
|
timeIt "blur":
|
|
mask.blur(12)
|
|
|
|
block spread_1:
|
|
let p = newPath()
|
|
p.rect(100, 100, 200, 200)
|
|
|
|
timeIt "spread_1":
|
|
mask.fill(0)
|
|
mask.fillPath(p)
|
|
mask.spread(5)
|
|
|
|
block spread_2:
|
|
let p = newPath()
|
|
p.rect(100, 100, 200, 200)
|
|
|
|
timeIt "spread_2":
|
|
mask.fill(0)
|
|
mask.fillPath(p)
|
|
mask.spread(10)
|
|
|
|
block spread_3:
|
|
timeIt "spread_3":
|
|
mask.fill(255)
|
|
mask.spread(10)
|
|
|
|
block spread_4:
|
|
timeIt "spread_4":
|
|
mask.fill(0)
|
|
mask.unsafe[200, 200] = 255
|
|
mask.spread(5)
|