support for an absurd hacky trick used by FD: appending to the frame ID via the directives parameter
wtf 😭
This commit is contained in:
parent
6435fd5e34
commit
515d71409c
@ -156,6 +156,15 @@ void Directives::parse(String&& directives) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StringView Directives::prefix() const {
|
||||||
|
if (!m_shared)
|
||||||
|
return "";
|
||||||
|
else if (m_shared->empty())
|
||||||
|
return m_shared->string;
|
||||||
|
else
|
||||||
|
return StringView(m_shared->string).substr(0, m_shared->entries.begin()->begin);
|
||||||
|
}
|
||||||
|
|
||||||
String Directives::string() const {
|
String Directives::string() const {
|
||||||
if (!m_shared)
|
if (!m_shared)
|
||||||
return "";
|
return "";
|
||||||
|
@ -55,6 +55,7 @@ public:
|
|||||||
|
|
||||||
void loadOperations() const;
|
void loadOperations() const;
|
||||||
void parse(String&& directives);
|
void parse(String&& directives);
|
||||||
|
StringView prefix() const;
|
||||||
String string() const;
|
String string() const;
|
||||||
String const* stringPtr() const;
|
String const* stringPtr() const;
|
||||||
String buildString() const;
|
String buildString() const;
|
||||||
|
@ -544,7 +544,7 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
auto backArmDrawable = [&](String const& frameSet, Directives const& directives) -> Drawable {
|
auto backArmDrawable = [&](String const& frameSet, Directives const& directives) -> Drawable {
|
||||||
String image = strf("{}:{}", frameSet, backHand.backFrame);
|
String image = strf("{}:{}{}", frameSet, backHand.backFrame, directives.prefix());
|
||||||
Drawable backArm = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, backArmFrameOffset);
|
Drawable backArm = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, backArmFrameOffset);
|
||||||
backArm.imagePart().addDirectives(directives, true);
|
backArm.imagePart().addDirectives(directives, true);
|
||||||
backArm.rotate(backHand.angle, backArmFrameOffset + m_backArmRotationCenter + m_backArmOffset);
|
backArm.rotate(backHand.angle, backArmFrameOffset + m_backArmRotationCenter + m_backArmOffset);
|
||||||
@ -553,15 +553,16 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
|
|
||||||
if (!m_backArmorFrameset.empty()) {
|
if (!m_backArmorFrameset.empty()) {
|
||||||
auto frameGroup = frameBase(m_state);
|
auto frameGroup = frameBase(m_state);
|
||||||
|
auto prefix = m_backArmorDirectives.prefix();
|
||||||
if (m_movingBackwards && (m_state == State::Run))
|
if (m_movingBackwards && (m_state == State::Run))
|
||||||
frameGroup = "runbackwards";
|
frameGroup = "runbackwards";
|
||||||
String image;
|
String image;
|
||||||
if (dance.isValid() && danceStep->bodyFrame)
|
if (dance.isValid() && danceStep->bodyFrame)
|
||||||
image = strf("{}:{}", m_backArmorFrameset, *danceStep->bodyFrame);
|
image = strf("{}:{}{}", m_backArmorFrameset, *danceStep->bodyFrame, prefix);
|
||||||
else if (m_state == Idle)
|
else if (m_state == Idle)
|
||||||
image = strf("{}:{}", m_backArmorFrameset, m_identity.personality.idle);
|
image = strf("{}:{}{}", m_backArmorFrameset, m_identity.personality.idle, prefix);
|
||||||
else
|
else
|
||||||
image = strf("{}:{}.{}", m_backArmorFrameset, frameGroup, bodyStateSeq);
|
image = strf("{}:{}.{}{}", m_backArmorFrameset, frameGroup, bodyStateSeq, prefix);
|
||||||
|
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, Vec2F());
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, Vec2F());
|
||||||
drawable.imagePart().addDirectives(getBackDirectives(), true);
|
drawable.imagePart().addDirectives(getBackDirectives(), true);
|
||||||
@ -588,16 +589,18 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
if (!m_backArmFrameset.empty() && !m_bodyHidden) {
|
if (!m_backArmFrameset.empty() && !m_bodyHidden) {
|
||||||
String image;
|
String image;
|
||||||
Vec2F position;
|
Vec2F position;
|
||||||
|
auto bodyDirectives = getBodyDirectives();
|
||||||
|
auto prefix = bodyDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->backArmFrame) {
|
if (dance.isValid() && danceStep->backArmFrame) {
|
||||||
image = strf("{}:{}", m_backArmFrameset, *danceStep->backArmFrame);
|
image = strf("{}:{}{}", m_backArmFrameset, *danceStep->backArmFrame, prefix);
|
||||||
position = danceStep->backArmOffset / TilePixels;
|
position = danceStep->backArmOffset / TilePixels;
|
||||||
} else if (m_state == Idle) {
|
} else if (m_state == Idle) {
|
||||||
image = strf("{}:{}", m_backArmFrameset, m_identity.personality.armIdle);
|
image = strf("{}:{}{}", m_backArmFrameset, m_identity.personality.armIdle, prefix);
|
||||||
position = m_identity.personality.armOffset / TilePixels;
|
position = m_identity.personality.armOffset / TilePixels;
|
||||||
} else
|
} else
|
||||||
image = strf("{}:{}.{}", m_backArmFrameset, frameBase(m_state), armStateSeq);
|
image = strf("{}:{}.{}{}", m_backArmFrameset, frameBase(m_state), armStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
||||||
drawable.imagePart().addDirectives(getBodyDirectives(), true);
|
drawable.imagePart().addDirectives(bodyDirectives, true);
|
||||||
if (dance.isValid())
|
if (dance.isValid())
|
||||||
drawable.rotate(danceStep->backArmRotation);
|
drawable.rotate(danceStep->backArmRotation);
|
||||||
addDrawable(std::move(drawable), m_bodyFullbright);
|
addDrawable(std::move(drawable), m_bodyFullbright);
|
||||||
@ -605,14 +608,15 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
if (!m_backSleeveFrameset.empty()) {
|
if (!m_backSleeveFrameset.empty()) {
|
||||||
String image;
|
String image;
|
||||||
Vec2F position;
|
Vec2F position;
|
||||||
|
auto prefix = m_chestArmorDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->backArmFrame) {
|
if (dance.isValid() && danceStep->backArmFrame) {
|
||||||
image = strf("{}:{}", m_backSleeveFrameset, *danceStep->backArmFrame);
|
image = strf("{}:{}{}", m_backSleeveFrameset, *danceStep->backArmFrame, prefix);
|
||||||
position = danceStep->backArmOffset / TilePixels;
|
position = danceStep->backArmOffset / TilePixels;
|
||||||
} else if (m_state == Idle) {
|
} else if (m_state == Idle) {
|
||||||
image = strf("{}:{}", m_backSleeveFrameset, m_identity.personality.armIdle);
|
image = strf("{}:{}{}", m_backSleeveFrameset, m_identity.personality.armIdle, prefix);
|
||||||
position = m_identity.personality.armOffset / TilePixels;
|
position = m_identity.personality.armOffset / TilePixels;
|
||||||
} else
|
} else
|
||||||
image = strf("{}:{}.{}", m_backSleeveFrameset, frameBase(m_state), armStateSeq);
|
image = strf("{}:{}.{}{}", m_backSleeveFrameset, frameBase(m_state), armStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
||||||
drawable.imagePart().addDirectives(getChestDirectives(), true);
|
drawable.imagePart().addDirectives(getChestDirectives(), true);
|
||||||
if (dance.isValid())
|
if (dance.isValid())
|
||||||
@ -645,9 +649,10 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!m_emoteFrameset.empty() && !m_bodyHidden) {
|
if (!m_emoteFrameset.empty() && !m_bodyHidden) {
|
||||||
String image = strf("{}:{}.{}", m_emoteFrameset, emoteFrameBase(m_emoteState), emoteStateSeq);
|
auto emoteDirectives = getEmoteDirectives();
|
||||||
|
String image = strf("{}:{}.{}{}", m_emoteFrameset, emoteFrameBase(m_emoteState), emoteStateSeq, emoteDirectives.prefix());
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, headPosition);
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, headPosition);
|
||||||
drawable.imagePart().addDirectives(getEmoteDirectives(), true);
|
drawable.imagePart().addDirectives(emoteDirectives, true);
|
||||||
addDrawable(std::move(drawable), m_bodyFullbright);
|
addDrawable(std::move(drawable), m_bodyFullbright);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -660,25 +665,28 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
|
|
||||||
if (!m_bodyFrameset.empty() && !m_bodyHidden) {
|
if (!m_bodyFrameset.empty() && !m_bodyHidden) {
|
||||||
String image;
|
String image;
|
||||||
|
auto bodyDirectives = getBodyDirectives();
|
||||||
|
auto prefix = bodyDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->bodyFrame)
|
if (dance.isValid() && danceStep->bodyFrame)
|
||||||
image = strf("{}:{}", m_bodyFrameset, *danceStep->bodyFrame);
|
image = strf("{}:{}{}", m_bodyFrameset, *danceStep->bodyFrame, prefix);
|
||||||
else if (m_state == Idle)
|
else if (m_state == Idle)
|
||||||
image = strf("{}:{}", m_bodyFrameset, m_identity.personality.idle);
|
image = strf("{}:{}{}", m_bodyFrameset, m_identity.personality.idle, prefix);
|
||||||
else
|
else
|
||||||
image = strf("{}:{}.{}", m_bodyFrameset, frameBase(m_state), bodyStateSeq);
|
image = strf("{}:{}.{}{}", m_bodyFrameset, frameBase(m_state), bodyStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, {});
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, {});
|
||||||
drawable.imagePart().addDirectives(getBodyDirectives(), true);
|
drawable.imagePart().addDirectives(bodyDirectives, true);
|
||||||
addDrawable(std::move(drawable), m_bodyFullbright);
|
addDrawable(std::move(drawable), m_bodyFullbright);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!m_legsArmorFrameset.empty()) {
|
if (!m_legsArmorFrameset.empty()) {
|
||||||
String image;
|
String image;
|
||||||
|
auto prefix = m_legsArmorDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->bodyFrame)
|
if (dance.isValid() && danceStep->bodyFrame)
|
||||||
image = strf("{}:{}", m_legsArmorFrameset, *danceStep->bodyFrame);
|
image = strf("{}:{}{}", m_legsArmorFrameset, *danceStep->bodyFrame, prefix);
|
||||||
else if (m_state == Idle)
|
else if (m_state == Idle)
|
||||||
image = strf("{}:{}", m_legsArmorFrameset, m_identity.personality.idle);
|
image = strf("{}:{}{}", m_legsArmorFrameset, m_identity.personality.idle, prefix);
|
||||||
else
|
else
|
||||||
image = strf("{}:{}.{}", m_legsArmorFrameset, frameBase(m_state), bodyStateSeq);
|
image = strf("{}:{}.{}{}", m_legsArmorFrameset, frameBase(m_state), bodyStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, {});
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, {});
|
||||||
drawable.imagePart().addDirectives(getLegsDirectives(), true);
|
drawable.imagePart().addDirectives(getLegsDirectives(), true);
|
||||||
addDrawable(std::move(drawable));
|
addDrawable(std::move(drawable));
|
||||||
@ -687,18 +695,19 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
if (!m_chestArmorFrameset.empty()) {
|
if (!m_chestArmorFrameset.empty()) {
|
||||||
String image;
|
String image;
|
||||||
Vec2F position;
|
Vec2F position;
|
||||||
|
auto prefix = m_chestArmorDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->bodyFrame)
|
if (dance.isValid() && danceStep->bodyFrame)
|
||||||
image = strf("{}:{}", m_chestArmorFrameset, *danceStep->bodyFrame);
|
image = strf("{}:{}{}", m_chestArmorFrameset, *danceStep->bodyFrame, prefix);
|
||||||
else if (m_state == Run)
|
else if (m_state == Run)
|
||||||
image = strf("{}:run", m_chestArmorFrameset);
|
image = strf("{}:run{}", m_chestArmorFrameset, prefix);
|
||||||
else if (m_state == Idle)
|
else if (m_state == Idle)
|
||||||
image = strf("{}:{}", m_chestArmorFrameset, m_identity.personality.idle);
|
image = strf("{}:{}{}", m_chestArmorFrameset, m_identity.personality.idle, prefix);
|
||||||
else if (m_state == Duck)
|
else if (m_state == Duck)
|
||||||
image = strf("{}:duck", m_chestArmorFrameset);
|
image = strf("{}:duck{}", m_chestArmorFrameset, prefix);
|
||||||
else if ((m_state == Swim) || (m_state == SwimIdle))
|
else if ((m_state == Swim) || (m_state == SwimIdle))
|
||||||
image = strf("{}:swim", m_chestArmorFrameset);
|
image = strf("{}:swim{}", m_chestArmorFrameset, prefix);
|
||||||
else
|
else
|
||||||
image = strf("{}:chest.1", m_chestArmorFrameset);
|
image = strf("{}:chest.1{}", m_chestArmorFrameset, prefix);
|
||||||
if (m_state != Duck)
|
if (m_state != Duck)
|
||||||
position[1] += bobYOffset;
|
position[1] += bobYOffset;
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
||||||
@ -728,7 +737,7 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto frontArmDrawable = [&](String const& frameSet, Directives const& directives) -> Drawable {
|
auto frontArmDrawable = [&](String const& frameSet, Directives const& directives) -> Drawable {
|
||||||
String image = strf("{}:{}", frameSet, frontHand.frontFrame);
|
String image = strf("{}:{}{}", frameSet, frontHand.frontFrame, directives.prefix());
|
||||||
Drawable frontArm = Drawable::makeImage(image, 1.0f / TilePixels, true, frontArmFrameOffset);
|
Drawable frontArm = Drawable::makeImage(image, 1.0f / TilePixels, true, frontArmFrameOffset);
|
||||||
frontArm.imagePart().addDirectives(directives, true);
|
frontArm.imagePart().addDirectives(directives, true);
|
||||||
frontArm.rotate(frontHand.angle, frontArmFrameOffset + m_frontArmRotationCenter);
|
frontArm.rotate(frontHand.angle, frontArmFrameOffset + m_frontArmRotationCenter);
|
||||||
@ -755,16 +764,18 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
if (!m_frontArmFrameset.empty() && !m_bodyHidden) {
|
if (!m_frontArmFrameset.empty() && !m_bodyHidden) {
|
||||||
String image;
|
String image;
|
||||||
Vec2F position;
|
Vec2F position;
|
||||||
|
auto bodyDirectives = getBodyDirectives();
|
||||||
|
auto prefix = bodyDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->frontArmFrame) {
|
if (dance.isValid() && danceStep->frontArmFrame) {
|
||||||
image = strf("{}:{}", m_frontArmFrameset, *danceStep->frontArmFrame);
|
image = strf("{}:{}{}", m_frontArmFrameset, *danceStep->frontArmFrame, prefix);
|
||||||
position = danceStep->frontArmOffset / TilePixels;
|
position = danceStep->frontArmOffset / TilePixels;
|
||||||
} else if (m_state == Idle) {
|
} else if (m_state == Idle) {
|
||||||
image = strf("{}:{}", m_frontArmFrameset, m_identity.personality.armIdle);
|
image = strf("{}:{}{}", m_frontArmFrameset, m_identity.personality.armIdle, prefix);
|
||||||
position = m_identity.personality.armOffset / TilePixels;
|
position = m_identity.personality.armOffset / TilePixels;
|
||||||
} else
|
} else
|
||||||
image = strf("{}:{}.{}", m_frontArmFrameset, frameBase(m_state), armStateSeq);
|
image = strf("{}:{}.{}{}", m_frontArmFrameset, frameBase(m_state), armStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
auto drawable = Drawable::makeImage(std::move(image), 1.0f / TilePixels, true, position);
|
||||||
drawable.imagePart().addDirectives(getBodyDirectives(), true);
|
drawable.imagePart().addDirectives(bodyDirectives, true);
|
||||||
if (dance.isValid())
|
if (dance.isValid())
|
||||||
drawable.rotate(danceStep->frontArmRotation);
|
drawable.rotate(danceStep->frontArmRotation);
|
||||||
addDrawable(drawable, m_bodyFullbright);
|
addDrawable(drawable, m_bodyFullbright);
|
||||||
@ -773,14 +784,15 @@ List<Drawable> Humanoid::render(bool withItems, bool withRotationAndScale) {
|
|||||||
if (!m_frontSleeveFrameset.empty()) {
|
if (!m_frontSleeveFrameset.empty()) {
|
||||||
String image;
|
String image;
|
||||||
Vec2F position;
|
Vec2F position;
|
||||||
|
auto prefix = m_chestArmorDirectives.prefix();
|
||||||
if (dance.isValid() && danceStep->frontArmFrame) {
|
if (dance.isValid() && danceStep->frontArmFrame) {
|
||||||
image = strf("{}:{}", m_frontSleeveFrameset, *danceStep->frontArmFrame);
|
image = strf("{}:{}{}", m_frontSleeveFrameset, *danceStep->frontArmFrame, prefix);
|
||||||
position = danceStep->frontArmOffset / TilePixels;
|
position = danceStep->frontArmOffset / TilePixels;
|
||||||
} else if (m_state == Idle) {
|
} else if (m_state == Idle) {
|
||||||
image = strf("{}:{}", m_frontSleeveFrameset, m_identity.personality.armIdle);
|
image = strf("{}:{}{}", m_frontSleeveFrameset, m_identity.personality.armIdle, prefix);
|
||||||
position = m_identity.personality.armOffset / TilePixels;
|
position = m_identity.personality.armOffset / TilePixels;
|
||||||
} else
|
} else
|
||||||
image = strf("{}:{}.{}", m_frontSleeveFrameset, frameBase(m_state), armStateSeq);
|
image = strf("{}:{}.{}{}", m_frontSleeveFrameset, frameBase(m_state), armStateSeq, prefix);
|
||||||
auto drawable = Drawable::makeImage(image, 1.0f / TilePixels, true, position);
|
auto drawable = Drawable::makeImage(image, 1.0f / TilePixels, true, position);
|
||||||
drawable.imagePart().addDirectives(getChestDirectives(), true);
|
drawable.imagePart().addDirectives(getChestDirectives(), true);
|
||||||
if (dance.isValid())
|
if (dance.isValid())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user