some generalization made
This commit is contained in:
parent
0758b0b32d
commit
b71c11a0f7
|
@ -23,6 +23,9 @@
|
|||
/****************************************************************************
|
||||
History
|
||||
$Log: not supported by cvs2svn $
|
||||
Revision 1.3 2008/02/16 14:12:30 benedetti
|
||||
first version
|
||||
|
||||
|
||||
****************************************************************************/
|
||||
|
||||
|
@ -108,13 +111,13 @@ void CoordinateFrame::Render(QGLWidget* glw)
|
|||
}
|
||||
if(drawlabels){
|
||||
font.setBold(true);
|
||||
font.setPixelSize(10);
|
||||
font.setPixelSize(12);
|
||||
glColor(xcolor);
|
||||
glw->renderText(size+(scalefactor*3),0,0,QString("X"),font);
|
||||
glw->renderText(size+scalefactor*linewidth*1.5,0,0,QString("X"),font);
|
||||
glColor(ycolor);
|
||||
glw->renderText(0,size+(scalefactor*3),0,QString("Y"),font);
|
||||
glw->renderText(0,size+scalefactor*linewidth*1.5,0,QString("Y"),font);
|
||||
glColor(zcolor);
|
||||
glw->renderText(0,0,size+(scalefactor*3),QString("Z"),font);
|
||||
glw->renderText(0,0,size+scalefactor*linewidth*1.5,QString("Z"),font);
|
||||
}
|
||||
if(drawvalues){
|
||||
font.setBold(false);
|
||||
|
@ -250,14 +253,14 @@ Quaternionf MovableCoordinateFrame::GetRotation()
|
|||
return rotation;
|
||||
}
|
||||
|
||||
void MovableCoordinateFrame::Flip(const Point3f axis)
|
||||
void MovableCoordinateFrame::Rot(float angle_deg,const Point3f axis)
|
||||
{
|
||||
Similarityf s;
|
||||
s.SetRotate(M_PI,Inverse(rotation).Rotate(axis));
|
||||
s.SetRotate(angle_deg*M_PI/180.0f,Inverse(rotation).Rotate(axis));
|
||||
Move(s);
|
||||
}
|
||||
|
||||
void MovableCoordinateFrame::AlignWith(const Point3f pri,const Point3f secondary)
|
||||
void MovableCoordinateFrame::AlignWith(const Point3f pri,const Point3f secondary,const char c1, const char c2)
|
||||
{
|
||||
const float EPSILON=1e-6;
|
||||
Point3f primary=pri;
|
||||
|
@ -267,36 +270,54 @@ void MovableCoordinateFrame::AlignWith(const Point3f pri,const Point3f secondary
|
|||
|
||||
primary.Normalize(); // ho l'asse primario, lo normalizzo
|
||||
Plane3f plane(0,primary); // piano di proiezione per la seconda rotazione
|
||||
Point3f old_z = Inverse(rotation).Rotate(Point3f(0,0,1)); // l'asse z
|
||||
Point3f old_y_pro = plane.Projection(Inverse(rotation).Rotate(Point3f(0,1,0))); //la proiezione dell'asse y
|
||||
Point3f old_x_pro = plane.Projection(Inverse(rotation).Rotate(Point3f(1,0,0))); //la proiezione dell'asse x
|
||||
|
||||
// allinea l'asse z corrente all'asse primary
|
||||
RotateToAlign(old_z,primary); // prima rotazione
|
||||
Point3f x(1,0,0),y(0,1,0),z(0,0,1);
|
||||
Point3f first(0,0,0),second(0,0,0),third(0,0,0);
|
||||
|
||||
if(c1=='X'){ first = x;
|
||||
if((c2=='Y')||(c2==' ')){ second = y; third = z; }
|
||||
else if(c2=='Z'){ second = z; third = y; }
|
||||
else assert (0);
|
||||
} else if(c1=='Y'){ first = y;
|
||||
if((c2=='Z')||(c2==' ')){ second = z; third = x; }
|
||||
else if(c2=='X'){ second = x; third = z; }
|
||||
else assert (0);
|
||||
} else if(c1=='Z'){ first = z;
|
||||
if((c2=='X')||(c2==' ')){ second = x; third = y; }
|
||||
else if(c2=='Y'){ second = y; third = x; }
|
||||
else assert (0);
|
||||
} else assert (0);
|
||||
|
||||
Point3f old_first = Inverse(rotation).Rotate(first); // l'asse 1
|
||||
Point3f old_second_pro = plane.Projection(Inverse(rotation).Rotate(second)); //la proiezione dell'asse 2
|
||||
Point3f old_third_pro = plane.Projection(Inverse(rotation).Rotate(third)); //la proiezione dell'asse 3
|
||||
|
||||
// allinea l'asse 1 corrente all'asse primary
|
||||
RotateToAlign(old_first,primary); // prima rotazione
|
||||
|
||||
Point3f secondary_pro = plane.Projection(secondary); // la proiezione di secondary
|
||||
Point3f new_y_pro = plane.Projection(Inverse(rotation).Rotate(Point3f(0,1,0))); // la proiezione dell'asse y dopo la prima rotazione
|
||||
Point3f new_second_pro = plane.Projection(Inverse(rotation).Rotate(second)); // la proiezione dell'asse 2 dopo la prima rotazione
|
||||
|
||||
// se c'e` un asse secondary e la sua proiezione non e` 0
|
||||
if( secondary.Norm() > EPSILON*size && secondary_pro.Norm() > EPSILON ){
|
||||
// allinea la proiezione dell'asse y dopo la prima rotazione alla proiezione dell'asse secondary
|
||||
// allinea la proiezione dell'asse 2 dopo la prima rotazione alla proiezione dell'asse secondary
|
||||
secondary_pro.Normalize();
|
||||
RotateToAlign(new_y_pro,secondary_pro);
|
||||
RotateToAlign(new_second_pro,secondary_pro);
|
||||
return;
|
||||
}
|
||||
// creco di riallineare la y
|
||||
if ( old_y_pro.Norm() > EPSILON ) {
|
||||
// allinea la proiezione dell'asse y dopo la prima rotazione alla proiezione dell'asse y
|
||||
old_y_pro.Normalize();
|
||||
RotateToAlign(new_y_pro,old_y_pro);
|
||||
// creco di riallineare l'asse 2
|
||||
if ( old_second_pro.Norm() > EPSILON ) {
|
||||
// allinea la proiezione dell'asse 2 dopo la prima rotazione alla proiezione dell'asse 2
|
||||
old_second_pro.Normalize();
|
||||
RotateToAlign(new_second_pro,old_second_pro);
|
||||
return;
|
||||
}
|
||||
// cerco di riallineare la x
|
||||
Point3f new_x_pro = plane.Projection(Inverse(rotation).Rotate(Point3f(1,0,0))); //la proiezione dell'asse x dopo la prima rotazione
|
||||
assert(old_x_pro.Norm() > EPSILON ); // la proiezione dell'asse x non dovrebbe essere 0
|
||||
// allinea la proiezione dell'asse x dopo la prima rotazione alla proiezione dell'asse x
|
||||
old_x_pro.Normalize();
|
||||
RotateToAlign(new_x_pro,old_x_pro);
|
||||
// cerco di riallineare l'asse 3
|
||||
Point3f new_third_pro = plane.Projection(Inverse(rotation).Rotate(third)); //la proiezione dell'asse 3 dopo la prima rotazione
|
||||
assert(old_third_pro.Norm() > EPSILON ); // la proiezione dell'asse 3 non dovrebbe essere 0
|
||||
// allinea la proiezione dell'asse 3 dopo la prima rotazione alla proiezione dell'asse 3
|
||||
old_third_pro.Normalize();
|
||||
RotateToAlign(new_third_pro,old_third_pro);
|
||||
}
|
||||
|
||||
void MovableCoordinateFrame::Move(const Similarityf track)
|
||||
|
@ -496,9 +517,9 @@ void ActiveCoordinateFrame::SetRotation(const Quaternionf newrot)
|
|||
manipulator->Reset();
|
||||
}
|
||||
|
||||
void ActiveCoordinateFrame::AlignWith(const Point3f primary,const Point3f secondary=Point3f(0,0,0))
|
||||
void ActiveCoordinateFrame::AlignWith(const Point3f primary,const Point3f secondary,const char c1,const char c2)
|
||||
{
|
||||
MovableCoordinateFrame::AlignWith(primary,secondary);
|
||||
MovableCoordinateFrame::AlignWith(primary,secondary,c1,c2);
|
||||
Update();
|
||||
manipulator->Reset();
|
||||
}
|
||||
|
|
|
@ -23,6 +23,9 @@
|
|||
/****************************************************************************
|
||||
History
|
||||
$Log: not supported by cvs2svn $
|
||||
Revision 1.3 2008/02/16 14:12:30 benedetti
|
||||
first version
|
||||
|
||||
|
||||
****************************************************************************/
|
||||
#ifndef COORDINATEFRAME_H
|
||||
|
@ -76,8 +79,8 @@ public:
|
|||
virtual Point3f GetPosition();
|
||||
virtual Quaternionf GetRotation();
|
||||
virtual void GetTransform(Matrix44f &);
|
||||
virtual void Flip(const Point3f);
|
||||
virtual void AlignWith(const Point3f, const Point3f);
|
||||
virtual void Rot(float,const Point3f);
|
||||
virtual void AlignWith(const Point3f, const Point3f, const char, const char);
|
||||
|
||||
protected:
|
||||
// data:
|
||||
|
@ -99,7 +102,7 @@ public:
|
|||
virtual void Reset(bool, bool);
|
||||
virtual void SetPosition(const Point3f);
|
||||
virtual void SetRotation(const Quaternionf);
|
||||
virtual void AlignWith(const Point3f, const Point3f);
|
||||
virtual void AlignWith(const Point3f, const Point3f,const char,const char);
|
||||
void MouseDown(QPoint,int, int, int);
|
||||
void MouseMove(QPoint,int, int);
|
||||
void MouseUp(int, int, int);
|
||||
|
|
Loading…
Reference in New Issue