405c299da21ae27cdeda754cc84e22305b9569b8
[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-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
18 #include <Aspect_AspectMarker.hxx>
19 #include <Aspect_TypeOfLine.hxx>
20 #include <Aspect_TypeOfMarker.hxx>
21 #include <DsgPrs.hxx>
22 #include <DsgPrs_EllipseRadiusPresentation.hxx>
23 #include <ElCLib.hxx>
24 #include <Geom_Ellipse.hxx>
25 #include <Geom_Line.hxx>
26 #include <Geom_OffsetCurve.hxx>
27 #include <Geom_TrimmedCurve.hxx>
28 #include <GeomAPI_ExtremaCurveCurve.hxx>
29 #include <gp_Dir.hxx>
30 #include <gp_Elips.hxx>
31 #include <gp_Lin.hxx>
32 #include <gp_Pnt.hxx>
33 #include <Graphic3d_ArrayOfPolylines.hxx>
34 #include <Graphic3d_ArrayOfSegments.hxx>
35 #include <Graphic3d_AspectLine3d.hxx>
36 #include <Graphic3d_AspectMarker3d.hxx>
37 #include <Graphic3d_Group.hxx>
38 #include <Graphic3d_Vertex.hxx>
39 #include <Precision.hxx>
40 #include <Prs3d_Arrow.hxx>
41 #include <Prs3d_ArrowAspect.hxx>
42 #include <Prs3d_DimensionAspect.hxx>
43 #include <Prs3d_LineAspect.hxx>
44 #include <Prs3d_Presentation.hxx>
45 #include <Prs3d_Text.hxx>
46 #include <Quantity_Color.hxx>
47 #include <TCollection_AsciiString.hxx>
48 #include <TCollection_ExtendedString.hxx>
49
50 //=======================================================================
51 //function : Add
52 //purpose  : 
53 //=======================================================================
54 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
55                                             const Handle(Prs3d_Drawer)& aDrawer,
56                                             const Standard_Real theval,
57                                             const TCollection_ExtendedString & aText,
58                                             const gp_Pnt & aPosition,
59                                             const gp_Pnt & anEndOfArrow,
60                                             const gp_Pnt & aCenter,
61                                             const Standard_Boolean IsMaxRadius,
62                                             const DsgPrs_ArrowSide ArrowPrs)
63 {
64   Handle(Prs3d_DimensionAspect) LA = aDrawer->DimensionAspect();
65   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
66  
67   const Standard_Real dist = aCenter.Distance( aPosition );
68   const Standard_Boolean inside = ( dist <= theval );
69   gp_Pnt EndPoint(inside? anEndOfArrow : aPosition);
70
71   Handle(Graphic3d_ArrayOfSegments) aPrims = new Graphic3d_ArrayOfSegments(2);
72   aPrims->AddVertex(aCenter);
73   aPrims->AddVertex(EndPoint);
74   Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(aPrims);
75
76   // value
77   TCollection_ExtendedString Text(IsMaxRadius? "a = " : "b = ");
78   Text += aText;
79   Prs3d_Text::Draw(aPresentation, LA->TextAspect(), Text, aPosition );
80
81   // arrows
82   gp_Dir arrdir( gp_Vec( aCenter, anEndOfArrow));
83   if (!inside) arrdir.Reverse();
84
85   DsgPrs::ComputeSymbol(aPresentation, LA, anEndOfArrow, anEndOfArrow, arrdir, arrdir, ArrowPrs );
86 }
87
88 //=======================================================================
89 //function : Add
90 //purpose  : 
91 //=======================================================================
92
93 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
94                                             const Handle(Prs3d_Drawer)& aDrawer,
95                                             const Standard_Real theval,
96                                             const TCollection_ExtendedString & aText,
97                                             const gp_Elips & anEllipse,
98                                             const gp_Pnt & aPosition,
99                                             const gp_Pnt & anEndOfArrow,
100                                             const gp_Pnt & aCenter,
101                                             const Standard_Real uFirst,
102                                             const Standard_Boolean IsInDomain,
103                                             const Standard_Boolean IsMaxRadius,
104                                             const DsgPrs_ArrowSide ArrowPrs)
105 {
106   Handle(Prs3d_DimensionAspect) LA = aDrawer->DimensionAspect();
107   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
108
109   if(!IsInDomain)
110   {
111     const Standard_Real uLast = ElCLib::Parameter ( anEllipse, anEndOfArrow );
112     const Standard_Real Alpha = DsgPrs::DistanceFromApex(anEllipse, anEndOfArrow, uFirst);//length of ellipse arc
113     gp_Vec Vapex(aCenter, ElCLib::Value( uLast, anEllipse )) ;
114     gp_Vec Vpnt(aCenter,  ElCLib::Value( uFirst, anEllipse )) ;
115     gp_Dir dir(Vpnt ^ Vapex);
116         Standard_Real parFirst = anEllipse.Position().Direction().IsOpposite( dir, Precision::Angular())? uLast : uFirst;
117     const Standard_Integer NodeNumber = Max (4 , Standard_Integer (50. * Alpha / M_PI));
118     const Standard_Real delta = Alpha / ( NodeNumber - 1 );
119
120     Handle(Graphic3d_ArrayOfPolylines) aPrims = new Graphic3d_ArrayOfPolylines(NodeNumber);
121     for (Standard_Integer i = 0 ; i < NodeNumber; i++, parFirst += delta)
122           aPrims->AddVertex(ElCLib::Value( parFirst, anEllipse ));
123     Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(aPrims);
124   }
125   DsgPrs_EllipseRadiusPresentation::Add(aPresentation, aDrawer, theval, aText,
126                                         aPosition, anEndOfArrow, aCenter, IsMaxRadius, ArrowPrs);
127 }
128
129
130 //=======================================================================
131 //function : Add
132 //purpose  : // for offset curve
133 //=======================================================================
134
135 void DsgPrs_EllipseRadiusPresentation::Add (const Handle(Prs3d_Presentation)& aPresentation,
136                                             const Handle(Prs3d_Drawer)& aDrawer,
137                                             const Standard_Real theval,
138                                             const TCollection_ExtendedString & aText,
139                                             const Handle(Geom_OffsetCurve) & aCurve,
140                                             const gp_Pnt & aPosition,
141                                             const gp_Pnt & anEndOfArrow,
142                                             const gp_Pnt & aCenter,
143                                             const Standard_Real uFirst,
144                                             const Standard_Boolean IsInDomain,
145                                             const Standard_Boolean IsMaxRadius,
146                                             const DsgPrs_ArrowSide ArrowPrs)
147 {
148   Handle(Prs3d_DimensionAspect) LA = aDrawer->DimensionAspect();
149   Prs3d_Root::CurrentGroup(aPresentation)->SetPrimitivesAspect(LA->LineAspect()->Aspect());
150
151   if(!IsInDomain)
152   {
153     if(!aCurve->IsCN(1)) return ;
154     gp_Elips aBEllipse = Handle(Geom_Ellipse)::DownCast(aCurve->BasisCurve ())->Elips();
155     const Standard_Real Offset = aCurve->Offset();
156     aBEllipse.SetMajorRadius(aBEllipse.MajorRadius() + Offset);
157     aBEllipse.SetMinorRadius(aBEllipse.MinorRadius() + Offset);
158     const Standard_Real uLast = ElCLib::Parameter ( aBEllipse, anEndOfArrow );
159     const Standard_Real Alpha = DsgPrs::DistanceFromApex(aBEllipse, anEndOfArrow, uFirst);//length of ellipse arc
160     gp_Pnt p1;
161     aCurve->D0(uFirst, p1);
162     gp_Vec Vapex(aCenter, anEndOfArrow) ;
163     gp_Vec Vpnt (aCenter, p1) ;
164     gp_Dir dir(Vpnt ^ Vapex);
165         Standard_Real parFirst = aCurve->Direction().IsOpposite( dir, Precision::Angular())? uLast : uFirst;
166     const Standard_Integer NodeNumber = Max (4 , Standard_Integer (50. * Alpha / M_PI));
167     const Standard_Real delta = Alpha / ( NodeNumber - 1 );
168
169     Handle(Graphic3d_ArrayOfPolylines) aPrims = new Graphic3d_ArrayOfPolylines(NodeNumber);
170     for (Standard_Integer i = 0 ; i < NodeNumber; i++, parFirst += delta)
171         {
172           aCurve->D0( parFirst, p1 );
173           aPrims->AddVertex(p1);
174         }
175     Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(aPrims);
176   }
177   DsgPrs_EllipseRadiusPresentation::Add(aPresentation, aDrawer, theval, aText,
178                                         aPosition, anEndOfArrow, aCenter, IsMaxRadius, ArrowPrs);
179 }