From e9dc7d18dd65b699781c383305fb45efbfb9d53c Mon Sep 17 00:00:00 2001 From: Relintai Date: Mon, 20 Jul 2020 21:22:17 +0200 Subject: [PATCH] Fix get_prop_uv_rect, and prop texture merging/setting in VoxelmanLibraryMerger. --- library/voxelman_library_merger.cpp | 50 +++++++++++++++++++++++++---- library/voxelman_library_merger.h | 3 ++ 2 files changed, 47 insertions(+), 6 deletions(-) diff --git a/library/voxelman_library_merger.cpp b/library/voxelman_library_merger.cpp index cd776c6..36b5037 100644 --- a/library/voxelman_library_merger.cpp +++ b/library/voxelman_library_merger.cpp @@ -160,6 +160,9 @@ Ref VoxelmanLibraryMerger::get_prop(const int index) { void VoxelmanLibraryMerger::add_prop(Ref value) { _props.push_back(value); } +bool VoxelmanLibraryMerger::has_prop(const Ref &value) const { + return _props.find(value) != -1; +} void VoxelmanLibraryMerger::set_prop(const int index, const Ref &value) { ERR_FAIL_INDEX(index, _props.size()); @@ -186,15 +189,41 @@ void VoxelmanLibraryMerger::set_props(const Vector &props) { } Rect2 VoxelmanLibraryMerger::get_prop_uv_rect(const Ref &texture) { - if (!texture.is_valid()) + if (!texture.is_valid()) { return Rect2(0, 0, 1, 1); + } Ref at = _prop_packer->get_texture(texture); - if (!at.is_valid()) + if (!at.is_valid()) { return Rect2(0, 0, 1, 1); + } - return at->get_region(); + Rect2 region = at->get_region(); + + Ref tex = at->get_atlas(); + + if (!tex.is_valid()) { + return Rect2(0, 0, 1, 1); + } + + Ref image = tex->get_data(); + + if (!image.is_valid()) { + return Rect2(0, 0, 1, 1); + } + + float w = image->get_width(); + float h = image->get_height(); + + region.position = Size2(region.position.x / w, region.position.y / h); + region.size = Size2(region.size.x / w, region.size.y / h); + + return region; +} + +Ref VoxelmanLibraryMerger::get_prop_packer() { + return _prop_packer; } #endif @@ -232,7 +261,8 @@ void VoxelmanLibraryMerger::refresh_rects() { } #ifdef PROPS_PRESENT - texture_added = false; + //todo add this back + //texture_added = false; for (int i = 0; i < _props.size(); i++) { Ref prop = _props.get(i); @@ -242,10 +272,11 @@ void VoxelmanLibraryMerger::refresh_rects() { } } - if (texture_added) { + //if (texture_added) { + if (_prop_packer->get_texture_count() > 0) { _prop_packer->merge(); - ERR_FAIL_COND(_prop_packer->get_texture_count() == 0); + //ERR_FAIL_COND(_prop_packer->get_texture_count() == 0); Ref tex = _prop_packer->get_generated_texture(0); @@ -311,6 +342,9 @@ void VoxelmanLibraryMerger::_setup_material_albedo(const int material_index, con case MATERIAL_INDEX_LIQUID: shmat = get_liquid_material(i); break; + case MATERIAL_INDEX_PROP: + shmat = get_prop_material(i); + break; } if (shmat.is_valid()) { @@ -427,6 +461,10 @@ void VoxelmanLibraryMerger::_bind_methods() { ClassDB::bind_method(D_METHOD("get_props"), &VoxelmanLibraryMerger::get_props); ClassDB::bind_method(D_METHOD("set_props"), &VoxelmanLibraryMerger::set_props); ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "17/17:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props"); + + ClassDB::bind_method(D_METHOD("get_prop_uv_rect", "texture"), &VoxelmanLibraryMerger::get_prop_uv_rect); + + ClassDB::bind_method(D_METHOD("get_prop_packer"), &VoxelmanLibraryMerger::get_prop_packer); #endif ClassDB::bind_method(D_METHOD("_setup_material_albedo", "material_index", "texture"), &VoxelmanLibraryMerger::_setup_material_albedo); diff --git a/library/voxelman_library_merger.h b/library/voxelman_library_merger.h index a36a4ec..d730c00 100644 --- a/library/voxelman_library_merger.h +++ b/library/voxelman_library_merger.h @@ -68,6 +68,7 @@ public: #ifdef PROPS_PRESENT Ref get_prop(const int index); void add_prop(Ref value); + bool has_prop(const Ref &value) const; void set_prop(const int index, const Ref &value); void remove_prop(const int index); int get_num_props() const; @@ -77,6 +78,8 @@ public: void set_props(const Vector &props); Rect2 get_prop_uv_rect(const Ref &texture); + + Ref get_prop_packer(); #endif void refresh_rects();