|
|
|
|
@@ -164,7 +164,9 @@ ModelObject* Model::add_object(const char *name, const char *path, const Triangl
|
|
|
|
|
this->objects.push_back(new_object);
|
|
|
|
|
new_object->name = name;
|
|
|
|
|
new_object->input_file = path;
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
ModelVolume *new_volume = new_object->add_volume(mesh);
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
new_volume->name = name;
|
|
|
|
|
new_object->invalidate_bounding_box();
|
|
|
|
|
return new_object;
|
|
|
|
|
@@ -176,7 +178,9 @@ ModelObject* Model::add_object(const char *name, const char *path, TriangleMesh
|
|
|
|
|
this->objects.push_back(new_object);
|
|
|
|
|
new_object->name = name;
|
|
|
|
|
new_object->input_file = path;
|
|
|
|
|
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
ModelVolume *new_volume = new_object->add_volume(std::move(mesh));
|
|
|
|
|
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
new_volume->name = name;
|
|
|
|
|
new_object->invalidate_bounding_box();
|
|
|
|
|
return new_object;
|
|
|
|
|
@@ -481,10 +485,39 @@ void Model::convert_multipart_object(unsigned int max_extruders)
|
|
|
|
|
|
|
|
|
|
reset_auto_extruder_id();
|
|
|
|
|
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
//#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
// for (const ModelObject* o : this->objects)
|
|
|
|
|
// {
|
|
|
|
|
// const ModelInstance* i = o->instances.front();
|
|
|
|
|
// const Geometry::Transformation& t = i->get_transformation();
|
|
|
|
|
// for (const ModelVolume* v : o->volumes)
|
|
|
|
|
// {
|
|
|
|
|
////$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
// ModelVolume* new_v = object->add_volume(*v);
|
|
|
|
|
////$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
// if (new_v != nullptr)
|
|
|
|
|
// {
|
|
|
|
|
// new_v->name = o->name;
|
|
|
|
|
// new_v->set_transformation(t * new_v->get_transformation());
|
|
|
|
|
// new_v->config.set_deserialize("extruder", get_auto_extruder_id_as_string(max_extruders));
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// for (const ModelInstance* i : this->objects.front()->instances)
|
|
|
|
|
// {
|
|
|
|
|
// ModelInstance* inst = object->add_instance(*i);
|
|
|
|
|
// inst->set_transformation(Geometry::Transformation());
|
|
|
|
|
// }
|
|
|
|
|
//#else
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
for (const ModelObject* o : this->objects)
|
|
|
|
|
for (const ModelVolume* v : o->volumes)
|
|
|
|
|
{
|
|
|
|
|
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
ModelVolume* new_v = object->add_volume(*v);
|
|
|
|
|
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
|
|
|
|
|
if (new_v != nullptr)
|
|
|
|
|
{
|
|
|
|
|
new_v->name = o->name;
|
|
|
|
|
@@ -494,6 +527,9 @@ void Model::convert_multipart_object(unsigned int max_extruders)
|
|
|
|
|
|
|
|
|
|
for (const ModelInstance* i : this->objects.front()->instances)
|
|
|
|
|
object->add_instance(*i);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
//#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
|
|
|
|
|
this->clear_objects();
|
|
|
|
|
this->objects.push_back(object);
|
|
|
|
|
@@ -641,6 +677,11 @@ ModelVolume* ModelObject::add_volume(const TriangleMesh &mesh)
|
|
|
|
|
{
|
|
|
|
|
ModelVolume* v = new ModelVolume(this, mesh);
|
|
|
|
|
this->volumes.push_back(v);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
v->center_geometry();
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
this->invalidate_bounding_box();
|
|
|
|
|
return v;
|
|
|
|
|
}
|
|
|
|
|
@@ -649,6 +690,11 @@ ModelVolume* ModelObject::add_volume(TriangleMesh &&mesh)
|
|
|
|
|
{
|
|
|
|
|
ModelVolume* v = new ModelVolume(this, std::move(mesh));
|
|
|
|
|
this->volumes.push_back(v);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
v->center_geometry();
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
this->invalidate_bounding_box();
|
|
|
|
|
return v;
|
|
|
|
|
}
|
|
|
|
|
@@ -657,6 +703,11 @@ ModelVolume* ModelObject::add_volume(const ModelVolume &other)
|
|
|
|
|
{
|
|
|
|
|
ModelVolume* v = new ModelVolume(this, other);
|
|
|
|
|
this->volumes.push_back(v);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
v->center_geometry();
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
this->invalidate_bounding_box();
|
|
|
|
|
return v;
|
|
|
|
|
}
|
|
|
|
|
@@ -665,6 +716,11 @@ ModelVolume* ModelObject::add_volume(const ModelVolume &other, TriangleMesh &&me
|
|
|
|
|
{
|
|
|
|
|
ModelVolume* v = new ModelVolume(this, other, std::move(mesh));
|
|
|
|
|
this->volumes.push_back(v);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
v->center_geometry();
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
this->invalidate_bounding_box();
|
|
|
|
|
return v;
|
|
|
|
|
}
|
|
|
|
|
@@ -675,6 +731,30 @@ void ModelObject::delete_volume(size_t idx)
|
|
|
|
|
delete *i;
|
|
|
|
|
this->volumes.erase(i);
|
|
|
|
|
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
if (this->volumes.size() == 1)
|
|
|
|
|
{
|
|
|
|
|
// only one volume left
|
|
|
|
|
// we need to collapse the volume transform into the instances transforms because now when selecting this volume
|
|
|
|
|
// it will be seen as a single full instance ans so its volume transform may be ignored
|
|
|
|
|
ModelVolume* v = this->volumes.front();
|
|
|
|
|
Transform3d v_t = v->get_transformation().get_matrix();
|
|
|
|
|
// Transform3d v_t = v->get_transformation().get_matrix(true);
|
|
|
|
|
for (ModelInstance* inst : this->instances)
|
|
|
|
|
{
|
|
|
|
|
// Vec3d offset = inst->get_offset();
|
|
|
|
|
inst->set_transformation(Geometry::Transformation(inst->get_transformation().get_matrix() * v_t));
|
|
|
|
|
// inst->set_transformation(Geometry::Transformation(inst->get_transformation().get_matrix(true) * v_t));
|
|
|
|
|
// inst->set_offset(offset);
|
|
|
|
|
}
|
|
|
|
|
Geometry::Transformation t;
|
|
|
|
|
// t.set_offset(v->get_offset());
|
|
|
|
|
v->set_transformation(t);
|
|
|
|
|
v->set_new_unique_id();
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
if (this->volumes.size() == 1)
|
|
|
|
|
{
|
|
|
|
|
// only one volume left
|
|
|
|
|
@@ -691,6 +771,9 @@ void ModelObject::delete_volume(size_t idx)
|
|
|
|
|
v->set_offset(Vec3d::Zero());
|
|
|
|
|
v->set_new_unique_id();
|
|
|
|
|
}
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
|
|
|
|
|
this->invalidate_bounding_box();
|
|
|
|
|
}
|
|
|
|
|
@@ -868,15 +951,39 @@ BoundingBoxf3 ModelObject::instance_bounding_box(size_t instance_idx, bool dont_
|
|
|
|
|
return bb;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
BoundingBoxf3 ModelObject::full_raw_mesh_bounding_box() const
|
|
|
|
|
{
|
|
|
|
|
BoundingBoxf3 bb;
|
|
|
|
|
for (const ModelVolume *v : this->volumes)
|
|
|
|
|
{
|
|
|
|
|
TriangleMesh vol_mesh(v->mesh);
|
|
|
|
|
vol_mesh.transform(v->get_matrix());
|
|
|
|
|
bb.merge(vol_mesh.bounding_box());
|
|
|
|
|
}
|
|
|
|
|
return bb;
|
|
|
|
|
}
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
|
|
|
|
|
void ModelObject::center_around_origin()
|
|
|
|
|
{
|
|
|
|
|
// calculate the displacements needed to
|
|
|
|
|
// center this object around the origin
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
BoundingBoxf3 bb = full_raw_mesh_bounding_box();
|
|
|
|
|
#else
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
BoundingBoxf3 bb;
|
|
|
|
|
for (ModelVolume *v : this->volumes)
|
|
|
|
|
if (v->is_model_part())
|
|
|
|
|
bb.merge(v->mesh.bounding_box());
|
|
|
|
|
|
|
|
|
|
bb.merge(v->mesh.bounding_box());
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
|
|
|
|
|
// Shift is the vector from the center of the bounding box to the origin
|
|
|
|
|
Vec3d shift = -bb.center();
|
|
|
|
|
|
|
|
|
|
@@ -1040,9 +1147,12 @@ ModelObjectPtrs ModelObject::cut(size_t instance, coordf_t z, bool keep_upper, b
|
|
|
|
|
|
|
|
|
|
volume->set_transformation(Geometry::Transformation(instance_matrix * volume_matrix));
|
|
|
|
|
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
if (keep_upper) { upper->add_volume(*volume); }
|
|
|
|
|
if (keep_lower) { lower->add_volume(*volume); }
|
|
|
|
|
} else {
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
TriangleMesh upper_mesh, lower_mesh;
|
|
|
|
|
|
|
|
|
|
// Transform the mesh by the combined transformation matrix
|
|
|
|
|
@@ -1067,14 +1177,18 @@ ModelObjectPtrs ModelObject::cut(size_t instance, coordf_t z, bool keep_upper, b
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (keep_upper && upper_mesh.facets_count() > 0) {
|
|
|
|
|
ModelVolume* vol = upper->add_volume(upper_mesh);
|
|
|
|
|
vol->name = volume->name;
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
ModelVolume* vol = upper->add_volume(upper_mesh);
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
vol->name = volume->name;
|
|
|
|
|
vol->config = volume->config;
|
|
|
|
|
vol->set_material(volume->material_id(), *volume->material());
|
|
|
|
|
}
|
|
|
|
|
if (keep_lower && lower_mesh.facets_count() > 0) {
|
|
|
|
|
ModelVolume* vol = lower->add_volume(lower_mesh);
|
|
|
|
|
vol->name = volume->name;
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
ModelVolume* vol = lower->add_volume(lower_mesh);
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
vol->name = volume->name;
|
|
|
|
|
vol->config = volume->config;
|
|
|
|
|
vol->set_material(volume->material_id(), *volume->material());
|
|
|
|
|
|
|
|
|
|
@@ -1152,8 +1266,10 @@ void ModelObject::split(ModelObjectPtrs* new_objects)
|
|
|
|
|
new_object->instances.reserve(this->instances.size());
|
|
|
|
|
for (const ModelInstance *model_instance : this->instances)
|
|
|
|
|
new_object->add_instance(*model_instance);
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
ModelVolume* new_vol = new_object->add_volume(*volume, std::move(*mesh));
|
|
|
|
|
new_vol->center_geometry();
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
|
|
|
|
|
for (ModelInstance* model_instance : new_object->instances)
|
|
|
|
|
{
|
|
|
|
|
@@ -1321,10 +1437,24 @@ int ModelVolume::extruder_id() const
|
|
|
|
|
|
|
|
|
|
void ModelVolume::center_geometry()
|
|
|
|
|
{
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#if ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
Vec3d shift = mesh.bounding_box().center();
|
|
|
|
|
if (!shift.isApprox(Vec3d::Zero()))
|
|
|
|
|
{
|
|
|
|
|
mesh.translate(-(float)shift(0), -(float)shift(1), -(float)shift(2));
|
|
|
|
|
m_convex_hull.translate(-(float)shift(0), -(float)shift(1), -(float)shift(2));
|
|
|
|
|
translate(shift);
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
Vec3d shift = -mesh.bounding_box().center();
|
|
|
|
|
mesh.translate((float)shift(0), (float)shift(1), (float)shift(2));
|
|
|
|
|
m_convex_hull.translate((float)shift(0), (float)shift(1), (float)shift(2));
|
|
|
|
|
translate(-shift);
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
#endif // ENABLE_VOLUMES_CENTERING_FIXES
|
|
|
|
|
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void ModelVolume::calculate_convex_hull()
|
|
|
|
|
@@ -1400,7 +1530,9 @@ size_t ModelVolume::split(unsigned int max_extruders)
|
|
|
|
|
this->object->volumes.insert(this->object->volumes.begin() + (++ivolume), new ModelVolume(object, *this, std::move(*mesh)));
|
|
|
|
|
|
|
|
|
|
this->object->volumes[ivolume]->set_offset(Vec3d::Zero());
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
this->object->volumes[ivolume]->center_geometry();
|
|
|
|
|
//#################################################################################################################################################################################
|
|
|
|
|
this->object->volumes[ivolume]->translate(offset);
|
|
|
|
|
this->object->volumes[ivolume]->name = name + "_" + std::to_string(idx + 1);
|
|
|
|
|
this->object->volumes[ivolume]->config.set_deserialize("extruder", Model::get_auto_extruder_id_as_string(max_extruders));
|
|
|
|
|
|