summaryrefslogtreecommitdiff
path: root/nextus/src/lineClipper.cpp
blob: eb9c480e21e1a471f5587b9aeee84954e1f3f942 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#include "lineClipper.h"

vector <colourPolyline> lineClipper::mask(
	vector <colourPolyline> shapes,
	ofRectangle frame,
	bool invert
	)
{
	vector <colourPolyline> output;

	ofx::Clipper clipper;
	
	clipper.Clear();
	clipper.addRectangle(frame, ClipperLib::ptClip, true);
	vector <ofPolyline> polys; //TODO make clipper clip colourpolylines

	for (auto& shape: shapes) polys.push_back(shape);
    
    clipper.addPolylines(polys,ClipperLib::ptSubject);
		
	vector <ofPolyline> clipped;

	if (invert){
		clipped = clipper.getClipped(ClipperLib::ctDifference);
	}else {
		clipped = clipper.getClipped(ClipperLib::ctIntersection);
	}

	for (auto& clip: clipped)
    {
    	//clip.simplify(contour_simplify);
        output.push_back(colourPolyline(clip,shapes[0].getColourAt(0)));
    }
   
    return output;
}