mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-12 05:41:15 +01:00
Ported: Improve error messages and classref for occluders and portals
Misused functions would previously produce no error messages which was confusing for users.
- lawnjelly
5a0cb54b3a
This commit is contained in:
parent
2e7ee5cef6
commit
1f20512f8c
@ -17,7 +17,8 @@
|
|||||||
<argument index="0" name="index" type="int" />
|
<argument index="0" name="index" type="int" />
|
||||||
<argument index="1" name="position" type="Vector2" />
|
<argument index="1" name="position" type="Vector2" />
|
||||||
<description>
|
<description>
|
||||||
Sets individual points. Primarily for use by the editor.
|
Sets individual points.
|
||||||
|
[b]Note:[/b] This function will not resize the point array. Set [member points] to set the number of points.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
</methods>
|
</methods>
|
||||||
|
@ -18,7 +18,8 @@
|
|||||||
<argument index="0" name="index" type="int" />
|
<argument index="0" name="index" type="int" />
|
||||||
<argument index="1" name="position" type="Vector3" />
|
<argument index="1" name="position" type="Vector3" />
|
||||||
<description>
|
<description>
|
||||||
Sets individual points. Primarily for use by the editor.
|
Sets individual points.
|
||||||
|
[b]Note:[/b] This function will not resize the point array. Set [member points] to set the number of points.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
</methods>
|
</methods>
|
||||||
|
@ -117,9 +117,7 @@ String Portal::get_configuration_warning() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Portal::set_point(int p_idx, const Vector2 &p_point) {
|
void Portal::set_point(int p_idx, const Vector2 &p_point) {
|
||||||
if (p_idx >= _pts_local_raw.size()) {
|
ERR_FAIL_INDEX_MSG(p_idx, _pts_local_raw.size(), "Index out of bounds. Call set_points() to set the size of the array.");
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_pts_local_raw.set(p_idx, p_point);
|
_pts_local_raw.set(p_idx, p_point);
|
||||||
_sanitize_points();
|
_sanitize_points();
|
||||||
|
@ -132,9 +132,7 @@ void Room::set_use_default_simplify(bool p_use) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Room::set_point(int p_idx, const Vector3 &p_point) {
|
void Room::set_point(int p_idx, const Vector3 &p_point) {
|
||||||
if (p_idx >= _bound_pts.size()) {
|
ERR_FAIL_INDEX_MSG(p_idx, _bound_pts.size(), "Index out of bounds. Call set_points() to set the size of the array.");
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_bound_pts.set(p_idx, p_point);
|
_bound_pts.set(p_idx, p_point);
|
||||||
|
|
||||||
|
@ -210,20 +210,22 @@ void OccluderShapeSphere::set_spheres(const Vector<Plane> &p_spheres) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void OccluderShapeSphere::set_sphere_position(int p_idx, const Vector3 &p_position) {
|
void OccluderShapeSphere::set_sphere_position(int p_idx, const Vector3 &p_position) {
|
||||||
if ((p_idx >= 0) && (p_idx < _spheres.size())) {
|
ERR_FAIL_INDEX(p_idx, _spheres.size());
|
||||||
|
|
||||||
Plane p = _spheres[p_idx];
|
Plane p = _spheres[p_idx];
|
||||||
p.normal = p_position;
|
p.normal = p_position;
|
||||||
_spheres.set(p_idx, p);
|
_spheres.set(p_idx, p);
|
||||||
|
|
||||||
#ifdef TOOLS_ENABLED
|
#ifdef TOOLS_ENABLED
|
||||||
_update_aabb();
|
_update_aabb();
|
||||||
#endif
|
#endif
|
||||||
update_shape_to_rendering_server();
|
update_shape_to_rendering_server();
|
||||||
notify_change_to_owners();
|
notify_change_to_owners();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void OccluderShapeSphere::set_sphere_radius(int p_idx, real_t p_radius) {
|
void OccluderShapeSphere::set_sphere_radius(int p_idx, real_t p_radius) {
|
||||||
if ((p_idx >= 0) && (p_idx < _spheres.size())) {
|
ERR_FAIL_INDEX(p_idx, _spheres.size());
|
||||||
|
|
||||||
Plane p = _spheres[p_idx];
|
Plane p = _spheres[p_idx];
|
||||||
p.d = MAX(p_radius, _min_radius);
|
p.d = MAX(p_radius, _min_radius);
|
||||||
_spheres.set(p_idx, p);
|
_spheres.set(p_idx, p);
|
||||||
@ -233,7 +235,6 @@ void OccluderShapeSphere::set_sphere_radius(int p_idx, real_t p_radius) {
|
|||||||
update_shape_to_rendering_server();
|
update_shape_to_rendering_server();
|
||||||
notify_change_to_owners();
|
notify_change_to_owners();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
OccluderShapeSphere::OccluderShapeSphere() {
|
OccluderShapeSphere::OccluderShapeSphere() {
|
||||||
if (get_shape().is_valid()) {
|
if (get_shape().is_valid()) {
|
||||||
|
@ -102,9 +102,7 @@ void OccluderShapePolygon::_sanitize_points() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void OccluderShapePolygon::set_polygon_point(int p_idx, const Vector2 &p_point) {
|
void OccluderShapePolygon::set_polygon_point(int p_idx, const Vector2 &p_point) {
|
||||||
if (p_idx >= _poly_pts_local_raw.size()) {
|
ERR_FAIL_INDEX_MSG(p_idx, _poly_pts_local_raw.size(), "Index out of bounds. Call set_polygon_points() to set the size of the array.");
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_poly_pts_local_raw.set(p_idx, p_point);
|
_poly_pts_local_raw.set(p_idx, p_point);
|
||||||
_sanitize_points();
|
_sanitize_points();
|
||||||
@ -113,9 +111,7 @@ void OccluderShapePolygon::set_polygon_point(int p_idx, const Vector2 &p_point)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void OccluderShapePolygon::set_hole_point(int p_idx, const Vector2 &p_point) {
|
void OccluderShapePolygon::set_hole_point(int p_idx, const Vector2 &p_point) {
|
||||||
if (p_idx >= _hole_pts_local_raw.size()) {
|
ERR_FAIL_INDEX_MSG(p_idx, _hole_pts_local_raw.size(), "Index out of bounds. Call set_hole_points() to set the size of the array.");
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_hole_pts_local_raw.set(p_idx, p_point);
|
_hole_pts_local_raw.set(p_idx, p_point);
|
||||||
_sanitize_points();
|
_sanitize_points();
|
||||||
|
Loading…
Reference in New Issue
Block a user