mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-18 07:17:18 +01:00
149 lines
7.7 KiB
C++
149 lines
7.7 KiB
C++
/*************************************************************************/
|
|
/* noise.cpp */
|
|
/*************************************************************************/
|
|
/* 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. */
|
|
/*************************************************************************/
|
|
|
|
#include "noise.h"
|
|
|
|
const String FastNoise::BINDING_STRING_TYPE = "Value,Value Fractal,Perlin,Perlin Fractal,Simplex,Simplex Fractal,Cellular,White Noise,Cubic,Cubic Fractal";
|
|
const String FastNoise::BINDING_STRING_INTERPOLATION = "Linear,Quintic,Hermite";
|
|
const String FastNoise::BINDING_STRING_FRACTAL_TYPE = "FBM,Billow,Rigid Multi";
|
|
const String FastNoise::BINDING_STRING_CELLULAR_DISTANCE_FUNCTION = "Euclidean,Manhattan,Naural";
|
|
const String FastNoise::BINDING_STRING_CELLULAR_RETURN_TYPE = "Cell Value,Noise lookup,Distance,Distance 2,Distance 2 Add,Distance 2 Sub,Distance 2 Mul,Distance 2 Div";
|
|
|
|
FastNoise::FastNoise() :
|
|
Reference() {
|
|
}
|
|
|
|
void FastNoise::set_cellular_noise_lookup(Ref<FastNoise> other_noise) {
|
|
_cellular_lookup_ref = other_noise;
|
|
|
|
if (_cellular_lookup_ref.is_null())
|
|
_noise.SetCellularNoiseLookup(NULL);
|
|
else
|
|
_noise.SetCellularNoiseLookup(&_cellular_lookup_ref->_noise);
|
|
}
|
|
|
|
void FastNoise::set_cellular_distance_2_indices(int index0, int index1) {
|
|
_noise.SetCellularDistance2Indices(index0, index1);
|
|
}
|
|
|
|
PoolIntArray FastNoise::get_cellular_distance_2_indices() const {
|
|
int i0, i1;
|
|
_noise.GetCellularDistance2Indices(i0, i1);
|
|
PoolIntArray a;
|
|
a.append(i0);
|
|
a.append(i1);
|
|
return a;
|
|
}
|
|
|
|
void FastNoise::_bind_methods() {
|
|
ClassDB::bind_method(D_METHOD("set_seed", "seed"), &FastNoise::set_seed);
|
|
ClassDB::bind_method(D_METHOD("get_seed"), &FastNoise::get_seed);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_noise_type", "type"), &FastNoise::set_noise_type);
|
|
ClassDB::bind_method(D_METHOD("get_noise_type"), &FastNoise::get_noise_type);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_interpolation", "interp"), &FastNoise::set_interpolation);
|
|
ClassDB::bind_method(D_METHOD("get_interpolation"), &FastNoise::get_interpolation);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_frequency", "freq"), &FastNoise::set_frequency);
|
|
ClassDB::bind_method(D_METHOD("get_frequency"), &FastNoise::get_frequency);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_fractal_gain", "gain"), &FastNoise::set_fractal_gain);
|
|
ClassDB::bind_method(D_METHOD("get_fractal_gain"), &FastNoise::get_fractal_gain);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_fractal_type", "type"), &FastNoise::set_fractal_type);
|
|
ClassDB::bind_method(D_METHOD("get_fractal_type"), &FastNoise::get_fractal_type);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_fractal_octaves", "octave_count"), &FastNoise::set_fractal_octaves);
|
|
ClassDB::bind_method(D_METHOD("get_fractal_octaves"), &FastNoise::get_fractal_octaves);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_fractal_lacunarity", "lacunarity"), &FastNoise::set_fractal_lacunarity);
|
|
ClassDB::bind_method(D_METHOD("get_fractal_lacunarity"), &FastNoise::get_fractal_lacunarity);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cellular_distance_function", "func"), &FastNoise::set_cellular_distance_function);
|
|
ClassDB::bind_method(D_METHOD("get_cellular_distance_function"), &FastNoise::get_cellular_distance_function);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cellular_return_type", "ret"), &FastNoise::set_cellular_return_type);
|
|
ClassDB::bind_method(D_METHOD("get_cellular_return_type"), &FastNoise::get_cellular_return_type);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cellular_noise_lookup", "other_noise"), &FastNoise::set_cellular_noise_lookup);
|
|
ClassDB::bind_method(D_METHOD("get_cellular_noise_lookup"), &FastNoise::get_cellular_noise_lookup);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cellular_distance_2_indices", "i0", "i1"), &FastNoise::set_cellular_distance_2_indices);
|
|
ClassDB::bind_method(D_METHOD("get_cellular_distance_2_indices"), &FastNoise::get_cellular_distance_2_indices);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cellular_jitter", "jitter"), &FastNoise::set_cellular_jitter);
|
|
ClassDB::bind_method(D_METHOD("get_cellular_jitter"), &FastNoise::get_cellular_jitter);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_gradient_perturbation_amplitude", "amp"), &FastNoise::set_gradient_perturbation_amplitude);
|
|
ClassDB::bind_method(D_METHOD("get_gradient_perturbation_amplitude"), &FastNoise::get_gradient_perturbation_amplitude);
|
|
|
|
ClassDB::bind_method(D_METHOD("get_noise_2d", "x", "y"), &FastNoise::get_noise_2d);
|
|
ClassDB::bind_method(D_METHOD("get_noise_2dv", "pos"), &FastNoise::get_noise_2dv);
|
|
ClassDB::bind_method(D_METHOD("get_noise_3d", "x", "y", "z"), &FastNoise::get_noise_3d);
|
|
ClassDB::bind_method(D_METHOD("get_noise_3dv", "pos"), &FastNoise::get_noise_3dv);
|
|
ClassDB::bind_method(D_METHOD("get_simplex_4d", "x", "y", "z", "w"), &FastNoise::get_simplex_4d);
|
|
ClassDB::bind_method(D_METHOD("get_white_noise_4d", "x", "y", "z", "w"), &FastNoise::get_white_noise_4d);
|
|
// TODO Bind intermediary functions?
|
|
|
|
BIND_ENUM_CONSTANT(TYPE_VALUE);
|
|
BIND_ENUM_CONSTANT(TYPE_VALUE_FRACTAL);
|
|
BIND_ENUM_CONSTANT(TYPE_PERLIN);
|
|
BIND_ENUM_CONSTANT(TYPE_PERLIN_FRACTAL);
|
|
BIND_ENUM_CONSTANT(TYPE_SIMPLEX);
|
|
BIND_ENUM_CONSTANT(TYPE_SIMPLEX_FRACTAL);
|
|
BIND_ENUM_CONSTANT(TYPE_CELLULAR);
|
|
BIND_ENUM_CONSTANT(TYPE_WHITE_NOISE);
|
|
BIND_ENUM_CONSTANT(TYPE_CUBIC);
|
|
BIND_ENUM_CONSTANT(TYPE_CUBIC_FRACTAL);
|
|
|
|
BIND_ENUM_CONSTANT(INTERP_LINEAR);
|
|
BIND_ENUM_CONSTANT(INTERP_QUINTIC);
|
|
BIND_ENUM_CONSTANT(INTERP_HERMITE);
|
|
|
|
BIND_ENUM_CONSTANT(FRACTAL_FBM);
|
|
BIND_ENUM_CONSTANT(FRACTAL_BILLOW);
|
|
BIND_ENUM_CONSTANT(FRACTAL_RIGID_MULTI);
|
|
|
|
BIND_ENUM_CONSTANT(DISTANCE_EUCLIDEAN);
|
|
BIND_ENUM_CONSTANT(DISTANCE_MANHATTAN);
|
|
BIND_ENUM_CONSTANT(DISTANCE_NATURAL);
|
|
|
|
BIND_ENUM_CONSTANT(RETURN_CELL_VALUE);
|
|
BIND_ENUM_CONSTANT(RETURN_NOISE_LOOKUP);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE_2);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE_2_ADD);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE_2_SUB);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE_2_MUL);
|
|
BIND_ENUM_CONSTANT(RETURN_DISTANCE_2_DIV);
|
|
}
|