pandemonium_engine/modules/procedural_tree_3d/procedural_tree_mesh.h

225 lines
7.7 KiB
C++
Raw Normal View History

2024-09-08 13:28:45 +02:00
#ifndef PROCEDURAL_TREE_3D_MESH_H
#define PROCEDURAL_TREE_3D_MESH_H
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"
class ProceduralTreeMesh : public Mesh {
GDCLASS(ProceduralTreeMesh, Mesh);
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
// 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);
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);
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 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;
Array get_mesh_arrays() const;
Ref<ArrayMesh> to_array_mesh() const;
ProceduralTreeMesh();
~ProceduralTreeMesh();
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
// Meshes
bool _enable_branch_mesh;
bool _enable_twig_mesh;
bool _flip_branch_mesh_faces;
bool _flip_twig_mesh_faces;
2024-09-08 13:28:45 +02:00
private:
RID mesh;
struct TreeSurface {
int surface_index;
2024-09-08 13:28:45 +02:00
Ref<Material> material;
TreeSurface() {
surface_index = -1;
}
2024-09-08 13:28:45 +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;
};
VARIANT_ENUM_CAST(ProceduralTreeMesh::TreeSurfaces);
2024-09-08 13:28:45 +02:00
#endif