Copy and paste -> Clipboard refactored to accept more than one object
This commit is contained in:
parent
a80978f84a
commit
7a1fab09d4
3 changed files with 38 additions and 61 deletions
|
@ -2167,6 +2167,7 @@ void ObjectList::update_selections_on_canvas()
|
|||
add_to_selection(item, selection, instance_idx, false);
|
||||
|
||||
wxGetApp().plater()->canvas3D()->update_gizmos_on_off_state();
|
||||
wxGetApp().plater()->canvas3D()->render();
|
||||
}
|
||||
|
||||
void ObjectList::select_item(const wxDataViewItem& item)
|
||||
|
|
|
@ -47,23 +47,6 @@ Selection::VolumeCache::VolumeCache(const Geometry::Transformation& volume_trans
|
|||
{
|
||||
}
|
||||
|
||||
Selection::Clipboard::Clipboard()
|
||||
: m_object(nullptr)
|
||||
{
|
||||
m_object = m_model.add_object();
|
||||
}
|
||||
|
||||
void Selection::Clipboard::add_volume(const ModelVolume& volume)
|
||||
{
|
||||
ModelVolume* v = m_object->add_volume(volume);
|
||||
v->config = volume.config;
|
||||
}
|
||||
|
||||
const ModelVolume* Selection::Clipboard::get_volume(unsigned int id) const
|
||||
{
|
||||
return (id < (unsigned int)m_object->volumes.size()) ? m_object->volumes[id] : nullptr;
|
||||
}
|
||||
|
||||
Selection::Selection()
|
||||
: m_volumes(nullptr)
|
||||
, m_model(nullptr)
|
||||
|
@ -1046,33 +1029,36 @@ void Selection::copy_to_clipboard()
|
|||
|
||||
m_clipboard.reset();
|
||||
|
||||
for (unsigned int i : m_list)
|
||||
for (const ObjectIdxsToInstanceIdxsMap::value_type& object : m_cache.content)
|
||||
{
|
||||
const GLVolume* volume = (*m_volumes)[i];
|
||||
int obj_idx = volume->object_idx();
|
||||
if ((0 <= obj_idx) && (obj_idx < (int)m_model->objects.size()))
|
||||
ModelObject* src_object = m_model->objects[object.first];
|
||||
ModelObject* dst_object = m_clipboard.add_object();
|
||||
|
||||
for (int i : object.second)
|
||||
{
|
||||
const ModelObject* model_object = m_model->objects[obj_idx];
|
||||
int vol_idx = volume->volume_idx();
|
||||
if ((0 <= vol_idx) && (vol_idx < (int)model_object->volumes.size()))
|
||||
m_clipboard.add_volume(*model_object->volumes[vol_idx]);
|
||||
dst_object->add_instance(*src_object->instances[i]);
|
||||
}
|
||||
|
||||
for (unsigned int i : m_list)
|
||||
{
|
||||
const GLVolume* volume = (*m_volumes)[i];
|
||||
if (volume->object_idx() == object.first)
|
||||
{
|
||||
ModelVolume* src_volume = src_object->volumes[i];
|
||||
ModelVolume* dst_volume = dst_object->add_volume(*src_volume);
|
||||
dst_volume->set_new_unique_id();
|
||||
dst_volume->config = src_volume->config;
|
||||
}
|
||||
}
|
||||
dst_object->config = src_object->config;
|
||||
}
|
||||
|
||||
int obj_idx = get_object_idx();
|
||||
if ((0 <= obj_idx) && (obj_idx < (int)m_model->objects.size()))
|
||||
m_clipboard.get_object()->config = m_model->objects[obj_idx]->config;
|
||||
|
||||
m_clipboard.set_mode(m_mode);
|
||||
m_clipboard.set_type(m_type);
|
||||
}
|
||||
|
||||
void Selection::paste_from_clipboard()
|
||||
{
|
||||
if (!m_valid)
|
||||
return;
|
||||
|
||||
if (m_clipboard.is_empty())
|
||||
if (!m_valid || m_clipboard.is_empty())
|
||||
return;
|
||||
|
||||
if ((m_clipboard.get_mode() == Volume) && is_from_single_instance())
|
||||
|
@ -1767,26 +1753,25 @@ void Selection::paste_volumes_from_clipboard()
|
|||
if ((obj_idx < 0) || ((int)m_model->objects.size() <= obj_idx))
|
||||
return;
|
||||
|
||||
ModelObject& model_object = *m_model->objects[obj_idx];
|
||||
unsigned int count = m_clipboard.get_volumes_count();
|
||||
ModelVolumePtrs volumes;
|
||||
for (unsigned int i = 0; i < count; ++i)
|
||||
ModelObject* src_object = m_clipboard.get_object(0);
|
||||
if (src_object != nullptr)
|
||||
{
|
||||
const ModelVolume* volume = m_clipboard.get_volume(i);
|
||||
ModelVolume* new_volume = model_object.add_volume(*volume);
|
||||
new_volume->config = volume->config;
|
||||
new_volume->set_new_unique_id();
|
||||
volumes.push_back(new_volume);
|
||||
ModelObject* dst_object = m_model->objects[obj_idx];
|
||||
|
||||
ModelVolumePtrs volumes;
|
||||
for (ModelVolume* src_volume : src_object->volumes)
|
||||
{
|
||||
ModelVolume* dst_volume = dst_object->add_volume(*src_volume);
|
||||
dst_volume->config = src_volume->config;
|
||||
dst_volume->set_new_unique_id();
|
||||
volumes.push_back(dst_volume);
|
||||
}
|
||||
wxGetApp().obj_list()->paste_volumes_into_list(obj_idx, volumes);
|
||||
}
|
||||
wxGetApp().obj_list()->paste_volumes_into_list(obj_idx, volumes);
|
||||
int a = 0;
|
||||
}
|
||||
|
||||
void Selection::paste_object_from_clipboard()
|
||||
{
|
||||
ModelObject* model_object = m_clipboard.get_object();
|
||||
if (model_object != nullptr)
|
||||
wxGetApp().obj_list()->paste_object_into_list(*model_object);
|
||||
}
|
||||
|
||||
} // namespace GUI
|
||||
|
|
|
@ -154,26 +154,17 @@ private:
|
|||
class Clipboard
|
||||
{
|
||||
Model m_model;
|
||||
ModelObject* m_object;
|
||||
Selection::EMode m_mode;
|
||||
Selection::EType m_type;
|
||||
|
||||
public:
|
||||
Clipboard();
|
||||
void reset() { m_model.clear_objects(); }
|
||||
bool is_empty() const { return m_model.objects.empty(); }
|
||||
|
||||
void reset() { if (m_object != nullptr) m_object->clear_volumes(); }
|
||||
void add_volume(const ModelVolume& volume);
|
||||
const ModelVolume* get_volume(unsigned int id) const;
|
||||
ModelObject* get_object() { return m_object; }
|
||||
const ModelObject* get_object() const { return m_object; }
|
||||
const unsigned int get_volumes_count() const { return (unsigned int)m_object->volumes.size(); }
|
||||
|
||||
bool is_empty() const { return (m_object == nullptr) || m_object->volumes.empty(); }
|
||||
ModelObject* add_object() { return m_model.add_object(); }
|
||||
ModelObject* get_object(unsigned int id) { return (id < (unsigned int)m_model.objects.size()) ? m_model.objects[id] : nullptr; }
|
||||
|
||||
Selection::EMode get_mode() const { return m_mode; }
|
||||
void set_mode(Selection::EMode mode) { m_mode = mode; }
|
||||
Selection::EType get_type() const { return m_type; }
|
||||
void set_type(Selection::EType type) { m_type = type; }
|
||||
};
|
||||
|
||||
// Volumes owned by GLCanvas3D.
|
||||
|
|
Loading…
Reference in a new issue