2013-07-14 12:56:43 +00:00
|
|
|
%module{Slic3r::XS};
|
|
|
|
|
|
|
|
%{
|
|
|
|
#include <myinit.h>
|
|
|
|
#include "SurfaceCollection.hpp"
|
|
|
|
%}
|
|
|
|
|
|
|
|
%name{Slic3r::Surface::Collection} class SurfaceCollection {
|
|
|
|
~SurfaceCollection();
|
|
|
|
void clear()
|
|
|
|
%code{% THIS->surfaces.clear(); %};
|
2013-09-17 21:38:23 +00:00
|
|
|
int count()
|
|
|
|
%code{% RETVAL = THIS->surfaces.size(); %};
|
2013-11-22 01:16:10 +00:00
|
|
|
void simplify(double tolerance);
|
2013-07-14 12:56:43 +00:00
|
|
|
%{
|
|
|
|
|
|
|
|
SurfaceCollection*
|
|
|
|
SurfaceCollection::new(...)
|
|
|
|
CODE:
|
2013-08-08 00:10:34 +00:00
|
|
|
RETVAL = new SurfaceCollection;
|
2013-07-14 12:56:43 +00:00
|
|
|
// ST(0) is class name, others are surfaces
|
|
|
|
RETVAL->surfaces.resize(items-1);
|
|
|
|
for (unsigned int i = 1; i < items; i++) {
|
2013-07-15 20:57:22 +00:00
|
|
|
// Note: a COPY of the input is stored
|
2013-08-08 00:10:34 +00:00
|
|
|
RETVAL->surfaces[i-1] = *(Surface *)SvIV((SV*)SvRV( ST(i) ));
|
2013-07-14 12:56:43 +00:00
|
|
|
}
|
|
|
|
OUTPUT:
|
|
|
|
RETVAL
|
|
|
|
|
|
|
|
SV*
|
|
|
|
SurfaceCollection::arrayref()
|
|
|
|
CODE:
|
|
|
|
AV* av = newAV();
|
|
|
|
av_fill(av, THIS->surfaces.size()-1);
|
|
|
|
int i = 0;
|
2013-08-08 00:10:34 +00:00
|
|
|
for (Surfaces::iterator it = THIS->surfaces.begin(); it != THIS->surfaces.end(); ++it) {
|
2013-09-06 16:36:38 +00:00
|
|
|
av_store(av, i++, (*it).to_SV_ref());
|
|
|
|
}
|
|
|
|
RETVAL = newRV_noinc((SV*)av);
|
|
|
|
OUTPUT:
|
|
|
|
RETVAL
|
|
|
|
|
|
|
|
SV*
|
|
|
|
SurfaceCollection::filter_by_type(surface_type)
|
|
|
|
SurfaceType surface_type;
|
|
|
|
CODE:
|
|
|
|
AV* av = newAV();
|
|
|
|
for (Surfaces::iterator it = THIS->surfaces.begin(); it != THIS->surfaces.end(); ++it) {
|
|
|
|
if ((*it).surface_type == surface_type) av_push(av, (*it).to_SV_ref());
|
2013-07-14 12:56:43 +00:00
|
|
|
}
|
|
|
|
RETVAL = newRV_noinc((SV*)av);
|
|
|
|
OUTPUT:
|
|
|
|
RETVAL
|
|
|
|
|
|
|
|
void
|
|
|
|
SurfaceCollection::append(...)
|
|
|
|
CODE:
|
|
|
|
for (unsigned int i = 1; i < items; i++) {
|
2013-09-06 16:36:38 +00:00
|
|
|
// Note: a COPY of the input is stored
|
2013-08-08 00:10:34 +00:00
|
|
|
THIS->surfaces.push_back(*(Surface *)SvIV((SV*)SvRV( ST(i) )));
|
2013-07-14 12:56:43 +00:00
|
|
|
}
|
|
|
|
|
2013-08-08 00:10:34 +00:00
|
|
|
void
|
|
|
|
SurfaceCollection::replace(index, surface)
|
|
|
|
int index
|
|
|
|
Surface* surface
|
|
|
|
CODE:
|
|
|
|
THIS->surfaces[index] = *surface;
|
|
|
|
|
|
|
|
void
|
|
|
|
SurfaceCollection::set_surface_type(index, surface_type)
|
|
|
|
int index
|
|
|
|
SurfaceType surface_type;
|
|
|
|
CODE:
|
|
|
|
THIS->surfaces[index].surface_type = surface_type;
|
|
|
|
|
2013-11-23 17:15:59 +00:00
|
|
|
SV*
|
|
|
|
SurfaceCollection::group(merge_solid = false)
|
|
|
|
bool merge_solid
|
|
|
|
CODE:
|
|
|
|
// perform grouping
|
|
|
|
std::vector<SurfacesPtr> groups;
|
|
|
|
THIS->group(groups, merge_solid);
|
|
|
|
|
|
|
|
// build return arrayref
|
|
|
|
AV* av = newAV();
|
|
|
|
av_fill(av, groups.size()-1);
|
|
|
|
size_t i = 0;
|
|
|
|
for (std::vector<SurfacesPtr>::iterator it = groups.begin(); it != groups.end(); ++it) {
|
|
|
|
AV* innerav = newAV();
|
|
|
|
av_fill(innerav, it->size()-1);
|
|
|
|
size_t j = 0;
|
|
|
|
for (SurfacesPtr::iterator it_s = it->begin(); it_s != it->end(); ++it_s) {
|
|
|
|
av_store(innerav, j++, (*it_s)->to_SV_clone_ref());
|
|
|
|
}
|
|
|
|
av_store(av, i++, newRV_noinc((SV*)innerav));
|
|
|
|
}
|
|
|
|
RETVAL = newRV_noinc((SV*)av);
|
|
|
|
OUTPUT:
|
|
|
|
RETVAL
|
|
|
|
|
2013-07-14 12:56:43 +00:00
|
|
|
%}
|
|
|
|
};
|