8a2a9dba2f
TriangleMesh newly only holds indexed_triangle_set and TriangleMeshStats. TriangleMeshStats contains an excerpt of stl_stats. TriangleMeshStats are updated when initializing with indexed_triangle_set. Admesh triangle mesh fixing is newly only used when loading an STL. AMF / 3MF / OBJ file formats are already indexed triangle sets, thus they are no more converted to admesh stl_file format, nor fixed through admesh repair machinery. When importing AMF / 3MF / OBJ files, volume is calculated and if negative, all faces are flipped. Also a bounding box and number of open edges is calculated. Implemented its_number_of_patches(), its_num_open_edges() Optimized its_split(), its_is_splittable() using a visitor pattern. Reworked QHull integration into TriangleMesh: 1) Face normals were not right. 2) Indexed triangle set is newly emitted instead of duplicating vertices for each face. Fixed cut_mesh(): Orient the triangulated faces correctly.
63 lines
1.7 KiB
C++
63 lines
1.7 KiB
C++
#include "ShaderCSGDisplay.hpp"
|
|
#include "libslic3r/SLAPrint.hpp"
|
|
#include <GL/glew.h>
|
|
|
|
namespace Slic3r { namespace GL {
|
|
|
|
void ShaderCSGDisplay::add_mesh(const TriangleMesh &mesh)
|
|
{
|
|
auto v = std::make_shared<CSGVolume>();
|
|
v->load_mesh(mesh);
|
|
m_volumes.emplace_back(v);
|
|
}
|
|
|
|
void ShaderCSGDisplay::render_scene()
|
|
{
|
|
GLfloat color[] = {1.f, 1.f, 0.f, 0.f};
|
|
glColor4fv(color);
|
|
glDepthFunc(GL_LESS);
|
|
for (auto &v : m_volumes) v->render();
|
|
glFlush();
|
|
}
|
|
|
|
void ShaderCSGDisplay::on_scene_updated(const Scene &scene)
|
|
{
|
|
// TriangleMesh mesh = print->objects().front()->hollowed_interior_mesh();
|
|
// Look at CSGDisplay::on_scene_updated to see how its done there.
|
|
|
|
const SLAPrint *print = scene.get_print();
|
|
if (!print) return;
|
|
|
|
m_volumes.clear();
|
|
|
|
for (const SLAPrintObject *po : print->objects()) {
|
|
const ModelObject *mo = po->model_object();
|
|
TriangleMesh msh = mo->raw_mesh();
|
|
|
|
sla::DrainHoles holedata = mo->sla_drain_holes;
|
|
|
|
for (const ModelInstance *mi : mo->instances) {
|
|
|
|
TriangleMesh mshinst = msh;
|
|
auto interior = po->hollowed_interior_mesh();
|
|
interior.transform(po->trafo().inverse());
|
|
|
|
mshinst.merge(interior);
|
|
|
|
mi->transform_mesh(&mshinst);
|
|
|
|
auto bb = mshinst.bounding_box();
|
|
auto center = bb.center().cast<float>();
|
|
mshinst.translate(-center);
|
|
|
|
add_mesh(mshinst);
|
|
}
|
|
|
|
for (const sla::DrainHole &holept : holedata)
|
|
add_mesh(sla::to_triangle_mesh(holept.to_mesh()));
|
|
}
|
|
|
|
repaint();
|
|
}
|
|
|
|
}} // namespace Slic3r::GL
|