Introduce FLOAT and DOUBLE types

This commit is contained in:
Martín Capello 2023-01-05 15:30:45 -03:00
parent eebc661a56
commit 03d66aa203
6 changed files with 116 additions and 14 deletions

View File

@ -17,6 +17,8 @@ ASE files use Intel (little-endian) byte order.
* `DWORD`: A 32-bit unsigned integer value * `DWORD`: A 32-bit unsigned integer value
* `LONG`: A 32-bit signed integer value * `LONG`: A 32-bit signed integer value
* `FIXED`: A 32-bit fixed point (16.16) value * `FIXED`: A 32-bit fixed point (16.16) value
* `FLOAT`: A 32-bit single-precision value
* `DOUBLE`: A 64-bit double-precision value
* `QWORD`: A 64-bit unsigned integer value * `QWORD`: A 64-bit unsigned integer value
* `LONG64`: A 64-bit signed integer value * `LONG64`: A 64-bit signed integer value
* `BYTE[n]`: "n" bytes. * `BYTE[n]`: "n" bytes.
@ -399,19 +401,23 @@ there is an User Data Chunk at the first frame after the Palette Chunk.
+ If type==0x000A + If type==0x000A
FIXED FIXED
+ If type==0x000B + If type==0x000B
STRING FLOAT
+ If type==0x000C + If type==0x000C
POINT DOUBLE
+ If type==0x000D + If type==0x000D
SIZE STRING
+ If type==0x000E + If type==0x000E
POINT
+ If type==0x000F
SIZE
+ If type==0x0010
RECT RECT
+ If type==0x000F (vector) + If type==0x0011 (vector)
DWORD Number of elements DWORD Number of elements
WORD Element's type WORD Element's type
BYTE[] As many values as the number of elements indicates BYTE[] As many values as the number of elements indicates
Structure depends on the element's type Structure depends on the element's type
+ If type==0x0010 (nested properties map) + If type==0x0012 (nested properties map)
DWORD Number of properties DWORD Number of properties
BYTE[] Nested properties data BYTE[] Nested properties data
Structure is the same as indicated in this loop Structure is the same as indicated in this loop

View File

@ -1459,6 +1459,12 @@ static void ase_file_write_property_value(FILE* f,
else if (const UserData::Fixed* v = std::get_if<UserData::Fixed>(&value)) { else if (const UserData::Fixed* v = std::get_if<UserData::Fixed>(&value)) {
fputl(v->value, f); fputl(v->value, f);
} }
else if (const float_t* v = std::get_if<float_t>(&value)) {
fputf(*v, f);
}
else if (const double_t* v = std::get_if<double_t>(&value)) {
fputd(*v, f);
}
else if (const std::string* v = std::get_if<std::string>(&value)) { else if (const std::string* v = std::get_if<std::string>(&value)) {
ase_file_write_string(f, *v); ase_file_write_string(f, *v);
} }

View File

@ -61,6 +61,19 @@ int get_value_from_lua(lua_State* L, int index) {
return lua_tointeger(L, index); return lua_tointeger(L, index);
} }
// ----------------------------------------------------------------------
// float
template<>
void push_value_to_lua(lua_State* L, const float& value) {
lua_pushnumber(L, value);
}
template<>
float get_value_from_lua(lua_State* L, int index) {
return lua_tonumber(L, index);
}
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
// double // double
@ -321,6 +334,11 @@ void push_value_to_lua(lua_State* L, const doc::UserData::Variant& value)
break; break;
case USER_DATA_PROPERTY_TYPE_FIXED: case USER_DATA_PROPERTY_TYPE_FIXED:
push_value_to_lua(L, *std::get_if<doc::UserData::Fixed>(&value)); push_value_to_lua(L, *std::get_if<doc::UserData::Fixed>(&value));
case USER_DATA_PROPERTY_TYPE_FLOAT:
push_value_to_lua(L, *std::get_if<float>(&value));
break;
case USER_DATA_PROPERTY_TYPE_DOUBLE:
push_value_to_lua(L, *std::get_if<double>(&value));
break; break;
case USER_DATA_PROPERTY_TYPE_STRING: case USER_DATA_PROPERTY_TYPE_STRING:
push_value_to_lua(L, *std::get_if<std::string>(&value)); push_value_to_lua(L, *std::get_if<std::string>(&value));
@ -366,9 +384,7 @@ doc::UserData::Variant get_value_from_lua(lua_State* L, int index)
if (lua_isinteger(L, index)) if (lua_isinteger(L, index))
v = lua_tointeger(L, index); v = lua_tointeger(L, index);
else { else {
v = doc::UserData::Fixed{ v = lua_tonumber(L, index);
fixmath::ftofix(lua_tonumber(L, index))
};
} }
break; break;

View File

@ -391,6 +391,67 @@ std::string AsepriteDecoder::readString()
return string; return string;
} }
float AsepriteDecoder::readFloat()
{
int b1, b2, b3, b4;
if ((b1 = read8()) == EOF)
return EOF;
if ((b2 = read8()) == EOF)
return EOF;
if ((b3 = read8()) == EOF)
return EOF;
if ((b4 = read8()) == EOF)
return EOF;
// Little endian.
int v = ((b4 << 24) | (b3 << 16) | (b2 << 8) | b1);
return *reinterpret_cast<float*>(&v);
}
double AsepriteDecoder::readDouble()
{
int b1, b2, b3, b4, b5, b6, b7, b8;
if ((b1 = read8()) == EOF)
return EOF;
if ((b2 = read8()) == EOF)
return EOF;
if ((b3 = read8()) == EOF)
return EOF;
if ((b4 = read8()) == EOF)
return EOF;
if ((b5 = read8()) == EOF)
return EOF;
if ((b6 = read8()) == EOF)
return EOF;
if ((b7 = read8()) == EOF)
return EOF;
if ((b8 = read8()) == EOF)
return EOF;
// Little endian.
long long v = (((long long)b8 << 56) |
((long long)b7 << 48) |
((long long)b6 << 40) |
((long long)b5 << 32) |
((long long)b4 << 24) |
((long long)b3 << 16) |
((long long)b2 << 8) |
(long long)b1);
return *reinterpret_cast<double*>(&v);
}
doc::Palette* AsepriteDecoder::readColorChunk(doc::Palette* prevPal, doc::Palette* AsepriteDecoder::readColorChunk(doc::Palette* prevPal,
doc::frame_t frame) doc::frame_t frame)
{ {
@ -1249,6 +1310,14 @@ const doc::UserData::Variant AsepriteDecoder::readPropertyValue(uint16_t type)
int32_t value = read32(); int32_t value = read32();
return doc::UserData::Fixed{value}; return doc::UserData::Fixed{value};
} }
case USER_DATA_PROPERTY_TYPE_FLOAT: {
float value = readFloat();
return value;
}
case USER_DATA_PROPERTY_TYPE_DOUBLE: {
double value = readDouble();
return value;
}
case USER_DATA_PROPERTY_TYPE_STRING: { case USER_DATA_PROPERTY_TYPE_STRING: {
std::string value = readString(); std::string value = readString();
return value; return value;

View File

@ -46,6 +46,8 @@ private:
void readFrameHeader(AsepriteFrameHeader* frame_header); void readFrameHeader(AsepriteFrameHeader* frame_header);
void readPadding(const int bytes); void readPadding(const int bytes);
std::string readString(); std::string readString();
float readFloat();
double readDouble();
doc::Palette* readColorChunk(doc::Palette* prevPal, doc::frame_t frame); doc::Palette* readColorChunk(doc::Palette* prevPal, doc::frame_t frame);
doc::Palette* readColor2Chunk(doc::Palette* prevPal, doc::frame_t frame); doc::Palette* readColor2Chunk(doc::Palette* prevPal, doc::frame_t frame);
doc::Palette* readPaletteChunk(doc::Palette* prevPal, doc::frame_t frame); doc::Palette* readPaletteChunk(doc::Palette* prevPal, doc::frame_t frame);

View File

@ -31,12 +31,14 @@
#define USER_DATA_PROPERTY_TYPE_INT64 0x0008 #define USER_DATA_PROPERTY_TYPE_INT64 0x0008
#define USER_DATA_PROPERTY_TYPE_UINT64 0x0009 #define USER_DATA_PROPERTY_TYPE_UINT64 0x0009
#define USER_DATA_PROPERTY_TYPE_FIXED 0x000A #define USER_DATA_PROPERTY_TYPE_FIXED 0x000A
#define USER_DATA_PROPERTY_TYPE_STRING 0x000B #define USER_DATA_PROPERTY_TYPE_FLOAT 0x000B
#define USER_DATA_PROPERTY_TYPE_POINT 0x000C #define USER_DATA_PROPERTY_TYPE_DOUBLE 0x000C
#define USER_DATA_PROPERTY_TYPE_SIZE 0x000D #define USER_DATA_PROPERTY_TYPE_STRING 0x000D
#define USER_DATA_PROPERTY_TYPE_RECT 0x000E #define USER_DATA_PROPERTY_TYPE_POINT 0x000E
#define USER_DATA_PROPERTY_TYPE_VECTOR 0x000F #define USER_DATA_PROPERTY_TYPE_SIZE 0x000F
#define USER_DATA_PROPERTY_TYPE_PROPERTIES 0x0010 #define USER_DATA_PROPERTY_TYPE_RECT 0x0010
#define USER_DATA_PROPERTY_TYPE_VECTOR 0x0011
#define USER_DATA_PROPERTY_TYPE_PROPERTIES 0x0012
namespace doc { namespace doc {
@ -59,6 +61,7 @@ namespace doc {
int32_t, uint32_t, int32_t, uint32_t,
int64_t, uint64_t, int64_t, uint64_t,
Fixed, Fixed,
float, double,
std::string, std::string,
gfx::Point, gfx::Point,
gfx::Size, gfx::Size,