You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

108 lines
1.9 KiB

#include "pch.h" // use stdafx.h in Visual Studio 2017 and earlier
#include "Path.h"
ClipSet clipSet;
BranchPointSet branchPointSet;
P dirP(P &A){
P B;
B.x=A.dx;
B.y=A.dy;
B.z=A.dz;
return B;
}
Path::Path(){
dia=0;
}
//����path�������
int Path::size() {
assert(inOut.size() == points.size());
return points.size();
}
void Path::markPoint(){
for(int i=0;i<points.size();i++){
P& tp=points[i];
if(tp.type==1||tp.type==2){
BranchPoint *pb=branchPointSet.getBranchPointPointer(tp.ref);
pb->used=true;
pb->pc1->used=true;
pb->pc2->used=true;
}
else if(tp.type==0){
clipSet.c[tp.ref].used=true;
}
}
}
//�̶����о����ķ�֧��
void Path::fixBranchPoint(){
for(int i=0;i<points.size();i++){
P& tp=points[i];
if(tp.type==1){
BranchPoint *pb=branchPointSet.getBranchPointPointer(tp.ref);
pb->fix();
}
}
}
//����·���Ϸ���
void Path::illegalCheck(){
map<P,int>vis;
for(int i=0;i<points.size();i++){
assert(vis[points[i]]==0);
vis[points[i]]=1;
if(i==0||i==points.size()-1){
assert(points[i].type==3);
}
if(points[i].type!=0){
assert(inOut[i]<0);
}
}
}
//��·���еĵ㷭ת���������򣬲�����inOut����
void Path::processDir(){
for(int j=0;j<points.size();j++){
if(points[j].type!=0){
inOut.push_back(-1);
continue;
}
double reverse=0;
P dir=dirP(points[j]);
if(j!=0){
reverse+=pi/2-Angle(points[j]-points[j-1],dir);
}
if(j!=points.size()-1){
reverse+=pi/2-Angle(points[j+1]-points[j],dir);
}
if(reverse<0){
//points[j].reverse();
inOut.push_back(1);
}
else inOut.push_back(0);
}
}
//��·��ȷ���󣬴���һЩ����pass���洦������Ϣ
void Path::postProcess(){
this->fixBranchPoint();
//this->processDir();
this->markPoint();
}
//��ת����·��
void Path::reverse(){
std::reverse(points.begin(),points.end());
assert(inOut.size()==points.size());
for(int i=0;i<points.size();i++){
if(inOut[i]!=-1){
inOut[i]=inOut[i]^1;
points[i].reverse();
}
}
}