Implement mark_dirty
in Curve2D and Curve3D
Implements a method `mark_dirty` in Curve2D and Curve3D like the one that already exists in Curve, it's a convenient way to set `baked_cache_dirty` to `true` and also emit the `changed` signal.
This commit is contained in:
parent
7ea8cde983
commit
0ba0d51c9e
2 changed files with 30 additions and 32 deletions
|
@ -546,16 +546,14 @@ void Curve2D::add_point(const Vector2 &p_position, const Vector2 &p_in, const Ve
|
||||||
points.push_back(n);
|
points.push_back(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Curve2D::set_point_position(int p_index, const Vector2 &p_position) {
|
void Curve2D::set_point_position(int p_index, const Vector2 &p_position) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].position = p_position;
|
points.write[p_index].position = p_position;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector2 Curve2D::get_point_position(int p_index) const {
|
Vector2 Curve2D::get_point_position(int p_index) const {
|
||||||
|
@ -567,8 +565,7 @@ void Curve2D::set_point_in(int p_index, const Vector2 &p_in) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].in = p_in;
|
points.write[p_index].in = p_in;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector2 Curve2D::get_point_in(int p_index) const {
|
Vector2 Curve2D::get_point_in(int p_index) const {
|
||||||
|
@ -580,8 +577,7 @@ void Curve2D::set_point_out(int p_index, const Vector2 &p_out) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].out = p_out;
|
points.write[p_index].out = p_out;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector2 Curve2D::get_point_out(int p_index) const {
|
Vector2 Curve2D::get_point_out(int p_index) const {
|
||||||
|
@ -592,15 +588,13 @@ Vector2 Curve2D::get_point_out(int p_index) const {
|
||||||
void Curve2D::remove_point(int p_index) {
|
void Curve2D::remove_point(int p_index) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
points.remove_at(p_index);
|
points.remove_at(p_index);
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Curve2D::clear_points() {
|
void Curve2D::clear_points() {
|
||||||
if (!points.is_empty()) {
|
if (!points.is_empty()) {
|
||||||
points.clear();
|
points.clear();
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -632,6 +626,11 @@ Vector2 Curve2D::interpolatef(real_t p_findex) const {
|
||||||
return interpolate((int)p_findex, Math::fmod(p_findex, (real_t)1.0));
|
return interpolate((int)p_findex, Math::fmod(p_findex, (real_t)1.0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Curve2D::mark_dirty() {
|
||||||
|
baked_cache_dirty = true;
|
||||||
|
emit_signal(CoreStringNames::get_singleton()->changed);
|
||||||
|
}
|
||||||
|
|
||||||
void Curve2D::_bake_segment2d(RBMap<real_t, Vector2> &r_bake, real_t p_begin, real_t p_end, const Vector2 &p_a, const Vector2 &p_out, const Vector2 &p_b, const Vector2 &p_in, int p_depth, int p_max_depth, real_t p_tol) const {
|
void Curve2D::_bake_segment2d(RBMap<real_t, Vector2> &r_bake, real_t p_begin, real_t p_end, const Vector2 &p_a, const Vector2 &p_out, const Vector2 &p_b, const Vector2 &p_in, int p_depth, int p_max_depth, real_t p_tol) const {
|
||||||
real_t mp = p_begin + (p_end - p_begin) * 0.5;
|
real_t mp = p_begin + (p_end - p_begin) * 0.5;
|
||||||
Vector2 beg = _bezier_interp(p_begin, p_a, p_a + p_out, p_b + p_in, p_b);
|
Vector2 beg = _bezier_interp(p_begin, p_a, p_a + p_out, p_b + p_in, p_b);
|
||||||
|
@ -825,8 +824,7 @@ PackedVector2Array Curve2D::get_baked_points() const {
|
||||||
|
|
||||||
void Curve2D::set_bake_interval(real_t p_tolerance) {
|
void Curve2D::set_bake_interval(real_t p_tolerance) {
|
||||||
bake_interval = p_tolerance;
|
bake_interval = p_tolerance;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
real_t Curve2D::get_bake_interval() const {
|
real_t Curve2D::get_bake_interval() const {
|
||||||
|
@ -1040,16 +1038,14 @@ void Curve3D::add_point(const Vector3 &p_position, const Vector3 &p_in, const Ve
|
||||||
points.push_back(n);
|
points.push_back(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Curve3D::set_point_position(int p_index, const Vector3 &p_position) {
|
void Curve3D::set_point_position(int p_index, const Vector3 &p_position) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].position = p_position;
|
points.write[p_index].position = p_position;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector3 Curve3D::get_point_position(int p_index) const {
|
Vector3 Curve3D::get_point_position(int p_index) const {
|
||||||
|
@ -1061,8 +1057,7 @@ void Curve3D::set_point_tilt(int p_index, real_t p_tilt) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].tilt = p_tilt;
|
points.write[p_index].tilt = p_tilt;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
real_t Curve3D::get_point_tilt(int p_index) const {
|
real_t Curve3D::get_point_tilt(int p_index) const {
|
||||||
|
@ -1074,8 +1069,7 @@ void Curve3D::set_point_in(int p_index, const Vector3 &p_in) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].in = p_in;
|
points.write[p_index].in = p_in;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector3 Curve3D::get_point_in(int p_index) const {
|
Vector3 Curve3D::get_point_in(int p_index) const {
|
||||||
|
@ -1087,8 +1081,7 @@ void Curve3D::set_point_out(int p_index, const Vector3 &p_out) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
|
|
||||||
points.write[p_index].out = p_out;
|
points.write[p_index].out = p_out;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector3 Curve3D::get_point_out(int p_index) const {
|
Vector3 Curve3D::get_point_out(int p_index) const {
|
||||||
|
@ -1099,15 +1092,13 @@ Vector3 Curve3D::get_point_out(int p_index) const {
|
||||||
void Curve3D::remove_point(int p_index) {
|
void Curve3D::remove_point(int p_index) {
|
||||||
ERR_FAIL_INDEX(p_index, points.size());
|
ERR_FAIL_INDEX(p_index, points.size());
|
||||||
points.remove_at(p_index);
|
points.remove_at(p_index);
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Curve3D::clear_points() {
|
void Curve3D::clear_points() {
|
||||||
if (!points.is_empty()) {
|
if (!points.is_empty()) {
|
||||||
points.clear();
|
points.clear();
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1139,6 +1130,11 @@ Vector3 Curve3D::interpolatef(real_t p_findex) const {
|
||||||
return interpolate((int)p_findex, Math::fmod(p_findex, (real_t)1.0));
|
return interpolate((int)p_findex, Math::fmod(p_findex, (real_t)1.0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Curve3D::mark_dirty() {
|
||||||
|
baked_cache_dirty = true;
|
||||||
|
emit_signal(CoreStringNames::get_singleton()->changed);
|
||||||
|
}
|
||||||
|
|
||||||
void Curve3D::_bake_segment3d(RBMap<real_t, Vector3> &r_bake, real_t p_begin, real_t p_end, const Vector3 &p_a, const Vector3 &p_out, const Vector3 &p_b, const Vector3 &p_in, int p_depth, int p_max_depth, real_t p_tol) const {
|
void Curve3D::_bake_segment3d(RBMap<real_t, Vector3> &r_bake, real_t p_begin, real_t p_end, const Vector3 &p_a, const Vector3 &p_out, const Vector3 &p_b, const Vector3 &p_in, int p_depth, int p_max_depth, real_t p_tol) const {
|
||||||
real_t mp = p_begin + (p_end - p_begin) * 0.5;
|
real_t mp = p_begin + (p_end - p_begin) * 0.5;
|
||||||
Vector3 beg = _bezier_interp(p_begin, p_a, p_a + p_out, p_b + p_in, p_b);
|
Vector3 beg = _bezier_interp(p_begin, p_a, p_a + p_out, p_b + p_in, p_b);
|
||||||
|
@ -1601,8 +1597,7 @@ real_t Curve3D::get_closest_offset(const Vector3 &p_to_point) const {
|
||||||
|
|
||||||
void Curve3D::set_bake_interval(real_t p_tolerance) {
|
void Curve3D::set_bake_interval(real_t p_tolerance) {
|
||||||
bake_interval = p_tolerance;
|
bake_interval = p_tolerance;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
real_t Curve3D::get_bake_interval() const {
|
real_t Curve3D::get_bake_interval() const {
|
||||||
|
@ -1611,8 +1606,7 @@ real_t Curve3D::get_bake_interval() const {
|
||||||
|
|
||||||
void Curve3D::set_up_vector_enabled(bool p_enable) {
|
void Curve3D::set_up_vector_enabled(bool p_enable) {
|
||||||
up_vector_enabled = p_enable;
|
up_vector_enabled = p_enable;
|
||||||
baked_cache_dirty = true;
|
mark_dirty();
|
||||||
emit_signal(CoreStringNames::get_singleton()->changed);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Curve3D::is_up_vector_enabled() const {
|
bool Curve3D::is_up_vector_enabled() const {
|
||||||
|
|
|
@ -164,6 +164,8 @@ class Curve2D : public Resource {
|
||||||
mutable Vector<real_t> baked_dist_cache;
|
mutable Vector<real_t> baked_dist_cache;
|
||||||
mutable real_t baked_max_ofs = 0.0;
|
mutable real_t baked_max_ofs = 0.0;
|
||||||
|
|
||||||
|
void mark_dirty();
|
||||||
|
|
||||||
void _bake() const;
|
void _bake() const;
|
||||||
|
|
||||||
real_t bake_interval = 5.0;
|
real_t bake_interval = 5.0;
|
||||||
|
@ -228,6 +230,8 @@ class Curve3D : public Resource {
|
||||||
mutable Vector<real_t> baked_dist_cache;
|
mutable Vector<real_t> baked_dist_cache;
|
||||||
mutable real_t baked_max_ofs = 0.0;
|
mutable real_t baked_max_ofs = 0.0;
|
||||||
|
|
||||||
|
void mark_dirty();
|
||||||
|
|
||||||
void _bake() const;
|
void _bake() const;
|
||||||
|
|
||||||
real_t bake_interval = 0.2;
|
real_t bake_interval = 0.2;
|
||||||
|
|
Loading…
Reference in a new issue