mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-06 22:47:32 -06:00

* NEW:add move and rotate gizmo in assemble view Cherry-picked from bambulab/BambuStudio@d9e47bd9a9 Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * Deselect other parts if Alt is pressed when selecting Cherry-picked from bambulab/BambuStudio@f5eb2899e7 Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * FIX:z offset is error after copy and paste several objects jira: STUDIO-6753 STUDIO-7135 Change-Id: I6d9c8eb0c957ff1e3194709704ceb6c3920baa4f (cherry picked from commit 847a7141a6f47e409566b19e73c0ebdeb08f39e2) (cherry picked from commit a5cc52beb7eef5848368e660ca4f14e95ad5f7d5) * FIX:arrow direction in scaling tool is incorrect Jira: STUDIO-5672 Change-Id: I82c0ab336805e34c8380f93e64d3b9dbbf283805 (cherry picked from commit f6f27b700f0305854fcdbcb1191af25a4b8bdbe4) * FIX:world cs is displayed incorrectly The value of world coordinate system for model_volume is displayed incorrectly Jira: STUDIO-6399 code is from PrusaSlicer thanks for PrusaSlicer and enricoturri1966 commit 325709c5ae9b937867b36103a41d12a102c99292 Author: enricoturri1966 <enricoturri@seznam.cz> Date: Thu Jan 26 15:49:00 2023 +0100 SPE-1419 - Fixed reset skew resetting mirror, reset scale resetting mirror, changed labels in Object Manipulator panel, scale of instances using the Object Manipulator panel always made as absolute Change-Id: I30fdd39effd73b8dc027e4263fa7e64937b84326 Cherry-picked from bambulab/BambuStudio@0b46b9848b Co-authored-by: enricoturri1966 <enricoturri@seznam.cz> * FIX:fix scale problem add tool tip for move,rotate,scale gizmo Jira: STUDIO-6425 STUDIO-6419 Change-Id: I0b89c9b70f83cde21c6a407bcecd78c925515cfa Cherry-picked from bambulab/BambuStudio@6dad59102b Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * NEW:add Object coordinates in move gizmo jira: none Part of the code references PrusaSlicer,thanks for PrusaSlicer and enricoturri1966 commit c12eeee12f9e2c91a9dfe7905f1370143805f038 Author: enricoturri1966 <enricoturri@seznam.cz> Date: Mon Oct 2 14:26:36 2023 +0200 SPE-1926: Tech ENABLE_CGAL_BOUNDING_SPHERE - Use selection's bounding sphere center as pivot for rotations Change-Id: Iae7e4539c198af3ff1aa99e1c0ce015fbcf80256 (cherry picked from commit 2b73bc915ee27218c9803ba0a01b0d3e47adf1da) Cherry-picked from bambulab/BambuStudio@98cce3b656 Co-authored-by: enricoturri1966 <enricoturri@seznam.cz> Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * FIX:fix imgui style at Object coordinate in move tool jira:STUDIO-7141 Change-Id: Ib2900012c28878c4e7ad97eb0cf319f693cb9f6f (cherry picked from commit b7b09c82897678c4f3615713bc5d1cc7a3b17b19) (cherry picked from commit c89732a04619a6d910b723c126515bae802f7167) * ENH:use local cs for non_model_part better jira: STUDIO-7234 Change-Id: I0f0e99429e5e0b7cc4932a661eceffcff4a495f6 (cherry picked from commit b4305a3bfc9e5ae05c1785a710238a70f2dfb44a) (cherry picked from commit b28ac4f812f0024ec619c5d1b3c96e4cef4debdb) * ENH:add a cross mark for object cs jira: STUDIO-6947 Change-Id: Iaaab4f072045756ac3ba12c3f65e1c7f04ba65b8 (cherry picked from commit a2a2f49b4d94f257d36c9d17b4ec952e5dc9f0eb) Cherry-picked from bambulab/BambuStudio@8400e162a7 Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * NEW:add tip button for move,rotate,scale jira: STUDIO-7273 Change-Id: I44aeecd8aaa17ec49ac1d8ff2bee5c3729c52061 (cherry picked from commit 998f33b4ce588f59cef345e327a97f6f669f6089) (cherry picked from commit f5eb2899e7252ea3ff0f8a79ef8d55c6009ebb28) * FIX:scale and size sholud >0 in scale tool jira: STUDIO-7433 Change-Id: Ibd4d00d9ca4762d002049e97a6d0819649f464db (cherry picked from commit eaaf11031ee49009af14abbd05bb4a07c88aceda) (cherry picked from commit 0d393d64b804ba7ae05454bf158de470cc74a6a6) * Fix crossmark rendering * Use combox as coord selection Cherry-picked from bambulab/BambuStudio@56f628dac1 Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * NEW:add "world coordinates" scale for scale gizmo upgrade Transformation class jira:none about 75% code is from PrusaSlicer,thanks for PrusaSlicer and enricoturri1966 commit b32e9366606dce7d4f8de8db84fd902113bdbe28 Author: enricoturri1966 <enricoturri@seznam.cz> Date: Tue Mar 7 14:32:18 2023 +0100 Rework of constrained scaling Change-Id: I1248ea586e6b8f2fb6cdf3aa901ed7f525c3f111 (cherry picked from commit e10381aad1412b0c47afa340b634faa3af9d1a1f) Cherry-picked from bambulab/BambuStudio@c0536c09b4 Co-authored-by: enricoturri1966 <enricoturri@seznam.cz> Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * ENH:set "Rotate (relative)" jira:none code is from PrusaSlicer,thanks for PrusaSlicer and enricoturri1966 commit 243985173e70c189ad9a86eefaaea0757d9749cb Author: enricoturri1966 <enricoturri@seznam.cz> Date: Thu May 12 14:33:41 2022 +0200 Tech ENABLE_TRANSFORMATIONS_BY_MATRICES - Allow for relative rotations Change-Id: I851939093ffb6881542fb21b434e17cc31a6dab2 (cherry picked from commit e412fa3492fa2ef59b84a84be1ede80935fb8a8d) * FIX:limit scaling ratio by grabber in scale tool jira: none Change-Id: I20a4404d4e4025ae230ab46ba8d8d3e5ffed10e3 (cherry picked from commit 97f63f167e80e859fec49666c8986f5a01f61838) * FIX:selection should be not empty when update_ui_from_settings jira: none Change-Id: I74b76733eba03d148dfd70279ec2ba65f19cc39a (cherry picked from commit f402685aee747fe5c3740b2cb80fc2a60e129918) * ENH:add "volume selection" checkbox jira: none Change-Id: I68b5f54e37ea2ab9e2b65ac84abc834060f400df (cherry picked from commit eec7de441bd40408fe688587d2834b0c42c0d66f) * FIX:add can_sequential_clearance_show_in_gizmo api jira: STUDIO-7836 Change-Id: Ie0cded272596bafee4e491e379722dcc23035dc4 (cherry picked from commit 715d2b9b7840939663e99e0ecbfcefd8ecf2904f) * FIX:select all should ban in paint,cut and so on gizmo jira: STUDIO-7872 Change-Id: Ic6496dbdd892814e1fc41625ee34ffc46f171657 (cherry picked from commit 95e8ca728553081db4ecbb3d865c8b999a6ff2fa) * FIX:add wipe tower'position in move gizmo jira: STUDIO-7861 Change-Id: I8147717bc61ba06a7e1fba45532cdadc2ba1174e (cherry picked from commit 065dddb890d3ec81643b9767397bdad72ae69ebd) * ENH:fix text coordinate system calculation jira: STUDIO-6449 Change-Id: I36214c14c348e8f52b96501cd027205819b0dabc (cherry picked from commit 44287812a0cb212f1bf6fe70e32e1075f532886d) Cherry-picked from bambulab/BambuStudio@4091f3e042 Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * FIX:delete old selection.translate api jira: STUDIO-8201 code is from PrusaSlicer,thanks for PrusaSlicer and enricoturri1966 commit 88ce6ccdef5f680709ea8b676688784a7af287dd Author: enricoturri1966 <enricoturri@seznam.cz> Date: Wed May 11 10:54:42 2022 +0200 Tech ENABLE_TRANSFORMATIONS_BY_MATRICES - Change-Id: Iafe963f0f7bf9028f32a4fb4a4cc8cc609662283 Change-Id: Ibbc36c004734f35564f0028dd1e537ac926a2f1f Cherry-picked from bambulab/BambuStudio@c6d9f2685e Co-authored-by: enricoturri1966 <enricoturri@seznam.cz> Co-authored-by: zhou.xu <zhou.xu@bambulab.com> * FIX:add protection for null pointer jira: none Change-Id: I9a9231bab893f5d2afa008f65165269ae176c962 (cherry picked from commit f27a713aaf77b1109fc57b8650efa6b23081f799) * FIX:when two dir is perpendicular to each other,scale error (plane_normal.dot(ray_dir)) jira:STUDIO-8274 Change-Id: Ib3145ab75e18c832d20065d204aa41b75f73b673 (cherry picked from commit fbdc9cd580f835d1a873d08ed64baed3b3db6f9a) * ENH:add "reset real zeros" button in rotate gizmo jira: STUDIO-8291 Change-Id: Ia10e4d8a2a3a073c22a1306aeab9ffa3e7b77c2b (cherry picked from commit 738e3f004daa9082709800e4e3d0d9bbe1b7ed7e) * FIX:add "absolute rotation" in rotate gizmo jira: STUDIO-8726 Change-Id: I23deb4ab11cf24ca4f0f0c5a35a74268c34f60f6 (cherry picked from commit d26b8f9fcadf8f7709a302991e43be711560e84e) (cherry picked from commit 496d69f9d1b91c6bd84804e57a276bccf79f0cbd) * Fix tooltip button size * Fix issue that reative rotation history not cleared after gizmo closed * Show selection box in assemble view * ENH:add an tip icon for assembly view jira: STUDIO-7155 Change-Id: Ie9e4fa578c8aa5bda9ff771d82f396f8b51026bb (cherry picked from commit 515f9473347fb912a9dc8c365f1c318506096083) --------- Co-authored-by: zhou.xu <zhou.xu@bambulab.com> Co-authored-by: enricoturri1966 <enricoturri@seznam.cz> Co-authored-by: SoftFever <softfeverever@gmail.com>
459 lines
20 KiB
C++
459 lines
20 KiB
C++
#ifndef slic3r_GUI_Selection_hpp_
|
|
#define slic3r_GUI_Selection_hpp_
|
|
|
|
#include "libslic3r/Geometry.hpp"
|
|
#include "GUI_Geometry.hpp"
|
|
#include "GLModel.hpp"
|
|
|
|
#include <set>
|
|
#include <optional>
|
|
|
|
namespace Slic3r {
|
|
|
|
class Shader;
|
|
class Model;
|
|
class ModelObject;
|
|
class ModelVolume;
|
|
class ObjectID;
|
|
class ModelInstance;
|
|
class GLVolume;
|
|
class GLArrow;
|
|
class GLCurvedArrow;
|
|
class DynamicPrintConfig;
|
|
class GLShaderProgram;
|
|
#if ENABLE_ENHANCED_PRINT_VOLUME_FIT
|
|
class BuildVolume;
|
|
#endif // ENABLE_ENHANCED_PRINT_VOLUME_FIT
|
|
|
|
using GLVolumePtrs = std::vector<GLVolume*>;
|
|
using ModelObjectPtrs = std::vector<ModelObject*>;
|
|
|
|
|
|
namespace GUI {
|
|
|
|
class Selection
|
|
{
|
|
public:
|
|
typedef std::set<unsigned int> IndicesList;
|
|
|
|
enum EMode : unsigned char
|
|
{
|
|
Volume,
|
|
Instance
|
|
};
|
|
|
|
enum EType : unsigned char
|
|
{
|
|
Invalid,
|
|
Empty,
|
|
WipeTower,
|
|
SingleModifier,
|
|
MultipleModifier,
|
|
SingleVolume,
|
|
MultipleVolume,
|
|
SingleFullObject,
|
|
MultipleFullObject,
|
|
SingleFullInstance,
|
|
MultipleFullInstance,
|
|
Mixed
|
|
};
|
|
|
|
private:
|
|
struct VolumeCache
|
|
{
|
|
private:
|
|
struct TransformCache
|
|
{
|
|
Vec3d position;
|
|
Transform3d rotation_matrix;
|
|
Transform3d scale_matrix;
|
|
Transform3d mirror_matrix;
|
|
|
|
Geometry::Transformation transform;
|
|
|
|
TransformCache();
|
|
explicit TransformCache(const Geometry::Transformation& transform);
|
|
};
|
|
|
|
TransformCache m_volume;
|
|
TransformCache m_instance;
|
|
|
|
public:
|
|
VolumeCache() = default;
|
|
VolumeCache(const Geometry::Transformation& volume_transform, const Geometry::Transformation& instance_transform);
|
|
|
|
const Vec3d& get_volume_position() const { return m_volume.position; }
|
|
const Transform3d& get_volume_scale_matrix() const { return m_volume.scale_matrix; }
|
|
const Geometry::Transformation& get_volume_transform() const { return m_volume.transform; }
|
|
|
|
const Vec3d& get_instance_position() const { return m_instance.position; }
|
|
const Transform3d& get_instance_rotation_matrix() const { return m_instance.rotation_matrix; }
|
|
const Transform3d& get_instance_scale_matrix() const { return m_instance.scale_matrix; }
|
|
const Transform3d& get_instance_mirror_matrix() const { return m_instance.mirror_matrix; }
|
|
const Geometry::Transformation &get_instance_transform() const { return m_instance.transform; }
|
|
};
|
|
|
|
public:
|
|
typedef std::map<unsigned int, VolumeCache> VolumesCache;
|
|
typedef std::set<int> InstanceIdxsList;
|
|
typedef std::map<int, InstanceIdxsList> ObjectIdxsToInstanceIdxsMap;
|
|
|
|
class Clipboard
|
|
{
|
|
// Model is stored through a pointer to avoid including heavy Model.hpp.
|
|
// It is created in constructor.
|
|
std::unique_ptr<Model> m_model;
|
|
|
|
Selection::EMode m_mode;
|
|
|
|
public:
|
|
Clipboard();
|
|
|
|
void reset();
|
|
bool is_empty() const;
|
|
|
|
bool is_sla_compliant() const;
|
|
|
|
ModelObject* add_object();
|
|
ModelObject* get_object(unsigned int id);
|
|
const ModelObjectPtrs& get_objects() const;
|
|
|
|
Selection::EMode get_mode() const { return m_mode; }
|
|
void set_mode(Selection::EMode mode) { m_mode = mode; }
|
|
};
|
|
|
|
private:
|
|
struct Cache
|
|
{
|
|
// Cache of GLVolume derived transformation matrices, valid during mouse dragging.
|
|
VolumesCache volumes_data;
|
|
// Center of the dragged selection, valid during mouse dragging.
|
|
Vec3d dragging_center;
|
|
// Map from indices of ModelObject instances in Model::objects
|
|
// to a set of indices of ModelVolume instances in ModelObject::instances
|
|
// Here the index means a position inside the respective std::vector, not ObjectID.
|
|
ObjectIdxsToInstanceIdxsMap content;
|
|
// List of ids of the volumes which are sinking when starting dragging
|
|
std::vector<unsigned int> sinking_volumes;
|
|
Vec3d rotation_pivot;
|
|
};
|
|
|
|
// Volumes owned by GLCanvas3D.
|
|
GLVolumePtrs* m_volumes;
|
|
// Model, not owned.
|
|
Model* m_model;
|
|
|
|
bool m_enabled;
|
|
bool m_valid;
|
|
EMode m_mode;
|
|
EType m_type;
|
|
// set of indices to m_volumes
|
|
IndicesList m_list;
|
|
Cache m_cache;
|
|
Clipboard m_clipboard;
|
|
std::optional<BoundingBoxf3> m_bounding_box;
|
|
// Bounding box of a single full instance selection, in world coordinates, with no instance scaling applied.
|
|
// This bounding box is useful for absolute scaling of tilted objects in world coordinate space.
|
|
// Modifiers are NOT taken in account
|
|
std::optional<BoundingBoxf3> m_unscaled_instance_bounding_box;
|
|
// Bounding box of a single full instance selection, in world coordinates.
|
|
// Modifiers are NOT taken in account
|
|
std::optional<BoundingBoxf3> m_scaled_instance_bounding_box;
|
|
// Bounding box of a single full instance selection, in world coordinates, with no instance scaling applied.
|
|
// Modifiers are taken in account
|
|
std::optional<BoundingBoxf3> m_full_unscaled_instance_bounding_box;
|
|
// Bounding box of a single full instance selection, in world coordinates.
|
|
// Modifiers are taken in account
|
|
std::optional<BoundingBoxf3> m_full_scaled_instance_bounding_box;
|
|
// Bounding box of a single full instance selection, in local coordinates, with no instance scaling applied.
|
|
// Modifiers are taken in account
|
|
std::optional<BoundingBoxf3> m_full_unscaled_instance_local_bounding_box;
|
|
// Bounding box aligned to the axis of the currently selected reference system (World/Object/Part)
|
|
// and transform to place and orient it in world coordinates
|
|
std::optional<std::pair<BoundingBoxf3, Transform3d>> m_bounding_box_in_current_reference_system;
|
|
|
|
std::optional<std::pair<Vec3d, double>> m_bounding_sphere;
|
|
|
|
#if ENABLE_RENDER_SELECTION_CENTER
|
|
GLModel m_vbo_sphere;
|
|
#endif // ENABLE_RENDER_SELECTION_CENTER
|
|
|
|
GLModel m_arrow;
|
|
GLModel m_curved_arrow;
|
|
GLModel m_box;
|
|
struct Planes
|
|
{
|
|
std::array<Vec3f, 2> check_points{ Vec3f::Zero(), Vec3f::Zero() };
|
|
std::array<GLModel, 2> models;
|
|
};
|
|
Planes m_planes;
|
|
|
|
float m_scale_factor;
|
|
|
|
// BBS
|
|
EMode m_volume_selection_mode{ Instance };
|
|
bool m_volume_selection_locked { false };
|
|
|
|
public:
|
|
Selection();
|
|
|
|
void set_volumes(GLVolumePtrs* volumes);
|
|
bool init();
|
|
|
|
bool is_enabled() const { return m_enabled; }
|
|
void set_enabled(bool enable) { m_enabled = enable; }
|
|
|
|
Model* get_model() const { return m_model; }
|
|
void set_model(Model* model);
|
|
|
|
EMode get_mode() const { return m_mode; }
|
|
void set_mode(EMode mode) { m_mode = mode; }
|
|
|
|
int query_real_volume_idx_from_other_view(unsigned int object_idx, unsigned int instance_idx, unsigned int model_volume_idx);
|
|
void add(unsigned int volume_idx, bool as_single_selection = true, bool check_for_already_contained = false);
|
|
void remove(unsigned int volume_idx);
|
|
|
|
void add_object(unsigned int object_idx, bool as_single_selection = true);
|
|
void remove_object(unsigned int object_idx);
|
|
|
|
void add_instance(unsigned int object_idx, unsigned int instance_idx, bool as_single_selection = true);
|
|
void remove_instance(unsigned int object_idx, unsigned int instance_idx);
|
|
|
|
void add_volume(unsigned int object_idx, unsigned int volume_idx, int instance_idx, bool as_single_selection = true);
|
|
void remove_volume(unsigned int object_idx, unsigned int volume_idx);
|
|
|
|
void add_volumes(EMode mode, const std::vector<unsigned int>& volume_idxs, bool as_single_selection = true);
|
|
void remove_volumes(EMode mode, const std::vector<unsigned int>& volume_idxs);
|
|
|
|
//BBS
|
|
ModelVolume * get_selected_single_volume(int &out_object_idx, int &out_volume_idx) const;
|
|
ModelObject * get_selected_single_object(int &out_object_idx) const;
|
|
const ModelInstance * get_selected_single_intance() const;
|
|
void add_curr_plate();
|
|
void add_object_from_idx(std::vector<int>& object_idxs);
|
|
void remove_curr_plate();
|
|
void clone(int numbers = 1);
|
|
void center();
|
|
void drop();
|
|
void center_plate(const int plate_idx);
|
|
void set_printable(bool printable);
|
|
|
|
void add_all();
|
|
void remove_all();
|
|
|
|
// To be called after Undo or Redo once the volumes are updated.
|
|
void set_deserialized(EMode mode, const std::vector<std::pair<size_t, size_t>> &volumes_and_instances);
|
|
|
|
// Update the selection based on the new instance IDs.
|
|
void instances_changed(const std::vector<size_t> &instance_ids_selected);
|
|
// Update the selection based on the map from old indices to new indices after m_volumes changed.
|
|
// If the current selection is by instance, this call may select newly added volumes, if they belong to already selected instances.
|
|
void volumes_changed(const std::vector<size_t> &map_volume_old_to_new);
|
|
void clear();
|
|
|
|
bool is_empty() const { return m_type == Empty; }
|
|
bool is_wipe_tower() const { return m_type == WipeTower; }
|
|
bool is_any_modifier() const { return is_single_modifier() || is_multiple_modifier(); }
|
|
bool is_single_modifier() const { return m_type == SingleModifier; }
|
|
bool is_multiple_modifier() const { return m_type == MultipleModifier; }
|
|
bool is_single_full_instance() const;
|
|
bool is_multiple_full_instance() const { return m_type == MultipleFullInstance; }
|
|
bool is_single_full_object() const { return m_type == SingleFullObject; }
|
|
bool is_multiple_full_object() const { return m_type == MultipleFullObject; }
|
|
bool is_single_volume() const { return m_type == SingleVolume; }
|
|
bool is_multiple_volume() const { return m_type == MultipleVolume; }
|
|
bool is_any_volume() const { return is_single_volume() || is_multiple_volume(); }
|
|
bool is_any_connector() const;
|
|
bool is_any_cut_volume() const;
|
|
bool is_mixed() const { return m_type == Mixed; }
|
|
bool is_from_single_instance() const { return get_instance_idx() != -1; }
|
|
bool is_from_single_object() const;
|
|
bool is_sla_compliant() const;
|
|
bool is_instance_mode() const { return m_mode == Instance; }
|
|
bool is_single_volume_or_modifier() const { return is_single_volume() || is_single_modifier(); }
|
|
bool is_single_volume_instance() const { return is_single_full_instance() && m_list.size() == 1; }
|
|
bool is_single_text() const;
|
|
|
|
bool contains_volume(unsigned int volume_idx) const { return m_list.find(volume_idx) != m_list.end(); }
|
|
// returns true if the selection contains all the given indices
|
|
bool contains_all_volumes(const std::vector<unsigned int>& volume_idxs) const;
|
|
// returns true if the selection contains at least one of the given indices
|
|
bool contains_any_volume(const std::vector<unsigned int>& volume_idxs) const;
|
|
// returns true if the selection contains any sinking volume
|
|
bool contains_sinking_volumes(bool ignore_modifiers = true) const;
|
|
// returns true if the selection contains all and only the given indices
|
|
bool matches(const std::vector<unsigned int>& volume_idxs) const;
|
|
|
|
bool requires_uniform_scale() const;
|
|
|
|
// Returns the the object id if the selection is from a single object, otherwise is -1
|
|
int get_object_idx() const;
|
|
// Returns the instance id if the selection is from a single object and from a single instance, otherwise is -1
|
|
int get_instance_idx() const;
|
|
// Returns the indices of selected instances.
|
|
// Can only be called if selection is from a single object.
|
|
const InstanceIdxsList& get_instance_idxs() const;
|
|
|
|
const IndicesList& get_volume_idxs() const { return m_list; }
|
|
const GLVolume* get_volume(unsigned int volume_idx) const;
|
|
const GLVolume* get_first_volume() const { return get_volume(*m_list.begin()); }
|
|
GLVolume* get_volume(unsigned int volume_idx);
|
|
|
|
const ObjectIdxsToInstanceIdxsMap& get_content() const { return m_cache.content; }
|
|
|
|
unsigned int volumes_count() const { return (unsigned int)m_list.size(); }
|
|
const BoundingBoxf3& get_bounding_box() const;
|
|
// Bounding box of a single full instance selection, in world coordinates, with no instance scaling applied.
|
|
// This bounding box is useful for absolute scaling of tilted objects in world coordinate space.
|
|
// Modifiers are NOT taken in account
|
|
const BoundingBoxf3& get_unscaled_instance_bounding_box() const;
|
|
// Bounding box of a single full instance selection, in world coordinates.
|
|
// Modifiers are NOT taken in account
|
|
const BoundingBoxf3& get_scaled_instance_bounding_box() const;
|
|
// Bounding box of a single full instance selection, in world coordinates, with no instance scaling applied.
|
|
// Modifiers are taken in account
|
|
const BoundingBoxf3& get_full_unscaled_instance_bounding_box() const;
|
|
// Bounding box of a single full instance selection, in world coordinates.
|
|
// Modifiers are taken in account
|
|
const BoundingBoxf3& get_full_scaled_instance_bounding_box() const;
|
|
// Bounding box of a single full instance selection, in local coordinates, with no instance scaling applied.
|
|
// Modifiers are taken in account
|
|
const BoundingBoxf3& get_full_unscaled_instance_local_bounding_box() const;
|
|
// Returns the bounding box aligned to the axes of the currently selected reference system (World/Object/Part)
|
|
// and the transform to place and orient it in world coordinates
|
|
const std::pair<BoundingBoxf3, Transform3d>& get_bounding_box_in_current_reference_system() const;
|
|
// Returns the bounding box aligned to the axes of the given reference system
|
|
// and the transform to place and orient it in world coordinates
|
|
std::pair<BoundingBoxf3, Transform3d> get_bounding_box_in_reference_system(ECoordinatesType type) const;
|
|
|
|
// Returns the bounding sphere: first = center, second = radius
|
|
const std::pair<Vec3d, double> get_bounding_sphere() const;
|
|
|
|
void setup_cache();
|
|
void translate(const Vec3d& displacement, TransformationType transformation_type);
|
|
void move_to_center(const Vec3d& displacement, bool local = false);
|
|
void rotate(const Vec3d& rotation, TransformationType transformation_type);
|
|
void flattening_rotate(const Vec3d& normal);
|
|
void scale(const Vec3d& scale, TransformationType transformation_type);
|
|
#if ENABLE_ENHANCED_PRINT_VOLUME_FIT
|
|
void scale_to_fit_print_volume(const BuildVolume& volume);
|
|
#else
|
|
void scale_to_fit_print_volume(const DynamicPrintConfig& config);
|
|
#endif // ENABLE_ENHANCED_PRINT_VOLUME_FIT
|
|
void scale_and_translate(const Vec3d &scale, const Vec3d &world_translation, TransformationType transformation_type);
|
|
void mirror(Axis axis, TransformationType transformation_type);
|
|
|
|
void translate(unsigned int object_idx, const Vec3d& displacement);
|
|
void translate(unsigned int object_idx, unsigned int instance_idx, const Vec3d& displacement);
|
|
void translate(unsigned int object_idx, unsigned int instance_idx, unsigned int volume_idx, const Vec3d &displacement);
|
|
|
|
void rotate(unsigned int object_idx, unsigned int instance_idx, const Transform3d &overwrite_tran);
|
|
void rotate(unsigned int object_idx, unsigned int instance_idx, unsigned int volume_idx, const Transform3d &overwrite_tran);
|
|
//BBS: add partplate related logic
|
|
void notify_instance_update(int object_idx, int instance_idx);
|
|
// BBS
|
|
EMode get_volume_selection_mode(){ return m_volume_selection_mode;}
|
|
void set_volume_selection_mode(EMode mode) { if (!m_volume_selection_locked) m_volume_selection_mode = mode; }
|
|
void lock_volume_selection_mode() { m_volume_selection_locked = true; }
|
|
void unlock_volume_selection_mode() { m_volume_selection_locked = false; }
|
|
|
|
void erase();
|
|
|
|
void render(float scale_factor = 1.0);
|
|
#if ENABLE_RENDER_SELECTION_CENTER
|
|
void render_center(bool gizmo_is_dragging);
|
|
#endif // ENABLE_RENDER_SELECTION_CENTER
|
|
//BBS: GUI refactor: add uniform scale from gizmo
|
|
void render_sidebar_hints(const std::string& sidebar_field, bool uniform_scale);
|
|
|
|
bool requires_local_axes() const;
|
|
|
|
void render_bounding_box(const BoundingBoxf3& box, const ColorRGB& color, float scale) {
|
|
m_scale_factor = scale;
|
|
render_bounding_box(box, Transform3d::Identity(), color);
|
|
}
|
|
|
|
//BBS
|
|
void cut_to_clipboard();
|
|
void copy_to_clipboard();
|
|
void paste_from_clipboard();
|
|
//BBS get selected object instance lists
|
|
std::set<std::pair<int, int>> get_selected_object_instances();
|
|
|
|
const Clipboard& get_clipboard() const { return m_clipboard; }
|
|
|
|
void fill_color(int extruder_id);
|
|
|
|
// returns the list of idxs of the volumes contained into the object with the given idx
|
|
std::vector<unsigned int> get_volume_idxs_from_object(unsigned int object_idx) const;
|
|
// returns the list of idxs of the volumes contained into the instance with the given idxs
|
|
std::vector<unsigned int> get_volume_idxs_from_instance(unsigned int object_idx, unsigned int instance_idx) const;
|
|
// returns the idx of the volume corresponding to the volume with the given idxs
|
|
std::vector<unsigned int> get_volume_idxs_from_volume(unsigned int object_idx, unsigned int instance_idx, unsigned int volume_idx) const;
|
|
// returns the list of idxs of the volumes contained in the selection but not in the given list
|
|
std::vector<unsigned int> get_missing_volume_idxs_from(const std::vector<unsigned int>& volume_idxs) const;
|
|
// returns the list of idxs of the volumes contained in the given list but not in the selection
|
|
std::vector<unsigned int> get_unselected_volume_idxs_from(const std::vector<unsigned int>& volume_idxs) const;
|
|
|
|
private:
|
|
void update_valid();
|
|
void update_type();
|
|
void set_caches();
|
|
void do_add_volume(unsigned int volume_idx);
|
|
void do_add_volumes(const std::vector<unsigned int>& volume_idxs);
|
|
void do_remove_volume(unsigned int volume_idx);
|
|
void do_remove_instance(unsigned int object_idx, unsigned int instance_idx);
|
|
void do_remove_object(unsigned int object_idx);
|
|
void set_bounding_boxes_dirty() {
|
|
m_bounding_box.reset();
|
|
m_unscaled_instance_bounding_box.reset(); m_scaled_instance_bounding_box.reset();
|
|
m_full_unscaled_instance_bounding_box.reset();
|
|
m_full_scaled_instance_bounding_box.reset();
|
|
m_full_unscaled_instance_local_bounding_box.reset();
|
|
m_bounding_box_in_current_reference_system.reset();
|
|
m_bounding_sphere.reset();
|
|
}
|
|
void render_synchronized_volumes();
|
|
void render_bounding_box(const BoundingBoxf3& box, const Transform3d& trafo, const ColorRGB& color);
|
|
void render_sidebar_position_hints(const std::string& sidebar_field, GLShaderProgram& shader, const Transform3d& matrix);
|
|
void render_sidebar_rotation_hints(const std::string& sidebar_field, GLShaderProgram& shader, const Transform3d& matrix);
|
|
//BBS: GUI refactor: add uniform_scale from gizmo
|
|
void render_sidebar_scale_hints(const std::string& sidebar_field, bool gizmo_uniform_scale, GLShaderProgram& shader, const Transform3d& matrix);
|
|
void render_sidebar_layers_hints(const std::string& sidebar_field, GLShaderProgram& shader);
|
|
|
|
public:
|
|
enum class SyncRotationType {
|
|
// Do not synchronize rotation. Either not rotating at all, or rotating by world Z axis.
|
|
NONE = 0,
|
|
// Synchronize after rotation by an axis not parallel with Z.
|
|
GENERAL = 1,
|
|
// Synchronize after rotation reset.
|
|
RESET = 2
|
|
};
|
|
void synchronize_unselected_instances(SyncRotationType sync_rotation_type);
|
|
void synchronize_unselected_volumes();
|
|
|
|
private:
|
|
void ensure_on_bed();
|
|
void ensure_not_below_bed();
|
|
bool is_from_fully_selected_instance(unsigned int volume_idx) const;
|
|
|
|
void paste_volumes_from_clipboard();
|
|
void paste_objects_from_clipboard();
|
|
|
|
void transform_instance_relative(GLVolume& volume, const VolumeCache& volume_data, TransformationType transformation_type,
|
|
const Transform3d& transform, const Vec3d& world_pivot);
|
|
void transform_volume_relative(GLVolume& volume, const VolumeCache& volume_data, TransformationType transformation_type,
|
|
const Transform3d& transform, const Vec3d& world_pivot);
|
|
};
|
|
|
|
ModelVolume *get_selected_volume (const Selection &selection);
|
|
const GLVolume *get_selected_gl_volume(const Selection &selection);
|
|
|
|
ModelVolume *get_selected_volume (const ObjectID &volume_id, const Selection &selection);
|
|
ModelVolume *get_volume (const ObjectID &volume_id, const Selection &selection);
|
|
|
|
} // namespace GUI
|
|
} // namespace Slic3r
|
|
|
|
#endif // slic3r_GUI_Selection_hpp_
|