d93871383a37ed5fc7c5c1e4f31668d03844fd8c
[occt.git] / src / DsgPrs / DsgPrs_EllipseRadiusPresentation.cxx
1 // Created on: 1998-01-26
2 // Created by: Sergey ZARITCHNY
3 // Copyright (c) 1998-1999 Matra Datavision
4 // Copyright (c) 1999-2012 OPEN CASCADE SAS
5 //
6 // The content of this file is subject to the Open CASCADE Technology Public
7 // License Version 6.5 (the "License"). You may not use the content of this file
8 // except in compliance with the License. Please obtain a copy of the License
9 // at http://www.opencascade.org and read it completely before using this file.
10 //
11 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
12 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
13 //
14 // The Original Code and all software distributed under the License is
15 // distributed on an "AS IS" basis, without warranty of any kind, and the
16 // Initial Developer hereby disclaims all such warranties, including without
17 // limitation, any warranties of merchantability, fitness for a particular
18 // purpose or non-infringement. Please see the License for the specific terms
19 // and conditions governing the rights and limitations under the License.
20
21
22
23 #include <DsgPrs_EllipseRadiusPresentation.ixx>
24
25 #include <gp_Lin.hxx>
26 #include <gp_Dir.hxx>
27 #include <gp_Elips.hxx>
28 #include <ElCLib.hxx>
29 #include <Graphic3d_Group.hxx>
30 #include <Graphic3d_Array1OfVertex.hxx>
31 #include <Prs3d_LengthAspect.hxx>
32 #include <Prs3d_Arrow.hxx>
33 #include <Prs3d_ArrowAspect.hxx>
34 #include <Prs3d_LineAspect.hxx>
35 #include <Prs3d_Text.hxx>
36 #include <TCollection_AsciiString.hxx>
37 #include <TCollection_ExtendedString.hxx>
38
39 #include <Graphic3d_Vertex.hxx>
40 #include <Graphic3d_AspectMarker3d.hxx>
41 #include <Graphic3d_AspectLine3d.hxx>
42 #include <Aspect_TypeOfLine.hxx>
43 #include <Aspect_TypeOfMarker.hxx>
44 #include <Aspect_AspectMarker.hxx>
45 #include <Quantity_Color.hxx>
46 #include <DsgPrs.hxx>
47 #include <Precision.hxx>
48
49 #include <Geom_Ellipse.hxx>
50 #include <Geom_Line.hxx>
51 #include <Geom_TrimmedCurve.hxx>
52 #include <GeomAPI_ExtremaCurveCurve.hxx>
53 #include <Geom_OffsetCurve.hxx>
54 //=======================================================================
55 //function : Add
56 //purpose  : 
57 //=======================================================================
58
59 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
60                                             const Handle(Prs3d_Drawer)& aDrawer,
61                                             const Standard_Real theval,
62                                             const TCollection_ExtendedString & aText,
63 //                                          const gp_Elips & anEllipse,
64                                             const gp_Pnt & aPosition,
65                                             const gp_Pnt & anEndOfArrow,
66                                             const gp_Pnt & aCenter,
67                                             const Standard_Boolean IsMaxRadius,
68                                             const DsgPrs_ArrowSide ArrowPrs)
69 {
70
71   Handle(Prs3d_LengthAspect) LA = aDrawer->LengthAspect();
72   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
73  
74   Standard_Boolean inside  = Standard_False;
75 //  gp_Pnt EndPoint, EndOfArrow;
76   gp_Pnt EndPoint;
77   Standard_Real dist    = aCenter.Distance( aPosition );
78   if( dist > theval ) EndPoint = aPosition;
79   else {
80     EndPoint = anEndOfArrow;
81     inside   = Standard_True;
82   }
83   Graphic3d_Array1OfVertex V(1,2);
84   Quantity_Length X,Y,Z;
85   aCenter.Coord(X,Y,Z);
86   V(1).SetCoord(X,Y,Z);
87   EndPoint.Coord(X,Y,Z);
88   V(2).SetCoord(X,Y,Z);
89   Prs3d_Root::CurrentGroup(aPresentation)->Polyline(V);
90   
91    // value
92   TCollection_ExtendedString Text;
93   if(IsMaxRadius)
94     Text = TCollection_ExtendedString("a = ");
95   else
96     Text = TCollection_ExtendedString("b = ");
97   Text +=  aText;
98   Prs3d_Text::Draw(aPresentation, LA->TextAspect(), Text, aPosition );
99
100    // arrows
101   gp_Dir arrdir( gp_Vec( aCenter, anEndOfArrow));
102   if (!inside) arrdir.Reverse();
103
104   DsgPrs::ComputeSymbol(aPresentation, LA,  anEndOfArrow,  anEndOfArrow, arrdir, arrdir, ArrowPrs );
105
106 }
107
108 //=======================================================================
109 //function : Add
110 //purpose  : 
111 //=======================================================================
112
113 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
114                                             const Handle(Prs3d_Drawer)& aDrawer,
115                                             const Standard_Real theval,
116                                             const TCollection_ExtendedString & aText,
117                                             const gp_Elips & anEllipse,
118                                             const gp_Pnt & aPosition,
119                                             const gp_Pnt & anEndOfArrow,
120                                             const gp_Pnt & aCenter,
121                                             const Standard_Real uFirst,
122                                             const Standard_Boolean IsInDomain,
123                                             const Standard_Boolean IsMaxRadius,
124                                             const DsgPrs_ArrowSide ArrowPrs)
125 {
126
127   Handle(Prs3d_LengthAspect) LA = aDrawer->LengthAspect();
128   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
129   if(!IsInDomain)
130     {
131       Standard_Real parFirst;
132       Standard_Real uLast = ElCLib::Parameter ( anEllipse, anEndOfArrow );
133       Standard_Real Alpha = DsgPrs::DistanceFromApex(anEllipse, anEndOfArrow, uFirst);//length of ellipse arc
134       gp_Vec Vapex(aCenter, ElCLib::Value( uLast, anEllipse )) ;
135       gp_Vec Vpnt(aCenter,  ElCLib::Value( uFirst, anEllipse )) ;
136       gp_Dir dir(Vpnt ^ Vapex);
137       if(anEllipse.Position().Direction().IsOpposite( dir, Precision::Angular()))
138         parFirst = uLast;
139       else
140         parFirst = uFirst;
141       Standard_Integer NodeNumber = Max (4 , Standard_Integer (50. * Alpha / M_PI));
142       Graphic3d_Array1OfVertex ApproxArc( 0, NodeNumber-1 );
143       Standard_Real delta = Alpha / ( NodeNumber - 1 );
144       gp_Pnt CurPnt;
145       for (Standard_Integer i = 0 ; i < NodeNumber; i++)
146         {
147           CurPnt =  ElCLib::Value( parFirst, anEllipse );
148           ApproxArc(i).SetCoord( CurPnt.X(), CurPnt.Y(), CurPnt.Z() );
149           parFirst += delta ;
150         }
151       Prs3d_Root::CurrentGroup( aPresentation )->Polyline( ApproxArc );
152     }
153   DsgPrs_EllipseRadiusPresentation::Add(aPresentation, aDrawer, theval, aText,
154                                         aPosition, anEndOfArrow, aCenter,  IsMaxRadius, ArrowPrs);
155   
156 }
157
158
159
160 //=======================================================================
161 //function : Add
162 //purpose  : // for offset curve
163 //=======================================================================
164
165 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
166                                             const Handle(Prs3d_Drawer)& aDrawer,
167                                             const Standard_Real theval,
168                                             const TCollection_ExtendedString & aText,
169                                             const Handle(Geom_OffsetCurve) & aCurve,
170                                             const gp_Pnt & aPosition,
171                                             const gp_Pnt & anEndOfArrow,
172                                             const gp_Pnt & aCenter,
173                                             const Standard_Real uFirst,
174                                             const Standard_Boolean IsInDomain,
175                                             const Standard_Boolean IsMaxRadius,
176                                             const DsgPrs_ArrowSide ArrowPrs)
177 {
178
179   Handle(Prs3d_LengthAspect) LA = aDrawer->LengthAspect();
180   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
181   if(!IsInDomain)
182     {
183       Standard_Real parFirst;
184       if(!aCurve->IsCN(1)) return ;
185       gp_Elips aBEllipse = Handle(Geom_Ellipse)::DownCast(aCurve->BasisCurve ())->Elips();
186       Standard_Real Offset = aCurve->Offset();
187       aBEllipse.SetMajorRadius(aBEllipse.MajorRadius() + Offset);
188       aBEllipse.SetMinorRadius(aBEllipse.MinorRadius() + Offset);
189       Standard_Real uLast = ElCLib::Parameter ( aBEllipse, anEndOfArrow );
190       Standard_Real Alpha = DsgPrs::DistanceFromApex(aBEllipse, anEndOfArrow, uFirst);//length of ellipse arc
191       gp_Pnt p1;
192       aCurve->D0(uFirst, p1);
193       gp_Vec Vapex(aCenter,  anEndOfArrow) ;
194       gp_Vec Vpnt (aCenter,   p1) ;
195       gp_Dir dir(Vpnt ^ Vapex);
196       if(aCurve->Direction().IsOpposite( dir, Precision::Angular()))
197         parFirst = uLast;
198       else
199         parFirst = uFirst;
200       Standard_Integer NodeNumber = Max (4 , Standard_Integer (50. * Alpha / M_PI));
201       Graphic3d_Array1OfVertex ApproxArc( 0, NodeNumber-1 );
202       Standard_Real delta = Alpha / ( NodeNumber - 1 );
203       gp_Pnt CurPnt;
204       for (Standard_Integer i = 0 ; i < NodeNumber; i++)
205         {
206           aCurve->D0( parFirst, CurPnt );
207           ApproxArc(i).SetCoord( CurPnt.X(), CurPnt.Y(), CurPnt.Z() );
208           parFirst += delta ;
209         }
210       Prs3d_Root::CurrentGroup( aPresentation )->Polyline( ApproxArc );
211     }
212   DsgPrs_EllipseRadiusPresentation::Add(aPresentation, aDrawer, theval, aText,
213                                         aPosition, anEndOfArrow, aCenter,  IsMaxRadius, ArrowPrs);
214
215 }