409ca791582a0689033203f0794bfa2c4b013a37
[occt.git] / src / Geom / Geom_Vector.cxx
1 // Created on: 1993-03-10
2 // Created by: JCV
3 // Copyright (c) 1993-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #include <Geom_Vector.ixx>
18
19 typedef Geom_Vector         Vector;
20 typedef Handle(Geom_Vector) Handle(Vector);
21 typedef gp_Ax1  Ax1;
22 typedef gp_Ax2  Ax2;
23 typedef gp_Pnt  Pnt;
24 typedef gp_Trsf Trsf;
25
26
27
28
29 void Geom_Vector::Reverse ()                  { gpVec.Reverse(); }
30
31 Standard_Real Geom_Vector::X () const                  { return gpVec.X(); }
32
33 Standard_Real Geom_Vector::Y () const                  { return gpVec.Y(); }
34
35 Standard_Real Geom_Vector::Z () const                  { return gpVec.Z(); }
36
37 const gp_Vec& Geom_Vector::Vec () const              { return gpVec; }
38
39 Handle(Vector) Geom_Vector::Reversed () const
40 {
41   Handle(Vector) V = Handle(Vector)::DownCast(Copy());
42   V->Reverse();
43   return V;
44 }
45
46
47 Standard_Real Geom_Vector::Angle (const Handle(Vector)& Other) const { 
48
49   return gpVec.Angle (Other->Vec());
50 }
51
52
53 Standard_Real Geom_Vector::AngleWithRef (
54 const Handle(Vector)& Other, const Handle(Vector)& VRef) const {
55
56    return gpVec.AngleWithRef (Other->Vec(), VRef->Vec());
57 }
58
59
60 void Geom_Vector::Coord (Standard_Real& X, Standard_Real& Y, Standard_Real& Z) const {
61
62    gpVec.Coord (X, Y, Z);
63 }
64  
65
66 Standard_Real Geom_Vector::Dot (const Handle(Vector)& Other) const  { 
67
68   return gpVec.Dot (Other->Vec());
69 }
70
71
72 Standard_Real Geom_Vector::DotCross (
73 const Handle(Vector)& V1, const Handle(Vector)& V2) const {
74
75   return gpVec.DotCross (V1->Vec(), V2->Vec());
76 }
77
78
79