mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Reduced max size of index buffers to 32M indices
This commit is contained in:
parent
d631bf7c0c
commit
62dedba32d
1 changed files with 5 additions and 2 deletions
|
@ -1454,6 +1454,10 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result)
|
||||||
for (TBuffer& buffer : m_buffers) {
|
for (TBuffer& buffer : m_buffers) {
|
||||||
buffer.paths.clear();
|
buffer.paths.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// max index buffer size
|
||||||
|
const size_t IBUFFER_THRESHOLD = 1024 * 1024 * 32;
|
||||||
|
|
||||||
// variable used to keep track of the current size (in vertices) of the vertex buffer
|
// variable used to keep track of the current size (in vertices) of the vertex buffer
|
||||||
std::vector<size_t> curr_buffer_vertices_size(m_buffers.size(), 0);
|
std::vector<size_t> curr_buffer_vertices_size(m_buffers.size(), 0);
|
||||||
for (size_t i = 0; i < m_moves_count; ++i) {
|
for (size_t i = 0; i < m_moves_count; ++i) {
|
||||||
|
@ -1478,10 +1482,9 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result)
|
||||||
if (buffer_indices.empty())
|
if (buffer_indices.empty())
|
||||||
buffer_indices.push_back(IndexBuffer());
|
buffer_indices.push_back(IndexBuffer());
|
||||||
|
|
||||||
static const size_t THRESHOLD = 1024 * 1024 * 128;
|
|
||||||
// if adding the indices for the current segment exceeds the threshold size of the current index buffer
|
// if adding the indices for the current segment exceeds the threshold size of the current index buffer
|
||||||
// create another index buffer, and move the current path indices into it
|
// create another index buffer, and move the current path indices into it
|
||||||
if (buffer_indices.back().size() >= THRESHOLD - static_cast<size_t>(buffer.indices_per_segment())) {
|
if (buffer_indices.back().size() >= IBUFFER_THRESHOLD - static_cast<size_t>(buffer.indices_per_segment())) {
|
||||||
buffer_indices.push_back(IndexBuffer());
|
buffer_indices.push_back(IndexBuffer());
|
||||||
if (buffer.render_primitive_type != TBuffer::ERenderPrimitiveType::Point) {
|
if (buffer.render_primitive_type != TBuffer::ERenderPrimitiveType::Point) {
|
||||||
if (!(prev.type != curr.type || !buffer.paths.back().matches(curr))) {
|
if (!(prev.type != curr.type || !buffer.paths.back().matches(curr))) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue