You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Consider the following scenario: 2 character sprite sheets that contain the exact same character frames, just with different colors (color indexes). In that case, rescomp will not realize it could avoid performing the sprite cutting on the second sheet.
I believe this is a relatively common scenario to work around the harsh color palette limitations of the Mega Drive. Xeno Crisis does this for the green and blue variants of the playable characters, for example.
What I guess you're doing internally in rescomp's sprite cutting logic is only care about which pixel is opaque or transparent, you don't care about the colors used, right? That means you could use that opaque vs transparent pixel matrix as a reference to determine whether a frame is a clone of an already-processed frame or not, which would cover the need above.
Just an idea. Thanks for entertaining the idea!
PS: This also makes me wonder if, ROM data wise, any data could be shared across such similar sprite sheets in order to reduce the footprint of similar sheets.
The text was updated successfully, but these errors were encountered:
Thanks the detailed report and the sprite sheets !
Indeed rescomp doesn't perform any check about duplicated sprite mask (opaque pixels shape) along all the sprite frames / animations / sheets and it would avoid recomputing the sprite cutting in that case as you said. Still that is not that easy to compare sprite mask along all already processed sprites, i guess I could compute a hash code based on the mask shape instead of the content...
I qualified your issue as enhancement and keep it open until i find sometime to work on that !
Hi.
Consider the following scenario: 2 character sprite sheets that contain the exact same character frames, just with different colors (color indexes). In that case, rescomp will not realize it could avoid performing the sprite cutting on the second sheet.
I believe this is a relatively common scenario to work around the harsh color palette limitations of the Mega Drive. Xeno Crisis does this for the green and blue variants of the playable characters, for example.
What I guess you're doing internally in rescomp's sprite cutting logic is only care about which pixel is opaque or transparent, you don't care about the colors used, right? That means you could use that opaque vs transparent pixel matrix as a reference to determine whether a frame is a clone of an already-processed frame or not, which would cover the need above.
Just an idea. Thanks for entertaining the idea!
PS: This also makes me wonder if, ROM data wise, any data could be shared across such similar sprite sheets in order to reduce the footprint of similar sheets.
The text was updated successfully, but these errors were encountered: