feat: variants in block json
This commit is contained in:
parent
5478d121f0
commit
325f0b1f02
@ -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
|
||||
|
||||
@ -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);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -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 {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user