Polygon.C
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 #ifndef POLYGON_C_DEFINED
00039 #define POLYGON_C_DEFINED
00040
00041 #include "FeatureMatching/Polygon.H"
00042 #include "Image/DrawOps.H"
00043 #include "GUI/DebugWin.H"
00044 #include "Util/FastMathFunctions.H"
00045
00046 void Polygon::addLine(const Line& line)
00047 {
00048 itsLines.push_back(line);
00049 }
00050
00051
00052 void Polygon::quantize(int nDirections)
00053 {
00054 itsNumDirections = nDirections;
00055 for(uint i=0; i<itsLines.size(); i++)
00056 itsLines[i].quantize(nDirections);
00057 }
00058
00059
00060 void Polygon::rotate(double theta)
00061 {
00062 for(uint i=0; i<itsLines.size(); i++)
00063 itsLines[i].rotate(theta);
00064 }
00065
00066
00067 void Polygon::shear(double k1, double k2)
00068 {
00069 for(uint i=0; i<itsLines.size(); i++)
00070 itsLines[i].shear(k1,k2);
00071 }
00072
00073
00074 void Polygon::scale(float s)
00075 {
00076 itsLength = 0;
00077 for(uint i=0; i<itsLines.size(); i++)
00078 {
00079 itsLines[i].scale(s);
00080 itsLines[i].setQuantizedDir(itsNumDirections);
00081 itsLength += itsLines[i].getLength();
00082 }
00083
00084 }
00085
00086
00087 void Polygon::scale(float sx, float sy)
00088 {
00089 itsLength = 0;
00090 for(uint i=0; i<itsLines.size(); i++)
00091 {
00092 itsLines[i].scale(sx, sy);
00093 itsLines[i].setQuantizedDir(itsNumDirections);
00094 itsLength += itsLines[i].getLength();
00095 }
00096 }
00097
00098
00099 void Polygon::setCOM()
00100 {
00101 Point2D<float> center(0,0);
00102 for (uint i=0 ; i<itsLines.size(); i++)
00103 center += itsLines[i].getCenter();
00104 center /= itsLines.size();
00105
00106 center *= -1;
00107
00108 trans(center);
00109 }
00110
00111
00112 void Polygon::trans(Point2D<float> p)
00113 {
00114 for(uint i=0; i<itsLines.size(); i++)
00115 itsLines[i].trans(p);
00116 }
00117
00118
00119 void Polygon::setWeights()
00120 {
00121 for(uint i=0; i<itsLines.size(); i++)
00122 itsLines[i].setWeight(itsLines[i].getLength()/itsLength);
00123 }
00124
00125
00126 void Polygon::getBoundary(double &minx, double &miny, double &maxx, double &maxy)
00127 {
00128 minx = miny = 1e+10;
00129 maxx = maxy = -1e+10;
00130
00131 for (uint i=0 ; i<itsLines.size() ; i++)
00132 {
00133 Point2D<float> p1 = itsLines[i].getP1();
00134 Point2D<float> p2 = itsLines[i].getP2();
00135
00136 if (minx > p1.i) minx = p1.i;
00137 if (minx > p2.i) minx = p2.i;
00138
00139 if (maxx < p1.i) maxx = p1.i;
00140 if (maxx < p2.i) maxx = p2.i;
00141
00142 if (miny > p1.j) miny = p1.j;
00143 if (miny > p2.j) miny = p2.j;
00144
00145 if (maxy < p1.j) maxy = p1.j;
00146 if (maxy < p2.j) maxy = p2.j;
00147 }
00148 }
00149
00150
00151
00152 double Polygon::getRadius()
00153 {
00154 double radius = 0;
00155 Point2D<float> center(0,0);
00156 for(uint i=0; i<itsLines.size(); i++)
00157 {
00158 double dist = center.distance(itsLines[i].getP1());
00159 if (dist > radius)
00160 radius = dist;
00161
00162 dist = center.distance(itsLines[i].getP2());
00163 if (dist > radius)
00164 radius = dist;
00165 }
00166 return radius;
00167 }
00168
00169
00170
00171
00172
00173
00174
00175
00176
00177 #endif
00178