feat: variants in block json

This commit is contained in:
MihailRis 2025-07-13 22:17:43 +03:00
parent 5478d121f0
commit 325f0b1f02
3 changed files with 20 additions and 5 deletions

View File

@ -117,6 +117,22 @@ template<> void ContentUnitLoader<Block>::loadUnit(
load_variant(def.defaults, root, name);
if (root.has("state-based")) {
const auto& stateBased = root["state-based"];
if (stateBased.has("variants")) {
const auto& variants = stateBased["variants"];
def.variants = std::make_unique<Variants>();
for (int i = 0; i < variants.size(); i++) {
Variant variant = def.defaults;
load_variant(variant, variants[i], name);
def.variants->variants.push_back(variant);
}
while (def.variants->variants.size() < BLOCK_MAX_VARIANTS) {
def.variants->variants.push_back(def.defaults);
}
}
}
root.at("material").get(def.material);
// rotation profile

View File

@ -66,7 +66,7 @@ void ContentGfxCache::refresh(const Block& def, const Atlas& atlas) {
refresh_variant(assets, def, def.defaults, 0, sideregions, atlas, settings, models);
if (def.variants) {
const auto& variants = def.variants->variants;
for (int i = 0; i < variants.size(); i++) {
for (int i = 0; i < variants.size() - 1; i++) {
refresh_variant(assets, def, variants[i], i + 1, sideregions, atlas, settings, models);
}
}
@ -79,8 +79,7 @@ void ContentGfxCache::refresh() {
const auto& blocks = indices->blocks.getIterable();
for (blockid_t i = 0; i < blocks.size(); i++) {
auto def = blocks[i];
refresh(*def, atlas);
refresh(*blocks[i], atlas);
}
}

View File

@ -156,7 +156,7 @@ struct Variant {
};
struct Variants {
util::stack_vector<Variant, BLOCK_MAX_VARIANTS> variants;
util::stack_vector<Variant, BLOCK_MAX_VARIANTS> variants {};
};
/// @brief Block properties definition
@ -289,7 +289,7 @@ public:
constexpr const Variant& getVariant(uint8_t bits) const {
if (bits == 0 || variants == nullptr)
return defaults;
return variants->variants[(bits - 1) % variants->variants.size()];
return variants->variants[(bits - 1) % BLOCK_MAX_VARIANTS];
}
constexpr const BlockModel& getModel(uint8_t bits) const {