|
|
|
#include "stdafx.h"
|
|
|
|
#include "BranchPoint.h"
|
|
|
|
#include <cmath>
|
|
|
|
#include <vector>
|
|
|
|
#include <queue>
|
|
|
|
#include <map>
|
|
|
|
#include <iostream>
|
|
|
|
#include <fstream>
|
|
|
|
#include <sstream>
|
|
|
|
#include <algorithm>
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
// ��·����Ϣ��·���滮��ֱ�ӽ���
|
|
|
|
struct Path
|
|
|
|
{
|
|
|
|
vector<string> wirelist; // ·���е�������
|
|
|
|
vector<P> points; // ·���ϵĵ㣬���������ͷ�֧��
|
|
|
|
vector<int> inOut; // ��������������Ϊ0������Ϊ1,��֧��Ϊ-1
|
|
|
|
double dia; // ·��ֱ��
|
|
|
|
Path()
|
|
|
|
{
|
|
|
|
dia = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ����path�������
|
|
|
|
inline int size()
|
|
|
|
{
|
|
|
|
assert(inOut.size() == points.size());
|
|
|
|
return points.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
// ��·���о����Ŀ����ͷ�֧�㶼���dz�ʹ�ù���״̬
|
|
|
|
void 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 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 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 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 postProcess()
|
|
|
|
{
|
|
|
|
this->fixBranchPoint();
|
|
|
|
// this->processDir();
|
|
|
|
this->markPoint();
|
|
|
|
}
|
|
|
|
|
|
|
|
// ��ת����·��
|
|
|
|
void 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();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|