mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			138 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| %module{Slic3r::XS};
 | |
| 
 | |
| %{
 | |
| #include <xsinit.h>
 | |
| #include "libslic3r/Point.hpp"
 | |
| #include "libslic3r/Line.hpp"
 | |
| #include "libslic3r/Polygon.hpp"
 | |
| #include "libslic3r/Polyline.hpp"
 | |
| %}
 | |
| 
 | |
| %name{Slic3r::Point} class Point {
 | |
|     Point(int _x = 0, int _y = 0);
 | |
|     ~Point();
 | |
|     Clone<Point> clone()
 | |
|         %code{% RETVAL=THIS; %}; 
 | |
|     void scale(double factor)
 | |
|         %code{% *THIS *= factor; %};
 | |
|     void translate(double x, double y)
 | |
|         %code{% *THIS += Point(x, y); %};
 | |
|     SV* arrayref()
 | |
|         %code{% RETVAL = to_SV_pureperl(THIS); %};
 | |
|     SV* pp()
 | |
|         %code{% RETVAL = to_SV_pureperl(THIS); %};
 | |
|     int x()
 | |
|         %code{% RETVAL = (*THIS)(0); %};
 | |
|     int y()
 | |
|         %code{% RETVAL = (*THIS)(1); %};
 | |
|     void set_x(int val)
 | |
|         %code{% (*THIS)(0) = val; %};
 | |
|     void set_y(int val)
 | |
|         %code{% (*THIS)(1) = val; %};
 | |
|     int nearest_point_index(Points points);
 | |
|     Clone<Point> nearest_point(Points points)
 | |
|         %code{% Point p; THIS->nearest_point(points, &p); RETVAL = p; %};
 | |
|     double distance_to(Point* point)
 | |
|         %code{% RETVAL = (*point - *THIS).cast<double>().norm(); %};
 | |
|     double distance_to_line(Line* line)
 | |
|         %code{% RETVAL = line->distance_to(*THIS); %};
 | |
|     double perp_distance_to_line(Line* line)
 | |
|         %code{% RETVAL = line->perp_distance_to(*THIS); %};
 | |
|     double ccw(Point* p1, Point* p2)
 | |
|         %code{% RETVAL = THIS->ccw(*p1, *p2); %};
 | |
|     double ccw_angle(Point* p1, Point* p2)
 | |
|         %code{% RETVAL = THIS->ccw_angle(*p1, *p2); %};
 | |
|     Point* projection_onto_polygon(Polygon* polygon)
 | |
|         %code{% RETVAL = new Point(THIS->projection_onto(*polygon)); %};
 | |
|     Point* projection_onto_polyline(Polyline* polyline)
 | |
|         %code{% RETVAL = new Point(THIS->projection_onto(*polyline)); %};
 | |
|     Point* projection_onto_line(Line* line)
 | |
|         %code{% RETVAL = new Point(THIS->projection_onto(*line)); %};
 | |
|     Point* negative()
 | |
|         %code{% RETVAL = new Point(- *THIS); %};
 | |
|     std::string serialize() %code{% char buf[2048]; sprintf(buf, "%ld,%ld", (*THIS)(0), (*THIS)(1)); RETVAL = buf; %};
 | |
| 
 | |
| %{
 | |
| 
 | |
| void
 | |
| Point::rotate(angle, center_sv)
 | |
|     double  angle;
 | |
|     SV*     center_sv;
 | |
|     CODE:
 | |
|         Point center;
 | |
|         from_SV_check(center_sv, ¢er);
 | |
|         THIS->rotate(angle, center);
 | |
| 
 | |
| bool
 | |
| Point::coincides_with(point_sv)
 | |
|     SV*     point_sv;
 | |
|     CODE:
 | |
|         Point point;
 | |
|         from_SV_check(point_sv, &point);
 | |
|         RETVAL = (*THIS) == point;
 | |
|     OUTPUT:
 | |
|         RETVAL
 | |
| 
 | |
| %}
 | |
| 
 | |
| };
 | |
| 
 | |
| %name{Slic3r::Pointf} class Vec2d {
 | |
|     Vec2d(double _x = 0, double _y = 0);
 | |
|     ~Vec2d();
 | |
|     Clone<Vec2d> clone()
 | |
|         %code{% RETVAL = THIS; %};
 | |
|     SV* arrayref()
 | |
|         %code{% RETVAL = to_SV_pureperl(THIS); %};
 | |
|     SV* pp()
 | |
|         %code{% RETVAL = to_SV_pureperl(THIS); %};
 | |
|     double x()
 | |
|         %code{% RETVAL = (*THIS)(0); %};
 | |
|     double y()
 | |
|         %code{% RETVAL = (*THIS)(1); %};
 | |
|     void set_x(double val)
 | |
|         %code{% (*THIS)(0) = val; %};
 | |
|     void set_y(double val)
 | |
|         %code{% (*THIS)(1) = val; %};
 | |
|     void translate(double x, double y)
 | |
|         %code{% *THIS += Vec2d(x, y); %};
 | |
|     void scale(double factor)
 | |
|         %code{% *THIS *= factor; %};
 | |
|     void rotate(double angle, Vec2d* center)
 | |
|         %code{% *THIS = Eigen::Translation2d(*center) * Eigen::Rotation2Dd(angle) * Eigen::Translation2d(- *center) * Eigen::Vector2d((*THIS)(0), (*THIS)(1)); %};
 | |
|     Vec2d* negative()
 | |
|         %code{% RETVAL = new Vec2d(- *THIS); %};
 | |
|     Vec2d* vector_to(Vec2d* point)
 | |
|         %code{% RETVAL = new Vec2d(*point - *THIS); %};
 | |
|     std::string serialize() %code{% char buf[2048]; sprintf(buf, "%lf,%lf", (*THIS)(0), (*THIS)(1)); RETVAL = buf; %};
 | |
| };
 | |
| 
 | |
| %name{Slic3r::Pointf3} class Vec3d {
 | |
|     Vec3d(double _x = 0, double _y = 0, double _z = 0);
 | |
|     ~Vec3d();
 | |
|     Clone<Vec3d> clone()
 | |
|         %code{% RETVAL = THIS; %};
 | |
|     double x()
 | |
|         %code{% RETVAL = (*THIS)(0); %};
 | |
|     double y()
 | |
|         %code{% RETVAL = (*THIS)(1); %};
 | |
|     double z()
 | |
|         %code{% RETVAL = (*THIS)(2); %};
 | |
|     void set_x(double val)
 | |
|         %code{% (*THIS)(0) = val; %};
 | |
|     void set_y(double val)
 | |
|         %code{% (*THIS)(1) = val; %};
 | |
|     void set_z(double val)
 | |
|         %code{% (*THIS)(2) = val; %};
 | |
|     void translate(double x, double y, double z)
 | |
|         %code{% *THIS += Vec3d(x, y, z); %};
 | |
|     void scale(double factor)
 | |
|         %code{% *THIS *= factor; %};
 | |
|     double distance_to(Vec3d* point)
 | |
|         %code{% RETVAL = (*point - *THIS).norm(); %};
 | |
|     Vec3d* negative()
 | |
|         %code{% RETVAL = new Vec3d(- *THIS); %};
 | |
|     Vec3d* vector_to(Vec3d* point)
 | |
|         %code{% RETVAL = new Vec3d(*point - *THIS); %};
 | |
|     std::string serialize() %code{% char buf[2048]; sprintf(buf, "%lf,%lf,%lf", (*THIS)(0), (*THIS)(1), (*THIS)(2)); RETVAL = buf; %};
 | |
| };
 | 
