mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-14 22:51:11 +01:00
Moved away from the MESH_DATA_RESOURCE_PRESENT define aswell.
This commit is contained in:
parent
73742e947d
commit
2fdaacfa66
@ -4,9 +4,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
|
||||||
|
|
||||||
sources = [
|
sources = [
|
||||||
"register_types.cpp",
|
"register_types.cpp",
|
||||||
|
|
||||||
|
@ -24,6 +24,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../../singletons/ess.h"
|
#include "../../singletons/ess.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
const String ModelVisualEntry::BINDING_STRING_MODEL_VISUAL_ENTRY_TYPES = "Bone,Attachment";
|
const String ModelVisualEntry::BINDING_STRING_MODEL_VISUAL_ENTRY_TYPES = "Bone,Attachment";
|
||||||
|
|
||||||
ModelVisualEntry::ModenVisualEntryType ModelVisualEntry::get_type() const {
|
ModelVisualEntry::ModenVisualEntryType ModelVisualEntry::get_type() const {
|
||||||
@ -61,7 +63,7 @@ void ModelVisualEntry::set_group(const int value) {
|
|||||||
_group = value;
|
_group = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<MeshDataResource> ModelVisualEntry::get_mesh(const int index) {
|
Ref<MeshDataResource> ModelVisualEntry::get_mesh(const int index) {
|
||||||
ERR_FAIL_INDEX_V(index, _entries.size(), Ref<MeshDataResource>());
|
ERR_FAIL_INDEX_V(index, _entries.size(), Ref<MeshDataResource>());
|
||||||
|
|
||||||
@ -155,7 +157,7 @@ bool ModelVisualEntry::_set(const StringName &p_name, const Variant &p_value) {
|
|||||||
_entries.write[index].texture = p_value;
|
_entries.write[index].texture = p_value;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
} else if (p == "mesh") {
|
} else if (p == "mesh") {
|
||||||
_entries.write[index].mesh = p_value;
|
_entries.write[index].mesh = p_value;
|
||||||
|
|
||||||
@ -194,7 +196,7 @@ bool ModelVisualEntry::_get(const StringName &p_name, Variant &r_ret) const {
|
|||||||
r_ret = _entries[index].texture;
|
r_ret = _entries[index].texture;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
} else if (p == "mesh") {
|
} else if (p == "mesh") {
|
||||||
r_ret = _entries[index].mesh;
|
r_ret = _entries[index].mesh;
|
||||||
|
|
||||||
@ -220,7 +222,7 @@ bool ModelVisualEntry::_get(const StringName &p_name, Variant &r_ret) const {
|
|||||||
void ModelVisualEntry::_get_property_list(List<PropertyInfo> *p_list) const {
|
void ModelVisualEntry::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
for (int i = 0; i < _entries.size(); ++i) {
|
for (int i = 0; i < _entries.size(); ++i) {
|
||||||
if (_type == ModelVisualEntry::MODEL_VISUAL_ENTRY_TYPE_BONE) {
|
if (_type == ModelVisualEntry::MODEL_VISUAL_ENTRY_TYPE_BONE) {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
p_list->push_back(PropertyInfo(Variant::OBJECT, "entry_" + itos(i) + "/mesh", PROPERTY_HINT_RESOURCE_TYPE, "MeshDataResource", PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_INTERNAL));
|
p_list->push_back(PropertyInfo(Variant::OBJECT, "entry_" + itos(i) + "/mesh", PROPERTY_HINT_RESOURCE_TYPE, "MeshDataResource", PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_INTERNAL));
|
||||||
#endif
|
#endif
|
||||||
p_list->push_back(PropertyInfo(Variant::OBJECT, "entry_" + itos(i) + "/texture", PROPERTY_HINT_RESOURCE_TYPE, "Texture", PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_INTERNAL));
|
p_list->push_back(PropertyInfo(Variant::OBJECT, "entry_" + itos(i) + "/texture", PROPERTY_HINT_RESOURCE_TYPE, "Texture", PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_INTERNAL));
|
||||||
@ -282,7 +284,7 @@ void ModelVisualEntry::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_group", "value"), &ModelVisualEntry::set_group);
|
ClassDB::bind_method(D_METHOD("set_group", "value"), &ModelVisualEntry::set_group);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::INT, "group", PROPERTY_HINT_ENUM), "set_group", "get_group");
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "group", PROPERTY_HINT_ENUM), "set_group", "get_group");
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("get_mesh", "index"), &ModelVisualEntry::get_mesh);
|
ClassDB::bind_method(D_METHOD("get_mesh", "index"), &ModelVisualEntry::get_mesh);
|
||||||
ClassDB::bind_method(D_METHOD("set_mesh", "index", "value"), &ModelVisualEntry::set_mesh);
|
ClassDB::bind_method(D_METHOD("set_mesh", "index", "value"), &ModelVisualEntry::set_mesh);
|
||||||
#endif
|
#endif
|
||||||
|
@ -34,7 +34,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -65,7 +67,7 @@ public:
|
|||||||
int get_group() const;
|
int get_group() const;
|
||||||
void set_group(const int value);
|
void set_group(const int value);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<MeshDataResource> get_mesh(const int index);
|
Ref<MeshDataResource> get_mesh(const int index);
|
||||||
void set_mesh(const int index, const Ref<MeshDataResource> &mesh);
|
void set_mesh(const int index, const Ref<MeshDataResource> &mesh);
|
||||||
#endif
|
#endif
|
||||||
@ -90,7 +92,7 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
struct MVEE {
|
struct MVEE {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<MeshDataResource> mesh;
|
Ref<MeshDataResource> mesh;
|
||||||
#endif
|
#endif
|
||||||
Ref<Texture> texture;
|
Ref<Texture> texture;
|
||||||
@ -104,7 +106,7 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~MVEE() {
|
~MVEE() {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
mesh.unref();
|
mesh.unref();
|
||||||
#endif
|
#endif
|
||||||
texture.unref();
|
texture.unref();
|
||||||
|
@ -30,7 +30,7 @@ SOFTWARE.
|
|||||||
#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
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -180,7 +180,7 @@ void ESSMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -221,7 +221,7 @@ void ESSMaterialCache::prop_remove_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -5,9 +5,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
|
||||||
|
|
||||||
sources = [
|
sources = [
|
||||||
"register_types.cpp",
|
"register_types.cpp",
|
||||||
"mesh_utils.cpp",
|
"mesh_utils.cpp",
|
||||||
|
@ -26,6 +26,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "scene/3d/mesh_instance.h"
|
#include "scene/3d/mesh_instance.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
bool MeshMerger::Vertex::operator==(const Vertex &p_vertex) const {
|
bool MeshMerger::Vertex::operator==(const Vertex &p_vertex) const {
|
||||||
if (vertex != p_vertex.vertex)
|
if (vertex != p_vertex.vertex)
|
||||||
return false;
|
return false;
|
||||||
@ -432,7 +434,7 @@ void MeshMerger::reset() {
|
|||||||
_last_tangent = Plane();
|
_last_tangent = Plane();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|
|
||||||
void MeshMerger::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Transform transform, Rect2 uv_rect) {
|
void MeshMerger::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Transform transform, Rect2 uv_rect) {
|
||||||
ERR_FAIL_COND(mesh->get_array().size() == 0);
|
ERR_FAIL_COND(mesh->get_array().size() == 0);
|
||||||
@ -933,7 +935,7 @@ void MeshMerger::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_uv_margin", "value"), &MeshMerger::set_uv_margin);
|
ClassDB::bind_method(D_METHOD("set_uv_margin", "value"), &MeshMerger::set_uv_margin);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::RECT2, "uv_margin"), "set_uv_margin", "get_uv_margin");
|
ADD_PROPERTY(PropertyInfo(Variant::RECT2, "uv_margin"), "set_uv_margin", "get_uv_margin");
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "transform", "uv_rect"), &MeshMerger::add_mesh_data_resource, DEFVAL(Transform()), DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "transform", "uv_rect"), &MeshMerger::add_mesh_data_resource, DEFVAL(Transform()), DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_bone", "mesh", "bones", "wrights", "transform", "uv_rect"), &MeshMerger::add_mesh_data_resource_bone, DEFVAL(Transform()), DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_bone", "mesh", "bones", "wrights", "transform", "uv_rect"), &MeshMerger::add_mesh_data_resource_bone, DEFVAL(Transform()), DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
#endif
|
#endif
|
||||||
|
@ -40,7 +40,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -103,7 +105,7 @@ public:
|
|||||||
|
|
||||||
void reset();
|
void reset();
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Transform transform = Transform(), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Transform transform = Transform(), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_bone(Ref<MeshDataResource> mesh, const Vector<int> &bones, const Vector<float> &weights, const Transform transform = Transform(), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_bone(Ref<MeshDataResource> mesh, const Vector<int> &bones, const Vector<float> &weights, const Transform transform = Transform(), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
#endif
|
#endif
|
||||||
|
@ -6,9 +6,6 @@ module_env = env.Clone()
|
|||||||
|
|
||||||
import version
|
import version
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_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'])
|
||||||
|
|
||||||
|
@ -28,7 +28,9 @@ SOFTWARE.
|
|||||||
#include "../singleton/prop_cache.h"
|
#include "../singleton/prop_cache.h"
|
||||||
#include "../tiled_wall/tiled_wall_data.h"
|
#include "../tiled_wall/tiled_wall_data.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -173,7 +175,7 @@ void PropMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -214,7 +216,7 @@ void PropMaterialCache::prop_remove_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -4,7 +4,9 @@
|
|||||||
|
|
||||||
#include "scene/3d/light.h"
|
#include "scene/3d/light.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -195,7 +197,7 @@ void PropInstance::_prop_preprocess(Transform transform, const Ref<PropData> &pr
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> mesh_data = e;
|
Ref<PropDataMeshData> mesh_data = e;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include "./singleton/prop_cache.h"
|
#include "./singleton/prop_cache.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -669,7 +669,7 @@ void PropInstanceMerger::_prop_preprocess(Transform transform, const Ref<PropDat
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> mesh_data = e;
|
Ref<PropDataMeshData> mesh_data = e;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
@ -35,7 +35,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ SOFTWARE.
|
|||||||
#include "../texture_packer/texture_packer.h"
|
#include "../texture_packer/texture_packer.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -114,7 +114,7 @@ void PropInstancePropJob::set_prop_mesher(const Ref<PropMesher> &mesher) {
|
|||||||
_prop_mesher = mesher;
|
_prop_mesher = mesher;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void PropInstancePropJob::add_mesh(const Ref<PropDataMeshData> &mesh_data, const Transform &base_transform) {
|
void PropInstancePropJob::add_mesh(const Ref<PropDataMeshData> &mesh_data, const Transform &base_transform) {
|
||||||
PMDREntry e;
|
PMDREntry e;
|
||||||
e.mesh_data = mesh_data;
|
e.mesh_data = mesh_data;
|
||||||
@ -150,7 +150,7 @@ void PropInstancePropJob::clear_lights() {
|
|||||||
void PropInstancePropJob::_physics_process(float delta) {
|
void PropInstancePropJob::_physics_process(float delta) {
|
||||||
if (_phase == 0) {
|
if (_phase == 0) {
|
||||||
phase_physics_process();
|
phase_physics_process();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void PropInstancePropJob::_execute_phase() {
|
void PropInstancePropJob::_execute_phase() {
|
||||||
@ -161,7 +161,7 @@ void PropInstancePropJob::_execute_phase() {
|
|||||||
finished();
|
finished();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
||||||
//reset_meshes();
|
//reset_meshes();
|
||||||
set_complete(true);
|
set_complete(true);
|
||||||
@ -200,7 +200,9 @@ void PropInstancePropJob::_reset() {
|
|||||||
|
|
||||||
_prop_tiled_wall_datas.clear();
|
_prop_tiled_wall_datas.clear();
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
_prop_mesh_datas.clear();
|
_prop_mesh_datas.clear();
|
||||||
|
#endif
|
||||||
clear_collision_shapes();
|
clear_collision_shapes();
|
||||||
|
|
||||||
set_build_phase_type(BUILD_PHASE_TYPE_PHYSICS_PROCESS);
|
set_build_phase_type(BUILD_PHASE_TYPE_PHYSICS_PROCESS);
|
||||||
@ -291,14 +293,18 @@ void PropInstancePropJob::phase_prop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (should_do()) {
|
if (should_do()) {
|
||||||
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
if (
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|
_prop_mesh_datas.size() == 0 &&
|
||||||
|
#endif
|
||||||
|
_prop_tiled_wall_datas.size() == 0) {
|
||||||
//reset_meshes();
|
//reset_meshes();
|
||||||
reset_stages();
|
reset_stages();
|
||||||
set_complete(true); //So threadpool knows it's done
|
set_complete(true); //So threadpool knows it's done
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < _prop_mesh_datas.size(); ++i) {
|
for (int i = 0; i < _prop_mesh_datas.size(); ++i) {
|
||||||
PMDREntry &e = _prop_mesh_datas.write[i];
|
PMDREntry &e = _prop_mesh_datas.write[i];
|
||||||
|
|
||||||
@ -419,7 +425,7 @@ void PropInstancePropJob::phase_steps() {
|
|||||||
|
|
||||||
if (RS::get_singleton()->mesh_get_surface_count(mesh_rid) > 0) {
|
if (RS::get_singleton()->mesh_get_surface_count(mesh_rid) > 0) {
|
||||||
RS::get_singleton()->mesh_remove_surface(mesh_rid, 0);
|
RS::get_singleton()->mesh_remove_surface(mesh_rid, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -605,7 +611,7 @@ Array PropInstancePropJob::merge_mesh_array(Array arr) const {
|
|||||||
|
|
||||||
if (Math::is_equal_approx(v.x, vc.x) && Math::is_equal_approx(v.y, vc.y) && Math::is_equal_approx(v.z, vc.z)) {
|
if (Math::is_equal_approx(v.x, vc.x) && Math::is_equal_approx(v.y, vc.y) && Math::is_equal_approx(v.z, vc.z)) {
|
||||||
equals.push_back(j);
|
equals.push_back(j);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int k = 0; k < equals.size(); ++k) {
|
for (int k = 0; k < equals.size(); ++k) {
|
||||||
@ -616,22 +622,22 @@ Array PropInstancePropJob::merge_mesh_array(Array arr) const {
|
|||||||
|
|
||||||
if (has_normals) {
|
if (has_normals) {
|
||||||
normals.remove(remk);
|
normals.remove(remk);
|
||||||
}
|
}
|
||||||
if (has_uvs) {
|
if (has_uvs) {
|
||||||
uvs.remove(remk);
|
uvs.remove(remk);
|
||||||
}
|
}
|
||||||
if (has_colors) {
|
if (has_colors) {
|
||||||
colors.remove(remk);
|
colors.remove(remk);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int j = 0; j < indices.size(); ++j) {
|
for (int j = 0; j < indices.size(); ++j) {
|
||||||
int indx = indices[j];
|
int indx = indices[j];
|
||||||
|
|
||||||
if (indx == remk) {
|
if (indx == remk) {
|
||||||
indices.set(j, i);
|
indices.set(j, i);
|
||||||
} else if (indx > remk) {
|
} else if (indx > remk) {
|
||||||
indices.set(j, indx - 1);
|
indices.set(j, indx - 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -642,13 +648,13 @@ Array PropInstancePropJob::merge_mesh_array(Array arr) const {
|
|||||||
|
|
||||||
if (has_normals) {
|
if (has_normals) {
|
||||||
arr[RenderingServer::ARRAY_NORMAL] = normals;
|
arr[RenderingServer::ARRAY_NORMAL] = normals;
|
||||||
}
|
}
|
||||||
if (has_uvs) {
|
if (has_uvs) {
|
||||||
arr[RenderingServer::ARRAY_TEX_UV] = uvs;
|
arr[RenderingServer::ARRAY_TEX_UV] = uvs;
|
||||||
}
|
}
|
||||||
if (has_colors) {
|
if (has_colors) {
|
||||||
arr[RenderingServer::ARRAY_COLOR] = colors;
|
arr[RenderingServer::ARRAY_COLOR] = colors;
|
||||||
}
|
}
|
||||||
|
|
||||||
arr[RenderingServer::ARRAY_INDEX] = indices;
|
arr[RenderingServer::ARRAY_INDEX] = indices;
|
||||||
|
|
||||||
@ -669,7 +675,7 @@ Array PropInstancePropJob::bake_mesh_array_uv(Array arr, Ref<Texture> tex, const
|
|||||||
|
|
||||||
if (colors.size() < uvs.size()) {
|
if (colors.size() < uvs.size()) {
|
||||||
colors.resize(uvs.size());
|
colors.resize(uvs.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
img->lock();
|
img->lock();
|
||||||
|
|
||||||
@ -706,7 +712,7 @@ void PropInstancePropJob::reset_meshes() {
|
|||||||
|
|
||||||
if (RS::get_singleton()->mesh_get_surface_count(mesh_rid) > 0) {
|
if (RS::get_singleton()->mesh_get_surface_count(mesh_rid) > 0) {
|
||||||
RS::get_singleton()->mesh_remove_surface(mesh_rid, 0);
|
RS::get_singleton()->mesh_remove_surface(mesh_rid, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "prop_instance_job.h"
|
#include "prop_instance_job.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class PropMesher;
|
class PropMesher;
|
||||||
class PropInstance;
|
class PropInstance;
|
||||||
class PropInstanceMerger;
|
class PropInstanceMerger;
|
||||||
@ -33,7 +35,7 @@ class Shape;
|
|||||||
class PropLight;
|
class PropLight;
|
||||||
class PropDataTiledWall;
|
class PropDataTiledWall;
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
class PropDataMeshData;
|
class PropDataMeshData;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -60,7 +62,7 @@ public:
|
|||||||
Ref<PropMesher> get_prop_mesher() const;
|
Ref<PropMesher> get_prop_mesher() const;
|
||||||
void set_prop_mesher(const Ref<PropMesher> &mesher);
|
void set_prop_mesher(const Ref<PropMesher> &mesher);
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh(const Ref<PropDataMeshData> &mesh_data, const Transform &base_transform);
|
void add_mesh(const Ref<PropDataMeshData> &mesh_data, const Transform &base_transform);
|
||||||
void clear_meshes();
|
void clear_meshes();
|
||||||
#endif
|
#endif
|
||||||
@ -99,7 +101,7 @@ protected:
|
|||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
struct PMDREntry {
|
struct PMDREntry {
|
||||||
Ref<PropDataMeshData> mesh_data;
|
Ref<PropDataMeshData> mesh_data;
|
||||||
Transform base_transform;
|
Transform base_transform;
|
||||||
@ -130,7 +132,7 @@ protected:
|
|||||||
Ref<PropMesher> _prop_mesher;
|
Ref<PropMesher> _prop_mesher;
|
||||||
PropInstanceMerger *_prop_instace;
|
PropInstanceMerger *_prop_instace;
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Vector<PMDREntry> _prop_mesh_datas;
|
Vector<PMDREntry> _prop_mesh_datas;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -743,7 +743,7 @@ Vector2 PropMesher::transform_uv_scaled(const Vector2 &uv, const Rect2 &rect, co
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void PropMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
void PropMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
||||||
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
||||||
|
|
||||||
@ -1488,7 +1488,7 @@ void PropMesher::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("transform_uv", "uv", "rect"), &PropMesher::transform_uv);
|
ClassDB::bind_method(D_METHOD("transform_uv", "uv", "rect"), &PropMesher::transform_uv);
|
||||||
ClassDB::bind_method(D_METHOD("transform_uv_scaled", "uv", "rect", "x", "y", "texture_scale"), &PropMesher::transform_uv_scaled);
|
ClassDB::bind_method(D_METHOD("transform_uv_scaled", "uv", "rect", "x", "y", "texture_scale"), &PropMesher::transform_uv_scaled);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &PropMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &PropMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &PropMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &PropMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &PropMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &PropMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
|
@ -37,7 +37,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "modules/modules_enabled.gen.h"
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ public:
|
|||||||
Vector2 transform_uv(const Vector2 &uv, const Rect2 &rect) const;
|
Vector2 transform_uv(const Vector2 &uv, const Rect2 &rect) const;
|
||||||
Vector2 transform_uv_scaled(const Vector2 &uv, const Rect2 &rect, const int x, const int y, const int texture_scale) const;
|
Vector2 transform_uv_scaled(const Vector2 &uv, const Rect2 &rect, const int x, const int y, const int texture_scale) const;
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
|
@ -31,8 +31,11 @@ SOFTWARE.
|
|||||||
#include "scene/3d/room_manager.h"
|
#include "scene/3d/room_manager.h"
|
||||||
|
|
||||||
#include "scene/3d/mesh_instance.h"
|
#include "scene/3d/mesh_instance.h"
|
||||||
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/nodes/mesh_data_instance.h"
|
#include "../../mesh_data_resource/nodes/mesh_data_instance.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -340,7 +343,7 @@ void PropUtils::get_mesh_arrays(Node *node, Vector<PoolVector<Vector3>> *arrs) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
{
|
{
|
||||||
MeshDataInstance *mdi = Object::cast_to<MeshDataInstance>(node);
|
MeshDataInstance *mdi = Object::cast_to<MeshDataInstance>(node);
|
||||||
|
|
||||||
|
@ -6,9 +6,6 @@ module_env = env.Clone()
|
|||||||
|
|
||||||
import version
|
import version
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
|
||||||
|
|
||||||
if os.path.isdir('../terraman_2d'):
|
if os.path.isdir('../terraman_2d'):
|
||||||
module_env.Append(CPPDEFINES=['TERRAMAN_2D_PRESENT'])
|
module_env.Append(CPPDEFINES=['TERRAMAN_2D_PRESENT'])
|
||||||
|
|
||||||
|
@ -28,7 +28,9 @@ SOFTWARE.
|
|||||||
#include "../singleton/prop_2d_cache.h"
|
#include "../singleton/prop_2d_cache.h"
|
||||||
#include "../tiled_wall/tiled_wall_2d_data.h"
|
#include "../tiled_wall/tiled_wall_2d_data.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
||||||
//but not when included from here.
|
//but not when included from here.
|
||||||
#define PROPS_2D_PRESENT 1
|
#define PROPS_2D_PRESENT 1
|
||||||
@ -139,7 +141,7 @@ void Prop2DMaterialCache::prop_add_textures(const Ref<Prop2DData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -180,7 +182,7 @@ void Prop2DMaterialCache::prop_remove_textures(const Ref<Prop2DData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -4,7 +4,9 @@
|
|||||||
|
|
||||||
#include "scene/3d/light.h"
|
#include "scene/3d/light.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
||||||
//but not when included from here.
|
//but not when included from here.
|
||||||
#define PROPS_2D_PRESENT 1
|
#define PROPS_2D_PRESENT 1
|
||||||
@ -193,7 +195,7 @@ void Prop2DInstance::_prop_preprocess(Transform2D transform, const Ref<Prop2DDat
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//TODO
|
//TODO
|
||||||
/*
|
/*
|
||||||
Ref<Prop2DDataMeshData> mesh_data = e;
|
Ref<Prop2DDataMeshData> mesh_data = e;
|
||||||
|
@ -21,7 +21,9 @@
|
|||||||
|
|
||||||
#include "servers/rendering_server.h"
|
#include "servers/rendering_server.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
||||||
//but not when included from here.
|
//but not when included from here.
|
||||||
#define PROPS_2D_PRESENT 1
|
#define PROPS_2D_PRESENT 1
|
||||||
@ -458,7 +460,7 @@ void Prop2DInstanceMerger::_prop_preprocess(Transform2D transform, const Ref<Pro
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> mesh_data = e;
|
Ref<Prop2DDataMeshData> mesh_data = e;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
@ -30,7 +30,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/shape.h"
|
#include "scene/resources/shape.h"
|
||||||
#include "singleton/prop_2d_cache.h"
|
#include "singleton/prop_2d_cache.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -42,7 +44,7 @@ SOFTWARE.
|
|||||||
#include "../texture_packer/texture_packer.h"
|
#include "../texture_packer/texture_packer.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
//define PROPS_PRESENT, so things compile. That module's scsub will define this too while compiling,
|
||||||
//but not when included from here.
|
//but not when included from here.
|
||||||
#define PROPS_2D_PRESENT 1
|
#define PROPS_2D_PRESENT 1
|
||||||
@ -90,7 +92,7 @@ void Prop2DInstanceProp2DJob::set_prop_mesher(const Ref<Prop2DMesher> &mesher) {
|
|||||||
_prop_mesher = mesher;
|
_prop_mesher = mesher;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void Prop2DInstanceProp2DJob::add_mesh(const Ref<Prop2DDataMeshData> &mesh_data, const Transform2D &base_transform) {
|
void Prop2DInstanceProp2DJob::add_mesh(const Ref<Prop2DDataMeshData> &mesh_data, const Transform2D &base_transform) {
|
||||||
PMDREntry e;
|
PMDREntry e;
|
||||||
e.mesh_data = mesh_data;
|
e.mesh_data = mesh_data;
|
||||||
@ -137,7 +139,7 @@ void Prop2DInstanceProp2DJob::_execute_phase() {
|
|||||||
finished();
|
finished();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
||||||
//reset_meshes();
|
//reset_meshes();
|
||||||
set_complete(true);
|
set_complete(true);
|
||||||
@ -172,8 +174,9 @@ void Prop2DInstanceProp2DJob::_reset() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_prop_tiled_wall_datas.clear();
|
_prop_tiled_wall_datas.clear();
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
_prop_mesh_datas.clear();
|
_prop_mesh_datas.clear();
|
||||||
|
#endif
|
||||||
clear_collision_shapes();
|
clear_collision_shapes();
|
||||||
|
|
||||||
set_build_phase_type(BUILD_PHASE_TYPE_PHYSICS_PROCESS);
|
set_build_phase_type(BUILD_PHASE_TYPE_PHYSICS_PROCESS);
|
||||||
@ -267,14 +270,19 @@ void Prop2DInstanceProp2DJob::phase_prop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (should_do()) {
|
if (should_do()) {
|
||||||
if (_prop_mesh_datas.size() == 0 && _prop_tiled_wall_datas.size() == 0) {
|
if (
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|
_prop_mesh_datas.size() == 0 &&
|
||||||
|
#endif
|
||||||
|
_prop_tiled_wall_datas.size() == 0
|
||||||
|
) {
|
||||||
//reset_meshes();
|
//reset_meshes();
|
||||||
reset_stages();
|
reset_stages();
|
||||||
set_complete(true); //So threadpool knows it's done
|
set_complete(true); //So threadpool knows it's done
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < _prop_mesh_datas.size(); ++i) {
|
for (int i = 0; i < _prop_mesh_datas.size(); ++i) {
|
||||||
PMDREntry &e = _prop_mesh_datas.write[i];
|
PMDREntry &e = _prop_mesh_datas.write[i];
|
||||||
|
|
||||||
|
@ -26,6 +26,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "scene/resources/shape_2d.h"
|
#include "scene/resources/shape_2d.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
class Prop2DMesher;
|
class Prop2DMesher;
|
||||||
class Prop2DInstance;
|
class Prop2DInstance;
|
||||||
class Prop2DInstanceMerger;
|
class Prop2DInstanceMerger;
|
||||||
@ -35,7 +37,7 @@ class Shape;
|
|||||||
class Prop2DLight;
|
class Prop2DLight;
|
||||||
class Prop2DDataTiledWall2D;
|
class Prop2DDataTiledWall2D;
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
class Prop2DDataMeshData;
|
class Prop2DDataMeshData;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -56,7 +58,7 @@ public:
|
|||||||
Ref<Prop2DMesher> get_prop_mesher() const;
|
Ref<Prop2DMesher> get_prop_mesher() const;
|
||||||
void set_prop_mesher(const Ref<Prop2DMesher> &mesher);
|
void set_prop_mesher(const Ref<Prop2DMesher> &mesher);
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh(const Ref<Prop2DDataMeshData> &mesh_data, const Transform2D &base_transform);
|
void add_mesh(const Ref<Prop2DDataMeshData> &mesh_data, const Transform2D &base_transform);
|
||||||
void clear_meshes();
|
void clear_meshes();
|
||||||
#endif
|
#endif
|
||||||
@ -90,7 +92,7 @@ protected:
|
|||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
struct PMDREntry {
|
struct PMDREntry {
|
||||||
Ref<Prop2DDataMeshData> mesh_data;
|
Ref<Prop2DDataMeshData> mesh_data;
|
||||||
Transform2D base_transform;
|
Transform2D base_transform;
|
||||||
@ -117,7 +119,7 @@ protected:
|
|||||||
Ref<Prop2DMesher> _prop_mesher;
|
Ref<Prop2DMesher> _prop_mesher;
|
||||||
Prop2DInstanceMerger *_prop_instace;
|
Prop2DInstanceMerger *_prop_instace;
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Vector<PMDREntry> _prop_mesh_datas;
|
Vector<PMDREntry> _prop_mesh_datas;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -29,6 +29,8 @@ SOFTWARE.
|
|||||||
#include "material_cache/prop_2d_material_cache.h"
|
#include "material_cache/prop_2d_material_cache.h"
|
||||||
#include "tiled_wall/tiled_wall_2d_data.h"
|
#include "tiled_wall/tiled_wall_2d_data.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
const String Prop2DMesher::BINDING_STRING_BUILD_FLAGS = "Use Lighting,Use AO,Use RAO,Bake Lights";
|
const String Prop2DMesher::BINDING_STRING_BUILD_FLAGS = "Use Lighting,Use AO,Use RAO,Bake Lights";
|
||||||
|
|
||||||
bool Prop2DMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
bool Prop2DMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
||||||
@ -528,7 +530,7 @@ _FORCE_INLINE_ Vector2 Prop2DMesher::transform_uv(const Vector2 &uv, const Rect2
|
|||||||
return ruv;
|
return ruv;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void Prop2DMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
void Prop2DMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
||||||
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
||||||
|
|
||||||
@ -1170,7 +1172,7 @@ void Prop2DMesher::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("add_tiled_wall_mesh_rect_simple", "x", "y", "transform", "texture_rect"), &Prop2DMesher::add_tiled_wall_mesh_rect_simple);
|
ClassDB::bind_method(D_METHOD("add_tiled_wall_mesh_rect_simple", "x", "y", "transform", "texture_rect"), &Prop2DMesher::add_tiled_wall_mesh_rect_simple);
|
||||||
ClassDB::bind_method(D_METHOD("transform_uv", "uv", "rect"), &Prop2DMesher::transform_uv);
|
ClassDB::bind_method(D_METHOD("transform_uv", "uv", "rect"), &Prop2DMesher::transform_uv);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &Prop2DMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &Prop2DMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &Prop2DMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &Prop2DMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &Prop2DMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &Prop2DMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
|
@ -35,7 +35,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../mesh_data_resource/mesh_data_resource.h"
|
#include "../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -122,7 +124,7 @@ public:
|
|||||||
void add_tiled_wall_mesh_rect_simple(const int x, const int y, const Transform2D &transform, const Rect2 &texture_uv_rect, const Vector2 &size);
|
void add_tiled_wall_mesh_rect_simple(const int x, const int y, const Transform2D &transform, const Rect2 &texture_uv_rect, const Vector2 &size);
|
||||||
Vector2 transform_uv(const Vector2 &uv, const Rect2 &rect) const;
|
Vector2 transform_uv(const Vector2 &uv, const Rect2 &rect) const;
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
|
@ -32,7 +32,9 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "scene/3d/mesh_instance.h"
|
#include "scene/3d/mesh_instance.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/nodes/mesh_data_instance.h"
|
#include "../../mesh_data_resource/nodes/mesh_data_instance.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -4,9 +4,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_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'])
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -411,7 +411,7 @@ bool TerrainLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
|||||||
bool texture_added = false;
|
bool texture_added = false;
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -33,7 +33,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -415,7 +415,7 @@ void TerrainLibraryMergerPCM::_prop_material_cache_get_key(Ref<TerrainChunk> chu
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
@ -510,7 +510,7 @@ void TerrainLibraryMergerPCM::_prop_material_cache_get_key(Ref<TerrainChunk> chu
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ SOFTWARE.
|
|||||||
#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"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -205,7 +205,7 @@ void TerrainMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -231,7 +231,7 @@ void TerrainMaterialCache::prop_remove_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -29,6 +29,8 @@ SOFTWARE.
|
|||||||
#include "../world/default/terrain_chunk_default.h"
|
#include "../world/default/terrain_chunk_default.h"
|
||||||
#include "../world/terrain_chunk.h"
|
#include "../world/terrain_chunk.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
bool TerrainMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
bool TerrainMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
||||||
if (vertex != p_vertex.vertex)
|
if (vertex != p_vertex.vertex)
|
||||||
return false;
|
return false;
|
||||||
@ -433,7 +435,7 @@ void TerrainMesher::add_chunk(Ref<TerrainChunk> chunk) {
|
|||||||
call("_add_chunk", chunk);
|
call("_add_chunk", chunk);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void TerrainMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
void TerrainMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
||||||
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
||||||
|
|
||||||
@ -992,7 +994,7 @@ void TerrainMesher::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &TerrainMesher::add_chunk);
|
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &TerrainMesher::add_chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &TerrainMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &TerrainMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &TerrainMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &TerrainMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &TerrainMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &TerrainMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
|
@ -39,7 +39,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -127,7 +129,7 @@ public:
|
|||||||
|
|
||||||
void add_chunk(Ref<TerrainChunk> chunk);
|
void add_chunk(Ref<TerrainChunk> chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
|
@ -34,7 +34,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/world_3d.h"
|
#include "scene/resources/world_3d.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -85,7 +87,7 @@ void TerrainPropJob::phase_physics_process() {
|
|||||||
|
|
||||||
chunk->colliders_clear();
|
chunk->colliders_clear();
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<MeshDataResource> mdr = chunk->mesh_data_resource_get(i);
|
Ref<MeshDataResource> mdr = chunk->mesh_data_resource_get(i);
|
||||||
|
|
||||||
@ -134,7 +136,7 @@ void TerrainPropJob::phase_physics_process() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void TerrainPropJob::phase_prop() {
|
void TerrainPropJob::phase_prop() {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<TerrainChunkDefault> chunk = _chunk;
|
Ref<TerrainChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!get_prop_mesher().is_valid()) {
|
if (!get_prop_mesher().is_valid()) {
|
||||||
@ -235,7 +237,7 @@ void TerrainPropJob::_execute_phase() {
|
|||||||
Ref<TerrainChunkDefault> chunk = _chunk;
|
Ref<TerrainChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!chunk.is_valid()
|
if (!chunk.is_valid()
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|| chunk->mesh_data_resource_get_count() == 0
|
|| chunk->mesh_data_resource_get_count() == 0
|
||||||
#endif
|
#endif
|
||||||
) {
|
) {
|
||||||
@ -302,7 +304,7 @@ void TerrainPropJob::phase_setup() {
|
|||||||
OS::get_singleton()->delay_usec(100);
|
OS::get_singleton()->delay_usec(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
|
@ -736,7 +736,7 @@ void TerrainChunk::props_clear() {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int TerrainChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
int TerrainChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
||||||
ERR_FAIL_COND_V(!mesh.is_valid(), 0);
|
ERR_FAIL_COND_V(!mesh.is_valid(), 0);
|
||||||
|
|
||||||
@ -1097,7 +1097,7 @@ TerrainChunk::~TerrainChunk() {
|
|||||||
props_clear();
|
props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
mesh_data_resource_clear();
|
mesh_data_resource_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1470,7 +1470,7 @@ void TerrainChunk::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("props_clear"), &TerrainChunk::props_clear);
|
ClassDB::bind_method(D_METHOD("props_clear"), &TerrainChunk::props_clear);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &TerrainChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &TerrainChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &TerrainChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &TerrainChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
|
|
||||||
|
@ -226,7 +226,7 @@ public:
|
|||||||
void props_clear();
|
void props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
int mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
||||||
int mesh_data_resource_add(const Transform &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
int mesh_data_resource_add(const Transform &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
||||||
|
|
||||||
@ -310,7 +310,7 @@ protected:
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
struct MeshDataResourceEntry {
|
struct MeshDataResourceEntry {
|
||||||
Ref<MeshDataResource> mesh;
|
Ref<MeshDataResource> mesh;
|
||||||
Ref<Texture> texture;
|
Ref<Texture> texture;
|
||||||
@ -389,7 +389,7 @@ protected:
|
|||||||
Vector<PropDataStore> _props;
|
Vector<PropDataStore> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ SOFTWARE.
|
|||||||
#include "../../props/props/prop_data_scene.h"
|
#include "../../props/props/prop_data_scene.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -656,7 +656,7 @@ void TerrainWorld::prop_add(Transform transform, const Ref<PropData> &prop, cons
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> mesh_data = entry;
|
Ref<PropDataMeshData> mesh_data = entry;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
@ -4,9 +4,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
|
||||||
|
|
||||||
if os.path.isdir('../props_2d'):
|
if os.path.isdir('../props_2d'):
|
||||||
module_env.Append(CPPDEFINES=['PROPS_2D_PRESENT'])
|
module_env.Append(CPPDEFINES=['PROPS_2D_PRESENT'])
|
||||||
|
|
||||||
|
@ -25,12 +25,14 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#ifdef PROPS_2D_PRESENT
|
#ifdef PROPS_2D_PRESENT
|
||||||
#include "../../props_2d/props/prop_2d_data.h"
|
#include "../../props_2d/props/prop_2d_data.h"
|
||||||
|
|
||||||
#include "../../props_2d/props/prop_2d_data_prop.h"
|
#include "../../props_2d/props/prop_2d_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -363,7 +365,7 @@ bool Terrain2DLibraryMerger::process_prop_textures(Ref<Prop2DData> prop) {
|
|||||||
bool texture_added = false;
|
bool texture_added = false;
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -26,12 +26,14 @@ SOFTWARE.
|
|||||||
#include "scene/resources/packed_scene.h"
|
#include "scene/resources/packed_scene.h"
|
||||||
#include "scene/resources/texture.h"
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#ifdef PROPS_2D_PRESENT
|
#ifdef PROPS_2D_PRESENT
|
||||||
#include "../../props_2d/props/prop_2d_data.h"
|
#include "../../props_2d/props/prop_2d_data.h"
|
||||||
|
|
||||||
#include "../../props_2d/props/prop_2d_data_prop.h"
|
#include "../../props_2d/props/prop_2d_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -260,7 +262,7 @@ void Terrain2DLibraryMergerPCM::_prop_material_cache_get_key(Ref<Terrain2DChunk>
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
@ -349,7 +351,7 @@ void Terrain2DLibraryMergerPCM::_prop_material_cache_get_key(Ref<Terrain2DChunk>
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
|
@ -24,11 +24,13 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#ifdef PROPS_2D_PRESENT
|
#ifdef PROPS_2D_PRESENT
|
||||||
#include "../../props_2d/props/prop_2d_data.h"
|
#include "../../props_2d/props/prop_2d_data.h"
|
||||||
#include "../../props_2d/props/prop_2d_data_prop.h"
|
#include "../../props_2d/props/prop_2d_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -166,7 +168,7 @@ void Terrain2DMaterialCache::prop_add_textures(const Ref<Prop2DData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -192,7 +194,7 @@ void Terrain2DMaterialCache::prop_remove_textures(const Ref<Prop2DData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
Ref<Prop2DDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -31,6 +31,8 @@ SOFTWARE.
|
|||||||
#include "scene/resources/rectangle_shape_2d.h"
|
#include "scene/resources/rectangle_shape_2d.h"
|
||||||
#include "servers/physics_2d_server.h"
|
#include "servers/physics_2d_server.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
bool Terrain2DMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
bool Terrain2DMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
||||||
if (vertex != p_vertex.vertex)
|
if (vertex != p_vertex.vertex)
|
||||||
return false;
|
return false;
|
||||||
@ -482,7 +484,7 @@ void Terrain2DMesher::add_chunk(Ref<Terrain2DChunk> chunk) {
|
|||||||
call("_add_chunk", chunk);
|
call("_add_chunk", chunk);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void Terrain2DMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
void Terrain2DMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
||||||
//Transform2D transform = Transform(Basis(rotation).scaled(scale), position);
|
//Transform2D transform = Transform(Basis(rotation).scaled(scale), position);
|
||||||
//TODO
|
//TODO
|
||||||
@ -935,7 +937,7 @@ void Terrain2DMesher::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &Terrain2DMesher::add_chunk);
|
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &Terrain2DMesher::add_chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &Terrain2DMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
|
@ -38,7 +38,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -118,7 +120,7 @@ public:
|
|||||||
|
|
||||||
void add_chunk(Ref<Terrain2DChunk> chunk);
|
void add_chunk(Ref<Terrain2DChunk> chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform2D transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform2D transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform2D transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform2D transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
|
@ -32,7 +32,9 @@ SOFTWARE.
|
|||||||
#include "../../meshers/terrain_2d_mesher.h"
|
#include "../../meshers/terrain_2d_mesher.h"
|
||||||
#include "../default/terrain_2d_chunk_default.h"
|
#include "../default/terrain_2d_chunk_default.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -62,7 +64,7 @@ void Terrain2DProp2DJob::phase_physics_process() {
|
|||||||
|
|
||||||
chunk->colliders_clear();
|
chunk->colliders_clear();
|
||||||
*/
|
*/
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
//TODO
|
//TODO
|
||||||
/*
|
/*
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
@ -114,7 +116,7 @@ void Terrain2DProp2DJob::phase_physics_process() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Terrain2DProp2DJob::phase_prop() {
|
void Terrain2DProp2DJob::phase_prop() {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Terrain2DChunkDefault> chunk = _chunk;
|
Ref<Terrain2DChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!get_prop_mesher().is_valid()) {
|
if (!get_prop_mesher().is_valid()) {
|
||||||
@ -218,7 +220,7 @@ void Terrain2DProp2DJob::_execute_phase() {
|
|||||||
Ref<Terrain2DChunkDefault> chunk = _chunk;
|
Ref<Terrain2DChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!chunk.is_valid()
|
if (!chunk.is_valid()
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|| chunk->mesh_data_resource_get_count() == 0
|
|| chunk->mesh_data_resource_get_count() == 0
|
||||||
#endif
|
#endif
|
||||||
) {
|
) {
|
||||||
@ -282,7 +284,7 @@ void Terrain2DProp2DJob::phase_setup() {
|
|||||||
OS::get_singleton()->delay_usec(100);
|
OS::get_singleton()->delay_usec(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
|
@ -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 Terrain2DChunk::get_process() const {
|
_FORCE_INLINE_ bool Terrain2DChunk::get_process() const {
|
||||||
return _is_processing;
|
return _is_processing;
|
||||||
}
|
}
|
||||||
@ -770,7 +772,7 @@ void Terrain2DChunk::props_clear() {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int Terrain2DChunk::mesh_data_resource_addv(const Vector2 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
int Terrain2DChunk::mesh_data_resource_addv(const Vector2 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
||||||
//TODO
|
//TODO
|
||||||
/*
|
/*
|
||||||
@ -1173,7 +1175,7 @@ Terrain2DChunk::~Terrain2DChunk() {
|
|||||||
props_clear();
|
props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
mesh_data_resource_clear();
|
mesh_data_resource_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1590,7 +1592,7 @@ void Terrain2DChunk::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("props_clear"), &Terrain2DChunk::props_clear);
|
ClassDB::bind_method(D_METHOD("props_clear"), &Terrain2DChunk::props_clear);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &Terrain2DChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &Terrain2DChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &Terrain2DChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &Terrain2DChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
|
|
||||||
|
@ -43,6 +43,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../meshers/terrain_2d_mesher.h"
|
#include "../meshers/terrain_2d_mesher.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#if PROPS_2D_PRESENT
|
#if PROPS_2D_PRESENT
|
||||||
#include "../../props_2d/props/prop_2d_data.h"
|
#include "../../props_2d/props/prop_2d_data.h"
|
||||||
#endif
|
#endif
|
||||||
@ -267,7 +269,7 @@ public:
|
|||||||
void props_clear();
|
void props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int mesh_data_resource_addv(const Vector2 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_scale = true);
|
int mesh_data_resource_addv(const Vector2 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_scale = true);
|
||||||
int mesh_data_resource_add(const Transform2D &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_scale = true);
|
int mesh_data_resource_add(const Transform2D &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_scale = true);
|
||||||
|
|
||||||
@ -364,7 +366,7 @@ protected:
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
struct MeshDataResourceEntry {
|
struct MeshDataResourceEntry {
|
||||||
Ref<MeshDataResource> mesh;
|
Ref<MeshDataResource> mesh;
|
||||||
Ref<Texture> texture;
|
Ref<Texture> texture;
|
||||||
@ -442,7 +444,7 @@ protected:
|
|||||||
Vector<Prop2DDataStore> _props;
|
Vector<Prop2DDataStore> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -28,6 +28,8 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../defines.h"
|
#include "../defines.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
#if PROPS_2D_PRESENT
|
#if PROPS_2D_PRESENT
|
||||||
#include "../../props_2d/props/prop_2d_data.h"
|
#include "../../props_2d/props/prop_2d_data.h"
|
||||||
#include "../../props_2d/props/prop_2d_data_entry.h"
|
#include "../../props_2d/props/prop_2d_data_entry.h"
|
||||||
@ -36,7 +38,7 @@ SOFTWARE.
|
|||||||
#include "../../props_2d/props/prop_2d_data_scene.h"
|
#include "../../props_2d/props/prop_2d_data_scene.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
#include "../../mesh_data_resource/props_2d/prop_2d_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -709,7 +711,7 @@ void Terrain2DWorld::prop_add(Transform transform, const Ref<Prop2DData> &prop,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<Prop2DDataMeshData> mesh_data = entry;
|
Ref<Prop2DDataMeshData> mesh_data = entry;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
@ -4,9 +4,6 @@ Import('env')
|
|||||||
|
|
||||||
module_env = env.Clone()
|
module_env = env.Clone()
|
||||||
|
|
||||||
if os.path.isdir('../mesh_data_resource'):
|
|
||||||
module_env.Append(CPPDEFINES=['MESH_DATA_RESOURCE_PRESENT'])
|
|
||||||
|
|
||||||
if os.path.isdir('../props'):
|
if os.path.isdir('../props'):
|
||||||
module_env.Append(CPPDEFINES=['PROPS_PRESENT'])
|
module_env.Append(CPPDEFINES=['PROPS_PRESENT'])
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ SOFTWARE.
|
|||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -410,6 +410,7 @@ bool VoxelLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
|||||||
|
|
||||||
bool texture_added = false;
|
bool texture_added = false;
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
@ -432,6 +433,7 @@ bool VoxelLibraryMerger::process_prop_textures(Ref<PropData> prop) {
|
|||||||
texture_added = true;
|
texture_added = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return texture_added;
|
return texture_added;
|
||||||
}
|
}
|
||||||
|
@ -33,7 +33,7 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../../props/props/prop_data_prop.h"
|
#include "../../props/props/prop_data_prop.h"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -235,7 +235,7 @@ void VoxelLibraryMergerPCM::_prop_material_cache_get_key(Ref<VoxelChunk> chunk)
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
@ -330,7 +330,7 @@ void VoxelLibraryMergerPCM::_prop_material_cache_get_key(Ref<VoxelChunk> chunk)
|
|||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
@ -753,6 +753,7 @@ bool VoxelLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
|||||||
|
|
||||||
bool texture_added = false;
|
bool texture_added = false;
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
@ -775,6 +776,7 @@ bool VoxelLibraryMergerPCM::process_prop_textures(Ref<PropData> prop) {
|
|||||||
texture_added = true;
|
texture_added = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return texture_added;
|
return texture_added;
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ SOFTWARE.
|
|||||||
#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"
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@ -205,7 +205,7 @@ void VoxelMaterialCache::prop_add_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
@ -231,7 +231,7 @@ void VoxelMaterialCache::prop_remove_textures(const Ref<PropData> &prop) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
for (int i = 0; i < prop->get_prop_count(); ++i) {
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
Ref<PropDataMeshData> pdm = prop->get_prop(i);
|
||||||
|
|
||||||
if (pdm.is_valid()) {
|
if (pdm.is_valid()) {
|
||||||
|
@ -29,6 +29,8 @@ SOFTWARE.
|
|||||||
#include "../world/default/voxel_chunk_default.h"
|
#include "../world/default/voxel_chunk_default.h"
|
||||||
#include "../world/voxel_chunk.h"
|
#include "../world/voxel_chunk.h"
|
||||||
|
|
||||||
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
bool VoxelMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
bool VoxelMesher::Vertex::operator==(const Vertex &p_vertex) const {
|
||||||
if (vertex != p_vertex.vertex)
|
if (vertex != p_vertex.vertex)
|
||||||
return false;
|
return false;
|
||||||
@ -429,7 +431,7 @@ void VoxelMesher::add_chunk(Ref<VoxelChunk> chunk) {
|
|||||||
call("_add_chunk", chunk);
|
call("_add_chunk", chunk);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void VoxelMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
void VoxelMesher::add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position, const Vector3 rotation, const Vector3 scale, const Rect2 uv_rect) {
|
||||||
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
Transform transform = Transform(Basis(rotation).scaled(scale), position);
|
||||||
|
|
||||||
@ -981,7 +983,7 @@ void VoxelMesher::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &VoxelMesher::add_chunk);
|
ClassDB::bind_method(D_METHOD("add_chunk", "chunk"), &VoxelMesher::add_chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &VoxelMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource", "mesh", "position", "rotation", "scale", "uv_rect"), &VoxelMesher::add_mesh_data_resource, DEFVAL(Rect2(0, 0, 1, 1)), DEFVAL(Vector3(1.0, 1.0, 1.0)), DEFVAL(Vector3()), DEFVAL(Vector3()));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &VoxelMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform", "mesh", "transform", "uv_rect"), &VoxelMesher::add_mesh_data_resource_transform, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &VoxelMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
ClassDB::bind_method(D_METHOD("add_mesh_data_resource_transform_colored", "mesh", "transform", "colors", "uv_rect"), &VoxelMesher::add_mesh_data_resource_transform_colored, DEFVAL(Rect2(0, 0, 1, 1)));
|
||||||
|
@ -37,7 +37,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/material.h"
|
#include "scene/resources/material.h"
|
||||||
#include "scene/resources/mesh.h"
|
#include "scene/resources/mesh.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -123,7 +125,7 @@ public:
|
|||||||
|
|
||||||
void add_chunk(Ref<VoxelChunk> chunk);
|
void add_chunk(Ref<VoxelChunk> chunk);
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource(Ref<MeshDataResource> mesh, const Vector3 position = Vector3(0, 0, 0), const Vector3 rotation = Vector3(0, 0, 0), const Vector3 scale = Vector3(1.0, 1.0, 1.0), const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform(Ref<MeshDataResource> mesh, const Transform transform, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
void add_mesh_data_resource_transform_colored(Ref<MeshDataResource> mesh, const Transform transform, const PoolColorArray &colors, const Rect2 uv_rect = Rect2(0, 0, 1, 1));
|
||||||
|
@ -35,7 +35,9 @@ SOFTWARE.
|
|||||||
#include "scene/resources/world_3d.h"
|
#include "scene/resources/world_3d.h"
|
||||||
#include "servers/physics_server.h"
|
#include "servers/physics_server.h"
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#include "modules/modules_enabled.gen.h"
|
||||||
|
|
||||||
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
#include "../../../mesh_data_resource/mesh_data_resource.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -86,7 +88,7 @@ void VoxelPropJob::phase_physics_process() {
|
|||||||
|
|
||||||
chunk->colliders_clear();
|
chunk->colliders_clear();
|
||||||
|
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<MeshDataResource> mdr = chunk->mesh_data_resource_get(i);
|
Ref<MeshDataResource> mdr = chunk->mesh_data_resource_get(i);
|
||||||
|
|
||||||
@ -135,7 +137,7 @@ void VoxelPropJob::phase_physics_process() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void VoxelPropJob::phase_prop() {
|
void VoxelPropJob::phase_prop() {
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<VoxelChunkDefault> chunk = _chunk;
|
Ref<VoxelChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!get_prop_mesher().is_valid()) {
|
if (!get_prop_mesher().is_valid()) {
|
||||||
@ -236,7 +238,7 @@ void VoxelPropJob::_execute_phase() {
|
|||||||
Ref<VoxelChunkDefault> chunk = _chunk;
|
Ref<VoxelChunkDefault> chunk = _chunk;
|
||||||
|
|
||||||
if (!chunk.is_valid()
|
if (!chunk.is_valid()
|
||||||
#ifdef MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
|| chunk->mesh_data_resource_get_count() == 0
|
|| chunk->mesh_data_resource_get_count() == 0
|
||||||
#endif
|
#endif
|
||||||
) {
|
) {
|
||||||
@ -303,7 +305,7 @@ void VoxelPropJob::phase_setup() {
|
|||||||
OS::get_singleton()->delay_usec(100);
|
OS::get_singleton()->delay_usec(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
for (int i = 0; i < _chunk->mesh_data_resource_get_count(); ++i) {
|
||||||
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
Ref<Texture> tex = _chunk->mesh_data_resource_get_texture(i);
|
||||||
|
|
||||||
|
@ -733,7 +733,7 @@ void VoxelChunk::props_clear() {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int VoxelChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
int VoxelChunk::mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture, const Color &color, const bool apply_voxel_scale) {
|
||||||
ERR_FAIL_COND_V(!mesh.is_valid(), 0);
|
ERR_FAIL_COND_V(!mesh.is_valid(), 0);
|
||||||
|
|
||||||
@ -1093,7 +1093,7 @@ VoxelChunk::~VoxelChunk() {
|
|||||||
props_clear();
|
props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
mesh_data_resource_clear();
|
mesh_data_resource_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1458,7 +1458,7 @@ void VoxelChunk::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("props_clear"), &VoxelChunk::props_clear);
|
ClassDB::bind_method(D_METHOD("props_clear"), &VoxelChunk::props_clear);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &VoxelChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_addv", "local_data_pos", "mesh", "texture", "color", "apply_voxel_scale"), &VoxelChunk::mesh_data_resource_addv, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &VoxelChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
ClassDB::bind_method(D_METHOD("mesh_data_resource_add", "local_transform", "mesh", "texture", "color", "apply_voxel_scale"), &VoxelChunk::mesh_data_resource_add, DEFVAL(Ref<Texture>()), DEFVAL(Color(1, 1, 1, 1)), DEFVAL(true));
|
||||||
|
|
||||||
|
@ -233,7 +233,7 @@ public:
|
|||||||
void props_clear();
|
void props_clear();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
int mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
int mesh_data_resource_addv(const Vector3 &local_data_pos, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
||||||
int mesh_data_resource_add(const Transform &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
int mesh_data_resource_add(const Transform &local_transform, const Ref<MeshDataResource> &mesh, const Ref<Texture> &texture = Ref<Texture>(), const Color &color = Color(1, 1, 1, 1), const bool apply_voxel_scale = true);
|
||||||
|
|
||||||
@ -315,7 +315,7 @@ protected:
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
struct MeshDataResourceEntry {
|
struct MeshDataResourceEntry {
|
||||||
Ref<MeshDataResource> mesh;
|
Ref<MeshDataResource> mesh;
|
||||||
Ref<Texture> texture;
|
Ref<Texture> texture;
|
||||||
@ -397,7 +397,7 @@ protected:
|
|||||||
Vector<PropDataStore> _props;
|
Vector<PropDataStore> _props;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
Vector<MeshDataResourceEntry> _mesh_data_resources;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ SOFTWARE.
|
|||||||
#include "../../props/props/prop_data_scene.h"
|
#include "../../props/props/prop_data_scene.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
#include "../../mesh_data_resource/props/prop_data_mesh_data.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -620,7 +620,7 @@ void VoxelWorld::prop_add(Transform tarnsform, const Ref<PropData> &prop, const
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MESH_DATA_RESOURCE_PRESENT
|
#ifdef MODULE_MESH_DATA_RESOURCE_ENABLED
|
||||||
Ref<PropDataMeshData> mesh_data = entry;
|
Ref<PropDataMeshData> mesh_data = entry;
|
||||||
|
|
||||||
if (mesh_data.is_valid()) {
|
if (mesh_data.is_valid()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user