本文整理汇总了C++中point类的典型用法代码示例。如果您正苦于以下问题:C++ point类的具体用法?C++ point怎么用?C++ point使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了point类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: calc_length
//
// Calculate the distance between two points.
//
float edge::calc_length( const point& a, const point& b )
{
int dx = a.get_x() - b.get_x();
int dy = a.get_y() - b.get_y();
return static_cast<float>(
std::sqrt( static_cast<double>( dx * dx + dy * dy ) ) );
}
示例2: main
int main() {
//freopen("","r",stdin);
//freopen("","w",stdout);
int i,j,k;
int n,r;
int CA=0;
while ( ~scanf ( "%d%d",&n,&r ) ) {
vector<point>P;
for ( i=0; i<n; i++ ) {
point foo;
foo.in();
P.PB ( foo );
}
// P=ConvexHull(P);
if ( !P.empty() ) P.PB ( P[0] );
for(nl=0,i=1;i<P.SZ;i++){
point s=P[i],e=P[i-1];
point d=(e-s).rotate().normal()*r;
L[nl++]=line(s+d,e+d);
}
nr=HPI(L,nl,R);
P.clear();
for(i=0;i<nr;i++)P.PB(R[i]);
P=ConvexHull(P);
ConvecDiameter(P);
if(sign(au.x-av.x)>0)swap(au,av);
au.out(" ");
av.out("\n");
}
return 0;
}
示例3: contains
bool map::contains(point<2> p) const
{
return p.x() >= min_x
&& p.x() <= max_x
&& p.y() >= min_y
&& p.y() <= max_y;
}
示例4: cmp
bool cmp(point left, point right) {
point a = left - points[0], b = right - left;
if(a.x * b.y > b.x * a.y) return 1;
if(a.x * b.y == b.x * a.y)
return left.len() < right.len();
return 0;
}
示例5: tour
bool tour(int board[8][8],point posNew,int step){
int x = posNew.getx();
int y = posNew.gety();
if (step==64) {
return true;
}
bool result;
for (int k=0; k<8; k++) {
point p = move(x,y,k+1);
int x1,y1;
x1 = p.getx();
y1 = p.gety();
if (x1<8 && x1>=0 && y1<8 && y1>=0 && board[x1][y1]==-1) {
board[x1][y1] = step;
result = tour(board, p, step+1);
if (result) {
return true;
}else{
board[x1][y1]=-1;
}
}
}
return false;
}
示例6: miseAjour
/*cubeCol* joueur::getCube()
{
return &collision;
}*/
void joueur::miseAjour(point newPosition, uint16_t newAngleX, uint16_t newAngleY, uint8_t newGaz, uint8_t newAxeX, uint8_t newAxeY, float newVitesse)
{
if(newPosition.getX() > -251 && newPosition.getX() < 251 && newPosition.getY() > -251 && newPosition.getY() < 251 && newPosition.getZ() > -251 && newPosition.getZ() < 251)
{
position = newPosition;
}
if(newAngleX < 361)
{
angleX = newAngleX;
}
if(newAngleY < 361)
{
angleY = newAngleY;
}
if(newGaz == 0 || newGaz == 1)
{
gaz = newGaz;
}
if(newAxeX == 0 || newAxeX == 1 || newAxeX == 2 )
{
axeX = newAxeX;
}
if(newAxeY == 0 || newAxeY == 1 || newAxeY == 2 )
{
axeY = newAxeY;
}
if(newVitesse >= 0 && newVitesse <= vitesseMax)
{
vitesse = newVitesse;
}
}
示例7: calc
double calc(const point &a, const point &b) {
point p[2];
int num = 0;
int ina = dcmp(a.norm()- r) < 0;
int inb = dcmp(b.norm() - r) < 0;
if (ina) {
if (inb) {
return fabs(det(a, b)) / 2;
} else {
circle_inter_line(a, b, point(0, 0), r, p, num);
return sector_area(b, p[0]) + fabs(det(a, p[0])) / 2;
}
} else {
if (inb) {
circle_inter_line(a, b, point(0, 0), r, p, num);
return sector_area(p[0], a) + fabs(det(p[0], b)) / 2;
} else {
circle_inter_line(a, b, point(0, 0), r, p, num);
if (num == 2) {
return sector_area(a, p[0]) + sector_area(p[1], b) + fabs(det(p[0], p[1])) / 2;
} else {
return sector_area(a, b);
}
}
}
}
示例8: g
point minimization::calcGoMin(point p) {
point g(p.size());
for (int i = 0; i < (int)p.size()/* && Fcnt < 1e6*/; i++) {
if (fabs(p[i] - FL->l0[i]) < eps) {
point p1(p);
p1[i] += eps1;
g[i] = -(calcF(p1) - calcF(p)) / eps1;
if (g[i] < 0) {
g[i] = 0;
}
} else
if (fabs(p[i] - FL->r0[i]) < eps) {
point p1(p);
p1[i] -= eps1;
g[i] = -(calcF(p) - calcF(p1)) / eps1;
if (g[i] > 0) {
g[i] = 0;
}
} else {
point p1(p);
p1[i] += eps1;
g[i] = -(calcF(p1) - calcF(p)) / eps1;
}
}
return g;
}
示例9: ikinAbs
void twoLinkArm::ikinAbs(point x, point &q)
{
x=x-params.x0;
double S=(std::pow(params.l1+params.l2,2)-(std::pow(x.X(),2)+std::pow(x.Y(),2)))/(std::pow(x.X(),2)+std::pow(x.Y(),2)-std::pow(params.l1-params.l2,2));
q[1]=-2.0*std::atan(std::sqrt(std::abs(S))); //Negative sign indicates elbow right.
q[0]=std::atan2(x.Y(),x.X())-std::atan2(params.l2*std::sin(q[1]),params.l1+params.l2*std::cos(q[1]));
}
示例10: set_point
void line::set_point(point p1, point p2) {
this->p1.set_x(p1.get_x());
this->p1.set_y(p1.get_y());
this->p2.set_x(p2.get_x());
this->p2.set_y(p2.get_y());
}
示例11: while
Ship::Ship(point originPoint, direction o, int l)
{
origin = originPoint;
orientation = o;
length = l;
lencopy = length;
hits = 0;
points.add(originPoint);
if (orientation == HORIZONTAL)
{
while((lencopy - 1) > 0)
{
points.add((originPoint.getX() + 1), originPoint.getY)
lencopy -= 1;
}
}
else
{
while((lencopy - 1) > 0)
{
points.add(originPoint.getX(), (originPoint.getY()+1))
lencopy -= 1;
}
}
}
示例12: trackMouse
// Processes mouse movements for skeleton manipulation
void trackMouse(int x, int y)
{
if(mode == 2 && selected >= joints.size())
{
point *s = &xydpoints.at(selected - joints.size());
if(RM)
{
double shift = (clickpos.gety() - y)/50.;
*s = point(s->getx(), s->gety(), clickpos.getz()+shift);
}
else
{
*s = point(x, y, s->getz());
}
setTargets();
}
else if(mode == 1)
{
if(LM && selected >= 0 && selected <= joints.size())
{
double shift = clickpos.gety() - y;
joints.at(selected)->settheta(clickpos.getz() + shift);
}
}
}
示例13: if
scalar arakawaKonorStripesTracerField::tracerAt
(
const point& p,
const Time& t
) const
{
scalar x = p.x() - xOffset;
if (mag(x) <= wavelength / 2)
{
if (p.z() >= z1Start - 1 && p.z() <= z1End - 1)
{
return -rho0*Foam::sin(2*M_PI*x/wavelength);
}
else if (p.z() >= z2Start - 1 && p.z() <= z2End - 1)
{
return rho0*Foam::sin(2*M_PI*x/wavelength);
}
else
{
return 0;
}
}
else
{
return 0;
}
}
示例14: origin
std::tuple<float, point> line::distance(const point &p) const {
float A = p.x() - origin().x();
float B = p.y() - origin().y();
float C = target().x() - origin().x();
float D = target().y() - origin().y();
float dot = A * C + B * D;
float len_sq = C * C + D * D;
float param = dot / len_sq;
float xx, yy;
if (param < 0 || (origin().x() == target().x() && origin().y() == origin().x())) {
xx = origin().x();
yy = origin().y();
}
else if (param > 1) {
xx = target().x();
yy = target().y();
}
else {
xx = origin().x() + param * C;
yy = origin().y() + param * D;
}
float dx = p.x() - xx;
float dy = p.y() - yy;
return std::make_tuple(sqrt(dx * dx + dy * dy), point(xx, yy));
}
示例15: smaller_angle
bool smaller_angle(const point<2>& first_point, const point<2>& p1, const point<2>& p2)
{
if (collinear(first_point, p1, p2))
return (first_point.square_distance(p1) > first_point.square_distance(p2));
return (!ccw(first_point, p1, p2));
}