2024-09-08 13:28:45 +02:00
|
|
|
#ifndef PROCEDURAL_TREE_3D_MESH_H
|
|
|
|
#define PROCEDURAL_TREE_3D_MESH_H
|
2024-09-08 10:19:20 +02:00
|
|
|
|
2024-09-08 16:52:38 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* procedural_tree_mesh.h */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* PANDEMONIUM ENGINE */
|
|
|
|
/* https://github.com/Relintai/pandemonium_engine */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* Copyright (c) 2022-present Péter Magyar. */
|
|
|
|
/* Copyright (c) 2014-2022 Godot Engine contributors (cf. AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2022 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/*************************************************************************/
|
|
|
|
|
2024-09-08 13:28:45 +02:00
|
|
|
#include "scene/resources/mesh/mesh.h"
|
2024-09-08 10:19:20 +02:00
|
|
|
|
2024-09-08 13:31:27 +02:00
|
|
|
class ProceduralTreeMesh : public Mesh {
|
|
|
|
GDCLASS(ProceduralTreeMesh, Mesh);
|
2024-09-08 10:19:20 +02:00
|
|
|
|
2024-09-08 14:25:06 +02:00
|
|
|
public:
|
|
|
|
// General
|
|
|
|
int get_seed() const;
|
|
|
|
void set_seed(const int p_value);
|
|
|
|
|
|
|
|
int get_branch_segments() const;
|
|
|
|
void set_branch_segments(const int p_value);
|
|
|
|
|
|
|
|
int get_branch_levels() const;
|
|
|
|
void set_branch_levels(const int p_value);
|
|
|
|
|
|
|
|
int get_trunk_forks() const;
|
|
|
|
void set_trunk_forks(const int p_value);
|
|
|
|
|
|
|
|
float get_texture_v_multiplier() const;
|
|
|
|
void set_texture_v_multiplier(const float p_value);
|
|
|
|
|
|
|
|
float get_twig_scale() const;
|
|
|
|
void set_twig_scale(const float p_value);
|
|
|
|
|
|
|
|
// Branching
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_initial_length() const;
|
|
|
|
void branching_set_initial_length(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_length_falloff_rate() const;
|
|
|
|
void branching_set_length_falloff_rate(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_length_falloff_power() const;
|
|
|
|
void branching_set_length_falloff_power(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_max_clumping() const;
|
|
|
|
void branching_set_max_clumping(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_min_clumping() const;
|
|
|
|
void branching_set_min_clumping(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_symmetry() const;
|
|
|
|
void branching_set_symmetry(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_droop() const;
|
|
|
|
void branching_set_droop(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_growth() const;
|
|
|
|
void branching_set_growth(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float branching_get_sweep() const;
|
|
|
|
void branching_set_sweep(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
|
|
|
// Trunk
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_radius() const;
|
|
|
|
void trunk_set_radius(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_radius_falloff() const;
|
|
|
|
void trunk_set_radius_falloff(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_climb_rate() const;
|
|
|
|
void trunk_set_climb_rate(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_kink() const;
|
|
|
|
void trunk_set_kink(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_taper_rate() const;
|
|
|
|
void trunk_set_taper_rate(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_twists() const;
|
|
|
|
void trunk_set_twists(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 14:36:59 +02:00
|
|
|
float trunk_get_length() const;
|
|
|
|
void trunk_set_length(const float p_value);
|
2024-09-08 14:25:06 +02:00
|
|
|
|
2024-09-08 16:03:54 +02:00
|
|
|
// Meshes
|
|
|
|
bool get_enable_branch_mesh() const;
|
|
|
|
void set_enable_branch_mesh(const bool p_value);
|
|
|
|
|
|
|
|
bool get_enable_twig_mesh() const;
|
|
|
|
void set_enable_twig_mesh(const bool p_value);
|
|
|
|
|
2024-09-08 16:26:35 +02:00
|
|
|
bool get_flip_branch_mesh_faces() const;
|
|
|
|
void set_flip_branch_mesh_faces(const bool p_value);
|
|
|
|
|
|
|
|
bool get_flip_twig_mesh_faces() const;
|
|
|
|
void set_flip_twig_mesh_faces(const bool p_value);
|
|
|
|
|
2024-09-08 10:19:20 +02:00
|
|
|
public:
|
2024-09-08 13:28:45 +02:00
|
|
|
enum TreeSurfaces {
|
2024-09-08 14:25:06 +02:00
|
|
|
TREE_SURFACE_TWIG = 0,
|
|
|
|
TREE_SURFACE_TRUNK = 1,
|
2024-09-08 13:28:45 +02:00
|
|
|
TREE_SURFACE_COUNT,
|
|
|
|
};
|
2024-09-08 10:19:20 +02:00
|
|
|
|
2024-09-08 13:28:45 +02:00
|
|
|
virtual int get_surface_count() const;
|
|
|
|
virtual int surface_get_array_len(int p_idx) const;
|
|
|
|
virtual int surface_get_array_index_len(int p_idx) const;
|
|
|
|
virtual Array surface_get_arrays(int p_surface) const;
|
|
|
|
virtual Array surface_get_blend_shape_arrays(int p_surface) const;
|
|
|
|
virtual uint32_t surface_get_format(int p_idx) const;
|
|
|
|
virtual Mesh::PrimitiveType surface_get_primitive_type(int p_idx) const;
|
|
|
|
virtual void surface_set_material(int p_idx, const Ref<Material> &p_material);
|
|
|
|
virtual Ref<Material> surface_get_material(int p_idx) const;
|
|
|
|
virtual int get_blend_shape_count() const;
|
|
|
|
virtual StringName get_blend_shape_name(int p_index) const;
|
|
|
|
virtual void set_blend_shape_name(int p_index, const StringName &p_name);
|
|
|
|
virtual AABB get_aabb() const;
|
|
|
|
virtual RID get_rid() const;
|
|
|
|
|
|
|
|
void set_twig_material(const Ref<Material> &p_material);
|
|
|
|
Ref<Material> get_twig_material() const;
|
|
|
|
|
2024-09-08 14:25:06 +02:00
|
|
|
void set_trunk_material(const Ref<Material> &p_material);
|
|
|
|
Ref<Material> get_trunk_material() const;
|
|
|
|
|
2024-09-08 13:28:45 +02:00
|
|
|
void set_custom_aabb(const AABB &p_custom);
|
|
|
|
AABB get_custom_aabb() const;
|
|
|
|
|
2024-09-08 16:37:04 +02:00
|
|
|
Array get_mesh_arrays() const;
|
|
|
|
Ref<ArrayMesh> to_array_mesh() const;
|
|
|
|
|
2024-09-08 13:31:27 +02:00
|
|
|
ProceduralTreeMesh();
|
|
|
|
~ProceduralTreeMesh();
|
2024-09-08 10:19:20 +02:00
|
|
|
|
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
2024-09-08 13:28:45 +02:00
|
|
|
|
|
|
|
void _request_update();
|
|
|
|
|
2024-09-08 14:25:06 +02:00
|
|
|
private:
|
|
|
|
// General
|
|
|
|
int _seed; //mProperties.mSeed
|
|
|
|
int _branch_segments; //mProperties.mSegments
|
|
|
|
int _branch_levels; //mProperties.mLevels
|
|
|
|
int _trunk_forks; //mProperties.mTreeSteps
|
|
|
|
float _texture_v_multiplier; //mProperties.mVMultiplier
|
|
|
|
float _twig_scale; //mProperties.mTwigScale
|
|
|
|
|
|
|
|
// Branching
|
2024-09-08 14:36:59 +02:00
|
|
|
float _branching_initial_length; //mProperties.mInitialBranchLength
|
|
|
|
float _branching_length_falloff_rate; //mProperties.mLengthFalloffFactor
|
|
|
|
float _branching_length_falloff_power; //mProperties.mLengthFalloffPower
|
|
|
|
float _branching_max_clumping; //mProperties.mClumpMax
|
|
|
|
float _branching_min_clumping; //mProperties.mClumpMin
|
|
|
|
float _branching_symmetry; //mProperties.mBranchFactor
|
|
|
|
float _branching_droop; //mProperties.mDropAmount
|
|
|
|
float _branching_growth; //mProperties.mGrowAmount
|
|
|
|
float _branching_sweep; //mProperties.mSweepAmount
|
2024-09-08 14:25:06 +02:00
|
|
|
|
|
|
|
// Trunk
|
|
|
|
float _trunk_radius; //mProperties.mMaxRadius
|
2024-09-08 14:36:59 +02:00
|
|
|
float _trunk_radius_falloff; //mProperties.mRadiusFalloffRate
|
|
|
|
float _trunk_climb_rate; //mProperties.mClimbRate
|
|
|
|
float _trunk_kink; //mProperties.mTrunkKink
|
|
|
|
float _trunk_taper_rate; //mProperties.mTaperRate
|
|
|
|
float _trunk_twists; //mProperties.mTwistRate
|
2024-09-08 14:25:06 +02:00
|
|
|
float _trunk_length; //mProperties.mTrunkLength
|
|
|
|
|
2024-09-08 16:03:54 +02:00
|
|
|
// Meshes
|
|
|
|
bool _enable_branch_mesh;
|
|
|
|
bool _enable_twig_mesh;
|
|
|
|
|
2024-09-08 16:26:35 +02:00
|
|
|
bool _flip_branch_mesh_faces;
|
|
|
|
bool _flip_twig_mesh_faces;
|
|
|
|
|
2024-09-08 13:28:45 +02:00
|
|
|
private:
|
|
|
|
RID mesh;
|
|
|
|
|
|
|
|
struct TreeSurface {
|
2024-09-08 16:03:54 +02:00
|
|
|
int surface_index;
|
2024-09-08 13:28:45 +02:00
|
|
|
Ref<Material> material;
|
2024-09-08 16:03:54 +02:00
|
|
|
|
|
|
|
TreeSurface() {
|
|
|
|
surface_index = -1;
|
|
|
|
}
|
2024-09-08 13:28:45 +02:00
|
|
|
};
|
|
|
|
|
2024-09-08 16:03:54 +02:00
|
|
|
mutable TreeSurface _surfaces[TREE_SURFACE_COUNT];
|
2024-09-08 13:28:45 +02:00
|
|
|
|
|
|
|
mutable AABB aabb;
|
|
|
|
AABB custom_aabb;
|
|
|
|
|
|
|
|
mutable bool pending_request;
|
|
|
|
void _update() const;
|
2024-09-08 10:19:20 +02:00
|
|
|
};
|
|
|
|
|
2024-09-08 13:31:27 +02:00
|
|
|
VARIANT_ENUM_CAST(ProceduralTreeMesh::TreeSurfaces);
|
2024-09-08 13:28:45 +02:00
|
|
|
|
2024-09-08 10:19:20 +02:00
|
|
|
#endif
|