mirror of
https://github.com/aseprite/aseprite.git
synced 2025-01-04 17:40:01 +00:00
Add export sprite sheet test when some cels are linked + TrimmedCels + Merge Duplicates + SplitLayers checked https://github.com/aseprite/aseprite/issues/2600
This commit is contained in:
parent
2a96d2d1c0
commit
09958449c3
71
cli/sheet.sh
71
cli/sheet.sh
@ -1,5 +1,5 @@
|
||||
#! /bin/bash
|
||||
# Copyright (C) 2019-2020 Igara Studio S.A.
|
||||
# Copyright (C) 2019-2022 Igara Studio S.A.
|
||||
|
||||
# $1 = first sprite sheet json file
|
||||
# $2 = second sprite sheet json file
|
||||
@ -331,3 +331,72 @@ assert(#sheet2.meta.layers == 8)
|
||||
assert(json.encode(sheet1.meta.layers) == json.encode(sheet2.meta.layers))
|
||||
EOF
|
||||
$ASEPRITE -b -script "$d/check.lua" || exit 1
|
||||
|
||||
# https://github.com/aseprite/aseprite/issues/2600
|
||||
# -merge-duplicates -split-layers -trim give incorrect 'frame' coordinates on linked cels
|
||||
d=$t/issue-2600
|
||||
$ASEPRITE -b -list-layers -format json-array -trim -merge-duplicates -split-layers -all-layers "sprites/link.aseprite" -data "$d/sheet.json" -sheet "$d/sheet.png"
|
||||
cat >$d/check.lua <<EOF
|
||||
local json = dofile('third_party/json/json.lua')
|
||||
local sheet = json.decode(io.open('$d/sheet.json'):read('a'))
|
||||
local restoredSprite = Sprite(sheet.frames[1].sourceSize.w, sheet.frames[1].sourceSize.h, ColorMode.RGB)
|
||||
local spriteSheet = Image{ fromFile="$d/sheet.png" }
|
||||
local lay = 1
|
||||
repeat
|
||||
local layerName = sheet.meta.layers[lay].name
|
||||
local layer = restoredSprite.layers[lay]
|
||||
for i=1, #sheet.frames do
|
||||
if string.find(sheet.frames[i].filename, layerName) ~= nil then
|
||||
local sample = sheet.frames[i]
|
||||
local dotAseIndex = string.find(sample.filename, ".ase")
|
||||
local frame = (string.sub(sample.filename, dotAseIndex - 2, dotAseIndex - 1)) + 1
|
||||
for f=#restoredSprite.frames, frame-1 do
|
||||
restoredSprite:newEmptyFrame()
|
||||
end
|
||||
local image = Image(sample.frame.w, sample.frame.h)
|
||||
for y=0,image.height-1 do
|
||||
for x=0,image.width-1 do
|
||||
image:drawPixel(x, y, spriteSheet:getPixel(sample.frame.x + x, sample.frame.y + y))
|
||||
end
|
||||
end
|
||||
restoredSprite:newCel(layer, frame, image, Point(sample.spriteSourceSize.x, sample.spriteSourceSize.y))
|
||||
end
|
||||
end
|
||||
if lay < #sheet.meta.layers then
|
||||
restoredSprite:newLayer()
|
||||
end
|
||||
lay = lay + 1
|
||||
until(lay > #sheet.meta.layers)
|
||||
|
||||
app.activeSprite = restoredSprite
|
||||
app.activeLayer = restoredSprite.layers[#restoredSprite.layers]
|
||||
for i=1,#restoredSprite.layers-1 do
|
||||
app.command.MergeDownLayer()
|
||||
end
|
||||
|
||||
local orig = app.open("sprites/link.aseprite")
|
||||
app.activeSprite = orig
|
||||
app.activeLayer = orig.layers[#orig.layers]
|
||||
for i=1,#orig.layers-1 do
|
||||
app.command.MergeDownLayer()
|
||||
end
|
||||
|
||||
assert(orig.width == restoredSprite.width)
|
||||
assert(orig.height == restoredSprite.height)
|
||||
assert(#orig.frames == #restoredSprite.frames)
|
||||
for fr=1,#restoredSprite.frames do
|
||||
for celIndex1=1,#restoredSprite.cels do
|
||||
if restoredSprite.cels[celIndex1].frameNumber == fr then
|
||||
for celIndex2=1,#orig.cels do
|
||||
if orig.cels[celIndex2].frameNumber == fr then
|
||||
assert(orig.cels[celIndex2].position == restoredSprite.cels[celIndex1].position)
|
||||
if orig.cels[celIndex2].image ~= nil and restoredSprite.cels[celIndex1].image ~= nil then
|
||||
assert(orig.cels[celIndex2].image:isEqual(restoredSprite.cels[celIndex1].image))
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
EOF
|
||||
$ASEPRITE -b -script "$d/check.lua" || exit 1
|
||||
|
BIN
sprites/link.aseprite
Normal file
BIN
sprites/link.aseprite
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user