mirror of
https://github.com/OpenRCT2/OpenRCT2
synced 2026-01-26 16:24:35 +01:00
Refactor SmallSceneryEntry (#14815)
This commit is contained in:
@@ -26,16 +26,16 @@
|
||||
void SmallSceneryObject::ReadLegacy(IReadObjectContext* context, OpenRCT2::IStream* stream)
|
||||
{
|
||||
stream->Seek(6, OpenRCT2::STREAM_SEEK_CURRENT);
|
||||
_legacyType.small_scenery.flags = stream->ReadValue<uint32_t>();
|
||||
_legacyType.small_scenery.height = stream->ReadValue<uint8_t>();
|
||||
_legacyType.small_scenery.tool_id = static_cast<CursorID>(stream->ReadValue<uint8_t>());
|
||||
_legacyType.small_scenery.price = stream->ReadValue<int16_t>();
|
||||
_legacyType.small_scenery.removal_price = stream->ReadValue<int16_t>();
|
||||
_legacyType.flags = stream->ReadValue<uint32_t>();
|
||||
_legacyType.height = stream->ReadValue<uint8_t>();
|
||||
_legacyType.tool_id = static_cast<CursorID>(stream->ReadValue<uint8_t>());
|
||||
_legacyType.price = stream->ReadValue<int16_t>();
|
||||
_legacyType.removal_price = stream->ReadValue<int16_t>();
|
||||
stream->Seek(4, OpenRCT2::STREAM_SEEK_CURRENT);
|
||||
_legacyType.small_scenery.animation_delay = stream->ReadValue<uint16_t>();
|
||||
_legacyType.small_scenery.animation_mask = stream->ReadValue<uint16_t>();
|
||||
_legacyType.small_scenery.num_frames = stream->ReadValue<uint16_t>();
|
||||
_legacyType.small_scenery.scenery_tab_id = OBJECT_ENTRY_INDEX_NULL;
|
||||
_legacyType.animation_delay = stream->ReadValue<uint16_t>();
|
||||
_legacyType.animation_mask = stream->ReadValue<uint16_t>();
|
||||
_legacyType.num_frames = stream->ReadValue<uint16_t>();
|
||||
_legacyType.scenery_tab_id = OBJECT_ENTRY_INDEX_NULL;
|
||||
|
||||
GetStringTable().Read(context, stream, ObjectStringID::NAME);
|
||||
|
||||
@@ -47,23 +47,23 @@ void SmallSceneryObject::ReadLegacy(IReadObjectContext* context, OpenRCT2::IStre
|
||||
_frameOffsets = ReadFrameOffsets(stream);
|
||||
}
|
||||
// This crude method was used by RCT2. JSON objects have a flag for this property.
|
||||
if (_legacyType.small_scenery.height > 64)
|
||||
if (_legacyType.height > 64)
|
||||
{
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_IS_TREE;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_IS_TREE;
|
||||
}
|
||||
|
||||
GetImageTable().Read(context, stream);
|
||||
|
||||
// Validate properties
|
||||
if (_legacyType.small_scenery.price <= 0)
|
||||
if (_legacyType.price <= 0)
|
||||
{
|
||||
context->LogError(ObjectError::InvalidProperty, "Price can not be free or negative.");
|
||||
}
|
||||
if (_legacyType.small_scenery.removal_price <= 0)
|
||||
if (_legacyType.removal_price <= 0)
|
||||
{
|
||||
// Make sure you don't make a profit when placing then removing.
|
||||
money16 reimbursement = _legacyType.small_scenery.removal_price;
|
||||
if (reimbursement > _legacyType.small_scenery.price)
|
||||
money16 reimbursement = _legacyType.removal_price;
|
||||
if (reimbursement > _legacyType.price)
|
||||
{
|
||||
context->LogError(ObjectError::InvalidProperty, "Sell price can not be more than buy price.");
|
||||
}
|
||||
@@ -76,11 +76,11 @@ void SmallSceneryObject::Load()
|
||||
_legacyType.name = language_allocate_object_string(GetName());
|
||||
_legacyType.image = gfx_object_allocate_images(GetImageTable().GetImages(), GetImageTable().GetCount());
|
||||
|
||||
_legacyType.small_scenery.scenery_tab_id = OBJECT_ENTRY_INDEX_NULL;
|
||||
_legacyType.scenery_tab_id = OBJECT_ENTRY_INDEX_NULL;
|
||||
|
||||
if (scenery_small_entry_has_flag(&_legacyType, SMALL_SCENERY_FLAG_HAS_FRAME_OFFSETS))
|
||||
{
|
||||
_legacyType.small_scenery.frame_offsets = _frameOffsets.data();
|
||||
_legacyType.frame_offsets = _frameOffsets.data();
|
||||
}
|
||||
|
||||
PerformFixes();
|
||||
@@ -107,7 +107,7 @@ void SmallSceneryObject::DrawPreview(rct_drawpixelinfo* dpi, int32_t width, int3
|
||||
}
|
||||
}
|
||||
|
||||
auto screenCoords = ScreenCoordsXY{ width / 2, (height / 2) + (_legacyType.small_scenery.height / 2) };
|
||||
auto screenCoords = ScreenCoordsXY{ width / 2, (height / 2) + (_legacyType.height / 2) };
|
||||
screenCoords.y = std::min(screenCoords.y, height - 16);
|
||||
|
||||
if ((scenery_small_entry_has_flag(&_legacyType, SMALL_SCENERY_FLAG_FULL_TILE))
|
||||
@@ -165,7 +165,7 @@ void SmallSceneryObject::PerformFixes()
|
||||
{
|
||||
SetPrimarySceneryGroup(scgWalls);
|
||||
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_BUILD_DIRECTLY_ONTOP;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_BUILD_DIRECTLY_ONTOP;
|
||||
}
|
||||
|
||||
// ToonTowner's Pirate roofs. Make them show up in the Pirate Theming.
|
||||
@@ -231,15 +231,15 @@ void SmallSceneryObject::ReadJson(IReadObjectContext* context, json_t& root)
|
||||
|
||||
if (properties.is_object())
|
||||
{
|
||||
_legacyType.small_scenery.height = Json::GetNumber<uint8_t>(properties["height"]);
|
||||
_legacyType.small_scenery.tool_id = Cursor::FromString(Json::GetString(properties["cursor"]), CursorID::StatueDown);
|
||||
_legacyType.small_scenery.price = Json::GetNumber<uint16_t>(properties["price"]);
|
||||
_legacyType.small_scenery.removal_price = Json::GetNumber<uint16_t>(properties["removalPrice"]);
|
||||
_legacyType.small_scenery.animation_delay = Json::GetNumber<uint16_t>(properties["animationDelay"]);
|
||||
_legacyType.small_scenery.animation_mask = Json::GetNumber<uint16_t>(properties["animationMask"]);
|
||||
_legacyType.small_scenery.num_frames = Json::GetNumber<uint16_t>(properties["numFrames"]);
|
||||
_legacyType.height = Json::GetNumber<uint8_t>(properties["height"]);
|
||||
_legacyType.tool_id = Cursor::FromString(Json::GetString(properties["cursor"]), CursorID::StatueDown);
|
||||
_legacyType.price = Json::GetNumber<uint16_t>(properties["price"]);
|
||||
_legacyType.removal_price = Json::GetNumber<uint16_t>(properties["removalPrice"]);
|
||||
_legacyType.animation_delay = Json::GetNumber<uint16_t>(properties["animationDelay"]);
|
||||
_legacyType.animation_mask = Json::GetNumber<uint16_t>(properties["animationMask"]);
|
||||
_legacyType.num_frames = Json::GetNumber<uint16_t>(properties["numFrames"]);
|
||||
|
||||
_legacyType.small_scenery.flags = Json::GetFlags<uint32_t>(
|
||||
_legacyType.flags = Json::GetFlags<uint32_t>(
|
||||
properties,
|
||||
{
|
||||
{ "SMALL_SCENERY_FLAG_VOFFSET_CENTRE", SMALL_SCENERY_FLAG_VOFFSET_CENTRE },
|
||||
@@ -275,21 +275,21 @@ void SmallSceneryObject::ReadJson(IReadObjectContext* context, json_t& root)
|
||||
auto quarters = shape.substr(0, 3);
|
||||
if (quarters == "2/4")
|
||||
{
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_FULL_TILE | SMALL_SCENERY_FLAG_HALF_SPACE;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_FULL_TILE | SMALL_SCENERY_FLAG_HALF_SPACE;
|
||||
}
|
||||
else if (quarters == "3/4")
|
||||
{
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_FULL_TILE | SMALL_SCENERY_FLAG_THREE_QUARTERS;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_FULL_TILE | SMALL_SCENERY_FLAG_THREE_QUARTERS;
|
||||
}
|
||||
else if (quarters == "4/4")
|
||||
{
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_FULL_TILE;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_FULL_TILE;
|
||||
}
|
||||
if (shape.size() >= 5)
|
||||
{
|
||||
if ((shape.substr(3) == "+D"))
|
||||
{
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_DIAGONAL;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_DIAGONAL;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -298,7 +298,7 @@ void SmallSceneryObject::ReadJson(IReadObjectContext* context, json_t& root)
|
||||
if (jFrameOffsets.is_array())
|
||||
{
|
||||
_frameOffsets = ReadJsonFrameOffsets(jFrameOffsets);
|
||||
_legacyType.small_scenery.flags |= SMALL_SCENERY_FLAG_HAS_FRAME_OFFSETS;
|
||||
_legacyType.flags |= SMALL_SCENERY_FLAG_HAS_FRAME_OFFSETS;
|
||||
}
|
||||
|
||||
SetPrimarySceneryGroup(ObjectEntryDescriptor(Json::GetString(properties["sceneryGroup"])));
|
||||
|
||||
Reference in New Issue
Block a user