1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00

0022683: Incorrect result of Select3D_Projector::Project() in the case of perspective projection

This commit is contained in:
APL 2012-02-10 09:30:38 +00:00 committed by bugmaster
parent 2166f0fad8
commit b0f0bd0c2f
3 changed files with 52 additions and 116 deletions

View File

@ -6,6 +6,21 @@
class Projector from Select3D inherits Transient from Standard
---Purpose: A framework to define 3D projectors.
-- Projector provides services for projecting points from
-- world-coordinates to a viewing plane. Projection could be defined by
-- corresponding transformation, or coordinate system. The transformation
-- could be constructed for a view with transposed view transformation
-- matrix ( that represents view-orientation ), including, for perspective
-- view, focal distance ( distance from an eye to the view plane ) and
-- translational part that represents translation of focal point in
-- view-coordinate space. The Select3D_Projector class recognizes the
-- predefined set of popular projections: axonometric, top view, front
-- view and uses more efficient algorithm for projection computations.
-- User-defined transformation could be also defined in constructor.
-- Perspective projection consists of two separate parts, that are
-- composed together during computation: transformation component and
-- focale distance.
uses
Real from Standard,
Boolean from Standard,
@ -30,33 +45,57 @@ is
Create returns Projector from Select3D;
Create(CS : Ax2 from gp)
---Purpose: Creates an axonometric projector. <CS> is the
-- viewing coordinate system.
---Purpose: Creates an axonometric projector. <CS> represents viewing coordinate
-- system and could be constructed from x direction, view plane normal direction,
-- and view point location in world-coordinate space.
returns Projector from Select3D;
Create(CS : Ax2 from gp;
Focus : Real from Standard)
---Purpose: Creates a perspective projector. <CS> is the
-- viewing coordinate system.
---Purpose: Creates a perspective projector. <CS> represents viewing
-- coordinate system and could be constructed from x direction,
-- view plane normal direction, and focal point location in world-coordinate
-- space. <Focus> should represent distance of an eye from view plane
-- in world-coordinate space (focal distance).
returns Projector from Select3D;
Create(T : Trsf from gp;
Persp : Boolean from Standard;
Focus : Real from Standard)
---Purpose: build a Projector with automatic minmax directions.
returns Projector from Select3D;
Create(T : Trsf from gp;
Persp : Boolean from Standard;
Focus : Real from Standard;
v1,v2,v3 : Vec2d from gp)
---Purpose: build a Projector with given minmax directions.
---Purpose: build a Projector from the given transformation.
-- In case, when <T> transformation should represent custom view projection,
-- it could be constructed from two separate components: transposed view
-- orientation matrix and translation of focal point in view-coordiante
-- system. <T> could be built up from x direction, up direction,
-- view plane normal direction vectors and translation with SetValues(...)
-- method, where first row arguments (a11, a12, a13, a14) are x, y, z
-- component of x direction vector, and x value of reversed translation
-- vector. Second row arguments, are x y z for up direction and y value of
-- reversed translation, and the third row defined in the same manner.
-- This also suits for simple perspective view, where <Focus> is the focale
-- distance of an eye from view plane in world-space coordiantes.
-- Note, that in that case amount of perspective distortion (perspective
-- angle) should be defined through focal distance.
returns Projector from Select3D;
Create(GT : GTrsf from gp;
Persp : Boolean from Standard;
Focus : Real from Standard)
---Purpose: build a Projector with automatic minmax directions.
---Purpose: build a Projector from the given transformation.
-- In case, when <GT> transformation should represent custom view
-- projection, it could be constructed from two separate components:
-- transposed view orientation matrix and translation of a focal point
-- in view-coordinate system.
-- This also suits for perspective view, with <Focus> that could be
-- equal to distance from an eye to a view plane in
-- world-coordinates (focal distance).
-- The 3x3 transformation matrix is built up from three vectors:
-- x direction, up direction and view plane normal vectors, where each
-- vector is a matrix row. Then <GT> is constructed from matrix and
-- reversed translation with methods SetTranslationPart(..) and
-- SetVectorialPart(..).
-- Note, that in that case amount of perspective distortion (perspective
-- angle) should be defined through focal distance.
returns Projector from Select3D;
Set (me : mutable;
@ -65,7 +104,6 @@ is
Focus : Real from Standard)
is static;
SetView(me : mutable; V : View from V3d);
---Purpose: Sets the 3D view V used at the time of construction.
@ -74,11 +112,6 @@ is
---C++: return const&
---C++: inline
Directions(me; D1 , D2 , D3 : out Vec2d from gp)
---C++: inline
is virtual;
Scaled(me : mutable; On : Boolean from Standard = Standard_False)
---Purpose: to compute with the given scale and translation.
is virtual;
@ -138,11 +171,6 @@ is
---Purpose: Transform and apply perspective if needed.
is virtual;
BoxAdd(me; P : Pnt2d from gp;
B : out Box from Bnd)
---Purpose: Adds to the box <B> the min-max of the point <P>.
is virtual;
Shoot(me; X , Y : Real from Standard)
returns Lin from gp
---Purpose: return a line going through the eye towards the
@ -166,9 +194,6 @@ is
--- projection functionality itself).
--- Should be used when call ::Shoot() to compute eyeline.
SetDirection(me : mutable)
is static private;
Transform(me; P : in out Pnt from gp;
T : GTrsf from gp)
---C++: inline
@ -187,9 +212,6 @@ fields
myScaledTrsf : Trsf from gp is protected;
myGTrsf : GTrsf from gp is protected;
myInvTrsf : GTrsf from gp is protected;
myD1 : Vec2d from gp is protected;
myD2 : Vec2d from gp is protected;
myD3 : Vec2d from gp is protected;
myView : View from V3d;
myDepthMin : Real from Standard;

View File

@ -28,9 +28,6 @@
Select3D_Projector::Select3D_Projector(const Handle(V3d_View)& aViou)
: myPersp(aViou->Type()==V3d_PERSPECTIVE),
myFocus(aViou->Focale()),
myD1(1,0),
myD2(0,1),
myD3(1,1),
myView(aViou),
myDepthMin(-Precision::Infinite()),
myDepthMax( Precision::Infinite())
@ -60,14 +57,10 @@ Select3D_Projector::Select3D_Projector(const Handle(V3d_View)& aViou)
Select3D_Projector::Select3D_Projector()
: myPersp(Standard_False),
myFocus(0),
myD1(1,0),
myD2(0,1),
myD3(1,1),
myDepthMin(-Precision::Infinite()),
myDepthMax( Precision::Infinite())
{
Scaled();
SetDirection();
}
//=======================================================================
@ -84,7 +77,6 @@ Select3D_Projector::Select3D_Projector (const gp_Ax2& CS)
myScaledTrsf.SetTransformation(CS);
myGTrsf.SetTrsf(myScaledTrsf);
Scaled();
SetDirection();
}
//=======================================================================
@ -102,7 +94,6 @@ Select3D_Projector::Select3D_Projector (const gp_Ax2& CS,
myScaledTrsf.SetTransformation(CS);
myGTrsf.SetTrsf(myScaledTrsf);
Scaled();
SetDirection();
}
//=======================================================================
@ -118,31 +109,6 @@ Select3D_Projector::Select3D_Projector (const gp_Trsf& T,
myScaledTrsf(T),
myDepthMin(-Precision::Infinite()),
myDepthMax( Precision::Infinite())
{
myGTrsf.SetTrsf(myScaledTrsf);
Scaled();
SetDirection();
}
//=======================================================================
//function : Select3D_Projector
//purpose :
//=======================================================================
Select3D_Projector::Select3D_Projector (const gp_Trsf& T,
const Standard_Boolean Persp,
const Standard_Real Focus,
const gp_Vec2d& v1,
const gp_Vec2d& v2,
const gp_Vec2d& v3)
: myPersp(Persp),
myFocus(Focus),
myScaledTrsf(T),
myD1(v1),
myD2(v2),
myD3(v3),
myDepthMin(-Precision::Infinite()),
myDepthMax( Precision::Infinite())
{
myGTrsf.SetTrsf(myScaledTrsf);
Scaled();
@ -163,7 +129,6 @@ Select3D_Projector::Select3D_Projector (const gp_GTrsf& GT,
myDepthMax( Precision::Infinite())
{
Scaled();
SetDirection();
}
//=======================================================================
@ -180,7 +145,6 @@ void Select3D_Projector::Set
myFocus = Focus;
myScaledTrsf = T;
Scaled();
SetDirection();
}
//=======================================================================
@ -438,19 +402,6 @@ void Select3D_Projector::Project (const gp_Pnt& P,
}
}
//=======================================================================
//function : BoxAdd
//purpose :
//=======================================================================
void Select3D_Projector::BoxAdd
(const gp_Pnt2d& P,
Bnd_Box& B) const
{
gp_Vec2d V(P.X(),P.Y());
gp_Pnt PP(myD1 * V, myD2 * V, myD3 * V);
B.Add(PP);
}
//=======================================================================
//function : Shoot
@ -476,30 +427,6 @@ gp_Lin Select3D_Projector::Shoot
}
//=======================================================================
//function : SetDirection
//purpose :
//=======================================================================
void Select3D_Projector::SetDirection ()
{
gp_Vec V1(1,0,0);
Transform(V1);
if ((Abs(V1.X()) + Abs(V1.Y())) < Precision::Angular()) V1.SetCoord(1,1,0);
gp_Vec2d D1(V1.X(),V1.Y());
myD1.SetCoord(-D1.Y(),D1.X());
gp_Vec V2(0,1,0);
Transform(V2);
if ((Abs(V2.X()) + Abs(V2.Y())) < Precision::Angular()) V2.SetCoord(1,1,0);
gp_Vec2d D2(V2.X(),V2.Y());
myD2.SetCoord(-D2.Y(),D2.X());
gp_Vec V3(0,0,1);
Transform(V3);
if ((Abs(V3.X()) + Abs(V3.Y())) < Precision::Angular()) V3.SetCoord(1,1,0);
gp_Vec2d D3(V3.X(),V3.Y());
myD3.SetCoord(-D3.Y(),D3.X());
}
void Select3D_Projector::SetView(const Handle(V3d_View)& aViou)
{
myView = aViou;

View File

@ -10,19 +10,6 @@
#include <V3d_View.hxx>
#include <V3d.hxx>
//=======================================================================
//function : Directions
//purpose :
//=======================================================================
inline void Select3D_Projector::Directions
(gp_Vec2d& D1, gp_Vec2d& D2, gp_Vec2d& D3) const
{
D1 = myD1;
D2 = myD2;
D3 = myD3;
}
//=======================================================================
//function : Perspective
//purpose :