- UID
- 658062
- 积分
- 2147
- 精华
- 贡献
-
- 威望
-
- 活跃度
-
- D豆
-
- 在线时间
- 小时
- 注册时间
- 2008-10-22
- 最后登录
- 1970-1-1
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
×
[ 本帖最后由 csharp 于 2014-5-15 09:46 编辑 ]\n\n[url=http://www.cnblogs.com/loveclumsybaby/p/3420795.html]http://www.cnblogs.com/loveclumsybaby/p/3420795.html[/url]
public static void ClockwiseSortPoints(List<Point3D> vPoints)
{
//计算重心
Point3D center = new Point3D();
double X = 0, Y = 0;
for (int i = 0; i < vPoints.Count; i++) {
X += vPoints[i].X;
Y += vPoints[i].Y;
}
center.X = (int)X / vPoints.Count;
center.Y = (int)Y / vPoints.Count;
//冒泡排序
for (int i = 0; i < vPoints.Count - 1; i++) {
for (int j = 0; j < vPoints.Count - i - 1; j++) {
if (PointCmp(vPoints[j], vPoints[j + 1], center)) {
Point3D tmp = vPoints[j];
vPoints[j] = vPoints[j + 1];
vPoints[j + 1] = tmp;
}
}
}
}
//若点a大于点b,即点a在点b顺时针方向,返回true,否则返回false
static bool PointCmp(Point3D a, Point3D b, Point3D center)
{
if (a.X >= 0 && b.X < 0)
return true;
if (a.X == 0 && b.X == 0)
return a.Y > b.Y;
//向量OA和向量OB的叉积
int det = Convert.ToInt32((a.X - center.X) * (b.Y - center.Y) - (b.X - center.X) * (a.Y - center.Y));
if (det < 0)
return true;
if (det > 0)
return false;
//向量OA和向量OB共线,以距离判断大小
double d1 = (a.X - center.X) * (a.X - center.X) + (a.Y - center.Y) * (a.Y - center.Y);
double d2 = (b.X - center.X) * (b.X - center.Y) + (b.Y - center.Y) * (b.Y - center.Y);
return d1 > d2;
}
|
|