mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	 812cbade4d
			
		
	
	
		812cbade4d
		
	
	
	
	
		
			
			1) New algorithm for connecting along the perimeters is now applied to Honeycomb, Hilbert and similar planar filling curves. 2) The old expensive path chaining is not applied if the new algorithm to connect along the perimeter lines is called afterwards.
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| %module{Slic3r::XS};
 | |
| 
 | |
| %{
 | |
| #include <xsinit.h>
 | |
| #include "libslic3r/Fill/Fill.hpp"
 | |
| #include "libslic3r/ExtrusionEntity.hpp"
 | |
| #include "libslic3r/ExtrusionEntityCollection.hpp"
 | |
| %}
 | |
| 
 | |
| %name{Slic3r::Filler} class Filler {
 | |
|     ~Filler();
 | |
| 
 | |
|     void set_bounding_box(BoundingBox *bbox)
 | |
|         %code{% THIS->fill->set_bounding_box(*bbox); %};
 | |
|     void set_spacing(coordf_t spacing)
 | |
|         %code{% THIS->fill->spacing = spacing; %};
 | |
|     coordf_t spacing()
 | |
|         %code{% RETVAL = THIS->fill->spacing; %};
 | |
|     void set_layer_id(size_t layer_id)
 | |
|         %code{% THIS->fill->layer_id = layer_id; %};
 | |
|     void set_z(coordf_t z)
 | |
|         %code{% THIS->fill->z = z; %};
 | |
|     void set_angle(float angle)
 | |
|         %code{% THIS->fill->angle = angle; %};
 | |
|     void set_link_max_length(coordf_t len)
 | |
|         %code{% THIS->fill->link_max_length = len; %};
 | |
|     void set_loop_clipping(coordf_t clipping)
 | |
|         %code{% THIS->fill->loop_clipping = clipping; %};
 | |
| 
 | |
|     bool use_bridge_flow()
 | |
|         %code{% RETVAL = THIS->fill->use_bridge_flow(); %};
 | |
|     bool no_sort()
 | |
|         %code{% RETVAL = THIS->fill->no_sort(); %};
 | |
| 
 | |
|     void set_density(float density)
 | |
|         %code{% THIS->params.density = density; %};
 | |
|     void set_dont_adjust(bool dont_adjust)
 | |
|         %code{% THIS->params.dont_adjust = dont_adjust; %};
 | |
| 
 | |
|     PolylineCollection* _fill_surface(Surface *surface)
 | |
|         %code{% 
 | |
|             PolylineCollection *pc = NULL;
 | |
|             if (THIS->fill != NULL) {
 | |
|                 pc = new PolylineCollection();
 | |
|                 pc->polylines = THIS->fill->fill_surface(surface, THIS->params);
 | |
|             }
 | |
|             RETVAL =  pc;
 | |
|         %};
 | |
| 
 | |
| %{
 | |
| 
 | |
| Filler*
 | |
| new_from_type(CLASS, type)
 | |
|     char*               CLASS;
 | |
|     std::string         type;
 | |
|     CODE:
 | |
|         Filler *filler = new Filler();
 | |
|         filler->fill = Fill::new_from_type(type);
 | |
|         RETVAL = filler;
 | |
|     OUTPUT:
 | |
|         RETVAL
 | |
| 
 | |
| %}
 | |
| 
 | |
| };
 |