mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-12 05:41:15 +01:00
Also replaced the old PROPS_PRESENT defines with the module system's generated defines.
This commit is contained in:
parent
a0472fb6eb
commit
ea2a36c4ea
@ -7,9 +7,6 @@ module_env = env.Clone()
|
|||||||
if os.path.isdir('../mesh_data_resource'):
|
if os.path.isdir('../mesh_data_resource'):
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
||||||
|
|
||||||
if os.path.isdir('../props'):
|
|
||||||
module_env.Append(CPPDEFINES=['PROPS_PRESENT'])
|
|
||||||
|
|
||||||
sources = [
|
sources = [
|
||||||
"register_types.cpp",
|
"register_types.cpp",
|
||||||
|
|
||||||
|
@ -22,16 +22,16 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "ess_material_cache.h"
|
#include "ess_material_cache.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
#include "../../props/props/prop_data_tiled_wall.h"
|
#include "../../props/props/prop_data_tiled_wall.h"
|
||||||
#include "../../props/tiled_wall/tiled_wall_data.h"
|
#include "../../props/tiled_wall/tiled_wall_data.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#if MESH_DATA_RESOURCE_PRESENT
|
||||||
#define PROPS_PRESENT 1
|
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#undef PROPS_PRESENT
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@ -173,7 +173,7 @@ Rect2 ESSMaterialCache::texture_get_uv_rect(const Ref<Texture> &texture) {
|
|||||||
return Rect2(0, 0, 1, 1);
|
return Rect2(0, 0, 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void ESSMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
void ESSMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return;
|
return;
|
||||||
@ -203,7 +203,7 @@ void ESSMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
|||||||
if (!twd.is_valid())
|
if (!twd.is_valid())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
twd->setup_cache(Ref<ESSMaterialCache>(this));
|
twd->setup_ess_cache(Ref<ESSMaterialCache>(this));
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -242,16 +242,16 @@ void ESSMaterialCache::prop_remove_textures(const Ref<PropData> &prop) {
|
|||||||
if (!twd.is_valid())
|
if (!twd.is_valid())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
for (int j = 0; j < twd->get_texture_count(); ++j) {
|
for (int j = 0; j < twd->get_tile_count(); ++j) {
|
||||||
const Ref<Texture> &tex = twd->get_texture(j);
|
const Ref<Texture> &tex = twd->get_tile_texture(j);
|
||||||
|
|
||||||
if (tex.is_valid()) {
|
if (tex.is_valid()) {
|
||||||
texture_remove(tex);
|
texture_remove(tex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int j = 0; j < twd->get_flavour_texture_count(); ++j) {
|
for (int j = 0; j < twd->get_flavour_tile_count(); ++j) {
|
||||||
const Ref<Texture> &tex = twd->get_flavour_texture(j);
|
const Ref<Texture> &tex = twd->get_flavour_tile_texture(j);
|
||||||
|
|
||||||
if (tex.is_valid()) {
|
if (tex.is_valid()) {
|
||||||
texture_remove(tex);
|
texture_remove(tex);
|
||||||
@ -349,7 +349,7 @@ void ESSMaterialCache::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("texture_get_atlas_tex", "index"), &ESSMaterialCache::texture_get_atlas_tex);
|
ClassDB::bind_method(D_METHOD("texture_get_atlas_tex", "index"), &ESSMaterialCache::texture_get_atlas_tex);
|
||||||
ClassDB::bind_method(D_METHOD("texture_get_uv_rect", "texture"), &ESSMaterialCache::texture_get_uv_rect);
|
ClassDB::bind_method(D_METHOD("texture_get_uv_rect", "texture"), &ESSMaterialCache::texture_get_uv_rect);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &ESSMaterialCache::prop_add_textures);
|
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &ESSMaterialCache::prop_add_textures);
|
||||||
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &ESSMaterialCache::prop_remove_textures);
|
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &ESSMaterialCache::prop_remove_textures);
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,6 +30,8 @@ SOFTWARE.
|
|||||||
#include "core/os/mutex.h"
|
#include "core/os/mutex.h"
|
||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class PropData;
|
class PropData;
|
||||||
|
|
||||||
class ESSMaterialCache : public Resource {
|
class ESSMaterialCache : public Resource {
|
||||||
@ -69,7 +71,7 @@ public:
|
|||||||
virtual Ref<AtlasTexture> texture_get_atlas_tex(const Ref<Texture> &texture);
|
virtual Ref<AtlasTexture> texture_get_atlas_tex(const Ref<Texture> &texture);
|
||||||
virtual Rect2 texture_get_uv_rect(const Ref<Texture> &texture);
|
virtual Rect2 texture_get_uv_rect(const Ref<Texture> &texture);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add_textures(const Ref<PropData> &prop);
|
void prop_add_textures(const Ref<PropData> &prop);
|
||||||
void prop_remove_textures(const Ref<PropData> &prop);
|
void prop_remove_textures(const Ref<PropData> &prop);
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,7 +22,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "prop_data_entity.h"
|
#include "prop_data_entity.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
|
|
||||||
Ref<EntityData> PropDataEntity::get_entity_data() const {
|
Ref<EntityData> PropDataEntity::get_entity_data() const {
|
||||||
return _entity_data;
|
return _entity_data;
|
||||||
|
@ -22,7 +22,9 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|||||||
SOFTWARE.
|
SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
|
|
||||||
#include "../../props/props/prop_data_entry.h"
|
#include "../../props/props/prop_data_entry.h"
|
||||||
|
|
||||||
|
@ -138,7 +138,7 @@ SOFTWARE.
|
|||||||
#include "material_cache/ess_material_cache_pcm.h"
|
#include "material_cache/ess_material_cache_pcm.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "props/prop_data_entity.h"
|
#include "props/prop_data_entity.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -146,7 +146,7 @@ static ESS *entity_data_manager = NULL;
|
|||||||
static ProfileManager *profile_manager = NULL;
|
static ProfileManager *profile_manager = NULL;
|
||||||
|
|
||||||
void register_entity_spell_system_types() {
|
void register_entity_spell_system_types() {
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::register_class<PropDataEntity>();
|
ClassDB::register_class<PropDataEntity>();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -4,9 +4,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if env["module_props_enabled"]:
|
|
||||||
module_env.Append(CPPDEFINES=['PROPS_PRESENT'])
|
|
||||||
|
|
||||||
if env["module_props_2d_enabled"]:
|
if env["module_props_2d_enabled"]:
|
||||||
module_env.Append(CPPDEFINES=['PROPS_2D_PRESENT'])
|
module_env.Append(CPPDEFINES=['PROPS_2D_PRESENT'])
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
|
|
||||||
#include "../nodes/mesh_data_instance.h"
|
#include "../nodes/mesh_data_instance.h"
|
||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
|
@ -24,7 +24,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
|
|
||||||
#include "../../props/props/prop_data_entry.h"
|
#include "../../props/props/prop_data_entry.h"
|
||||||
#include "core/math/vector3.h"
|
#include "core/math/vector3.h"
|
||||||
|
@ -39,7 +39,7 @@ SOFTWARE.
|
|||||||
#include "./editor/mdi_ed_plugin.h"
|
#include "./editor/mdi_ed_plugin.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../props/singleton/prop_utils.h"
|
#include "../props/singleton/prop_utils.h"
|
||||||
#include "props/prop_data_mesh_data.h"
|
#include "props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
@ -56,7 +56,7 @@ void register_mesh_data_resource_types() {
|
|||||||
ClassDB::register_class<MeshDataInstance>();
|
ClassDB::register_class<MeshDataInstance>();
|
||||||
ClassDB::register_class<MeshDataInstance2D>();
|
ClassDB::register_class<MeshDataInstance2D>();
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::register_class<PropDataMeshData>();
|
ClassDB::register_class<PropDataMeshData>();
|
||||||
Ref<PropDataMeshData> processor = Ref<PropDataMeshData>(memnew(PropDataMeshData));
|
Ref<PropDataMeshData> processor = Ref<PropDataMeshData>(memnew(PropDataMeshData));
|
||||||
PropUtils::add_processor(processor);
|
PropUtils::add_processor(processor);
|
||||||
|
@ -29,9 +29,7 @@ SOFTWARE.
|
|||||||
#include "../tiled_wall/tiled_wall_data.h"
|
#include "../tiled_wall/tiled_wall_data.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#if MESH_DATA_RESOURCE_PRESENT
|
||||||
#define PROPS_PRESENT 1
|
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#undef PROPS_PRESENT
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define VARIANT_ARRAY_GET(arr) \
|
#define VARIANT_ARRAY_GET(arr) \
|
||||||
|
@ -5,9 +5,6 @@
|
|||||||
#include "scene/3d/light.h"
|
#include "scene/3d/light.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#if MESH_DATA_RESOURCE_PRESENT
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
|
||||||
//but not when included from here.
|
|
||||||
#define PROPS_PRESENT 1
|
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -23,9 +23,6 @@
|
|||||||
#include "./singleton/prop_cache.h"
|
#include "./singleton/prop_cache.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#if MESH_DATA_RESOURCE_PRESENT
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
|
||||||
//but not when included from here.
|
|
||||||
#define PROPS_PRESENT 1
|
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -48,11 +48,7 @@ SOFTWARE.
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#if MESH_DATA_RESOURCE_PRESENT
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
|
||||||
//but not when included from here.
|
|
||||||
#define PROPS_PRESENT 1
|
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#undef PROPS_PRESENT
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "props/prop_data_tiled_wall.h"
|
#include "props/prop_data_tiled_wall.h"
|
||||||
|
@ -42,6 +42,10 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_ENTITY_SPELL_SYSTEM_ENABLED
|
||||||
|
#include "modules/entity_spell_system/material_cache/ess_material_cache.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
const String TiledWallData::BINDING_STRING_TILED_WALL_TILING_TYPE = "None,Horizontal,Vertical,Both";
|
const String TiledWallData::BINDING_STRING_TILED_WALL_TILING_TYPE = "None,Horizontal,Vertical,Both";
|
||||||
const String TiledWallData::BINDING_STRING_TILED_WALL_COLLIDER_TYPE = "None,Plane,Box,Convex Mesh,Concave Mesh";
|
const String TiledWallData::BINDING_STRING_TILED_WALL_COLLIDER_TYPE = "None,Plane,Box,Convex Mesh,Concave Mesh";
|
||||||
|
|
||||||
@ -333,6 +337,43 @@ void TiledWallData::_setup_cache(Ref<PropMaterialCache> cache) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MODULE_ENTITY_SPELL_SYSTEM_ENABLED
|
||||||
|
void TiledWallData::setup_ess_cache(Ref<ESSMaterialCache> cache) {
|
||||||
|
//Note: the caller should lock and unlock the cache!
|
||||||
|
|
||||||
|
call("_setup_ess_cache", cache);
|
||||||
|
}
|
||||||
|
void TiledWallData::_setup_ess_cache(Ref<ESSMaterialCache> cache) {
|
||||||
|
if (cache->material_get_num() == 0) {
|
||||||
|
for (int i = 0; i < _materials.size(); ++i) {
|
||||||
|
const Ref<Material> &m = _materials[i];
|
||||||
|
|
||||||
|
if (m.is_valid()) {
|
||||||
|
Ref<Material> nm = m->duplicate();
|
||||||
|
|
||||||
|
cache->material_add(nm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < _tiles.size(); ++i) {
|
||||||
|
const Ref<Texture> &t = _tiles[i].texture;
|
||||||
|
|
||||||
|
if (t.is_valid()) {
|
||||||
|
cache->texture_add(t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < _flavour_tiles.size(); ++i) {
|
||||||
|
const Ref<Texture> &t = _flavour_tiles[i].texture;
|
||||||
|
|
||||||
|
if (t.is_valid()) {
|
||||||
|
cache->texture_add(t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void TiledWallData::copy_from(const Ref<TiledWallData> &tiled_wall_data) {
|
void TiledWallData::copy_from(const Ref<TiledWallData> &tiled_wall_data) {
|
||||||
ERR_FAIL_COND(!tiled_wall_data.is_valid());
|
ERR_FAIL_COND(!tiled_wall_data.is_valid());
|
||||||
|
|
||||||
@ -578,6 +619,13 @@ void TiledWallData::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("setup_cache", "cache"), &TiledWallData::setup_cache);
|
ClassDB::bind_method(D_METHOD("setup_cache", "cache"), &TiledWallData::setup_cache);
|
||||||
ClassDB::bind_method(D_METHOD("_setup_cache", "cache"), &TiledWallData::_setup_cache);
|
ClassDB::bind_method(D_METHOD("_setup_cache", "cache"), &TiledWallData::_setup_cache);
|
||||||
|
|
||||||
|
#ifdef MODULE_ENTITY_SPELL_SYSTEM_ENABLED
|
||||||
|
BIND_VMETHOD(MethodInfo("_setup_ess_cache", PropertyInfo(Variant::OBJECT, "cache", PROPERTY_HINT_RESOURCE_TYPE, "ESSMaterialCache")));
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("setup_ess_cache", "cache"), &TiledWallData::setup_ess_cache);
|
||||||
|
ClassDB::bind_method(D_METHOD("_setup_ess_cache", "cache"), &TiledWallData::_setup_ess_cache);
|
||||||
|
#endif
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("copy_from", "prop_data"), &TiledWallData::copy_from);
|
ClassDB::bind_method(D_METHOD("copy_from", "prop_data"), &TiledWallData::copy_from);
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(TILED_WALL_TILING_TYPE_NONE);
|
BIND_ENUM_CONSTANT(TILED_WALL_TILING_TYPE_NONE);
|
||||||
|
@ -22,8 +22,8 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|||||||
SOFTWARE.
|
SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "core/object/reference.h"
|
|
||||||
#include "core/containers/vector.h"
|
#include "core/containers/vector.h"
|
||||||
|
#include "core/object/reference.h"
|
||||||
|
|
||||||
#include "core/math/rect2.h"
|
#include "core/math/rect2.h"
|
||||||
#include "core/math/transform.h"
|
#include "core/math/transform.h"
|
||||||
@ -41,6 +41,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
class PropMaterialCache;
|
class PropMaterialCache;
|
||||||
class PropMesher;
|
class PropMesher;
|
||||||
|
#ifdef MODULE_ENTITY_SPELL_SYSTEM_ENABLED
|
||||||
|
class ESSMaterialCache;
|
||||||
|
#endif
|
||||||
|
|
||||||
class TiledWallData : public Resource {
|
class TiledWallData : public Resource {
|
||||||
GDCLASS(TiledWallData, Resource);
|
GDCLASS(TiledWallData, Resource);
|
||||||
@ -154,6 +157,11 @@ public:
|
|||||||
void setup_cache(Ref<PropMaterialCache> cache);
|
void setup_cache(Ref<PropMaterialCache> cache);
|
||||||
void _setup_cache(Ref<PropMaterialCache> cache);
|
void _setup_cache(Ref<PropMaterialCache> cache);
|
||||||
|
|
||||||
|
#ifdef MODULE_ENTITY_SPELL_SYSTEM_ENABLED
|
||||||
|
void setup_ess_cache(Ref<ESSMaterialCache> cache);
|
||||||
|
void _setup_ess_cache(Ref<ESSMaterialCache> cache);
|
||||||
|
#endif
|
||||||
|
|
||||||
void copy_from(const Ref<TiledWallData> &tiled_wall_data);
|
void copy_from(const Ref<TiledWallData> &tiled_wall_data);
|
||||||
|
|
||||||
//Ref<Shape> get_collider_shape();
|
//Ref<Shape> get_collider_shape();
|
||||||
|
@ -30,8 +30,6 @@ SOFTWARE.
|
|||||||
#include "scene/resources/shape.h"
|
#include "scene/resources/shape.h"
|
||||||
#include "singleton/prop_2d_cache.h"
|
#include "singleton/prop_2d_cache.h"
|
||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MESH_DATA_RESOURCE_PRESENT
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -7,9 +7,6 @@ module_env = env.Clone()
|
|||||||
if os.path.isdir('../mesh_data_resource'):
|
if os.path.isdir('../mesh_data_resource'):
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
||||||
|
|
||||||
if os.path.isdir('../props'):
|
|
||||||
module_env.Append(CPPDEFINES=['PROPS_PRESENT'])
|
|
||||||
|
|
||||||
if os.path.isdir('../mesh_utils'):
|
if os.path.isdir('../mesh_utils'):
|
||||||
module_env.Append(CPPDEFINES=['MESH_UTILS_PRESENT'])
|
module_env.Append(CPPDEFINES=['MESH_UTILS_PRESENT'])
|
||||||
|
|
||||||
|
@ -26,7 +26,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "terrain_material_cache.h"
|
#include "terrain_material_cache.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -311,7 +313,7 @@ int TerrainLibrary::scene_get_num() const {
|
|||||||
void TerrainLibrary::scenes_clear() {
|
void TerrainLibrary::scenes_clear() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> TerrainLibrary::prop_get(const int id) {
|
Ref<PropData> TerrainLibrary::prop_get(const int id) {
|
||||||
return Ref<PropData>();
|
return Ref<PropData>();
|
||||||
}
|
}
|
||||||
@ -454,7 +456,7 @@ void TerrainLibrary::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("scene_get_num"), &TerrainLibrary::scene_get_num);
|
ClassDB::bind_method(D_METHOD("scene_get_num"), &TerrainLibrary::scene_get_num);
|
||||||
ClassDB::bind_method(D_METHOD("scenes_clear"), &TerrainLibrary::scenes_clear);
|
ClassDB::bind_method(D_METHOD("scenes_clear"), &TerrainLibrary::scenes_clear);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_get", "id"), &TerrainLibrary::prop_get);
|
ClassDB::bind_method(D_METHOD("prop_get", "id"), &TerrainLibrary::prop_get);
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "value"), &TerrainLibrary::prop_add);
|
ClassDB::bind_method(D_METHOD("prop_add", "value"), &TerrainLibrary::prop_add);
|
||||||
ClassDB::bind_method(D_METHOD("prop_has", "prop"), &TerrainLibrary::prop_has);
|
ClassDB::bind_method(D_METHOD("prop_has", "prop"), &TerrainLibrary::prop_has);
|
||||||
|
@ -30,12 +30,14 @@ SOFTWARE.
|
|||||||
#include "../data/terrain_light.h"
|
#include "../data/terrain_light.h"
|
||||||
#include "terrain_surface.h"
|
#include "terrain_surface.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class TerrainMaterialCache;
|
class TerrainMaterialCache;
|
||||||
class TerrainSurface;
|
class TerrainSurface;
|
||||||
class TerrainMesher;
|
class TerrainMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
class TerrainChunk;
|
class TerrainChunk;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
class PropData;
|
class PropData;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -127,7 +129,7 @@ public:
|
|||||||
virtual int scene_get_num() const;
|
virtual int scene_get_num() const;
|
||||||
virtual void scenes_clear();
|
virtual void scenes_clear();
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
virtual Ref<PropData> prop_get(const int id);
|
virtual Ref<PropData> prop_get(const int id);
|
||||||
virtual void prop_add(Ref<PropData> value);
|
virtual void prop_add(Ref<PropData> value);
|
||||||
virtual bool prop_has(const Ref<PropData> &value) const;
|
virtual bool prop_has(const Ref<PropData> &value) const;
|
||||||
|
@ -25,7 +25,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
@ -151,7 +153,7 @@ void TerrainLibraryMerger::set_terra_surfaces(const Vector<Variant> &surfaces) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> TerrainLibraryMerger::get_prop(const int index) {
|
Ref<PropData> TerrainLibraryMerger::get_prop(const int index) {
|
||||||
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
||||||
|
|
||||||
@ -260,7 +262,7 @@ void TerrainLibraryMerger::refresh_rects() {
|
|||||||
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
//todo add this back
|
//todo add this back
|
||||||
//texture_added = false;
|
//texture_added = false;
|
||||||
for (int i = 0; i < _props.size(); i++) {
|
for (int i = 0; i < _props.size(); i++) {
|
||||||
@ -400,7 +402,7 @@ TerrainLibraryMerger::~TerrainLibraryMerger() {
|
|||||||
_prop_packer.unref();
|
_prop_packer.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool TerrainLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
bool TerrainLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return false;
|
return false;
|
||||||
@ -462,7 +464,7 @@ void TerrainLibraryMerger::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_terra_surfaces"), &TerrainLibraryMerger::set_terra_surfaces);
|
ClassDB::bind_method(D_METHOD("set_terra_surfaces"), &TerrainLibraryMerger::set_terra_surfaces);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "terra_surfaces", PROPERTY_HINT_NONE, "23/19:TerrainSurfaceMerger", PROPERTY_USAGE_DEFAULT, "TerrainSurfaceMerger"), "set_terra_surfaces", "get_terra_surfaces");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "terra_surfaces", PROPERTY_HINT_NONE, "23/19:TerrainSurfaceMerger", PROPERTY_USAGE_DEFAULT, "TerrainSurfaceMerger"), "set_terra_surfaces", "get_terra_surfaces");
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("get_props"), &TerrainLibraryMerger::get_props);
|
ClassDB::bind_method(D_METHOD("get_props"), &TerrainLibraryMerger::get_props);
|
||||||
ClassDB::bind_method(D_METHOD("set_props"), &TerrainLibraryMerger::set_props);
|
ClassDB::bind_method(D_METHOD("set_props"), &TerrainLibraryMerger::set_props);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
||||||
|
@ -32,6 +32,8 @@ SOFTWARE.
|
|||||||
#include "../data/terrain_light.h"
|
#include "../data/terrain_light.h"
|
||||||
#include "terrain_surface_merger.h"
|
#include "terrain_surface_merger.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class TerrainSurfaceSimple;
|
class TerrainSurfaceSimple;
|
||||||
class TerrainMesher;
|
class TerrainMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
@ -65,7 +67,7 @@ public:
|
|||||||
Vector<Variant> get_terra_surfaces();
|
Vector<Variant> get_terra_surfaces();
|
||||||
void set_terra_surfaces(const Vector<Variant> &surfaces);
|
void set_terra_surfaces(const Vector<Variant> &surfaces);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> get_prop(const int index);
|
Ref<PropData> get_prop(const int index);
|
||||||
void add_prop(Ref<PropData> value);
|
void add_prop(Ref<PropData> value);
|
||||||
bool has_prop(const Ref<PropData> &value) const;
|
bool has_prop(const Ref<PropData> &value) const;
|
||||||
@ -90,14 +92,14 @@ public:
|
|||||||
~TerrainLibraryMerger();
|
~TerrainLibraryMerger();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool process_prop_textures(Ref<PropData> prop);
|
bool process_prop_textures(Ref<PropData> prop);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
Vector<Ref<TerrainSurfaceMerger>> _terra_surfaces;
|
Vector<Ref<TerrainSurfaceMerger>> _terra_surfaces;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<Ref<PropData>> _props;
|
Vector<Ref<PropData>> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -26,7 +26,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
@ -388,7 +390,7 @@ void TerrainLibraryMergerPCM::_prop_material_cache_get_key(Ref<TerrainChunk> chu
|
|||||||
Vector<uint64_t> props;
|
Vector<uint64_t> props;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
||||||
Ref<PropData> prop = chunk->prop_get(i);
|
Ref<PropData> prop = chunk->prop_get(i);
|
||||||
|
|
||||||
@ -497,7 +499,7 @@ void TerrainLibraryMergerPCM::_prop_material_cache_get_key(Ref<TerrainChunk> chu
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
||||||
Ref<PropData> prop = chunk->prop_get(i);
|
Ref<PropData> prop = chunk->prop_get(i);
|
||||||
|
|
||||||
@ -686,7 +688,7 @@ void TerrainLibraryMergerPCM::set_terra_surfaces(const Vector<Variant> &surfaces
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> TerrainLibraryMergerPCM::get_prop(const int index) {
|
Ref<PropData> TerrainLibraryMergerPCM::get_prop(const int index) {
|
||||||
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
||||||
|
|
||||||
@ -796,7 +798,7 @@ void TerrainLibraryMergerPCM::refresh_rects() {
|
|||||||
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
//todo add this back
|
//todo add this back
|
||||||
//texture_added = false;
|
//texture_added = false;
|
||||||
for (int i = 0; i < _props.size(); i++) {
|
for (int i = 0; i < _props.size(); i++) {
|
||||||
@ -938,7 +940,7 @@ TerrainLibraryMergerPCM::~TerrainLibraryMergerPCM() {
|
|||||||
_prop_packer.unref();
|
_prop_packer.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool TerrainLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
bool TerrainLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
||||||
/*
|
/*
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
@ -1002,7 +1004,7 @@ void TerrainLibraryMergerPCM::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_terra_surfaces"), &TerrainLibraryMergerPCM::set_terra_surfaces);
|
ClassDB::bind_method(D_METHOD("set_terra_surfaces"), &TerrainLibraryMergerPCM::set_terra_surfaces);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "terra_surfaces", PROPERTY_HINT_NONE, "23/19:TerrainSurfaceMerger", PROPERTY_USAGE_DEFAULT, "TerrainSurfaceMerger"), "set_terra_surfaces", "get_terra_surfaces");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "terra_surfaces", PROPERTY_HINT_NONE, "23/19:TerrainSurfaceMerger", PROPERTY_USAGE_DEFAULT, "TerrainSurfaceMerger"), "set_terra_surfaces", "get_terra_surfaces");
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("get_props"), &TerrainLibraryMergerPCM::get_props);
|
ClassDB::bind_method(D_METHOD("get_props"), &TerrainLibraryMergerPCM::get_props);
|
||||||
ClassDB::bind_method(D_METHOD("set_props"), &TerrainLibraryMergerPCM::set_props);
|
ClassDB::bind_method(D_METHOD("set_props"), &TerrainLibraryMergerPCM::set_props);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
||||||
|
@ -34,6 +34,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/mutex.h"
|
#include "core/os/mutex.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class TerrainSurfaceSimple;
|
class TerrainSurfaceSimple;
|
||||||
class TerrainMesher;
|
class TerrainMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
@ -84,7 +86,7 @@ public:
|
|||||||
Vector<Variant> get_terra_surfaces();
|
Vector<Variant> get_terra_surfaces();
|
||||||
void set_terra_surfaces(const Vector<Variant> &surfaces);
|
void set_terra_surfaces(const Vector<Variant> &surfaces);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> get_prop(const int index);
|
Ref<PropData> get_prop(const int index);
|
||||||
void add_prop(Ref<PropData> value);
|
void add_prop(Ref<PropData> value);
|
||||||
bool has_prop(const Ref<PropData> &value) const;
|
bool has_prop(const Ref<PropData> &value) const;
|
||||||
@ -109,7 +111,7 @@ public:
|
|||||||
~TerrainLibraryMergerPCM();
|
~TerrainLibraryMergerPCM();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool process_prop_textures(Ref<PropData> prop);
|
bool process_prop_textures(Ref<PropData> prop);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -120,7 +122,7 @@ protected:
|
|||||||
Map<int, Ref<TerrainMaterialCachePCM>> _prop_material_cache;
|
Map<int, Ref<TerrainMaterialCachePCM>> _prop_material_cache;
|
||||||
|
|
||||||
Vector<Ref<TerrainSurfaceMerger>> _terra_surfaces;
|
Vector<Ref<TerrainSurfaceMerger>> _terra_surfaces;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<Ref<PropData>> _props;
|
Vector<Ref<PropData>> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -24,7 +24,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
|
|
||||||
@ -196,7 +198,7 @@ Rect2 TerrainMaterialCache::additional_texture_get_uv_rect(const Ref<Texture> &t
|
|||||||
return Rect2(0, 0, 1, 1);
|
return Rect2(0, 0, 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void TerrainMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
void TerrainMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return;
|
return;
|
||||||
@ -315,7 +317,7 @@ void TerrainMaterialCache::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("additional_texture_get_atlas_tex", "index"), &TerrainMaterialCache::additional_texture_get_atlas_tex);
|
ClassDB::bind_method(D_METHOD("additional_texture_get_atlas_tex", "index"), &TerrainMaterialCache::additional_texture_get_atlas_tex);
|
||||||
ClassDB::bind_method(D_METHOD("additional_texture_get_uv_rect", "texture"), &TerrainMaterialCache::additional_texture_get_uv_rect);
|
ClassDB::bind_method(D_METHOD("additional_texture_get_uv_rect", "texture"), &TerrainMaterialCache::additional_texture_get_uv_rect);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &TerrainMaterialCache::prop_add_textures);
|
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &TerrainMaterialCache::prop_add_textures);
|
||||||
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &TerrainMaterialCache::prop_remove_textures);
|
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &TerrainMaterialCache::prop_remove_textures);
|
||||||
#endif
|
#endif
|
||||||
|
@ -33,6 +33,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class TerrainLibrary;
|
class TerrainLibrary;
|
||||||
|
|
||||||
class TerrainMaterialCache : public Resource {
|
class TerrainMaterialCache : public Resource {
|
||||||
@ -76,7 +78,7 @@ public:
|
|||||||
virtual Ref<AtlasTexture> additional_texture_get_atlas_tex(const Ref<Texture> &texture);
|
virtual Ref<AtlasTexture> additional_texture_get_atlas_tex(const Ref<Texture> &texture);
|
||||||
virtual Rect2 additional_texture_get_uv_rect(const Ref<Texture> &texture);
|
virtual Rect2 additional_texture_get_uv_rect(const Ref<Texture> &texture);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add_textures(const Ref<PropData> &prop);
|
void prop_add_textures(const Ref<PropData> &prop);
|
||||||
void prop_remove_textures(const Ref<PropData> &prop);
|
void prop_remove_textures(const Ref<PropData> &prop);
|
||||||
#endif
|
#endif
|
||||||
|
@ -35,6 +35,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/thread_pool.h"
|
#include "core/os/thread_pool.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
_FORCE_INLINE_ bool TerrainChunk::get_process() const {
|
_FORCE_INLINE_ bool TerrainChunk::get_process() const {
|
||||||
return _is_processing;
|
return _is_processing;
|
||||||
}
|
}
|
||||||
@ -701,7 +703,7 @@ void TerrainChunk::clear_baked_lights() {
|
|||||||
call("_clear_baked_lights");
|
call("_clear_baked_lights");
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void TerrainChunk::prop_add(const Transform &tarnsform, const Ref<PropData> &prop) {
|
void TerrainChunk::prop_add(const Transform &tarnsform, const Ref<PropData> &prop) {
|
||||||
ERR_FAIL_COND(!prop.is_valid());
|
ERR_FAIL_COND(!prop.is_valid());
|
||||||
|
|
||||||
@ -757,7 +759,7 @@ int TerrainChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const R
|
|||||||
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
||||||
e.is_inside = aabb.encloses(mesh_aabb);
|
e.is_inside = aabb.encloses(mesh_aabb);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
if (get_library().is_valid() && texture.is_valid()) {
|
if (get_library().is_valid() && texture.is_valid()) {
|
||||||
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
||||||
} else {
|
} else {
|
||||||
@ -797,7 +799,7 @@ int TerrainChunk::mesh_data_resource_add(const Transform &local_transform, const
|
|||||||
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
||||||
e.is_inside = aabb.encloses(mesh_aabb);
|
e.is_inside = aabb.encloses(mesh_aabb);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
if (get_library().is_valid() && texture.is_valid())
|
if (get_library().is_valid() && texture.is_valid())
|
||||||
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
||||||
else
|
else
|
||||||
@ -1091,7 +1093,7 @@ TerrainChunk::~TerrainChunk() {
|
|||||||
_library.unref();
|
_library.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
props_clear();
|
props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1460,7 +1462,7 @@ void TerrainChunk::_bind_methods() {
|
|||||||
|
|
||||||
//Meshes
|
//Meshes
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "prop"), &TerrainChunk::prop_add);
|
ClassDB::bind_method(D_METHOD("prop_add", "prop"), &TerrainChunk::prop_add);
|
||||||
ClassDB::bind_method(D_METHOD("prop_get", "index"), &TerrainChunk::prop_get);
|
ClassDB::bind_method(D_METHOD("prop_get", "index"), &TerrainChunk::prop_get);
|
||||||
ClassDB::bind_method(D_METHOD("prop_get_count"), &TerrainChunk::prop_get_count);
|
ClassDB::bind_method(D_METHOD("prop_get_count"), &TerrainChunk::prop_get_count);
|
||||||
|
@ -43,7 +43,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../meshers/terrain_mesher.h"
|
#include "../meshers/terrain_mesher.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -215,7 +217,7 @@ public:
|
|||||||
void bake_light(Ref<TerrainLight> light);
|
void bake_light(Ref<TerrainLight> light);
|
||||||
void clear_baked_lights();
|
void clear_baked_lights();
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add(const Transform &tarnsform, const Ref<PropData> &prop);
|
void prop_add(const Transform &tarnsform, const Ref<PropData> &prop);
|
||||||
Ref<PropData> prop_get(const int index);
|
Ref<PropData> prop_get(const int index);
|
||||||
Transform prop_get_tarnsform(const int index);
|
Transform prop_get_tarnsform(const int index);
|
||||||
@ -301,7 +303,7 @@ protected:
|
|||||||
virtual void _generation_physics_process(const float delta);
|
virtual void _generation_physics_process(const float delta);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
struct PropDataStore {
|
struct PropDataStore {
|
||||||
Transform transform;
|
Transform transform;
|
||||||
Ref<PropData> prop;
|
Ref<PropData> prop;
|
||||||
@ -383,7 +385,7 @@ protected:
|
|||||||
|
|
||||||
Vector<Ref<TerrainStructure>> _voxel_structures;
|
Vector<Ref<TerrainStructure>> _voxel_structures;
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<PropDataStore> _props;
|
Vector<PropDataStore> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -28,7 +28,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#include "../../props/props/prop_data_entry.h"
|
#include "../../props/props/prop_data_entry.h"
|
||||||
#include "../../props/props/prop_data_light.h"
|
#include "../../props/props/prop_data_light.h"
|
||||||
@ -579,7 +581,7 @@ int TerrainWorld::generation_get_size() const {
|
|||||||
return _generating.size();
|
return _generating.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void TerrainWorld::prop_add(Transform transform, const Ref<PropData> &prop, const bool apply_voxel_scale) {
|
void TerrainWorld::prop_add(Transform transform, const Ref<PropData> &prop, const bool apply_voxel_scale) {
|
||||||
ERR_FAIL_COND(!prop.is_valid());
|
ERR_FAIL_COND(!prop.is_valid());
|
||||||
|
|
||||||
@ -1197,7 +1199,7 @@ void TerrainWorld::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("is_position_walkable", "position"), &TerrainWorld::is_position_walkable);
|
ClassDB::bind_method(D_METHOD("is_position_walkable", "position"), &TerrainWorld::is_position_walkable);
|
||||||
ClassDB::bind_method(D_METHOD("on_chunk_mesh_generation_finished", "chunk"), &TerrainWorld::on_chunk_mesh_generation_finished);
|
ClassDB::bind_method(D_METHOD("on_chunk_mesh_generation_finished", "chunk"), &TerrainWorld::on_chunk_mesh_generation_finished);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "transform", "prop", "apply_voxel_scale"), &TerrainWorld::prop_add, DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("prop_add", "transform", "prop", "apply_voxel_scale"), &TerrainWorld::prop_add, DEFVAL(true));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -35,7 +35,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/os.h"
|
#include "core/os/os.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -161,7 +163,7 @@ public:
|
|||||||
void generation_remove_index(const int index);
|
void generation_remove_index(const int index);
|
||||||
int generation_get_size() const;
|
int generation_get_size() const;
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add(Transform transform, const Ref<PropData> &prop, const bool apply_voxel_scale = true);
|
void prop_add(Transform transform, const Ref<PropData> &prop, const bool apply_voxel_scale = true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -25,7 +25,9 @@ SOFTWARE.
|
|||||||
#include "../world/voxel_chunk.h"
|
#include "../world/voxel_chunk.h"
|
||||||
#include "voxel_material_cache.h"
|
#include "voxel_material_cache.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -312,7 +314,7 @@ int VoxelLibrary::scene_get_num() const {
|
|||||||
void VoxelLibrary::scenes_clear() {
|
void VoxelLibrary::scenes_clear() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> VoxelLibrary::prop_get(const int id) {
|
Ref<PropData> VoxelLibrary::prop_get(const int id) {
|
||||||
return Ref<PropData>();
|
return Ref<PropData>();
|
||||||
}
|
}
|
||||||
@ -455,7 +457,7 @@ void VoxelLibrary::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("scene_get_num"), &VoxelLibrary::scene_get_num);
|
ClassDB::bind_method(D_METHOD("scene_get_num"), &VoxelLibrary::scene_get_num);
|
||||||
ClassDB::bind_method(D_METHOD("scenes_clear"), &VoxelLibrary::scenes_clear);
|
ClassDB::bind_method(D_METHOD("scenes_clear"), &VoxelLibrary::scenes_clear);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_get", "id"), &VoxelLibrary::prop_get);
|
ClassDB::bind_method(D_METHOD("prop_get", "id"), &VoxelLibrary::prop_get);
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "value"), &VoxelLibrary::prop_add);
|
ClassDB::bind_method(D_METHOD("prop_add", "value"), &VoxelLibrary::prop_add);
|
||||||
ClassDB::bind_method(D_METHOD("prop_has", "prop"), &VoxelLibrary::prop_has);
|
ClassDB::bind_method(D_METHOD("prop_has", "prop"), &VoxelLibrary::prop_has);
|
||||||
|
@ -32,12 +32,14 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class VoxelMaterialCache;
|
class VoxelMaterialCache;
|
||||||
class VoxelChunk;
|
class VoxelChunk;
|
||||||
class VoxelSurface;
|
class VoxelSurface;
|
||||||
class VoxelMesher;
|
class VoxelMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
class PropData;
|
class PropData;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -129,7 +131,7 @@ public:
|
|||||||
virtual int scene_get_num() const;
|
virtual int scene_get_num() const;
|
||||||
virtual void scenes_clear();
|
virtual void scenes_clear();
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
virtual Ref<PropData> prop_get(const int id);
|
virtual Ref<PropData> prop_get(const int id);
|
||||||
virtual void prop_add(Ref<PropData> value);
|
virtual void prop_add(Ref<PropData> value);
|
||||||
virtual bool prop_has(const Ref<PropData> &value) const;
|
virtual bool prop_has(const Ref<PropData> &value) const;
|
||||||
|
@ -25,7 +25,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
@ -151,7 +153,7 @@ void VoxelLibraryMerger::set_voxel_surfaces(const Vector<Variant> &surfaces) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> VoxelLibraryMerger::get_prop(const int index) {
|
Ref<PropData> VoxelLibraryMerger::get_prop(const int index) {
|
||||||
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
||||||
|
|
||||||
@ -260,7 +262,7 @@ void VoxelLibraryMerger::refresh_rects() {
|
|||||||
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
//todo add this back
|
//todo add this back
|
||||||
//texture_added = false;
|
//texture_added = false;
|
||||||
for (int i = 0; i < _props.size(); i++) {
|
for (int i = 0; i < _props.size(); i++) {
|
||||||
@ -400,7 +402,7 @@ VoxelLibraryMerger::~VoxelLibraryMerger() {
|
|||||||
_prop_packer.unref();
|
_prop_packer.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool VoxelLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
bool VoxelLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return false;
|
return false;
|
||||||
@ -460,7 +462,7 @@ void VoxelLibraryMerger::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_voxel_surfaces"), &VoxelLibraryMerger::set_voxel_surfaces);
|
ClassDB::bind_method(D_METHOD("set_voxel_surfaces"), &VoxelLibraryMerger::set_voxel_surfaces);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "voxel_surfaces", PROPERTY_HINT_NONE, "23/19:VoxelSurfaceMerger", PROPERTY_USAGE_DEFAULT, "VoxelSurfaceMerger"), "set_voxel_surfaces", "get_voxel_surfaces");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "voxel_surfaces", PROPERTY_HINT_NONE, "23/19:VoxelSurfaceMerger", PROPERTY_USAGE_DEFAULT, "VoxelSurfaceMerger"), "set_voxel_surfaces", "get_voxel_surfaces");
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("get_props"), &VoxelLibraryMerger::get_props);
|
ClassDB::bind_method(D_METHOD("get_props"), &VoxelLibraryMerger::get_props);
|
||||||
ClassDB::bind_method(D_METHOD("set_props"), &VoxelLibraryMerger::set_props);
|
ClassDB::bind_method(D_METHOD("set_props"), &VoxelLibraryMerger::set_props);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
||||||
|
@ -32,6 +32,12 @@ SOFTWARE.
|
|||||||
#include "../data/voxel_light.h"
|
#include "../data/voxel_light.h"
|
||||||
#include "voxel_surface_merger.h"
|
#include "voxel_surface_merger.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
|
class PropData;
|
||||||
|
#endif
|
||||||
|
|
||||||
class VoxelSurfaceSimple;
|
class VoxelSurfaceSimple;
|
||||||
class VoxelMesher;
|
class VoxelMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
@ -65,7 +71,7 @@ public:
|
|||||||
Vector<Variant> get_voxel_surfaces();
|
Vector<Variant> get_voxel_surfaces();
|
||||||
void set_voxel_surfaces(const Vector<Variant> &surfaces);
|
void set_voxel_surfaces(const Vector<Variant> &surfaces);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> get_prop(const int index);
|
Ref<PropData> get_prop(const int index);
|
||||||
void add_prop(Ref<PropData> value);
|
void add_prop(Ref<PropData> value);
|
||||||
bool has_prop(const Ref<PropData> &value) const;
|
bool has_prop(const Ref<PropData> &value) const;
|
||||||
@ -90,14 +96,14 @@ public:
|
|||||||
~VoxelLibraryMerger();
|
~VoxelLibraryMerger();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool process_prop_textures(Ref<PropData> prop);
|
bool process_prop_textures(Ref<PropData> prop);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
Vector<Ref<VoxelSurfaceMerger>> _voxel_surfaces;
|
Vector<Ref<VoxelSurfaceMerger>> _voxel_surfaces;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<Ref<PropData>> _props;
|
Vector<Ref<PropData>> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -26,7 +26,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
@ -208,7 +210,7 @@ void VoxelLibraryMergerPCM::_prop_material_cache_get_key(Ref<VoxelChunk> chunk)
|
|||||||
Vector<uint64_t> props;
|
Vector<uint64_t> props;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
||||||
Ref<PropData> prop = chunk->prop_get(i);
|
Ref<PropData> prop = chunk->prop_get(i);
|
||||||
|
|
||||||
@ -317,7 +319,7 @@ void VoxelLibraryMergerPCM::_prop_material_cache_get_key(Ref<VoxelChunk> chunk)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
for (int i = 0; i < chunk->prop_get_count(); ++i) {
|
||||||
Ref<PropData> prop = chunk->prop_get(i);
|
Ref<PropData> prop = chunk->prop_get(i);
|
||||||
|
|
||||||
@ -494,7 +496,7 @@ void VoxelLibraryMergerPCM::set_voxel_surfaces(const Vector<Variant> &surfaces)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> VoxelLibraryMergerPCM::get_prop(const int index) {
|
Ref<PropData> VoxelLibraryMergerPCM::get_prop(const int index) {
|
||||||
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
ERR_FAIL_INDEX_V(index, _props.size(), Ref<PropData>());
|
||||||
|
|
||||||
@ -603,7 +605,7 @@ void VoxelLibraryMergerPCM::refresh_rects() {
|
|||||||
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
setup_material_albedo(MATERIAL_INDEX_LIQUID, tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
//todo add this back
|
//todo add this back
|
||||||
//texture_added = false;
|
//texture_added = false;
|
||||||
for (int i = 0; i < _props.size(); i++) {
|
for (int i = 0; i < _props.size(); i++) {
|
||||||
@ -743,7 +745,7 @@ VoxelLibraryMergerPCM::~VoxelLibraryMergerPCM() {
|
|||||||
_prop_packer.unref();
|
_prop_packer.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool VoxelLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
bool VoxelLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return false;
|
return false;
|
||||||
@ -803,7 +805,7 @@ void VoxelLibraryMergerPCM::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_voxel_surfaces"), &VoxelLibraryMergerPCM::set_voxel_surfaces);
|
ClassDB::bind_method(D_METHOD("set_voxel_surfaces"), &VoxelLibraryMergerPCM::set_voxel_surfaces);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "voxel_surfaces", PROPERTY_HINT_NONE, "23/19:VoxelSurfaceMerger", PROPERTY_USAGE_DEFAULT, "VoxelSurfaceMerger"), "set_voxel_surfaces", "get_voxel_surfaces");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "voxel_surfaces", PROPERTY_HINT_NONE, "23/19:VoxelSurfaceMerger", PROPERTY_USAGE_DEFAULT, "VoxelSurfaceMerger"), "set_voxel_surfaces", "get_voxel_surfaces");
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("get_props"), &VoxelLibraryMergerPCM::get_props);
|
ClassDB::bind_method(D_METHOD("get_props"), &VoxelLibraryMergerPCM::get_props);
|
||||||
ClassDB::bind_method(D_METHOD("set_props"), &VoxelLibraryMergerPCM::set_props);
|
ClassDB::bind_method(D_METHOD("set_props"), &VoxelLibraryMergerPCM::set_props);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "props", PROPERTY_HINT_NONE, "23/19:PropData", PROPERTY_USAGE_DEFAULT, "PropData"), "set_props", "get_props");
|
||||||
|
@ -34,6 +34,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/mutex.h"
|
#include "core/os/mutex.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class VoxelSurfaceSimple;
|
class VoxelSurfaceSimple;
|
||||||
class VoxelMesher;
|
class VoxelMesher;
|
||||||
class PackedScene;
|
class PackedScene;
|
||||||
@ -82,7 +84,7 @@ public:
|
|||||||
Vector<Variant> get_voxel_surfaces();
|
Vector<Variant> get_voxel_surfaces();
|
||||||
void set_voxel_surfaces(const Vector<Variant> &surfaces);
|
void set_voxel_surfaces(const Vector<Variant> &surfaces);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Ref<PropData> get_prop(const int index);
|
Ref<PropData> get_prop(const int index);
|
||||||
void add_prop(Ref<PropData> value);
|
void add_prop(Ref<PropData> value);
|
||||||
bool has_prop(const Ref<PropData> &value) const;
|
bool has_prop(const Ref<PropData> &value) const;
|
||||||
@ -107,7 +109,7 @@ public:
|
|||||||
~VoxelLibraryMergerPCM();
|
~VoxelLibraryMergerPCM();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
bool process_prop_textures(Ref<PropData> prop);
|
bool process_prop_textures(Ref<PropData> prop);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -117,7 +119,7 @@ protected:
|
|||||||
Map<int, Ref<VoxelMaterialCachePCM>> _prop_material_cache;
|
Map<int, Ref<VoxelMaterialCachePCM>> _prop_material_cache;
|
||||||
|
|
||||||
Vector<Ref<VoxelSurfaceMerger>> _voxel_surfaces;
|
Vector<Ref<VoxelSurfaceMerger>> _voxel_surfaces;
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<Ref<PropData>> _props;
|
Vector<Ref<PropData>> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -24,7 +24,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
|
|
||||||
@ -196,7 +198,7 @@ Rect2 VoxelMaterialCache::additional_texture_get_uv_rect(const Ref<Texture> &tex
|
|||||||
return Rect2(0, 0, 1, 1);
|
return Rect2(0, 0, 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void VoxelMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
void VoxelMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
||||||
if (!prop.is_valid()) {
|
if (!prop.is_valid()) {
|
||||||
return;
|
return;
|
||||||
@ -315,7 +317,7 @@ void VoxelMaterialCache::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("additional_texture_get_atlas_tex", "index"), &VoxelMaterialCache::additional_texture_get_atlas_tex);
|
ClassDB::bind_method(D_METHOD("additional_texture_get_atlas_tex", "index"), &VoxelMaterialCache::additional_texture_get_atlas_tex);
|
||||||
ClassDB::bind_method(D_METHOD("additional_texture_get_uv_rect", "texture"), &VoxelMaterialCache::additional_texture_get_uv_rect);
|
ClassDB::bind_method(D_METHOD("additional_texture_get_uv_rect", "texture"), &VoxelMaterialCache::additional_texture_get_uv_rect);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &VoxelMaterialCache::prop_add_textures);
|
ClassDB::bind_method(D_METHOD("prop_add_textures", "prop"), &VoxelMaterialCache::prop_add_textures);
|
||||||
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &VoxelMaterialCache::prop_remove_textures);
|
ClassDB::bind_method(D_METHOD("prop_remove_textures", "prop"), &VoxelMaterialCache::prop_remove_textures);
|
||||||
#endif
|
#endif
|
||||||
|
@ -33,6 +33,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class VoxelLibrary;
|
class VoxelLibrary;
|
||||||
|
|
||||||
class VoxelMaterialCache : public Resource {
|
class VoxelMaterialCache : public Resource {
|
||||||
@ -76,7 +78,7 @@ public:
|
|||||||
virtual Ref<AtlasTexture> additional_texture_get_atlas_tex(const Ref<Texture> &texture);
|
virtual Ref<AtlasTexture> additional_texture_get_atlas_tex(const Ref<Texture> &texture);
|
||||||
virtual Rect2 additional_texture_get_uv_rect(const Ref<Texture> &texture);
|
virtual Rect2 additional_texture_get_uv_rect(const Ref<Texture> &texture);
|
||||||
|
|
||||||
#ifdef PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add_textures(const Ref<PropData> &prop);
|
void prop_add_textures(const Ref<PropData> &prop);
|
||||||
void prop_remove_textures(const Ref<PropData> &prop);
|
void prop_remove_textures(const Ref<PropData> &prop);
|
||||||
#endif
|
#endif
|
||||||
|
@ -34,6 +34,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/thread_pool.h"
|
#include "core/os/thread_pool.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
_FORCE_INLINE_ bool VoxelChunk::get_is_build_threaded() const {
|
_FORCE_INLINE_ bool VoxelChunk::get_is_build_threaded() const {
|
||||||
return _is_build_threaded;
|
return _is_build_threaded;
|
||||||
}
|
}
|
||||||
@ -698,7 +700,7 @@ void VoxelChunk::clear_baked_lights() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void VoxelChunk::prop_add(const Transform &tarnsform, const Ref<PropData> &prop) {
|
void VoxelChunk::prop_add(const Transform &tarnsform, const Ref<PropData> &prop) {
|
||||||
ERR_FAIL_COND(!prop.is_valid());
|
ERR_FAIL_COND(!prop.is_valid());
|
||||||
|
|
||||||
@ -754,7 +756,7 @@ int VoxelChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref
|
|||||||
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
||||||
e.is_inside = aabb.encloses(mesh_aabb);
|
e.is_inside = aabb.encloses(mesh_aabb);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
if (get_library().is_valid() && texture.is_valid()) {
|
if (get_library().is_valid() && texture.is_valid()) {
|
||||||
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
||||||
} else {
|
} else {
|
||||||
@ -795,7 +797,7 @@ int VoxelChunk::mesh_data_resource_add(const Transform &local_transform, const R
|
|||||||
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
AABB mesh_aabb = e.transform.xform(mesh->get_aabb());
|
||||||
e.is_inside = aabb.encloses(mesh_aabb);
|
e.is_inside = aabb.encloses(mesh_aabb);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
if (get_library().is_valid() && texture.is_valid())
|
if (get_library().is_valid() && texture.is_valid())
|
||||||
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
e.uv_rect = get_library()->get_prop_uv_rect(texture);
|
||||||
else
|
else
|
||||||
@ -1087,7 +1089,7 @@ VoxelChunk::~VoxelChunk() {
|
|||||||
_library.unref();
|
_library.unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
props_clear();
|
props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1448,7 +1450,7 @@ void VoxelChunk::_bind_methods() {
|
|||||||
|
|
||||||
//Meshes
|
//Meshes
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "prop"), &VoxelChunk::prop_add);
|
ClassDB::bind_method(D_METHOD("prop_add", "prop"), &VoxelChunk::prop_add);
|
||||||
ClassDB::bind_method(D_METHOD("prop_get", "index"), &VoxelChunk::prop_get);
|
ClassDB::bind_method(D_METHOD("prop_get", "index"), &VoxelChunk::prop_get);
|
||||||
ClassDB::bind_method(D_METHOD("prop_get_count"), &VoxelChunk::prop_get_count);
|
ClassDB::bind_method(D_METHOD("prop_get_count"), &VoxelChunk::prop_get_count);
|
||||||
|
@ -43,7 +43,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../meshers/voxel_mesher.h"
|
#include "../meshers/voxel_mesher.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -222,7 +224,7 @@ public:
|
|||||||
void bake_light(Ref<VoxelLight> light);
|
void bake_light(Ref<VoxelLight> light);
|
||||||
void clear_baked_lights();
|
void clear_baked_lights();
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add(const Transform &tarnsform, const Ref<PropData> &prop);
|
void prop_add(const Transform &tarnsform, const Ref<PropData> &prop);
|
||||||
Ref<PropData> prop_get(const int index);
|
Ref<PropData> prop_get(const int index);
|
||||||
Transform prop_get_tarnsform(const int index);
|
Transform prop_get_tarnsform(const int index);
|
||||||
@ -306,7 +308,7 @@ protected:
|
|||||||
virtual void _generation_physics_process(const float delta);
|
virtual void _generation_physics_process(const float delta);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
struct PropDataStore {
|
struct PropDataStore {
|
||||||
Transform transform;
|
Transform transform;
|
||||||
Ref<PropData> prop;
|
Ref<PropData> prop;
|
||||||
@ -391,7 +393,7 @@ protected:
|
|||||||
|
|
||||||
Vector<Ref<VoxelStructure>> _voxel_structures;
|
Vector<Ref<VoxelStructure>> _voxel_structures;
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
Vector<PropDataStore> _props;
|
Vector<PropDataStore> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -27,7 +27,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#include "../../props/props/prop_data_entry.h"
|
#include "../../props/props/prop_data_entry.h"
|
||||||
#include "../../props/props/prop_data_light.h"
|
#include "../../props/props/prop_data_light.h"
|
||||||
@ -543,7 +545,7 @@ int VoxelWorld::generation_get_size() const {
|
|||||||
return _generating.size();
|
return _generating.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void VoxelWorld::prop_add(Transform tarnsform, const Ref<PropData> &prop, const bool apply_voxel_scael) {
|
void VoxelWorld::prop_add(Transform tarnsform, const Ref<PropData> &prop, const bool apply_voxel_scael) {
|
||||||
ERR_FAIL_COND(!prop.is_valid());
|
ERR_FAIL_COND(!prop.is_valid());
|
||||||
|
|
||||||
@ -1157,7 +1159,7 @@ void VoxelWorld::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("is_position_walkable", "position"), &VoxelWorld::is_position_walkable);
|
ClassDB::bind_method(D_METHOD("is_position_walkable", "position"), &VoxelWorld::is_position_walkable);
|
||||||
ClassDB::bind_method(D_METHOD("on_chunk_mesh_generation_finished", "chunk"), &VoxelWorld::on_chunk_mesh_generation_finished);
|
ClassDB::bind_method(D_METHOD("on_chunk_mesh_generation_finished", "chunk"), &VoxelWorld::on_chunk_mesh_generation_finished);
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("prop_add", "transform", "prop", "apply_voxel_scael"), &VoxelWorld::prop_add, DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("prop_add", "transform", "prop", "apply_voxel_scael"), &VoxelWorld::prop_add, DEFVAL(true));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -35,7 +35,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "core/os/os.h"
|
#include "core/os/os.h"
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
#include "../../props/props/prop_data.h"
|
#include "../../props/props/prop_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -160,7 +162,7 @@ public:
|
|||||||
void generation_remove_index(const int index);
|
void generation_remove_index(const int index);
|
||||||
int generation_get_size() const;
|
int generation_get_size() const;
|
||||||
|
|
||||||
#if PROPS_PRESENT
|
#ifdef MODULE_PROPS_ENABLED
|
||||||
void prop_add(Transform tarnsform, const Ref<PropData> &prop, const bool apply_voxel_scael = true);
|
void prop_add(Transform tarnsform, const Ref<PropData> &prop, const bool apply_voxel_scael = true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user