mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-30 20:21:12 -06:00 
			
		
		
		
	 ed2ee2f6f3
			
		
	
	
		ed2ee2f6f3
		
	
	
	
	
		
			
			When extruding supports, the support is interleaved with interface if possible (when extruded with the same extruder). Otherwise the base is extruded first.
		
			
				
	
	
		
			104 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| %module{Slic3r::XS};
 | |
| 
 | |
| %{
 | |
| #include <xsinit.h>
 | |
| #include "libslic3r/ExtrusionEntityCollection.hpp"
 | |
| %}
 | |
| 
 | |
| %name{Slic3r::ExtrusionPath::Collection} class ExtrusionEntityCollection {
 | |
|     %name{_new} ExtrusionEntityCollection();
 | |
|     ~ExtrusionEntityCollection();
 | |
|     Clone<ExtrusionEntityCollection> clone()
 | |
|         %code{% RETVAL = THIS->clone(); %};
 | |
|     void reverse();
 | |
|     void clear();
 | |
|     ExtrusionEntityCollection* chained_path(bool no_reverse, ExtrusionRole role = erMixed)
 | |
|         %code{%
 | |
|             RETVAL = new ExtrusionEntityCollection();
 | |
|             THIS->chained_path(RETVAL, no_reverse, role);
 | |
|         %};
 | |
|     ExtrusionEntityCollection* chained_path_from(Point* start_near, bool no_reverse, ExtrusionRole role = erMixed)
 | |
|         %code{%
 | |
|             RETVAL = new ExtrusionEntityCollection();
 | |
|             THIS->chained_path_from(*start_near, RETVAL, no_reverse, role);
 | |
|         %};
 | |
|     Clone<Point> first_point();
 | |
|     Clone<Point> last_point();
 | |
|     int count()
 | |
|         %code{% RETVAL = THIS->entities.size(); %};
 | |
|     int items_count()
 | |
|         %code{% RETVAL = THIS->items_count(); %};
 | |
|     ExtrusionEntityCollection* flatten()
 | |
|         %code{%
 | |
|             RETVAL = new ExtrusionEntityCollection();
 | |
|             THIS->flatten(RETVAL);
 | |
|         %};
 | |
|     double min_mm3_per_mm();
 | |
|     bool empty()
 | |
|         %code{% RETVAL = THIS->entities.empty(); %};
 | |
|     std::vector<size_t> orig_indices()
 | |
|         %code{% RETVAL = THIS->orig_indices; %};
 | |
|     Polygons polygons_covered_by_width();
 | |
|     Polygons polygons_covered_by_spacing();
 | |
| %{
 | |
| 
 | |
| SV*
 | |
| ExtrusionEntityCollection::arrayref()
 | |
|     CODE:
 | |
|         AV* av = newAV();
 | |
|         av_fill(av, THIS->entities.size()-1);
 | |
|         int i = 0;
 | |
|         for (ExtrusionEntitiesPtr::iterator it = THIS->entities.begin(); it != THIS->entities.end(); ++it) {
 | |
|             SV* sv = newSV(0);
 | |
|             // return our item by reference
 | |
|             if (ExtrusionPath* path = dynamic_cast<ExtrusionPath*>(*it)) {
 | |
|                 sv_setref_pv( sv, perl_class_name_ref(path), path );
 | |
|             } else if (ExtrusionMultiPath* multipath = dynamic_cast<ExtrusionMultiPath*>(*it)) {
 | |
|                 sv_setref_pv( sv, perl_class_name_ref(multipath), multipath );
 | |
|             } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(*it)) {
 | |
|                 sv_setref_pv( sv, perl_class_name_ref(loop), loop );
 | |
|             } else if (ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(*it)) {
 | |
|                 sv_setref_pv( sv, perl_class_name_ref(collection), collection );
 | |
|             } else {
 | |
|                 croak("Unexpected type in ExtrusionEntityCollection");
 | |
|             }
 | |
|             av_store(av, i++, sv);
 | |
|         }
 | |
|         RETVAL = newRV_noinc((SV*)av);
 | |
|     OUTPUT:
 | |
|         RETVAL
 | |
| 
 | |
| void
 | |
| ExtrusionEntityCollection::append(...)
 | |
|     CODE:
 | |
|         for (unsigned int i = 1; i < items; i++) {
 | |
|             if(!sv_isobject( ST(i) ) || (SvTYPE(SvRV( ST(i) )) != SVt_PVMG)) {
 | |
|                 croak("Argument %d is not object", i);
 | |
|             }
 | |
|             ExtrusionEntity* entity = (ExtrusionEntity *)SvIV((SV*)SvRV( ST(i) ));
 | |
|             // append COPIES
 | |
|             if (ExtrusionPath* path = dynamic_cast<ExtrusionPath*>(entity)) {
 | |
|                 THIS->entities.push_back( new ExtrusionPath(*path) );
 | |
|             } else if (ExtrusionMultiPath* multipath = dynamic_cast<ExtrusionMultiPath*>(entity)) {
 | |
|                 THIS->entities.push_back( new ExtrusionMultiPath(*multipath) );
 | |
|             } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(entity)) {
 | |
|                 THIS->entities.push_back( new ExtrusionLoop(*loop) );
 | |
|             } else if(ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(entity)) {
 | |
|                 THIS->entities.push_back( collection->clone() );
 | |
|             } else {
 | |
|                 croak("Argument %d is of unknown type", i);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| bool
 | |
| ExtrusionEntityCollection::no_sort(...)
 | |
|     CODE:
 | |
|         if (items > 1) {
 | |
|             THIS->no_sort = SvTRUE(ST(1));
 | |
|         }
 | |
|         RETVAL = THIS->no_sort;
 | |
|     OUTPUT:
 | |
|         RETVAL
 | |
| 
 | |
| %}
 | |
| };
 |