diff options
author | Saracen <SaracenOne@gmail.com> | 2017-10-18 05:16:05 +0100 |
---|---|---|
committer | Saracen <SaracenOne@gmail.com> | 2017-10-18 05:16:05 +0100 |
commit | c566899dcf81d452d975d72ab8e0d07eb0510337 (patch) | |
tree | 50387ddad7e2d53fdf4eb897290528d183380f7d /editor/plugins | |
parent | 6e960c7d6bbf7481bae41ab0ebb39bc75619272a (diff) |
Fix drag and drop collision with non-centred origin points.
Diffstat (limited to 'editor/plugins')
-rw-r--r-- | editor/plugins/spatial_editor_plugin.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/editor/plugins/spatial_editor_plugin.cpp b/editor/plugins/spatial_editor_plugin.cpp index 703c9e96b6..547679b056 100644 --- a/editor/plugins/spatial_editor_plugin.cpp +++ b/editor/plugins/spatial_editor_plugin.cpp @@ -2765,8 +2765,14 @@ Vector3 SpatialEditorViewport::_get_instance_position(const Point2 &p_pos) const normal = hit_normal; } } - Vector3 center = preview_bounds->get_size() * 0.5; - return point + (center * normal); + Vector3 offset = Vector3(); + for (int i = 0; i < 3; i++) { + if (normal[i] > 0.0) + offset[i] = (preview_bounds->get_size()[i] - (preview_bounds->get_size()[i] + preview_bounds->get_position()[i])); + else if (normal[i] < 0.0) + offset[i] = -(preview_bounds->get_size()[i] + preview_bounds->get_position()[i]); + } + return point + offset; } Rect3 SpatialEditorViewport::_calculate_spatial_bounds(const Spatial *p_parent, const Rect3 p_bounds) { |