Logo Search packages:      
Sourcecode: opencascade version File versions  Download package

GeomSources.cpp

// GeomSources.cpp: implementation of the GeomSources class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "GeomSources.h"
#include "GeometryApp.h"
#include "MainFrm.h"
//#include "Geom_Axis2Placement.hxx"

GeomSources::GeomSources()
{
}

GeomSources::~GeomSources()
{
}


void GeomSources::PreProcess(CGeometryDoc* aDoc,DisplayType aDisplayType)
{
    if (aDisplayType == No2D3D )
    {   
      aDoc->GetAISContext()->EraseAll(Standard_False);
        aDoc->Put3DOnTop(); 
    }

    if (aDisplayType == a2DNo3D)
    { 
      aDoc->GetISessionContext()->EraseAll();
        aDoc->Put2DOnTop();
    }

    if (aDisplayType != No2D3D && aDisplayType != a2D3D)
    {  
      aDoc->Minimize3D();
    }

    if (aDisplayType != a2DNo3D && aDisplayType != a2D3D)
    {  
      aDoc->Minimize2D();
    }

    if (aDisplayType == a2D3D)
    {
      aDoc->GetAISContext()->EraseAll(Standard_False);
      aDoc->GetISessionContext()->EraseAll();
      aDoc->Put3DOnTop(false); 
      aDoc->Put2DOnTop(false);

        // both on top
        // send the message Title Horizontaly to the child of doc main frame
      CGeometryApp* TheAppli = (CGeometryApp*)AfxGetApp();
      CMainFrame* TheMainFrame= (CMainFrame*)TheAppli->m_pMainWnd;
        ::SendMessage(TheMainFrame->m_hWndMDIClient, WM_MDITILE, 0, 0);
    }

    //aDoc->myCResultDialog.Empty();
}

void GeomSources::PostProcess(CGeometryDoc* aDoc,
                                            UINT anID,
                                            DisplayType aDisplayType,
                                            const char* aString,
                                            Quantity_Coefficient Coef /* = -1 */
                                            /* double Zoom = -1 */)
{
    if (aDisplayType == No2D3D || aDisplayType == a2D3D)
    {   
      aDoc->Fit3DViews(Coef);
      //if (Zoom != -1)    aDoc->Set3DViewsZoom(Zoom);
    }

    if (aDisplayType == a2DNo3D || aDisplayType == a2D3D)
    { 
      aDoc->Fit2DViews();  
      //if (Zoom != -1) MessageBox(0,"Set 2D Zoom Not Yet Implemented","CasCade Error",MB_ICONERROR);// aDoc->Set2DViewsZoom(Zoom);
    }

       TCollection_AsciiString Message("Results are ");

  switch (aDisplayType)
  {
    case No2DNo3D: Message = "All results are in this box \n";
    break;
    case No2D3D:   Message += "only in 3D \n";
    break;
    case a2DNo3D:   Message += "only in 2d \n";
    break;
    case a2D3D:     Message += "in both 2D and 3D \n";
    break;
    }   
    Message += "====================================\n";
    Message += aString;
 //   MessageBox(0,Message.ToCString(),aTitle,MB_OK);
    //aDoc->myCResultDialog.ShowWindow(SW_RESTORE);

    CString text(Message.ToCString());
      aDoc->myCResultDialog.SetText(text);

    CString s;
    if (! s.LoadString( anID ))
      AfxMessageBox("Error Loading String: ");

    CString Title = s.Left( s.Find( '\n' ));

    aDoc->myCResultDialog.SetTitle(Title);
    aDoc->SetTitle(Title);
}

void GeomSources::AddSeparator(CGeometryDoc* aDoc,TCollection_AsciiString& aMessage)
{
    aMessage+= "------------------------------------------------------------------------\n";
}
void GeomSources::DisplayPoint(CGeometryDoc* aDoc,
                          gp_Pnt2d& aPoint,
                          const char* aText,
                          Standard_Boolean UpdateViewer,
                          Standard_Real anXoffset,
                          Standard_Real anYoffset,
                          Standard_Real TextScale)
{
    Handle(ISession_Point) aGraphicPoint = new ISession_Point(aPoint);
    aDoc->GetISessionContext()->Display(aGraphicPoint,UpdateViewer);
    Handle(ISession_Text)  aGraphicText = new ISession_Text(aText,aPoint.X()+anXoffset,aPoint.Y()+anYoffset);
    aGraphicText->SetScale  (TextScale);
    aDoc->GetISessionContext()->Display(aGraphicText,UpdateViewer);
}

void GeomSources::DisplayPoint(CGeometryDoc* aDoc,
                          gp_Pnt& aPoint,
                          const char* aText,
                          Standard_Boolean UpdateViewer,
                          Standard_Real anXoffset,
                          Standard_Real anYoffset,
                          Standard_Real aZoffset,
                          Standard_Real TextScale)
{
    Handle(ISession_Point) aGraphicPoint = new ISession_Point(aPoint);
    aDoc->GetAISContext()->Display(aGraphicPoint,UpdateViewer);
    Handle(ISession_Text)  aGraphicText = new ISession_Text(aText,aPoint.X()+anXoffset,aPoint.Y()+anYoffset,aPoint.Z()+aZoffset);
    aGraphicText->SetScale  (TextScale);
    aDoc->GetAISContext()->Display(aGraphicText,UpdateViewer);
}

void GeomSources::DisplayCurve(CGeometryDoc* aDoc,
                          Handle(Geom2d_Curve) aCurve,
                          Standard_Integer aColorIndex,
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession2D_Curve) aGraphicCurve = new ISession2D_Curve(aCurve);
    aGraphicCurve->SetColorIndex(aColorIndex) ;
    aDoc->GetISessionContext()->Display(aGraphicCurve,UpdateViewer);
}

void GeomSources::DisplayCurveAndCurvature(CGeometryDoc* aDoc,
                          Handle(Geom2d_Curve) aCurve,
                          Standard_Integer aColorIndex,
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession2D_Curve) aGraphicCurve = new ISession2D_Curve(aCurve);
    aGraphicCurve->SetDisplayCurbure(Standard_True) ;
    aGraphicCurve->SetDiscretisation(20);
    aGraphicCurve->SetColorIndex(aColorIndex) ;
    aDoc->GetISessionContext()->Display(aGraphicCurve,UpdateViewer);
}

void GeomSources::DisplayCurve(CGeometryDoc* aDoc,
                          Handle(Geom_Curve) aCurve,
                          Quantity_NameOfColor aNameOfColor, 
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession_Curve) aGraphicCurve = new ISession_Curve(aCurve);
    aDoc->GetAISContext()->SetColor(aGraphicCurve,aNameOfColor, Standard_False);
    aGraphicCurve->Attributes()->LineAspect()->SetColor(aNameOfColor);
    aDoc->GetAISContext()->Display(aGraphicCurve,UpdateViewer);
}

void GeomSources::DisplayCurve(CGeometryDoc* aDoc,
                          Handle(Geom_Curve) aCurve,
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession_Curve) aGraphicCurve = new ISession_Curve(aCurve);
    aDoc->GetAISContext()->Display(aGraphicCurve,UpdateViewer);
}




void GeomSources::DisplaySurface(CGeometryDoc* aDoc,
                          Handle(Geom_Surface) aSurface,
                          Quantity_NameOfColor aNameOfColor, 
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession_Surface) aGraphicalSurface = new ISession_Surface(aSurface);
    aDoc->GetAISContext()->SetColor(aGraphicalSurface,aNameOfColor, Standard_False);
    aGraphicalSurface->Attributes()->FreeBoundaryAspect()->SetColor(aNameOfColor);
    aGraphicalSurface->Attributes()->UIsoAspect()->SetColor(aNameOfColor);
    aGraphicalSurface->Attributes()->VIsoAspect()->SetColor(aNameOfColor);
    aDoc->GetAISContext()->Display(aGraphicalSurface,UpdateViewer);
}

void GeomSources::DisplaySurface(CGeometryDoc* aDoc,
                          Handle(Geom_Surface) aSurface,
                          Standard_Boolean UpdateViewer)
{
    Handle(ISession_Surface) aGraphicalSurface = new ISession_Surface(aSurface);
    aDoc->GetAISContext()->Display(aGraphicalSurface,UpdateViewer);
}

// Function name  : GeomSources::gpTest1
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest1(CGeometryDoc* aDoc)
{
  DisplayType TheDisplayType = No2D3D;
  PreProcess(aDoc,TheDisplayType);
//==============================================================
                                        
gp_XYZ A(1,2,3);                        
gp_XYZ B(2,2,2);                        
gp_XYZ C(3,2,3);                        
Standard_Real result = A.DotCross(B,C); 
                                        
//==============================================================
    TCollection_AsciiString Message ("\
                                        \n\
gp_XYZ A(1,2,3);                        \n\
gp_XYZ B(2,2,2);                        \n\
gp_XYZ C(3,2,3);                        \n\
Standard_Real result = A.DotCross(B,C); \n\
                                        \n");
    AddSeparator(aDoc,Message);
//--------------------------------------------------------------
    DisplayPoint(aDoc,gp_Pnt(A),"A (1,2,3)",false,0.1);
    DisplayPoint(aDoc,gp_Pnt(B),"B (2,2,2)",false,0.1);
    DisplayPoint(aDoc,gp_Pnt(C),"C (3,2,3)", false,0.1);

// to add a numeric value in a TCollectionAsciiString 
      TCollection_AsciiString Message2 (result);
    
      Message+= " result = ";
    Message+= Message2;

    PostProcess(aDoc,ID_BUTTON_Test_1,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest2
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest2(CGeometryDoc* aDoc)
{
  DisplayType TheDisplayType = No2D3D;
  PreProcess(aDoc,TheDisplayType);
//==============================================================
                   
gp_Pnt P1(1,2,3);  
                   
//==============================================================
TCollection_AsciiString Message ("\
                  \n\
gp_Pnt P1(1,2,3); \n\
                  \n");
AddSeparator(aDoc,Message);
//--------------------------------------------------------------
DisplayPoint(aDoc,P1,"P1 (1,2,3)",false,0.5);
PostProcess(aDoc,ID_BUTTON_Test_2,TheDisplayType,Message.ToCString(),1.0);
}


// Function name  : GeomSources::gpTest3
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest3(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                  
gp_XYZ A(1,2,3);  
gp_Pnt P2(A);     
                  
//==============================================================
    TCollection_AsciiString Message ("\
                   \n\
gp_XYZ A(1,2,3);   \n\
gp_Pnt P2(A);      \n\
                   \n");
AddSeparator(aDoc,Message);
//--------------------------------------------------------------
DisplayPoint(aDoc,P2,"P2 (1,2,3)",false,0.5);

PostProcess(aDoc,ID_BUTTON_Test_3,TheDisplayType,Message.ToCString(),1.0 /*0.02*/);
}


// Function name  : GeomSources::gpTest4
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest4(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                              
gp_Pnt P3 = gp::Origin();                     
Standard_Real TheX = P3.X();
Standard_Real TheY = P3.Y();
Standard_Real TheZ = P3.Z();
  
                                              
//==============================================================
    TCollection_AsciiString Message ("\
                               \n\
gp_Pnt P3 = gp::Origin();      \n\
Standard_Real TheX = P3.X();   \n\
Standard_Real TheY = P3.Y();   \n\
Standard_Real TheZ = P3.Z();   \n\
                               \n");
AddSeparator(aDoc,Message);
//--------------------------------------------------------------
DisplayPoint(aDoc,P3,"P3 = gp::Origin()",false,0.5);

TCollection_AsciiString Message2 (TheX);
TCollection_AsciiString Message3 (TheY);
TCollection_AsciiString Message4 (TheZ);
          
      Message += " TheX = ";
      Message += Message2;
    Message += " TheY = "; 
      Message += Message3;
    Message += " TheZ = "; 
      Message4 = TheZ;
      Message += Message4;

PostProcess(aDoc,ID_BUTTON_Test_4,TheDisplayType,Message.ToCString(),1.0 /*0.02*/);
}


// Function name  : GeomSources::gpTest5
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest5(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                               
gp_Pnt P1(1,2,3);              
gp_Pnt P2(3,4,5);              
gp_Pnt PB = P1;                
Standard_Real alpha = 3;       
Standard_Real beta = 7;        
PB.BaryCenter(alpha,P2,beta);  
                               
//==============================================================
    TCollection_AsciiString Message ("\
                                 \n\
gp_Pnt P1(1,2,3);                \n\
gp_Pnt P2(3,4,5);                \n\
gp_Pnt PB = P1;                  \n\
Standard_Real alpha = 3;         \n\
Standard_Real beta = 7;          \n\
PB.BaryCenter(alpha,P2,beta);    \n\
                                 \n");

    AddSeparator(aDoc,Message);
//--------------------------------------------------------------

    DisplayPoint(aDoc,P1,"P1",false,0.2);
    DisplayPoint(aDoc,P2,"P2",false,0.2);
    DisplayPoint(aDoc,PB,"PB = barycenter ( 3 * P1 , 7 * P2) ",false,0.2);

    TCollection_AsciiString Message2 (PB.X());
      TCollection_AsciiString Message3 (PB.Y());
      TCollection_AsciiString Message4 (PB.Z());

      
      
      Message += " PB ( ";
      Message += Message2; 
      Message += " , ";
    Message += Message3; 
      Message += " , ";
    Message += Message4; 
      Message += " ); ";
    PostProcess(aDoc,ID_BUTTON_Test_5,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest6
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest6(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
//  Compute a 3d point P as BaryCenter of an array of point
gp_Pnt P1(0,0,5);                                                
gp_Pnt P2(1,2,3);                                                
gp_Pnt P3(2,3,-2);                                                
gp_Pnt P4(4,3,5);                                                
gp_Pnt P5(5,5,4);                                                
TColgp_Array1OfPnt array (1,5); // sizing array                  
array.SetValue(1,P1);                                            
array.SetValue(2,P2);                                            
array.SetValue(3,P3);                                            
array.SetValue(4,P4);                                            
array.SetValue(5,P5);                                            
                                                                 
Standard_Real Tolerance = 8; // ajout de la tolerance            
GProp_PEquation PE (array,Tolerance);                            
                                                                 
gp_Pnt P; // P declaration                                    
Standard_Boolean IsPoint;                                        

if (PE.IsPoint()){
      IsPoint = true;                                
    P = PE .Point();
      }                              
else { 
      IsPoint = false;  
      }                     

if (PE.IsLinear()){ /*... */ }  
if (PE.IsPlanar()){ /*... */ }   
if (PE.IsSpace()) { /*... */ }     
                                                                 
//==============================================================
    TCollection_AsciiString Message ("\
                                                                 \n\
                                                                 \n\
//  Compute a 3d point P as BaryCenter of an array of point      \n\
gp_Pnt P1(0,0,5);                                                \n\
gp_Pnt P2(1,2,3);                                                \n\
gp_Pnt P3(2,3,-2);                                               \n\
gp_Pnt P4(4,3,5);                                                \n\
gp_Pnt P5(5,5,4);                                                \n\
TColgp_Array1OfPnt array (1,5); // sizing array                  \n\
array.SetValue(1,P1);                                            \n\
array.SetValue(2,P2);                                            \n\
array.SetValue(3,P3);                                            \n\
array.SetValue(4,P4);                                            \n\
array.SetValue(5,P5);                                            \n\
                                                                 \n\
Standard_Real Tolerance = 8; // ajout de la tolerance            \n\
GProp_PEquation PE (array,Tolerance);                            \n\
                                                                 \n\
gp_Pnt P; // P declaration                                       \n\
Standard_Boolean IsPoint;                                        \n\
if (PE.IsPoint()){IsPoint = true;                                \n\
                  P = PE .Point();}                              \n\
                  else { IsPoint = false;  }                     \n\
if (PE.IsLinear()){ /*... */ }                                   \n\
if (PE.IsPlanar()){ /*... */ }                                   \n\
if (PE.IsSpace()) { /*... */ }                                   \n\
                                                                 \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    TCollection_AsciiString PointName("P");
    

      for(Standard_Integer i= array.Lower();i <= array.Upper(); i++)
    {
          
            TCollection_AsciiString TheString (i);
            TheString = PointName+ TheString;
            DisplayPoint(aDoc,array(i),TheString.ToCString(),false,0.5);
    }

    DisplayPoint(aDoc,P,"P",false,0.5);
      TCollection_AsciiString Message2 (P.X());
      TCollection_AsciiString Message3 (P.Y());
      TCollection_AsciiString Message4 (P.Z());


     Message += " IsPoint = ";  if (IsPoint) {
     Message += "True   -->  ";
     Message += " P ( ";
     
       Message += Message2; Message += " , ";
     Message += Message3; Message += " , ";
     Message += Message4; Message += " ); \n";
    
      
      }  else Message += "False\n";
    Message += " IsLinear = ";  if (PE.IsLinear()) Message += "True \n";  else Message += "False\n";
    Message += " IsPlanar = ";  if (PE.IsPlanar()) Message += "True \n";  else Message += "False\n";
    Message += " IsSpace = ";   if (PE.IsSpace() ) Message += "True \n";  else Message += "False\n";

    PostProcess(aDoc,ID_BUTTON_Test_6,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest7
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest7(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                           
gp_Pnt2d P1(0,5);                                       
gp_Pnt2d P2(5.5,1);                                     
gp_Pnt2d P3(-2,2);                                      
                                                        
Handle(Geom2d_TrimmedCurve) C =                         
    GCE2d_MakeArcOfCircle (P1,P2,P3).Value();           

Standard_Real FirstParameter = C->FirstParameter();
Standard_Real LastParameter = C->LastParameter();
Standard_Real MiddleParameter = (FirstParameter+LastParameter)/2;
Standard_Real param = MiddleParameter; //in radians    

gp_Pnt2d P;                                             
gp_Vec2d V;                                             
C->D1(param,P,V);                          
// we recover point P and the vector V     
                                           
//==============================================================
    TCollection_AsciiString Message ("\
                                                    \n\
                                                    \n\
gp_Pnt2d P1(0,5);                                   \n\
gp_Pnt2d P2(5.5,1);                                 \n\
gp_Pnt2d P3(-2,2);                                  \n\
                                                    \n\
Handle(Geom2d_TrimmedCurve) C =                     \n\
    GCE2d_MakeArcOfCircle (P1,P2,P3).Value();       \n\
                                                    \n\
Standard_Real FirstParameter = C->FirstParameter(); \n\
Standard_Real LastParameter = C->LastParameter();   \n\
Standard_Real MiddleParameter =                     \n\
           (FirstParameter+LastParameter)/2;        \n\
Standard_Real param = MiddleParameter; //in radians \n\
                                                    \n\
gp_Pnt2d P;                                         \n\
gp_Vec2d V;                                         \n\
C->D1(param,P,V);                                   \n\
// we recover point P and the vector V              \n\
                                                    \n");

    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayCurve(aDoc,C);
    Handle(ISession_Direction) aDirection = new ISession_Direction(P,V);
    aDoc->GetISessionContext()->Display(aDirection, Standard_False);

    DisplayPoint(aDoc,P,"P",false,0.5);

    PostProcess(aDoc,ID_BUTTON_Test_7,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest8
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest8(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                   
Standard_Real radius = 5;                          
Handle(Geom2d_Circle) C =                          
    new Geom2d_Circle(gp::OX2d(),radius);          
Standard_Real param = 1.2*PI;                      
Geom2dLProp_CLProps2d CLP                          
    (C,param,2,Precision::PConfusion());           
    gp_Dir2d D;                                    
CLP.Tangent(D);                                    
// D is the Tangent direction at parameter 1.2*PI  
                                                   
//==============================================================
    TCollection_AsciiString Message (" \
                                                   \n\
Standard_Real radius = 5;                          \n\
Handle(Geom2d_Circle) C =                          \n\
    new Geom2d_Circle(gp::OX2d(),radius);          \n\
Standard_Real param = 1.2*PI;                      \n\
Geom2dLProp_CLProps2d CLP                          \n\
    (C,param,2,Precision::PConfusion());           \n\
    gp_Dir2d D;                                    \n\
CLP.Tangent(D);                                    \n\
// D is the Tangent direction at parameter 1.2*PI  \n\
                                                   \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(C);
    aDoc->GetISessionContext()->Display(aCurve,Standard_False);
    Handle(ISession_Direction) aDirection = new ISession_Direction(gp_Pnt2d(0,0),D,2);
    aDoc->GetISessionContext()->Display(aDirection,Standard_False);
      
      TCollection_AsciiString Message2 (D.X());
      TCollection_AsciiString Message3 (D.Y());
      

     
      Message += " D ( ";
     Message += Message2; Message += " , ";
     Message += Message3; Message += " ); \n";

    PostProcess(aDoc,ID_BUTTON_Test_8,TheDisplayType,Message.ToCString());
}



// Function name  : GeomSources::gpTest9
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest9(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
    //==============================================================
                                                             
Standard_Real radius = 5;                                    
Handle(Geom2d_Circle) C =                                    
    new Geom2d_Circle(gp::OX2d(),radius);                    
Geom2dAdaptor_Curve GAC (C);                                 
Standard_Real startparam = 10*PI180;                                
Standard_Real abscissa = 45*PI180;                                  
gp_Pnt2d P1;
C->D0(startparam,P1);                                                
// abscissa is the distance along the curve from startparam  
GCPnts_AbscissaPoint AP (GAC, abscissa, startparam);         
gp_Pnt2d P2;                                                  
if (AP.IsDone()){C->D0(AP.Parameter(),P2);}                   
// P is now correctly set                                    
                                                             
    //==============================================================
    TCollection_AsciiString Message (" \n\
                                                             \n\
                                                             \n\
Standard_Real radius = 5;                                    \n\
Handle(Geom2d_Circle) C =                                    \n\
    new Geom2d_Circle(gp::OX2d(),radius);                    \n\
Geom2dAdaptor_Curve GAC (C);                                 \n\
Standard_Real startparam = 10*PI180;                            \n\
Standard_Real abscissa = 45*PI180;                                 \n\
gp_Pnt2d P1;                                                 \n\
C->D0(startparam,P1);                                                \n\
// abscissa is the distance along the curve from startparam  \n\
GCPnts_AbscissaPoint AP (GAC, abscissa, startparam);         \n\
gp_Pnt2d P2;                                                  \n\
if (AP.IsDone()){C->D0(AP.Parameter(),P2);}                   \n\
// P is now correctly set                                    \n\
                                                             \n\
                                                             \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(C);
    aDoc->GetISessionContext()->Display(aCurve,Standard_False);

    DisplayPoint(aDoc,P1,"P1");
if (AP.IsDone())    DisplayPoint(aDoc,P2,"P2");
      
      TCollection_AsciiString Message2 (P1.X());
      TCollection_AsciiString Message3 (P1.Y());
      
      TCollection_AsciiString Message4 (P2.X());
      TCollection_AsciiString Message5 (P2.Y());
      

     Message += " P1 ( ";
     Message += Message2; Message += " , ";
     Message += Message3; Message += " ); \n";

     Message += " P2 ( ";
     Message += Message4; Message += " , ";
     Message += Message5; Message += " ); \n";
    PostProcess(aDoc,ID_BUTTON_Test_9,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest10
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest10(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                        
gp_Pnt2d P;                                             
Standard_Real radius = 5;                               
Handle(Geom2d_Circle) C =                               
    new Geom2d_Circle(gp::OX2d(),radius);               
Geom2dAdaptor_Curve GAC (C);                            
Standard_Real abscissa = 3;                             
GCPnts_UniformAbscissa UA (GAC,abscissa);               
TColgp_SequenceOfPnt2d aSequence;                       
if (UA.IsDone())                                        
  {                                                     
    Standard_Real N = UA.NbPoints();                    
    Standard_Integer count = 1;                         
    for(;count<=N;count++)                              
     {                                                  
        C->D0(UA.Parameter(count),P);                   
        Standard_Real Parameter = UA.Parameter(count);  
        // append P in a Sequence                       
        aSequence.Append(P);                            
    }                                                   
}                                                       
Standard_Real Abscissa  = UA.Abscissa();                
                                                        
//==============================================================
    TCollection_AsciiString Message (" \
                                                        \n\
gp_Pnt2d P;                                             \n\
Standard_Real radius = 5;                               \n\
Handle(Geom2d_Circle) C =                               \n\
    new Geom2d_Circle(gp::OX2d(),radius);               \n\
Geom2dAdaptor_Curve GAC (C);                            \n\
Standard_Real abscissa = 3;                             \n\
GCPnts_UniformAbscissa UA (GAC,abscissa);               \n\
TColgp_SequenceOfPnt2d aSequence;                       \n\
if (UA.IsDone())                                        \n\
  {                                                     \n\
    Standard_Real N = UA.NbPoints();                    \n\
    Standard_Integer count = 1;                         \n\
    for(;count<=N;count++)                              \n\
     {                                                  \n\
        C->D0(UA.Parameter(count),P);                   \n\
        Standard_Real Parameter = UA.Parameter(count);  \n\
        // append P in a Sequence                       \n\
        aSequence.Append(P);                            \n\
    }                                                   \n\
}                                                       \n\
Standard_Real Abscissa  = UA.Abscissa();                \n\
                                                        \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(C);
    aDoc->GetISessionContext()->Display(aCurve,Standard_False);

    TCollection_AsciiString aString;
    for (Standard_Integer i=1;i<= aSequence.Length();i++)
    {
     
      TCollection_AsciiString Message2 (i);
      TCollection_AsciiString Message3 (UA.Parameter(i));

      aString = "P";
      aString += Message2; 
      aString +=": Parameter : "; 
      aString += Message3;
     
      //   First and Last texts are displayed with an Y offset, point 4 is upper
     Standard_Real YOffset = -0.3;
     YOffset +=  0.2 * ( i == 1 ) ;
     YOffset +=  0.4 * ( i == 4 ) ;
     YOffset += -0.2 * ( i == aSequence.Length() ); 

     DisplayPoint(aDoc,aSequence(i),aString.ToCString(),false,0.5,YOffset,0.04);
    }
    
      TCollection_AsciiString Message3 (Abscissa);

      Message += "Abscissa  = "; Message += Message3; Message += " \n";
    PostProcess(aDoc,ID_BUTTON_Test_10,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest11
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest11(CGeometryDoc* aDoc)
{
   DisplayType TheDisplayType = No2D3D;
   PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                          
Standard_Real radius = 5;                                 
Handle(Geom_SphericalSurface) SP =                        
    new Geom_SphericalSurface(gp_Ax3(gp::XOY()),radius);  
Standard_Real u = 2;                                      
Standard_Real v = 3;                                      
gp_Pnt P = SP->Value(u,v);                                
                                                          
//==============================================================
    TCollection_AsciiString Message (" \
                                                          \n\
Standard_Real radius = 5;                                 \n\
Handle(Geom_SphericalSurface) SP =                        \n\
    new Geom_SphericalSurface(gp_Ax3(gp::XOY()),radius);  \n\
Standard_Real u = 2;                                      \n\
Standard_Real v = 3;                                      \n\
gp_Pnt P = SP->Value(u,v);                                \n\
                                                          \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplaySurface(aDoc,SP);
    DisplayPoint(aDoc,P,"P",false,0.5);
      TCollection_AsciiString Message2 (P.X());
      TCollection_AsciiString Message3 (P.Y());
      

    Message += " P ( ";
    Message += Message2; 
      Message += " , ";
    Message += Message3; 
      Message += " ); \n";
    PostProcess(aDoc,ID_BUTTON_Test_11,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest12
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest12(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                            
gp_Pnt N,Q,P(1,2,3);                                        
Standard_Real distance, radius = 5;                         
Handle(Geom_Circle) C = new Geom_Circle(gp::XOY(),radius);  
GeomAPI_ProjectPointOnCurve PPC (P,C);                      
N = PPC.NearestPoint();                                     
Standard_Integer NbResults = PPC.NbPoints();                
                                                            
if(NbResults>0){                                            
    for(Standard_Integer i = 1;i<=NbResults;i++){           
      Q = PPC.Point(i);                                     
      distance = PPC.Distance(i);                           
        // do something with Q or distance here             
      }                                                     
 }                                                          
                                                            
//==============================================================
    TCollection_AsciiString Message (" \
                                                            \n\
gp_Pnt N,Q,P(1,2,3);                                        \n\
Standard_Real distance, radius = 5;                         \n\
Handle(Geom_Circle) C = new Geom_Circle(gp::XOY(),radius);  \n\
GeomAPI_ProjectPointOnCurve PPC (P,C);                      \n\
N = PPC.NearestPoint();                                     \n\
Standard_Integer NbResults = PPC.NbPoints();                \n\
                                                            \n\
if(NbResults>0){                                            \n\
    for(Standard_Integer i = 1;i<=NbResults;i++){           \n\
      Q = PPC.Point(i);                                     \n\
      distance = PPC.Distance(i);                           \n\
        // do something with Q or distance here             \n\
      }                                                     \n\
 }                                                          \n\
                                                            \n");
    AddSeparator(aDoc,Message);
//--------------------------------------------------------------

    TCollection_AsciiString aString;

    DisplayPoint(aDoc,P,"P",false,0.5);
      
      TCollection_AsciiString Message2 (PPC.LowerDistance());

    aString = "N : at Distance : "; 
      aString += Message2;
    
      DisplayPoint(aDoc,N,aString.ToCString(),false,0.5,0,-0.5);

    DisplayCurve(aDoc,C,false);

      if(NbResults>0){
            for(Standard_Integer i = 1;i<=NbResults;i++){
            
            
            Q = PPC.Point(i);
            distance = PPC.Distance(i);   
        TCollection_AsciiString Message3 (i);
            TCollection_AsciiString Message4 (distance);

        aString = "Q";
            aString += Message3; 
            aString +=": at Distance : "; 
            aString += Message4;
        DisplayPoint(aDoc,Q,aString.ToCString(),false,0.5);
            }
      }

    PostProcess(aDoc,ID_BUTTON_Test_12,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest13
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest13(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                          
gp_Pnt N,Q,P(7,8,9);                                      
Standard_Real distance, radius = 5;                       
Handle(Geom_SphericalSurface) SP =                        
    new Geom_SphericalSurface(gp_Ax3(gp::XOY()),radius);  
GeomAPI_ProjectPointOnSurf PPS(P,SP);                     
N = PPS.NearestPoint();                                   
Standard_Integer NbResults = PPS.NbPoints();              
if(NbResults>0){                                          
    for(Standard_Integer i = 1;i<=NbResults;i++){         
    Q = PPS.Point(i);                                     
    distance = PPS.Distance(i);                           
    // do something with Q or distance here               
    }                                                     
}                                                         
                                                          
//==============================================================
    TCollection_AsciiString Message (" \
                                                          \n\
gp_Pnt N,Q,P(7,8,9);                                      \n\
Standard_Real distance, radius = 5;                       \n\
Handle(Geom_SphericalSurface) SP =                        \n\
    new Geom_SphericalSurface(gp_Ax3(gp::XOY()),radius);  \n\
GeomAPI_ProjectPointOnSurf PPS(P,SP);                     \n\
N = PPS.NearestPoint();                                   \n\
Standard_Integer NbResults = PPS.NbPoints();              \n\
if(NbResults>0){                                          \n\
    for(Standard_Integer i = 1;i<=NbResults;i++){         \n\
    Q = PPS.Point(i);                                     \n\
    distance = PPS.Distance(i);                           \n\
    // do something with Q or distance here               \n\
    }                                                     \n\
}                                                         \n\
                                                          \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    TCollection_AsciiString aString;

    DisplayPoint(aDoc,P,"P",false,0.5);
      TCollection_AsciiString Message2 (PPS.LowerDistance());

    aString = "N  : at Distance : "; aString += Message2;
    DisplayPoint(aDoc,N,aString.ToCString(),false,0.5,0,-0.6);



    Handle(ISession_Surface) aSurface = new ISession_Surface(SP);
      Handle (AIS_Drawer) CurDrawer = aSurface->Attributes();
    CurDrawer->UIsoAspect()->SetNumber(10);
    CurDrawer->VIsoAspect()->SetNumber(10);
    aDoc->GetAISContext()->SetLocalAttributes(aSurface, CurDrawer);
    aDoc->GetAISContext()->Display(aSurface, Standard_False);

      if(NbResults>0){
            for(Standard_Integer i = 1;i<=NbResults;i++){
            
            Q = PPS.Point(i);
            distance = PPS.Distance(i);   
        TCollection_AsciiString Message3 (i);
            TCollection_AsciiString Message4 (distance);

        aString = "Q";
            aString += Message3; 
            aString +=": at Distance : "; 
            aString += Message4;
      
            DisplayPoint(aDoc,Q,aString.ToCString(),false,0.5);               
            }
      }

   PostProcess(aDoc,ID_BUTTON_Test_13,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest14
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest14(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                          
gp_Pnt P; 
gp_Ax3 theAxe(gp::XOY());
gp_Pln PL(theAxe);                            
Standard_Real MinorRadius = 5;                            
Standard_Real MajorRadius = 8;                            
gp_Elips EL (gp::YOZ(),MajorRadius,MinorRadius);          
IntAna_IntConicQuad ICQ                                   
    (EL,PL,Precision::Angular(),Precision::Confusion());  
if (ICQ.IsDone()){                                        
    Standard_Integer NbResults = ICQ.NbPoints();          
    if (NbResults>0){                                     
    for(Standard_Integer i = 1;i<=NbResults;i++){         
        P = ICQ.Point(i);                                 
        // do something with P here                       
        }                                                 
   }                                                      
}                                                         
                                                          
//==============================================================
    TCollection_AsciiString Message (" \
                                                          \n\
gp_Pnt P;                                                 \n\
gp_Pln PL (gp_Ax3(gp::XOY()));                            \n\
Standard_Real MinorRadius = 5;                            \n\
Standard_Real MajorRadius = 8;                            \n\
gp_Elips EL (gp::YOZ(),MajorRadius,MinorRadius);          \n\
IntAna_IntConicQuad ICQ                                   \n\
    (EL,PL,Precision::Angular(),Precision::Confusion());  \n\
if (ICQ.IsDone()){                                        \n\
    Standard_Integer NbResults = ICQ.NbPoints();          \n\
    if (NbResults>0){                                     \n\
    for(Standard_Integer i = 1;i<=NbResults;i++){         \n\
        P = ICQ.Point(i);                                 \n\
        // do something with P here                       \n\
        }                                                 \n\
   }                                                      \n\
}                                                         \n\
                                                          \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    Handle(Geom_Plane) aPlane = GC_MakePlane(PL).Value();
    Handle(Geom_RectangularTrimmedSurface) aSurface= new Geom_RectangularTrimmedSurface(aPlane,-8.,8.,-12.,12.);
        
    DisplaySurface(aDoc,aSurface);


    Handle(Geom_Ellipse) anEllips = GC_MakeEllipse(EL).Value();
    DisplayCurve(aDoc,anEllips,false);

    TCollection_AsciiString aString;

      if (ICQ.IsDone()){
            Standard_Integer NbResults = ICQ.NbPoints();
            if (NbResults>0){
            for(Standard_Integer i = 1;i<=NbResults;i++){
                  
                  TCollection_AsciiString Message2(i);
                  
                  P = ICQ.Point(i);
            aString = "P";aString += Message2; 
            DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
                  }
               }
            }

    PostProcess(aDoc,ID_BUTTON_Test_14,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest15
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest15(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                     
gp_Pnt P1(1,2,3);    
gp_Pnt P1Copy = P1;  
gp_Pnt P2(5,4,6);    
gp_Trsf TRSF;        
TRSF.SetMirror(P2);  
P1Copy.Transform(TRSF);  
                     
//==============================================================
    TCollection_AsciiString Message (" \
                         \n\
gp_Pnt P1(1,2,3);        \n\
gp_Pnt P1Copy = P1;      \n\
gp_Pnt P2(5,4,6);        \n\
gp_Trsf TRSF;            \n\
TRSF.SetMirror(P2);      \n\
P1Copy.Transform(TRSF);  \n\
                         \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P1Copy,"P1Copy",false,0.5);
    DisplayPoint(aDoc,P1,"P1",false,0.5);
    DisplayPoint(aDoc,P2,"P2",false,0.5);

    PostProcess(aDoc,ID_BUTTON_Test_15,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest16
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest16(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                         
gp_Pnt P1(1,2,3);                        
gp_Pnt P2(5,4,6);                        
gp_Vec V1 (P1,P2);                       
                                         
gp_Pnt P3(10,4,7);                       
gp_Pnt P4(2,0,1);                        
gp_Vec V2 (P3,P4);                       
                                         
Standard_Boolean result =                
V1.IsOpposite(V2,Precision::Angular());  
// result should be true                 
                                         
//==============================================================
    TCollection_AsciiString Message (" \
                                         \n\
gp_Pnt P1(1,2,3);                        \n\
gp_Pnt P2(5,4,6);                        \n\
gp_Vec V1 (P1,P2);                       \n\
                                         \n\
gp_Pnt P3(10,4,7);                       \n\
gp_Pnt P4(2,0,1);                        \n\
gp_Vec V2 (P3,P4);                       \n\
                                         \n\
Standard_Boolean result =                \n\
V1.IsOpposite(V2,Precision::Angular());  \n\
// result should be true                 \n\
                                         \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P1,"P1",false,0.5);
    DisplayPoint(aDoc,P2,"P2",false,0.5);
    DisplayPoint(aDoc,P3,"P3",false,0.5);
    DisplayPoint(aDoc,P4,"P4",false,0.5);

    Handle(ISession_Direction) aDirection1 = new ISession_Direction(P1,V1);
    aDoc->GetAISContext()->Display(aDirection1, Standard_False);

    Handle(ISession_Direction) aDirection2 = new ISession_Direction(P3,V2);
    aDoc->GetAISContext()->Display(aDirection2, Standard_False);

    Message += "result = ";
    if (result) Message += "True \n"; else Message += "False \n";

    PostProcess(aDoc,ID_BUTTON_Test_16,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest17
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest17(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                 
gp_Dir D1(1,2,3);                                
gp_Dir D2(3,4,5);                                
Standard_Real ang = D1.Angle(D2);                
// the result is in radians in the range [0,PI]  
                                                 
//==============================================================
    TCollection_AsciiString Message (" \
                                                 \n\
gp_Dir D1(1,2,3);                                \n\
gp_Dir D2(3,4,5);                                \n\
Standard_Real ang = D1.Angle(D2);                \n\
// the result is in radians in the range [0,PI]  \n\
                                                 \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    Handle(ISession_Direction) aDirection1 = new ISession_Direction(gp_Pnt(0,0,0),D1,3);
    aDoc->GetAISContext()->Display(aDirection1, Standard_False);

    Handle(ISession_Direction) aDirection2 = new ISession_Direction(gp_Pnt(0,0,0),D2,3);
    aDoc->GetAISContext()->Display(aDirection2, Standard_False);
    
    cout<<" D1.Angle(D2) : "<<ang<<endl;

    TCollection_AsciiString Message2 (ang);
      TCollection_AsciiString Message3 (ang/PI180);
      
      Message += " ang =  "; 
      Message += Message2; 
      Message += "   radian \n";
    Message += " ang/PI180 =  "; 
      Message += Message3; 
      Message += "   degree \n";

    PostProcess(aDoc,ID_BUTTON_Test_17,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest18
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest18(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                          
gp_Pnt2d P(2,3);                          
gp_Dir2d D(4,5);                          
gp_Ax22d A(P,D);                          
gp_Parab2d Para(A,6);                     
// P is the vertex point                  
// P and D give the axis of symmetry      
// 6 is the focal length of the parabola  
                                          
//==============================================================
    TCollection_AsciiString Message (" \
                                          \n\
gp_Pnt2d P(2,3);                          \n\
gp_Dir2d D(4,5);                          \n\
gp_Ax22d A(P,D);                          \n\
gp_Parab2d Para(A,6);                     \n\
// P is the vertex point                  \n\
// P and D give the axis of symmetry      \n\
// 6 is the focal length of the parabola  \n\
                                          \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P,"P",false,0.5,0,3);

    Handle(ISession_Direction) aDirection = new ISession_Direction(P,D,200);
    aDoc->GetISessionContext()->Display(aDirection,Standard_False);
    Handle(Geom2d_Parabola) aParabola = GCE2d_MakeParabola(Para);
    Handle(Geom2d_TrimmedCurve) aTrimmedCurve = new Geom2d_TrimmedCurve(aParabola,-100,100);
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aTrimmedCurve);
    //aCurve->SetColorIndex(3);
    aDoc->GetISessionContext()->Display(aCurve, Standard_False);  

    Message += " The entity A of type gp_Ax22d is not displayable \n ";
    Message += " The entity D of type gp_Dir2d is displayed as a vector \n    ( mean with a length != 1 ) \n ";
    PostProcess(aDoc,ID_BUTTON_Test_18,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest19
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest19(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                            
gp_Pnt P1(2,3,4);                           
gp_Dir D(4,5,6);                            
gp_Ax3 A(P1,D);                              
Standard_Boolean IsDirectA = A.Direct();    
                                            
gp_Dir AXDirection = A.XDirection() ;       
gp_Dir AYDirection = A.YDirection() ;       
                                            
gp_Pnt P2(5,3,4);                           
gp_Ax3 A2(P2,D);                            
A2.YReverse();                              
// axis3 is now left handed                 
Standard_Boolean IsDirectA2 = A2.Direct();  
                                            
gp_Dir A2XDirection = A2.XDirection() ;     
gp_Dir A2YDirection = A2.YDirection() ;     
                                            
//==============================================================
    TCollection_AsciiString Message (" \
                                            \n\
gp_Pnt P1(2,3,4);                           \n\
gp_Dir D(4,5,6);                            \n\
gp_Ax3 A(P,D);                              \n\
Standard_Boolean IsDirectA = A.Direct();    \n\
                                            \n\
gp_Dir AXDirection = A.XDirection() ;       \n\
gp_Dir AYDirection = A.YDirection() ;       \n\
                                            \n\
gp_Pnt P2(5,3,4);                           \n\
gp_Ax3 A2(P2,D);                            \n\
A2.YReverse();                              \n\
// axis3 is now left handed                 \n\
Standard_Boolean IsDirectA2 = A2.Direct();  \n\
                                            \n\
gp_Dir A2XDirection = A2.XDirection() ;     \n\
gp_Dir A2YDirection = A2.YDirection() ;     \n\
                                            \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P1,"P1",false,0.1);
    Handle(ISession_Direction) aDirection = new ISession_Direction(P1,D,2);
    aDoc->GetAISContext()->Display(aDirection, Standard_False);

    Handle(ISession_Direction) aDirection2 = new ISession_Direction(P1,AXDirection,2);
    aDirection2->SetText(TCollection_ExtendedString("A.XDirection"));
    aDoc->GetAISContext()->Display(aDirection2, Standard_False);
    Handle(ISession_Direction) aDirection3 = new ISession_Direction(P1,AYDirection,2);
    aDirection3->SetText(TCollection_ExtendedString("A.YDirection"));
    aDoc->GetAISContext()->Display(aDirection3, Standard_False);

    DisplayPoint(aDoc,P2,"P2",false,0.1);
    Handle(ISession_Direction) aDirection4 = new ISession_Direction(P2,D,2);
    aDoc->GetAISContext()->Display(aDirection4, Standard_False);

    Handle(ISession_Direction) aDirection5 = new ISession_Direction(P2,A2XDirection,2);
    aDirection5->SetText(TCollection_ExtendedString("A2 XDirection"));
    aDoc->GetAISContext()->Display(aDirection5, Standard_False);
    Handle(ISession_Direction) aDirection6 = new ISession_Direction(P2,A2YDirection,2);
    aDirection6->SetText(TCollection_ExtendedString("A2 YDirection"));
    aDoc->GetAISContext()->Display(aDirection6, Standard_False);

    Message += "IsDirectA = ";
    if (IsDirectA) Message += "True = Right Handed \n"; else Message += "False = Left Handed \n";

    Message += "IsDirectA2 = ";
    if (IsDirectA2) Message += "True = Right Handed \n"; else Message += "False = Left Handed  \n";

    PostProcess(aDoc,ID_BUTTON_Test_19,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest20
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest20(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                     
TColgp_Array1OfPnt2d array (1,5); // sizing array                    
array.SetValue(1,gp_Pnt2d (0,0));                                    
array.SetValue(2,gp_Pnt2d (1,2));                                    
array.SetValue(3,gp_Pnt2d (2,3));                                    
array.SetValue(4,gp_Pnt2d (4,3));                                    
array.SetValue(5,gp_Pnt2d (5,5));                                    
Handle(Geom2d_BSplineCurve) SPL1 =                                   
    Geom2dAPI_PointsToBSpline(array);                                
                                                                     
Handle(TColgp_HArray1OfPnt2d) harray =                               
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray                
harray->SetValue(1,gp_Pnt2d (7+ 0,0));                               
harray->SetValue(2,gp_Pnt2d (7+ 1,2));                               
harray->SetValue(3,gp_Pnt2d (7+ 2,3));                               
harray->SetValue(4,gp_Pnt2d (7+ 4,3));                               
harray->SetValue(5,gp_Pnt2d (7+ 5,5));                                                                                            
Geom2dAPI_Interpolate anInterpolation(harray,Standard_False,0.01);   
anInterpolation.Perform();                                           
Handle(Geom2d_BSplineCurve) SPL2 = anInterpolation.Curve();          
                                                                     
Handle(TColgp_HArray1OfPnt2d) harray2 =                              
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray                
harray2->SetValue(1,gp_Pnt2d (11+ 0,0));                             
harray2->SetValue(2,gp_Pnt2d (11+ 1,2));                             
harray2->SetValue(3,gp_Pnt2d (11+ 2,3));                             
harray2->SetValue(4,gp_Pnt2d (11+ 4,3));                             
harray2->SetValue(5,gp_Pnt2d (11+ 5,5));                             
Geom2dAPI_Interpolate anInterpolation2(harray2,Standard_True,0.01);  
anInterpolation2.Perform();                                          
Handle(Geom2d_BSplineCurve) SPL3 = anInterpolation2.Curve();         
// redefined C++ operator allows these assignments                   
                                                                     
//==============================================================
    TCollection_AsciiString Message (" \
                                                                     \n\
TColgp_Array1OfPnt2d array (1,5); // sizing array                    \n\
array.SetValue(1,gp_Pnt2d (0,0));                                    \n\
array.SetValue(2,gp_Pnt2d (1,2));                                    \n\
array.SetValue(3,gp_Pnt2d (2,3));                                    \n\
array.SetValue(4,gp_Pnt2d (4,3));                                    \n\
array.SetValue(5,gp_Pnt2d (5,5));                                    \n\
Handle(Geom2d_BSplineCurve) SPL1 =                                   \n\
    Geom2dAPI_PointsToBSpline(array);                                \n\
                                                                     \n\
Handle(TColgp_HArray1OfPnt2d) harray =                               \n\
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray                \n\
harray->SetValue(1,gp_Pnt2d (7+ 0,0));                               \n\
harray->SetValue(2,gp_Pnt2d (7+ 1,2));                               \n\
harray->SetValue(3,gp_Pnt2d (7+ 2,3));                               \n\
harray->SetValue(4,gp_Pnt2d (7+ 4,3));                               \n\
harray->SetValue(5,gp_Pnt2d (7+ 5,5));                               \n\
Geom2dAPI_Interpolate anInterpolation(harray,Standard_False,0.01);   \n\
anInterpolation.Perform();                                           \n\
Handle(Geom2d_BSplineCurve) SPL2 = anInterpolation.Curve();          \n\
                                                                     \n\
Handle(TColgp_HArray1OfPnt2d) harray2 =                              \n\
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray                \n");
    Message += "\
harray2->SetValue(1,gp_Pnt2d (11+ 0,0));                             \n\
harray2->SetValue(2,gp_Pnt2d (11+ 1,2));                             \n\
harray2->SetValue(3,gp_Pnt2d (11+ 2,3));                             \n\
harray2->SetValue(4,gp_Pnt2d (11+ 4,3));                             \n\
harray2->SetValue(5,gp_Pnt2d (11+ 5,5));                             \n\
Geom2dAPI_Interpolate anInterpolation2(harray2,Standard_True,0.01);  \n\
anInterpolation2.Perform();                                          \n\
Handle(Geom2d_BSplineCurve) SPL3 = anInterpolation2.Curve();         \n\
// redefined C++ operator allows these assignments                   \n\
                                                                     \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    TCollection_AsciiString aString;
    for(Standard_Integer i = array.Lower();i<=array.Upper();i++){
            gp_Pnt2d P = array(i);
        TCollection_AsciiString Message2 (i);
            aString = "array ";aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }
    for( i = harray->Lower();i<=harray->Upper();i++){
            gp_Pnt2d P = harray->Value(i);
        TCollection_AsciiString Message2 (i);
            aString = "harray ";aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }
    for( i = harray2->Lower();i<=harray2->Upper();i++){
            gp_Pnt2d P = harray2->Value(i);
            TCollection_AsciiString Message2 (i);
        aString = "harray2 ";aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }

    if (!SPL1.IsNull())
    { 
      Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(SPL1);
      aCurve->SetColorIndex(3);
      aDoc->GetISessionContext()->Display(aCurve, Standard_False);
    }
    else
      MessageBox(0,"SPL1.IsNull()","CasCade Error",MB_ICONERROR);
    
    if (!SPL2.IsNull())
    {
      Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(SPL2);
      aCurve2->SetColorIndex(5);
      aDoc->GetISessionContext()->Display(aCurve2, Standard_False);  
    }
    else
      MessageBox(0,"SPL2.IsNull()","CasCade Error",MB_ICONERROR);

    if (!SPL3.IsNull())
    {
      Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(SPL3);
      aCurve2->SetColorIndex(6);
      aDoc->GetISessionContext()->Display(aCurve2, Standard_False);  
    }
    else
      MessageBox(0,"SPL3.IsNull()","CasCade Error",MB_ICONERROR);

    Message += " SPL1  is Red  \n";
    Message += " SPL2  is Blue \n";   
    Message += " SPL3  is Yellow \n";   

    PostProcess(aDoc,ID_BUTTON_Test_20,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest21(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                            
gp_Pnt2d P1(-184, 101);                     
gp_Pnt2d P2(20 ,84);                        
Standard_Real aheight = 1;                  
FairCurve_Batten B (P1,P2,aheight);         
B.SetAngle1(22*PI180);                      
B.SetAngle2(44*PI180);                      
FairCurve_AnalysisCode anAnalysisCode;      
B.Compute(anAnalysisCode);                  
Handle(Geom2d_BSplineCurve) C = B.Curve();  
                                            
//==============================================================
    TCollection_AsciiString Message (" \
                                            \n\
gp_Pnt2d P1(-184, 101);                     \n\
gp_Pnt2d P2(20 ,84);                        \n\
Standard_Real aheight = 1;                  \n\
FairCurve_Batten B (P1,P2,aheight);         \n\
B.SetAngle1(22*PI180);                      \n\
B.SetAngle2(44*PI180);                      \n\
FairCurve_AnalysisCode anAnalysisCode;      \n\
B.Compute(anAnalysisCode);                  \n\
Handle(Geom2d_BSplineCurve) C = B.Curve();  \n\
                                            \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayCurveAndCurvature(aDoc,C,6,Standard_False);               

    PostProcess(aDoc,ID_BUTTON_Test_21,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest22(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                
gp_Pnt2d P1(-184, 41);                          
gp_Pnt2d P2(20 ,24);                            
Standard_Real aheight = 1;                      
FairCurve_MinimalVariation MV (P1,P2,aheight);  
MV.SetAngle1(22*PI180);                         
MV.SetAngle2(44*PI180);                         
                                                
FairCurve_AnalysisCode anAnalysisCode;          
MV.Compute(anAnalysisCode);                     
                                                
Handle(Geom2d_BSplineCurve) C = MV.Curve();     
                                                
//==============================================================
    TCollection_AsciiString Message (" \
                                                \n\
gp_Pnt2d P1(-184, 41);                          \n\
gp_Pnt2d P2(20 ,24);                            \n\
Standard_Real aheight = 1;                      \n\
FairCurve_MinimalVariation MV (P1,P2,aheight);  \n\
MV.SetAngle1(22*PI180);                         \n\
MV.SetAngle2(44*PI180);                         \n\
                                                \n\
FairCurve_AnalysisCode anAnalysisCode;          \n\
MV.Compute(anAnalysisCode);                     \n\
                                                \n\
Handle(Geom2d_BSplineCurve) C = MV.Curve();     \n\
                                                \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayCurveAndCurvature(aDoc,C,7,Standard_False);                   
    DisplayPoint(aDoc,P1,"P1",false,0.5);
    DisplayPoint(aDoc,P2,"P2",false,0.5);

    PostProcess(aDoc,ID_BUTTON_Test_22,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest23
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest23(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                               
Standard_Real major = 12;                                               
Standard_Real minor = 4;                                                
gp_Ax2d axis = gp::OX2d();                                              
Handle(Geom2d_Ellipse) E = GCE2d_MakeEllipse (axis,major,minor);        
                   
Handle(Geom2d_TrimmedCurve) TC = new Geom2d_TrimmedCurve(E,-1,2);
       
// The segment goes in the direction Vfrom P1  
// to the point projected on this line by P2   
// In the example (0,6).                       
Handle(Geom2d_BSplineCurve) SPL =              
    Geom2dConvert::CurveToBSplineCurve(TC);    
                                               
//==============================================================
    TCollection_AsciiString Message (" \
                                                                   \n\
Standard_Real major = 12;                                          \n\
Standard_Real minor = 4;                                           \n\
gp_Ax2d axis = gp::OX2d();                                         \n\
Handle(Geom2d_Ellipse) E = GCE2d_MakeEllipse (axis,major,minor);   \n\
                                                                   \n\
Handle(Geom2d_TrimmedCurve) TC = new Geom2d_TrimmedCurve(E,-1,2);  \n\
                                                                   \n\
// The segment goes in the direction Vfrom P1                      \n\
// to the point projected on this line by P2                       \n\
// In the example (0,6).                                           \n\
Handle(Geom2d_BSplineCurve) SPL =                                  \n\
    Geom2dConvert::CurveToBSplineCurve(TC);                        \n\
                                                                   \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(E);
    aCurve->SetColorIndex(3); // Red
    aCurve->SetTypeOfLine(Aspect_TOL_DOTDASH);
    aDoc->GetISessionContext()->Display(aCurve, Standard_False);

    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(SPL);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);

    PostProcess(aDoc,ID_BUTTON_Test_23,TheDisplayType,Message.ToCString());
}



// Function name  : GeomSources::gpTest24
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest24(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                        
Standard_Real radius = 5;                               
gp_Ax2d ax2d(gp_Pnt2d(2,3),gp_Dir2d(1,0));              
                                                        
Handle(Geom2d_Circle) circ2d =                          
    new Geom2d_Circle(ax2d,radius);                     
                                                        
gp_Ax2d circ2dXAxis = circ2d->XAxis();                  
                                                        
// create a 3D curve in a given plane                   
Handle(Geom_Curve) C3D =                                
    GeomAPI::To3d(circ2d,gp_Pln(gp_Ax3(gp::XOY())));    
Handle(Geom_Circle) C3DCircle =                         
   Handle(Geom_Circle)::DownCast(C3D);                  
                                                        
gp_Ax1 C3DCircleXAxis = C3DCircle->XAxis();             
                                                        
// project it to a 2D curve in another plane            
                                                        
gp_Pln ProjectionPlane(gp_Pnt(1,1,0),gp_Dir( 1,1,1 ));  
                                                        
Handle(Geom2d_Curve) C2D =                              
    GeomAPI::To2d(C3D,ProjectionPlane);                 
                                                        
Handle(Geom2d_Circle) C2DCircle =                       
  Handle(Geom2d_Circle)::DownCast(C2D);                 
gp_Ax2d C2DCircleXAxis = C2DCircle->XAxis();            
                                                        
//==============================================================
    TCollection_AsciiString Message (" \
                                                        \n\
Standard_Real radius = 5;                               \n\
gp_Ax2d ax2d(gp_Pnt2d(2,3),gp_Dir2d(1,0));              \n\
                                                        \n\
Handle(Geom2d_Circle) circ2d =                          \n\
    new Geom2d_Circle(ax2d,radius);                     \n\
                                                        \n\
gp_Ax2d circ2dXAxis = circ2d->XAxis();                  \n\
                                                        \n\
// create a 3D curve in a given plane                   \n\
Handle(Geom_Curve) C3D =                                \n\
    GeomAPI::To3d(circ2d,gp_Pln(gp_Ax3(gp::XOY())));    \n\
Handle(Geom_Circle) C3DCircle =                         \n\
   Handle(Geom_Circle)::DownCast(C3D);                  \n\
                                                        \n\
gp_Ax1 C3DCircleXAxis = C3DCircle->XAxis();             \n\
                                                        \n\
// project it to a 2D curve in another plane            \n\
                                                        \n\
gp_Pln ProjectionPlane(gp_Pnt(1,1,0),gp_Dir( 1,1,1 ));  \n\
                                                        \n\
Handle(Geom2d_Curve) C2D =                              \n\
    GeomAPI::To2d(C3D,ProjectionPlane);                 \n\
                                                        \n\
Handle(Geom2d_Circle) C2DCircle =                       \n\
  Handle(Geom2d_Circle)::DownCast(C2D);                 \n\
gp_Ax2d C2DCircleXAxis = C2DCircle->XAxis();            \n\
                                                        \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    Handle(Geom_Plane) aPlane = GC_MakePlane(gp_Pln(gp_Ax3(gp::XOY()))).Value();
    Handle(Geom_RectangularTrimmedSurface) aSurface= new Geom_RectangularTrimmedSurface(aPlane,-8.,8.,-12.,12.);   
    DisplaySurface(aDoc,aSurface);

    Handle(Geom_Plane) aProjectionPlane = GC_MakePlane(ProjectionPlane).Value();
    Handle(Geom_RectangularTrimmedSurface) aProjectionPlaneSurface=
        new Geom_RectangularTrimmedSurface(aProjectionPlane,-8.,8.,-12.,12.);
        
    DisplaySurface(aDoc,aProjectionPlaneSurface);

    Standard_CString aC3DEntityTypeName = C3D->DynamicType()->Name();        
    Standard_CString aC2DEntityTypeName = C2D->DynamicType()->Name();        

    Message += " C3D->DynamicType()->Name() = ";
    Message += aC3DEntityTypeName; Message += " \n";
    Message += " C2D->DynamicType()->Name() = ";
    Message += aC2DEntityTypeName; Message += " \n";

    DisplayCurve(aDoc,circ2d,4,false);
    DisplayCurve(aDoc,C3D,false);
    DisplayCurve(aDoc,C2D,5,false);

    Handle(ISession_Direction) aC3DCircleXAxisDirection = new ISession_Direction((gp_Pnt)C3DCircleXAxis.Location(),
                                                                                 (gp_Dir)C3DCircleXAxis.Direction(),
                                                                                 5.2);
    aDoc->GetAISContext()->Display(aC3DCircleXAxisDirection, Standard_False);

    Handle(ISession_Direction) acirc2dXAxisDirection = new ISession_Direction((gp_Pnt2d)circ2dXAxis.Location(),
                                                                              (gp_Dir2d)circ2dXAxis.Direction(),
                                                                              5.2);
    aDoc->GetISessionContext()->Display(acirc2dXAxisDirection, Standard_False);

    Handle(ISession_Direction) aC2DCircleXAxisDirection = new ISession_Direction((gp_Pnt2d)C2DCircleXAxis.Location(),
                                                                              (gp_Dir2d)C2DCircleXAxis.Direction(),
                                                                              5.2);
    aDoc->GetISessionContext()->Display(aC2DCircleXAxisDirection, Standard_False);


    PostProcess(aDoc,ID_BUTTON_Test_24,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest25
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest25(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                    
Handle(TColgp_HArray1OfPnt2d) harray =                              
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray               
harray->SetValue(1,gp_Pnt2d (0,0));                                 
harray->SetValue(2,gp_Pnt2d (-3,1));                                
harray->SetValue(3,gp_Pnt2d (-2,5));                                
harray->SetValue(4,gp_Pnt2d (2,9));                                 
harray->SetValue(5,gp_Pnt2d (-4,14));                               
                                                                    
Geom2dAPI_Interpolate anInterpolation(harray,Standard_False,0.01);  
anInterpolation.Perform();                                          
Handle(Geom2d_BSplineCurve) SPL = anInterpolation.Curve();          
                                                                    
gp_Pnt2d P1(-1,-2);                                                 
gp_Pnt2d P2(0,15);                                                  
gp_Dir2d V1 = gp::DY2d();                                           
Handle(Geom2d_TrimmedCurve) TC1=                                    
    GCE2d_MakeSegment(P1,V1,P2);                                    
                                                                    
Standard_Real tolerance = Precision::Confusion();                   
Geom2dAPI_InterCurveCurve ICC (SPL,TC1,tolerance);                  
Standard_Integer NbPoints =ICC.NbPoints();                          
gp_Pnt2d PK;                                                        
for (Standard_Integer k = 1;k<=NbPoints;k++)                        
  {                                                                 
    PK = ICC.Point(k);                                              
    // do something with each intersection point                    
  }                                                                 
                                                                    
//==============================================================
    TCollection_AsciiString Message (" \
                                                                    \n\
Handle(TColgp_HArray1OfPnt2d) harray =                              \n\
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray               \n\
harray->SetValue(1,gp_Pnt2d (0,0));                                 \n\
harray->SetValue(2,gp_Pnt2d (-3,1));                                \n\
harray->SetValue(3,gp_Pnt2d (-2,5));                                \n\
harray->SetValue(4,gp_Pnt2d (2,9));                                 \n\
harray->SetValue(5,gp_Pnt2d (-4,14));                               \n\
                                                                    \n\
Geom2dAPI_Interpolate anInterpolation(harray,Standard_False,0.01);  \n\
anInterpolation.Perform();                                          \n\
Handle(Geom2d_BSplineCurve) SPL = anInterpolation.Curve();          \n\
                                                                    \n\
gp_Pnt2d P1(-1,-2);                                                 \n\
gp_Pnt2d P2(0,15);                                                  \n\
gp_Dir2d V1 = gp::DY2d();                                           \n\
Handle(Geom2d_TrimmedCurve) TC1=                                    \n\
    GCE2d_MakeSegment(P1,V1,P2);                                    \n\
                                                                    \n\
Standard_Real tolerance = Precision::Confusion();                   \n\
Geom2dAPI_InterCurveCurve ICC (SPL,TC1,tolerance);                  \n\
Standard_Integer NbPoints =ICC.NbPoints();                          \n\
gp_Pnt2d PK;                                                        \n\
for (Standard_Integer k = 1;k<=NbPoints;k++)                        \n\
  {                                                                 \n\
    PK = ICC.Point(k);                                              \n\
    // do something with each intersection point                    \n\
  }                                                                 \n\
                                                                    \n");
    AddSeparator(aDoc,Message);
   //--------------------------------------------------------------

    Handle(ISession2D_Curve) aCurve1 = new ISession2D_Curve(SPL);
    aCurve1->SetDisplayPole(Standard_False);
    aDoc->GetISessionContext()->Display(aCurve1, Standard_False);
    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(TC1);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);

    TCollection_AsciiString aString;
      for (Standard_Integer i = 1;i<=NbPoints;i++)
      {
            PK = ICC.Point(i);
            // do something with each intersection point
        TCollection_AsciiString Message2 (i);
            TCollection_AsciiString Message3 (PK.X());
            TCollection_AsciiString Message4 (PK.Y());
            aString = "PK_";
            aString += Message2; 
        
            DisplayPoint(aDoc,PK,aString.ToCString(),false,0.5);
        
            Message += "PK_"; 
            Message += Message2; 
            Message += " ( ";
        Message += Message3; 
            Message += " , "; 
        Message += Message4; 
            Message += " )\n"; 
      }

   PostProcess(aDoc,ID_BUTTON_Test_25,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest26
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest26(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                      
//----------- Build TC1 -----------------------                       
gp_Pnt2d P1(0,0);  gp_Pnt2d P2(2,6);                                  
gp_Dir2d V1 = gp::DY2d();                                             
Handle(Geom2d_TrimmedCurve) TC1 =  GCE2d_MakeSegment(P1,V1,P2);       
Standard_Real FP1 = TC1->FirstParameter();                            
Standard_Real LP1 = TC1->LastParameter();                             
//----------- Build TC2 -----------------------                       
gp_Pnt2d P3(-9,6.5);       gp_Dir2d V2 = gp::DX2d();                    
Handle(Geom2d_TrimmedCurve) TC2 = GCE2d_MakeSegment(P3,V2,P2);        
Standard_Real FP2 = TC1->FirstParameter();                            
Standard_Real LP2 = TC1->LastParameter();                             
//----------- Extrema TC1 / TC2 ---------------                       
Geom2dAPI_ExtremaCurveCurve ECC (TC1,TC2, FP1,LP1, FP2,LP2);          
Standard_Real shortestdistance =-1;                                   
if (ECC.NbExtrema() != 0)  shortestdistance = ECC.LowerDistance();    
//----------- Build SPL1 ----------------------                       
TColgp_Array1OfPnt2d array (1,5); // sizing array                     
array.SetValue(1,gp_Pnt2d (-4,0)); array.SetValue(2,gp_Pnt2d (-7,2)); 
array.SetValue(3,gp_Pnt2d (-6,3)); array.SetValue(4,gp_Pnt2d (-4,3)); 
array.SetValue(5,gp_Pnt2d (-3,5));                                    
Handle(Geom2d_BSplineCurve) SPL1 = Geom2dAPI_PointsToBSpline(array);  
Standard_Real FPSPL1 = SPL1->FirstParameter();                        
Standard_Real LPSPL1 = SPL1->LastParameter();                         
//----------- Extrema TC1 / SPL1  -------------                       
Geom2dAPI_ExtremaCurveCurve ECC2 (TC1,SPL1, FP1,LP1, FPSPL1,LPSPL1);  
Standard_Real SPL1shortestdistance =-1;                               
if (ECC2.NbExtrema()!=0) SPL1shortestdistance = ECC2.LowerDistance(); 
Standard_Integer NbExtrema = ECC2.NbExtrema();                        
TColgp_Array2OfPnt2d aSolutionArray(1,NbExtrema,1,2);                 
for(int i=1;i <= NbExtrema; i++)   {                                  
    gp_Pnt2d P1,P2;                                                   
    ECC2.Points(i,P1,P2);                                             
    aSolutionArray(i,1) = P1;  aSolutionArray(i,2) = P2; }            
                                                                      
//==============================================================
    TCollection_AsciiString Message (" \
//----------- Build TC1 -----------------------                       \n\
gp_Pnt2d P1(0,0);  gp_Pnt2d P2(2,6);                                  \n\
gp_Dir2d V1 = gp::DY2d();                                             \n\
Handle(Geom2d_TrimmedCurve) TC1 =  GCE2d_MakeSegment(P1,V1,P2);       \n\
Standard_Real FP1 = TC1->FirstParameter();                            \n\
Standard_Real LP1 = TC1->LastParameter();                             \n\
//----------- Build TC2 -----------------------                       \n\
gp_Pnt2d P3(-9,6.5);       gp_Dir2d V2 = gp::DX2d();                    \n\
Handle(Geom2d_TrimmedCurve) TC2 = GCE2d_MakeSegment(P3,V2,P2);        \n\
Standard_Real FP2 = TC1->FirstParameter();                            \n\
Standard_Real LP2 = TC1->LastParameter();                             \n\
//----------- Extrema TC1 / TC2 ---------------                       \n\
Geom2dAPI_ExtremaCurveCurve ECC (TC1,TC2, FP1,LP1, FP2,LP2);          \n\
Standard_Real shortestdistance =-1;                                   \n\
if (ECC.NbExtrema() != 0)  shortestdistance = ECC.LowerDistance();    \n\
//----------- Build SPL1 ----------------------                       \n\
TColgp_Array1OfPnt2d array (1,5); // sizing array                     \n\
array.SetValue(1,gp_Pnt2d (-4,0)); array.SetValue(2,gp_Pnt2d (-7,2)); \n\
array.SetValue(3,gp_Pnt2d (-6,3)); array.SetValue(4,gp_Pnt2d (-4,3)); \n\
array.SetValue(5,gp_Pnt2d (-3,5));                                    \n\
Handle(Geom2d_BSplineCurve) SPL1 = Geom2dAPI_PointsToBSpline(array);  \n\
Standard_Real FPSPL1 = SPL1->FirstParameter();                        \n");
Message += "\
Standard_Real LPSPL1 = SPL1->LastParameter();                         \n\
//----------- Extrema TC1 / SPL1  -------------                       \n\
Geom2dAPI_ExtremaCurveCurve ECC2 (TC1,SPL1, FP1,LP1, FPSPL1,LPSPL1);  \n\
Standard_Real SPL1shortestdistance =-1;                               \n\
if (ECC2.NbExtrema()!=0) SPL1shortestdistance = ECC2.LowerDistance(); \n\
Standard_Integer NbExtrema = ECC2.NbExtrema();                        \n\
TColgp_Array2OfPnt2d aSolutionArray(1,NbExtrema,1,2);                 \n\
for(int i=1;i <= NbExtrema; i++)   {                                  \n\
    gp_Pnt2d P1,P2;                                                   \n\
    ECC2.Points(i,P1,P2);                                             \n\
    aSolutionArray(i,1) = P1;  aSolutionArray(i,2) = P2; }            \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    TCollection_AsciiString aString;
    for(i = array.Lower();i<=array.Upper();i++){
            TCollection_AsciiString Message2 (i);
            gp_Pnt2d P = array(i);
        aString = "array ";
            aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }

    if (!SPL1.IsNull())
    { 
      Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(SPL1);
      aCurve->SetDisplayPole(Standard_False);
      aCurve->SetColorIndex(3);
      aDoc->GetISessionContext()->Display(aCurve, Standard_False);
    }
    else
      MessageBox(0,"SPL1.IsNull()","CasCade Error",MB_ICONERROR);

    Handle(ISession2D_Curve) aCurve1 = new ISession2D_Curve(TC1);
    aCurve1->SetColorIndex(6);
    aDoc->GetISessionContext()->Display(aCurve1, Standard_False);
    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(TC2);
    aCurve2->SetColorIndex(5);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);


    for(i=1;i <= NbExtrema; i++)
    {
        gp_Pnt2d P1 =aSolutionArray(i,1);
        
            TCollection_AsciiString Message2 (i);
            aString = "P1_";
            aString += Message2; 
        DisplayPoint(aDoc,P1,aString.ToCString(),false,0.7*i);

        gp_Pnt2d P2 = aSolutionArray(i,2);
        
        Handle(Geom2d_TrimmedCurve) SolutionCurve =            
               GCE2d_MakeSegment(P1,P2);             
        Handle(ISession2D_Curve) aSolutionCurve = new ISession2D_Curve(SolutionCurve);
        aDoc->GetISessionContext()->Display(aSolutionCurve, Standard_False);
    }

    Message += "TC1 is  Yellow ,TC2 is  Blue ,SPL1 is Red \n";
    Message += "ECC.NbExtrema()  = "; Message += ECC.NbExtrema();
    Message += "    shortestdistance = "; Message+= shortestdistance; Message += "\n";
    Message += "ECC2.NbExtrema() = "; Message += NbExtrema;
    Message += "    SPL1shortestdistance = "; Message+= SPL1shortestdistance; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_26,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest27
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest27(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                       
TColgp_Array1OfPnt2d array (1,5); // sizing array                      
array.SetValue(1,gp_Pnt2d (-4,0)); array.SetValue(2,gp_Pnt2d (-7,2));  
array.SetValue(3,gp_Pnt2d (-6,3)); array.SetValue(4,gp_Pnt2d (-4,3));  
array.SetValue(5,gp_Pnt2d (-3,5));                                     
Handle(Geom2d_BSplineCurve) SPL1 = Geom2dAPI_PointsToBSpline(array);   
                                                                       
Standard_Real dist = 1;                                                
Handle(Geom2d_OffsetCurve) OC =                                        
       new Geom2d_OffsetCurve(SPL1,dist);                              
Standard_Boolean result = OC->IsCN(2);                                 
                                                                       
Standard_Real dist2 = 1.5;                                             
Handle(Geom2d_OffsetCurve) OC2 =                                       
       new Geom2d_OffsetCurve(SPL1,dist2);                             
Standard_Boolean result2 = OC2->IsCN(2);                               
                                                                       
//==============================================================
    TCollection_AsciiString Message (" \
                                                                       \n\
TColgp_Array1OfPnt2d array (1,5); // sizing array                      \n\
array.SetValue(1,gp_Pnt2d (-4,0)); array.SetValue(2,gp_Pnt2d (-7,2));  \n\
array.SetValue(3,gp_Pnt2d (-6,3)); array.SetValue(4,gp_Pnt2d (-4,3));  \n\
array.SetValue(5,gp_Pnt2d (-3,5));                                     \n\
Handle(Geom2d_BSplineCurve) SPL1 = Geom2dAPI_PointsToBSpline(array);   \n\
                                                                       \n\
Standard_Real dist = 1;                                                \n\
Handle(Geom2d_OffsetCurve) OC =                                        \n\
       new Geom2d_OffsetCurve(SPL1,dist);                              \n\
Standard_Boolean result = OC->IsCN(2);                                 \n\
                                                                       \n\
Standard_Real dist2 = 1.5;                                             \n\
Handle(Geom2d_OffsetCurve) OC2 =                                       \n\
       new Geom2d_OffsetCurve(SPL1,dist2);                             \n\
Standard_Boolean result2 = OC2->IsCN(2);                               \n\
                                                                       \n");
    AddSeparator(aDoc,Message);
//--------------------------------------------------------------
    Handle(ISession2D_Curve) aCurve1 = new ISession2D_Curve(SPL1);
    aCurve1->SetColorIndex(6);
    aDoc->GetISessionContext()->Display(aCurve1, Standard_False);
    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(OC);
    aCurve2->SetColorIndex(5);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);
    Handle(ISession2D_Curve) aCurve3 = new ISession2D_Curve(OC2);
    aCurve3->SetColorIndex(3);
    aDoc->GetISessionContext()->Display(aCurve3, Standard_False);


    Message += "SPL1 is Yellow \n";
    Message += "OC   is Blue \n";
    Message += "OC2  is Red \n\n";
      Message += "  Warning, Continuity is not guaranteed :  \n ";
      if(result)    Message += " result  = True  \n";
    else          Message += " result  = False \n";
      if(result2)   Message += " result2 = True  \n";
    else          Message += " result2 = False \n";

    PostProcess(aDoc,ID_BUTTON_Test_27,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest28
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest28(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                      
gp_Pnt2d P1(1,2);                     
gp_Pnt2d P2(4,5);                     
gp_Lin2d L = gce_MakeLin2d(P1,P2);    
// assignment by overloaded operator  
                                      
//==============================================================
    TCollection_AsciiString Message (" \
                                      \n\
gp_Pnt2d P1(1,2);                     \n\
gp_Pnt2d P2(4,5);                     \n\
gp_Lin2d L = gce_MakeLin2d(P1,P2);    \n\
// assignment by overloaded operator  \n\
                                      \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    
    DisplayPoint(aDoc,P1,"P1",false,0.5);
    DisplayPoint(aDoc,P2,"P2",false,0.5);

    Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-3,8);
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aLine);
    aDoc->GetISessionContext()->Display(aCurve, Standard_False);

    PostProcess(aDoc,ID_BUTTON_Test_28,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest29
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest29(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                             
gp_Pnt2d P1(1,2);            
gp_Pnt2d P2(4,5);            
gp_Lin2d L;                  
GccAna_Pnt2dBisec B(P1,P2);  
if (B.IsDone())              
    {                        
    L = B.ThisSolution();    
    }                        
                             
//==============================================================
    TCollection_AsciiString Message (" \
                             \n\
gp_Pnt2d P1(1,2);            \n\
gp_Pnt2d P2(4,5);            \n\
gp_Lin2d L;                  \n\
GccAna_Pnt2dBisec B(P1,P2);  \n\
if (B.IsDone())              \n\
    {                        \n\
    L = B.ThisSolution();    \n\
    }                        \n\
                             \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P1,"P1",false,0.5);
    DisplayPoint(aDoc,P2,"P2",false,0.5);

      if (B.IsDone())
        {
        Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-8,8);
        Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aLine);
        aDoc->GetISessionContext()->Display(aCurve, Standard_False);
      }

      if (B.IsDone()) Message += " \n   B Is Done   ";
    else            Message += " \n   B Is not Done    ";
    PostProcess(aDoc,ID_BUTTON_Test_29,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest30
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest30(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType =a2DNo3D ;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                     
gp_Pnt2d P1 (2,3);                                   
gp_Pnt2d P2 (4,4);                                   
gp_Pnt2d P3 (6,7);                                   
gp_Pnt2d P4 (10,10);                                 
gp_Circ2d C = gce_MakeCirc2d (P1,P2,P3);             
GccEnt_QualifiedCirc QC = GccEnt::Outside(C);        
GccAna_Lin2d2Tan LT (QC,P4,Precision::Confusion());  
Standard_Integer NbSol;                              
if (LT.IsDone())                                     
  {                                                  
      NbSol = LT.NbSolutions();                      
      for(Standard_Integer k=1; k<=NbSol; k++)       
        {                                            
         gp_Lin2d L = LT.ThisSolution(k);            
          // do something with L                     
        }                                            
  }                                                  
                                                     
//==============================================================
    TCollection_AsciiString Message (" \
                                                     \n\
gp_Pnt2d P1 (2,3);                                   \n\
gp_Pnt2d P2 (4,4);                                   \n\
gp_Pnt2d P3 (6,7);                                   \n\
gp_Pnt2d P4 (10,10);                                 \n\
gp_Circ2d C = gce_MakeCirc2d (P1,P2,P3);             \n\
GccEnt_QualifiedCirc QC = GccEnt::Outside(C);        \n\
GccAna_Lin2d2Tan LT (QC,P4,Precision::Confusion());  \n\
Standard_Integer NbSol;                              \n\
if (LT.IsDone())                                     \n\
  {                                                  \n\
      NbSol = LT.NbSolutions();                      \n\
      for(Standard_Integer k=1; k<=NbSol; k++)       \n\
        {                                            \n\
         gp_Lin2d L = LT.ThisSolution(k);            \n\
          // do something with L                     \n\
        }                                            \n\
  }                                                  \n\
                                                     \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,P1,"P1",false,0.5,-1,0.1);
    DisplayPoint(aDoc,P2,"P2",false,0.5,-0.7,0.1);
    DisplayPoint(aDoc,P3,"P3",false,0.5,-0.5,0.1);
    DisplayPoint(aDoc,P4,"P4",false,0.5,0,0.1);
        
    Handle(Geom2d_Circle) aCircle = new Geom2d_Circle(C);
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aCircle);
    aCurve->SetColorIndex(5);
    aDoc->GetISessionContext()->Display(aCurve, Standard_False);

      if (LT.IsDone())
            {
              Standard_Integer NbSol = LT.NbSolutions();
              for(Standard_Integer k=1; k<=NbSol; k++)
                  {
                    gp_Lin2d L = LT.ThisSolution(k);
              Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-10,20);
              Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aLine);
              aDoc->GetISessionContext()->Display(aCurve, Standard_False);
                  }
            }
    Message += " C is Blue \n\n";
    Message += "LT.IsDone() = "; 
    if (LT.IsDone())  Message += "True \n"; else Message += "False \n";
    TCollection_AsciiString Message2 (NbSol);
      Message += "NbSol       = "; Message += Message2      ; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_30,TheDisplayType,Message.ToCString());
}


// Function name  : GeomSources::gpTest31
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest31(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                              
gp_Pnt2d P1 (9,6);                                                            
gp_Pnt2d P2 (10,4);                                                           
gp_Pnt2d P3 (6,7);                                                            
gp_Circ2d C = gce_MakeCirc2d (P1,P2,P3);                                      
GccEnt_QualifiedCirc QC = GccEnt::Outside(C);                                 
gp_Pnt2d P4 (-2,7);                                                           
gp_Pnt2d P5 (12,-3);                                                          
gp_Lin2d L = GccAna_Lin2d2Tan(P4,P5,Precision::Confusion()).ThisSolution(1);  
GccEnt_QualifiedLin QL = GccEnt::Unqualified(L);                              
Standard_Real radius = 2;                                                     
GccAna_Circ2d2TanRad TR (QC,QL,radius,Precision::Confusion());                
Standard_Real parsol,pararg;                                                  
gp_Pnt2d tangentpoint1,tangentpoint2;                                         
gp_Circ2d circ;                                                               
if (TR.IsDone())                                                              
    {                                                                         
      Standard_Integer NbSol = TR.NbSolutions();                              
      for (Standard_Integer k=1; k<=NbSol; k++)                               
        {                                                                     
          circ = TR.ThisSolution(k);                                          
          // find the solution circle                                         
          TR.Tangency1(k,parsol,pararg,tangentpoint1);                        
          // find the first tangent point                                     
          TR.Tangency2(k,parsol,pararg,tangentpoint2);                        
          // find the second tangent point                                    
        }                                                                     
    }                                                                         
                                                                              
//==============================================================
    TCollection_AsciiString Message;
Message = "\
                                                                              \n\
gp_Pnt2d P1 (9,6);                                                            \n\
gp_Pnt2d P2 (10,4);                                                           \n\
gp_Pnt2d P3 (6,7);                                                            \n\
gp_Circ2d C = gce_MakeCirc2d (P1,P2,P3);                                      \n\
GccEnt_QualifiedCirc QC = GccEnt::Outside(C);                                 \n\
gp_Pnt2d P4 (-2,7);                                                           \n\
gp_Pnt2d P5 (12,-3);                                                          \n\
gp_Lin2d L = GccAna_Lin2d2Tan(P4,P5,Precision::Confusion()).ThisSolution(1);  \n\
GccEnt_QualifiedLin QL = GccEnt::Unqualified(L);                              \n\
Standard_Real radius = 2;                                                     \n\
GccAna_Circ2d2TanRad TR (QC,QL,radius,Precision::Confusion());                \n\
Standard_Real parsol,pararg;                                                  \n\
gp_Pnt2d tangentpoint1,tangentpoint2;                                         \n\
gp_Circ2d circ;                                                               \n\
if (TR.IsDone())                                                              \n\
    {                                                                         \n\
      Standard_Integer NbSol = TR.NbSolutions();                              \n\
      for (Standard_Integer k=1; k<=NbSol; k++)                               \n\
        {                                                                     \n";
        Message += "\
          circ = TR.ThisSolution(k);                                          \n\
          // find the solution circle                                         \n\
          TR.Tangency1(k,parsol,pararg,tangentpoint1);                        \n\
          // find the first tangent point                                     \n\
          TR.Tangency2(k,parsol,pararg,tangentpoint2);                        \n\
          // find the second tangent point                                    \n\
        }                                                                     \n\
    }                                                                         \n\
                                                                              \n";
    AddSeparator(aDoc,Message);
//--------------------------------------------------------------
    DisplayPoint(aDoc,P1,"P1",false,0.3);
    DisplayPoint(aDoc,P2,"P2",false,0.3);
    DisplayPoint(aDoc,P3,"P3",false,0.3);
    DisplayPoint(aDoc,P4,"P4",false,0.3);
    DisplayPoint(aDoc,P5,"P5",false,0.3);

    Handle(Geom2d_Circle) aCircle = new Geom2d_Circle(C);
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aCircle);
    aCurve->SetColorIndex(3);

    aDoc->GetISessionContext()->Display(aCurve, Standard_False);
    Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-2,20);
    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(aLine);
    aCurve2->SetColorIndex(5);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);

      if (TR.IsDone())
            {
              Standard_Integer NbSol = TR.NbSolutions();
              for (Standard_Integer k=1; k<=NbSol; k++)
                  {
                    circ = TR.ThisSolution(k);
              Handle(Geom2d_Circle) aCircle = new Geom2d_Circle(circ);
              Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aCircle);
              aDoc->GetISessionContext()->Display(aCurve, Standard_False);

                    // find the solution circle
                    TR.Tangency1(k,parsol,pararg,tangentpoint1);
                    // find the first tangent point                                                    
              TR.Tangency2(k,parsol,pararg,tangentpoint2);
                    // find the second tangent point
              DisplayPoint(aDoc,tangentpoint1,"tangentpoint1",false,0.3);
              DisplayPoint(aDoc,tangentpoint2,"tangentpoint2",false,0.3);
                  }
            }
    Message += "C is Red \n";
    Message += "L is Blue \n";
    PostProcess(aDoc,ID_BUTTON_Test_31,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest32
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest32(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                        
Standard_Real major = 12;                                               
Standard_Real minor = 4;                                                
gp_Ax2d axis = gp::OX2d();                                              
gp_Elips2d EE(axis,major,minor);;                                           
Handle(Geom2d_TrimmedCurve) arc = GCE2d_MakeArcOfEllipse(EE,0.0,PI/4);  
                                                                        
//==============================================================
    TCollection_AsciiString Message (" \
                                                                        \n\
Standard_Real major = 12;                                               \n\
Standard_Real minor = 4;                                                \n\
gp_Ax2d axis = gp::OX2d();                                              \n\
gp_Elips2d EE(axis,major,minor);                                        \n\
Handle(Geom2d_TrimmedCurve) arc = GCE2d_MakeArcOfEllipse(EE,0.0,PI/4);  \n\
                                                                        \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    Handle(Geom2d_Curve) E = GCE2d_MakeEllipse(EE);
    Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(E);
    aCurve->SetColorIndex(3);
    aCurve->SetTypeOfLine(Aspect_TOL_DOTDASH);
    //SetWidthOfLine                 
    aDoc->GetISessionContext()->Display(aCurve, Standard_False);
    Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(arc);
    aDoc->GetISessionContext()->Display(aCurve2, Standard_False);
      TCollection_AsciiString Message2 (PI);
    Message += " PI = ";Message+= Message2;
    PostProcess(aDoc,ID_BUTTON_Test_32,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest33
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest33(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                                        
gp_Pnt P1(0,0,1);                                                                       
gp_Pnt P2(1,2,2);                                                                       
gp_Pnt P3(2,3,3);                                                                       
gp_Pnt P4(4,3,4);                                                                       
gp_Pnt P5(5,5,5);                                                                       
TColgp_Array1OfPnt array (1,5); // sizing array                                         
array.SetValue(1,P1);                                                                   
array.SetValue(2,P2);                                                                   
array.SetValue(3,P3);                                                                   
array.SetValue(4,P4);                                                                   
array.SetValue(5,P5);                                                                   
Handle(TColgp_HArray1OfPnt) harray =                                                    
    new TColgp_HArray1OfPnt (1,5); // sizing harray                                     
harray->SetValue(1,P1.Translated(gp_Vec(4,0,0)));                                       
harray->SetValue(2,P2.Translated(gp_Vec(4,0,0)));                                       
harray->SetValue(3,P3.Translated(gp_Vec(4,0,0)));                                       
harray->SetValue(4,P4.Translated(gp_Vec(4,0,0)));                                       
harray->SetValue(5,P5.Translated(gp_Vec(4,0,0)));                                       
Handle(Geom_BSplineCurve) SPL1 =                                                        
    GeomAPI_PointsToBSpline(array).Curve();                                             
                                                                                        
GeomAPI_Interpolate anInterpolation(harray,Standard_False,Precision::Approximation());  
anInterpolation.Perform();                                                              
                                                                                        
Handle(Geom_BSplineCurve) SPL2;                                                         
if (anInterpolation.IsDone())                                                           
       SPL2 = anInterpolation.Curve();                                                  
else                                                                                    
   MessageBox(0,"The Interpolation is Not done","CasCade Warning",MB_ICONWARNING);      
                                                                                        
//==============================================================
    TCollection_AsciiString Message (" \
                                                                                        \n\
gp_Pnt P1(0,0,1);                                                                       \n\
gp_Pnt P2(1,2,2);                                                                       \n\
gp_Pnt P3(2,3,3);                                                                       \n\
gp_Pnt P4(4,3,4);                                                                       \n\
gp_Pnt P5(5,5,5);                                                                       \n\
TColgp_Array1OfPnt array (1,5); // sizing array                                         \n\
array.SetValue(1,P1);                                                                   \n\
array.SetValue(2,P2);                                                                   \n\
array.SetValue(3,P3);                                                                   \n\
array.SetValue(4,P4);                                                                   \n\
array.SetValue(5,P5);                                                                   \n\
Handle(TColgp_HArray1OfPnt) harray =                                                    \n\
    new TColgp_HArray1OfPnt (1,5); // sizing harray                                     \n\
harray->SetValue(1,P1.Translated(gp_Vec(4,0,0)));                                       \n\
harray->SetValue(2,P2.Translated(gp_Vec(4,0,0)));                                       \n\
harray->SetValue(3,P3.Translated(gp_Vec(4,0,0)));                                       \n\
harray->SetValue(4,P4.Translated(gp_Vec(4,0,0)));                                       \n\
harray->SetValue(5,P5.Translated(gp_Vec(4,0,0)));                                       \n\
Handle(Geom_BSplineCurve) SPL1 =                                                        \n\
    GeomAPI_PointsToBSpline(array).Curve();                                             \n");
    Message += "\
                                                                                        \n\
GeomAPI_Interpolate anInterpolation(harray,Standard_False,Precision::Approximation());  \n\
anInterpolation.Perform();                                                              \n\
                                                                                        \n\
Handle(Geom_BSplineCurve) SPL2;                                                         \n\
if (anInterpolation.IsDone())                                                           \n\
       SPL2 = anInterpolation.Curve();                                                  \n\
else                                                                                    \n\
   MessageBox(0,\"The Interpolation is Not done\",\"CasCade Warning\",MB_ICONWARNING);  \n\
                                                                                        \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    TCollection_AsciiString aString;
    for(Standard_Integer i = array.Lower();i<=array.Upper();i++){
            
            TCollection_AsciiString Message2 (i);
            gp_Pnt P = array(i);
        
            aString = "P";
            aString += Message2; 
        if (i == 1) aString += " (array)  ";
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);\
        
            aString = "P";
            aString += Message2; 
        if (i == 1) aString += " (harray)  ";
        DisplayPoint(aDoc,P.Translated(gp_Vec(4,0,0)),aString.ToCString(),false,0.5);\
        
            }

    Handle(ISession_Curve) aCurve = new ISession_Curve(SPL1);
    aDoc->GetAISContext()->SetDisplayMode(aCurve,1);
    aDoc->GetAISContext()->Display(aCurve, Standard_False);

    if (anInterpolation.IsDone()) {
        Handle(ISession_Curve) aCurve2 = new ISession_Curve(SPL2);
        aDoc->GetAISContext()->SetDisplayMode(aCurve2,1);
        aDoc->GetAISContext()->Display(aCurve2, Standard_False);
    }
    PostProcess(aDoc,ID_BUTTON_Test_33,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest34
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest34(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
TColgp_Array1OfPnt array (1,5); // sizing array                  
array.SetValue(1,gp_Pnt(0,0,1));                                 
array.SetValue(2,gp_Pnt(1,2,2));                                 
array.SetValue(3,gp_Pnt(2,3,3));                                 
array.SetValue(4,gp_Pnt(4,4,4));                                 
array.SetValue(5,gp_Pnt(5,5,5));                                 
                                                                 
GProp_PEquation PE (array,1.5 );                                 
                                                                 
if (PE.IsPoint()){ /* ... */  }     
gp_Lin L;                                                        
if (PE.IsLinear()) {  L = PE.Line();    }                      
if (PE.IsPlanar()){ /* ... */  }     
if (PE.IsSpace()) { /* ... */  }     
                                                                 
//==============================================================
    TCollection_AsciiString Message (" \
                                                \n\
TColgp_Array1OfPnt array (1,5); // sizing array \n\
array.SetValue(1,gp_Pnt(0,0,1));                \n\
array.SetValue(2,gp_Pnt(1,2,2));                \n\
array.SetValue(3,gp_Pnt(2,3,3));                \n\
array.SetValue(4,gp_Pnt(4,4,4));                \n\
array.SetValue(5,gp_Pnt(5,5,5));                \n\
                                                \n\
GProp_PEquation PE (array,1.5 );                \n\
                                                \n\
if (PE.IsPoint()){ /* ... */  }                 \n\
gp_Lin L;                                       \n\
if (PE.IsLinear()) {  L = PE.Line();    }       \n\
if (PE.IsPlanar()){ /* ... */  }                \n\
if (PE.IsSpace()) { /* ... */  }                \n\
                                                \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    TCollection_AsciiString aString;
    for(Standard_Integer i = array.Lower();i<=array.Upper();i++){
            TCollection_AsciiString Message2 (i);
            gp_Pnt P = array(i);
        
            aString = "P";
            aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }

    Message += " PE.IsPoint()  = ";  if (PE.IsPoint()) Message += "True \n";  else Message += "False\n";

      if (PE.IsLinear()) { 
         Message += " PE.IsLinear() = True \n";
         L = PE.Line();
         Handle(Geom_Line) aLine = new Geom_Line(L);
         Handle(Geom_TrimmedCurve) aTrimmedCurve = new Geom_TrimmedCurve(aLine,-10,10);
         Handle(ISession_Curve) aCurve = new ISession_Curve(aTrimmedCurve);
         aDoc->GetAISContext()->Display(aCurve, Standard_False);
    }
    else
    Message += "PE.IsLinear() = False \n";

    Message += " PE.IsPlanar() = ";  if (PE.IsPlanar()) Message += "True \n";  else Message += "False\n";
    Message += " PE.IsSpace() = ";   if (PE.IsSpace() ) Message += "True \n";  else Message += "False\n";

    PostProcess(aDoc,ID_BUTTON_Test_34,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest35
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest35(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                            
gp_Pnt P1(-5,-5,0);                                         
gp_Pnt P2(9,9,9);                                          
Handle(Geom_Curve) aCurve = GC_MakeSegment(P1,P2).Value();  
gp_Pnt P3(3,0,0);                                           
gp_Pnt P4(3,0,10);                                          
Standard_Real radius1 = 3;                                  
Standard_Real radius2 = 2;                                  
Handle(Geom_Surface) aSurface =                             
    GC_MakeConicalSurface(P3,P4,radius1,radius2).Value();   
GeomAPI_IntCS CS (aCurve,aSurface);                         
Handle(Geom_Curve) segment;                                 
                                                            
Standard_Integer NbSeg;                                     
Standard_Integer NbPoints;                                  
if(CS.IsDone())                                             
    {                                                       
      NbSeg = CS.NbSegments();                              
      for (Standard_Integer k=1; k<=NbSeg; k++)             
        {                                                   
          segment = CS.Segment(k);                          
         // do something with the segment                   
        }                                                   
                                                            
      NbPoints = CS.NbPoints();                             
      for (k=1; k<=NbPoints; k++)                           
        {                                                   
          gp_Pnt aPoint=CS.Point(k);                        
          // do something with the point                    
        }                                                   
    }                                                       
                                                            
//==============================================================
    TCollection_AsciiString Message (" \
                                                            \n\
gp_Pnt P1(-5,-5,0);                                         \n\
gp_Pnt P2(9,9,9);                                           \n\
Handle(Geom_Curve) aCurve = GC_MakeSegment(P1,P2).Value();  \n\
gp_Pnt P3(3,0,0);                                           \n\
gp_Pnt P4(3,0,10);                                          \n\
Standard_Real radius1 = 3;                                  \n\
Standard_Real radius2 = 2;                                  \n\
Handle(Geom_Surface) aSurface =                             \n\
    GC_MakeConicalSurface(P3,P4,radius1,radius2).Value();   \n\
GeomAPI_IntCS CS (aCurve,aSurface);                         \n\
Handle(Geom_Curve) segment;                                 \n\
                                                            \n\
Standard_Integer NbSeg;                                     \n\
Standard_Integer NbPoints;                                  \n\
if(CS.IsDone())                                             \n\
    {                                                       \n\
      NbSeg = CS.NbSegments();                              \n\
      for (Standard_Integer k=1; k<=NbSeg; k++)             \n\
        {                                                   \n\
          segment = CS.Segment(k);                          \n\
         // do something with the segment                   \n\
        }                                                   \n\
                                                            \n\
      NbPoints = CS.NbPoints();                             \n\
      for (k=1; k<=NbPoints; k++)                           \n\
        {                                                   \n\
          gp_Pnt aPoint=CS.Point(k);                        \n\
          // do something with the point                    \n\
        }                                                   \n\
    }                                                       \n\
                                                            \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
 
    Handle(ISession_Curve) aCurve2 = new ISession_Curve(aCurve);
    aDoc->GetAISContext()->Display(aCurve2, Standard_False);

    Handle(Geom_RectangularTrimmedSurface) aTrimmedSurface= new Geom_RectangularTrimmedSurface(aSurface,-50.,50.,false);

    DisplaySurface(aDoc,aTrimmedSurface);

    TCollection_AsciiString aString;
    if(CS.IsDone())
            {
              Standard_Integer NbSeg = CS.NbSegments();
              for (Standard_Integer k=1; k<=NbSeg; k++)
                  {
                    TCollection_AsciiString Message2 (k);
                    segment = CS.Segment(k);
              aString = "S_";aString += Message2;
              Handle(ISession_Curve) aCurve = new ISession_Curve(segment);
              aDoc->GetAISContext()->Display(aCurve, Standard_False);
                  }
        
      for ( k=1; k<=NbPoints; k++)              
        {                                                   
            TCollection_AsciiString Message2 (k);
              gp_Pnt aPoint=CS.Point(k);
          aString = "P_";aString += Message2; 
          DisplayPoint(aDoc,aPoint,aString.ToCString(),false,0.5);
          // do something with the point            
        }                                                  
      }
      TCollection_AsciiString Message2 (NbSeg);
      TCollection_AsciiString Message3 (NbPoints);

    Message += "NbSeg       = "; Message += Message2      ; Message += "\n";
    Message += "NbPoints  = "; Message += Message3      ; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_35,TheDisplayType,Message.ToCString());
}

//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

// Function name  : GeomSources::gpTest36
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest36(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                                    
gp_Pnt centre (5,5,0);  gp_Pnt axispoint (9,9,0);                                   
Standard_Real radius = 3;                                                           
Handle(Geom_Circle) circle =                                                        
    GC_MakeCircle(centre,axispoint,radius);                                         
                                                                                    
Handle(Geom_Geometry) aRotatedEntity  = circle->Rotated(gp::OZ(),PI/4);             
Standard_CString aRotatedEntityTypeName = aRotatedEntity->DynamicType()->Name();        
                                                                                    
Handle(Geom_Geometry) aMirroredEntity = aRotatedEntity->Mirrored(gp::ZOX());        
Standard_CString aMirroredEntityTypeName = aMirroredEntity->DynamicType()->Name();      
                                                                                    
gp_Pnt scalepoint (4,8,0);                                                          
Standard_Real scalefactor = 0.2;                                                    
Handle(Geom_Geometry) aScaledEntity =                                               
     aMirroredEntity->Scaled(scalepoint, scalefactor);                              
Standard_CString aScaledEntityTypeName = aScaledEntity->DynamicType()->Name();          
                                                                                    
Handle (Geom_Transformation) GT =   GC_MakeTranslation  (centre, scalepoint);       
gp_Trsf TR = GT->Trsf();                                                            
                                                                                    
gp_Vec aTranslationVector(TR.TranslationPart ());                                   
Handle(Geom_Geometry) aTranslatedEntity =                                           
       aScaledEntity->Translated(  aTranslationVector  );                           
Standard_CString aTranslatedEntityTypeName = aTranslatedEntity->DynamicType()->Name();  
                                                                                    
gp_Mat matrix = TR.HVectorialPart();                                                
Standard_Real value = matrix.Determinant();                                         
                                                                                    
//==============================================================
    TCollection_AsciiString Message (" \
                                                                                        \n\
gp_Pnt centre (5,5,0);  gp_Pnt axispoint (9,9,0);                                       \n\
Standard_Real radius = 3;                                                               \n\
Handle(Geom_Circle) circle =                                                            \n\
    GC_MakeCircle(centre,axispoint,radius);                                             \n\
                                                                                        \n\
Handle(Geom_Geometry) aRotatedEntity  = circle->Rotated(gp::OZ(),PI/4);                 \n\
Standard_CString aRotatedEntityTypeName = aRotatedEntity->DynamicType()->Name();        \n\
                                                                                        \n\
Handle(Geom_Geometry) aMirroredEntity = aRotatedEntity->Mirrored(gp::ZOX());            \n\
Standard_CString aMirroredEntityTypeName = aMirroredEntity->DynamicType()->Name();      \n\
                                                                                        \n\
gp_Pnt scalepoint (4,8,0);                                                              \n\
Standard_Real scalefactor = 0.2;                                                        \n\
Handle(Geom_Geometry) aScaledEntity =                                                   \n\
     aMirroredEntity->Scaled(scalepoint, scalefactor);                                  \n\
Standard_CString aScaledEntityTypeName = aScaledEntity->DynamicType()->Name();          \n\
                                                                                        \n\
Handle (Geom_Transformation) GT =   GC_MakeTranslation  (centre, scalepoint);           \n\
gp_Trsf TR = GT->Trsf();                                                                \n\
                                                                                        \n");
   Message +="\
gp_Vec aTranslationVector(TR.TranslationPart ());                                       \n\
Handle(Geom_Geometry) aTranslatedEntity =                                               \n\
       aScaledEntity->Translated(  aTranslationVector  );                               \n\
Standard_CString aTranslatedEntityTypeName = aTranslatedEntity->DynamicType()->Name();  \n\
                                                                                        \n\
gp_Mat matrix = TR.HVectorialPart();                                                    \n\
Standard_Real value = matrix.Determinant();                                             \n\
                                                                                        \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayPoint(aDoc,centre,"centre",false,0.5);
    DisplayPoint(aDoc,axispoint,"axispoint",false,0.5);
    DisplayPoint(aDoc,scalepoint,"scalepoint",false,0.5);

    DisplayCurve(aDoc,circle, Quantity_NOC_RED,false);
    DisplayCurve(aDoc,Handle(Geom_Curve)::DownCast(aRotatedEntity),Quantity_NOC_PEACHPUFF, false);
    DisplayCurve(aDoc,Handle(Geom_Curve)::DownCast(aMirroredEntity), Quantity_NOC_YELLOWGREEN,false);
    DisplayCurve(aDoc,Handle(Geom_Curve)::DownCast(aScaledEntity), Quantity_NOC_GREEN,false);
    DisplayCurve(aDoc,Handle(Geom_Curve)::DownCast(aTranslatedEntity),Quantity_NOC_WHITE,false);

      TCollection_AsciiString Message0 (PI);    
    Message += " PI = ";
      Message+= Message0; 
      Message += "\n";
    Message += " circle is Red;  aRotatedEntity is Peach; aMirroredEntity is Yellow Green\n";
    Message += " aScaleEntity is Green; aTranslatedEntity is White\n\n";

   
      TCollection_AsciiString Message2 (aTranslationVector.X());
      TCollection_AsciiString Message3 (aTranslationVector.Y());
      TCollection_AsciiString Message4 (aTranslationVector.Z());
      Message += " aTranslationVector ( "; 
    Message += Message2; Message += " , ";
    Message += Message3; Message += " , ";
    Message += Message4; Message += " ); \n";
       
      TCollection_AsciiString Message5 (value);
    Message += " value = ";Message+= Message5; Message += "\n";
      
      TCollection_AsciiString Message6 (aRotatedEntityTypeName);
      TCollection_AsciiString Message7 (aMirroredEntityTypeName);
      TCollection_AsciiString Message8 (aScaledEntityTypeName);
    TCollection_AsciiString Message9 (aTranslatedEntityTypeName);

      Message += " aRotatedEntityTypeName     = ";Message+= Message6; Message += "\n";
    Message += " aMirroredEntityTypeName     = ";Message+= Message7; Message += "\n";
    Message += " aScaledEntityTypeName       = ";Message+= Message8; Message += "\n";
    Message += " aTranslatedEntityTypeName  = ";Message+= Message9; Message += "\n";


   PostProcess(aDoc,ID_BUTTON_Test_36,TheDisplayType,Message.ToCString());
}

// Function name  : GeomSources::gpTest37
// Description        : 
// Return type          : void 
// Argument         : CGeometryDoc* aDoc
void GeomSources::gpTest37(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
TColgp_Array1OfPnt anArrayofPnt (1,5); // sizing array           
anArrayofPnt.SetValue(1,gp_Pnt(0,0,1));                          
anArrayofPnt.SetValue(2,gp_Pnt(1,2,2));                          
anArrayofPnt.SetValue(3,gp_Pnt(2,3,3));                          
anArrayofPnt.SetValue(4,gp_Pnt(4,3,4));                          
anArrayofPnt.SetValue(5,gp_Pnt(5,5,5));                          
                                                                 
Standard_Real Tolerance = 1;                
                                                                 
gp_Pln P;                                                        
GProp_PEquation PE (anArrayofPnt,Tolerance);                     
if (PE.IsPlanar()) { P = PE.Plane();}                            
                                                                 
if (PE.IsPoint())  { /* ... */  }     
if (PE.IsLinear()) { /* ... */  }     
if (PE.IsPlanar()) { P = PE.Plane();}                                             
if (PE.IsSpace())  { /* ... */  }     
                                                                 
//==============================================================
    TCollection_AsciiString Message (" \
                                                                 \n\
TColgp_Array1OfPnt anArrayofPnt (1,5); // sizing array           \n\
anArrayofPnt.SetValue(1,gp_Pnt(0,0,1));                          \n\
anArrayofPnt.SetValue(2,gp_Pnt(1,2,2));                          \n\
anArrayofPnt.SetValue(3,gp_Pnt(2,3,3));                          \n\
anArrayofPnt.SetValue(4,gp_Pnt(4,3,4));                          \n\
anArrayofPnt.SetValue(5,gp_Pnt(5,5,5));                          \n\
                                                                 \n\
Standard_Real Tolerance = 1;                                     \n\
                                                                 \n\
gp_Pln P;                                                        \n\
GProp_PEquation PE (anArrayofPnt,Tolerance);                     \n\
if (PE.IsPlanar()) { P = PE.Plane();}                            \n\
                                                                 \n\
if (PE.IsPoint())  { /* ... */  }                                \n\
if (PE.IsLinear()) { /* ... */  }                                \n\
if (PE.IsPlanar()) { P = PE.Plane();}                            \n\
if (PE.IsSpace())  { /* ... */  }                                \n\
                                                                 \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    TCollection_AsciiString aString;
    for(Standard_Integer i = anArrayofPnt.Lower();i<=anArrayofPnt.Upper();i++){
            TCollection_AsciiString Message2(i);
            gp_Pnt P = anArrayofPnt(i);
        aString = "P";aString += Message2; 
        DisplayPoint(aDoc,P,aString.ToCString(),false,0.5);
            }

    Message += " PE.IsPoint()  = ";  if (PE.IsPoint()) Message += "True \n";  else Message += "False\n";
    Message += " PE.IsLinear() = ";  if (PE.IsLinear()) Message += "True \n";  else Message += "False\n";

      if (PE.IsPlanar()) { 
         Message +=  " PE.IsPlanar() = True \n";
         P = PE.Plane();
         Handle(Geom_Plane) aPlane = new Geom_Plane(P);
         Handle(Geom_RectangularTrimmedSurface) aSurface= new Geom_RectangularTrimmedSurface(aPlane,-4.,4.,-4.,4.);

         DisplaySurface(aDoc,aSurface);

    }
    else
    Message += " PE.IsPlanar() = False \n";

    Message += " PE.IsSpace() = ";   if (PE.IsSpace() ) Message += "True \n";  else Message += "False\n";

    PostProcess(aDoc,ID_BUTTON_Test_37,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest38(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                              
TColgp_Array1OfPnt array1 (1,5); // sizing array                                      
array1.SetValue(1,gp_Pnt (-4,0,2 )); array1.SetValue(2,gp_Pnt (-7,2,2 ));             
array1.SetValue(3,gp_Pnt (-6,3,1 )); array1.SetValue(4,gp_Pnt (-4,3,-1));             
array1.SetValue(5,gp_Pnt (-3,5,-2));                                                  
Handle(Geom_BSplineCurve) SPL1 = GeomAPI_PointsToBSpline(array1).Curve();             
                                                                                      
TColgp_Array1OfPnt array2 (1,5); // sizing array                                      
array2.SetValue(1,gp_Pnt (-4,0, 2)); array2.SetValue(2,gp_Pnt (-2,2,0 ));             
array2.SetValue(3,gp_Pnt (2 ,3,-1)); array2.SetValue(4,gp_Pnt (3 ,7,-2));             
array2.SetValue(5,gp_Pnt (4 ,9,-1));                                                  
Handle(Geom_BSplineCurve) SPL2 = GeomAPI_PointsToBSpline(array2).Curve();             
                                                                                      
GeomFill_FillingStyle Type = GeomFill_StretchStyle;                                   
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                                    
Handle(Geom_BSplineSurface)    aBSplineSurface1 = aGeomFill1.Surface();               
                                                                                      
Type = GeomFill_CoonsStyle;                                                           
GeomFill_BSplineCurves aGeomFill2(                                                    
        Handle(Geom_BSplineCurve)::DownCast(SPL1->Translated(gp_Vec(10,0,0))),        
        Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(10,0,0))),Type);  
Handle(Geom_BSplineSurface)    aBSplineSurface2 = aGeomFill2.Surface();               
Type = GeomFill_CurvedStyle;                                                          
GeomFill_BSplineCurves aGeomFill3(                                                    
        Handle(Geom_BSplineCurve)::DownCast(SPL1->Translated(gp_Vec(20,0,0))),        
        Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(20,0,0))),Type);  
Handle(Geom_BSplineSurface)    aBSplineSurface3 = aGeomFill3.Surface();               
                                                                                      
//==============================================================
    TCollection_AsciiString Message (" \
                                                                                      \n\
TColgp_Array1OfPnt array1 (1,5); // sizing array                                      \n\
array1.SetValue(1,gp_Pnt (-4,0,2 )); array1.SetValue(2,gp_Pnt (-7,2,2 ));             \n\
array1.SetValue(3,gp_Pnt (-6,3,1 )); array1.SetValue(4,gp_Pnt (-4,3,-1));             \n\
array1.SetValue(5,gp_Pnt (-3,5,-2));                                                  \n\
Handle(Geom_BSplineCurve) SPL1 = GeomAPI_PointsToBSpline(array1).Curve();             \n\
                                                                                      \n\
TColgp_Array1OfPnt array2 (1,5); // sizing array                                      \n\
array2.SetValue(1,gp_Pnt (-4,0, 2)); array2.SetValue(2,gp_Pnt (-2,2,0 ));             \n\
array2.SetValue(3,gp_Pnt (2 ,3,-1)); array2.SetValue(4,gp_Pnt (3 ,7,-2));             \n\
array2.SetValue(5,gp_Pnt (4 ,9,-1));                                                  \n\
Handle(Geom_BSplineCurve) SPL2 = GeomAPI_PointsToBSpline(array2).Curve();             \n\
                                                                                      \n\
GeomFill_FillingStyle Type = GeomFill_StretchStyle;                                   \n\
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                                    \n\
Handle(Geom_BSplineSurface)    aBSplineSurface1 = aGeomFill1.Surface();               \n\
                                                                                      \n\
Type = GeomFill_CoonsStyle;                                                           \n\
GeomFill_BSplineCurves aGeomFill2(                                                    \n");
Message += "\
        Handle(Geom_BSplineCurve)::DownCast(SPL1->Translated(gp_Vec(10,0,0))),        \n\
        Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(10,0,0))),Type);  \n\
Handle(Geom_BSplineSurface)    aBSplineSurface2 = aGeomFill2.Surface();               \n\
Type = GeomFill_CurvedStyle;                                                          \n\
GeomFill_BSplineCurves aGeomFill3(                                                    \n\
        Handle(Geom_BSplineCurve)::DownCast(SPL1->Translated(gp_Vec(20,0,0))),        \n\
        Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(20,0,0))),Type);  \n\
Handle(Geom_BSplineSurface)    aBSplineSurface3 = aGeomFill3.Surface();               \n\
                                                                                      \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    // Trace des frontieres.  -> FreeBoundaryAspect
    // Trace des isoparametriques.  --> UIsoAspect()
    
    DisplaySurface(aDoc,aBSplineSurface1,Quantity_NOC_YELLOW);
    DisplaySurface(aDoc,aBSplineSurface2,Quantity_NOC_SALMON);
    DisplaySurface(aDoc,aBSplineSurface3,Quantity_NOC_HOTPINK);

    for (int i=0;i<=2;i++)
    {
        DisplayCurve(aDoc,Handle(Geom_BSplineCurve)::DownCast(SPL1->Translated(gp_Vec(i*10,0,0))), Quantity_NOC_RED,false);
        DisplayCurve(aDoc,Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(i*10,0,0))), Quantity_NOC_GREEN,false);
    }

    Message += "SPL1                      is Red; \n";
    Message += "SPL2                      is Green; \n";
    Message += "aBSplineSurface1  is Yellow;       ( GeomFill_StretchStyle )\n";   
    Message += "aBSplineSurface2  is Salmon;     ( GeomFill_CoonsStyle ) \n";
    Message += "aBSplineSurface3  is Hot pink;   ( GeomFill_CurvedStyle ) \n";

    PostProcess(aDoc,ID_BUTTON_Test_38,TheDisplayType,Message.ToCString());
}
void GeomSources::gpTest39(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
TColgp_Array1OfPnt array1 (1,5); // sizing array                                      
array1.SetValue(1,gp_Pnt (-4,0,2 )); 
array1.SetValue(2,gp_Pnt (-5,1,0 ));             
array1.SetValue(3,gp_Pnt (-6,2,-2 )); 
array1.SetValue(4,gp_Pnt (-5,4,-7));             
array1.SetValue(5,gp_Pnt (-3,5,-12));                                                  
                                                                                      
TColgp_Array1OfPnt array2 (1,5); // sizing array                                      
array2.SetValue(1,gp_Pnt (-4,0, 2)); 
array2.SetValue(2,gp_Pnt (-3,2,1 ));             
array2.SetValue(3,gp_Pnt (-1,5,0)); 
array2.SetValue(4,gp_Pnt (2 ,7,-1));             
array2.SetValue(5,gp_Pnt (4 ,9,-1));                                                  
                                                                                      
TColgp_Array1OfPnt array3 (1,4); // sizing array                                      
array3.SetValue(1,gp_Pnt (-3,5, -12)); 
array3.SetValue(2,gp_Pnt (-2,6,-7 ));             
array3.SetValue(3,gp_Pnt (0 ,8,-3)); 
array3.SetValue(4,gp_Pnt (4 ,9,-1));  
           
Handle(Geom_BSplineCurve) SPL1 = GeomAPI_PointsToBSpline(array1).Curve();             
Handle(Geom_BSplineCurve) SPL2 = GeomAPI_PointsToBSpline(array2).Curve();             
Handle(Geom_BSplineCurve) SPL3 = GeomAPI_PointsToBSpline(array3).Curve();             
                                                                                      
Handle(GeomAdaptor_HCurve) SPL1Adaptor = new GeomAdaptor_HCurve(SPL1);                     
Handle(GeomFill_SimpleBound) B1 =                                                          
   new GeomFill_SimpleBound(SPL1Adaptor,Precision::Approximation(),Precision::Angular());  
Handle(GeomAdaptor_HCurve) SPL2Adaptor = new GeomAdaptor_HCurve(SPL2);                     
Handle(GeomFill_SimpleBound) B2 =                                                          
   new GeomFill_SimpleBound(SPL2Adaptor,Precision::Approximation(),Precision::Angular());  
Handle(GeomAdaptor_HCurve) SPL3Adaptor = new GeomAdaptor_HCurve(SPL3);                     
Handle(GeomFill_SimpleBound) B3 =                                                          
   new GeomFill_SimpleBound(SPL3Adaptor,Precision::Approximation(),Precision::Angular());  
Standard_Boolean NoCheck= Standard_False;                                                  
                                                                                           
Standard_Integer MaxDeg = 8;                                                               
Standard_Integer MaxSeg = 2;                                                               
GeomFill_ConstrainedFilling aConstrainedFilling(MaxDeg, MaxSeg);                           
                                                                                           
aConstrainedFilling.Init(B1,B2,B3,NoCheck);                                                
                                                                                           
Handle(Geom_BSplineSurface) aBSplineSurface = aConstrainedFilling.Surface();               
                                                                                           
//==============================================================
    TCollection_AsciiString Message (" \
                                                                                           \n\
TColgp_Array1OfPnt array1 (1,5); // sizing array                                           \n\
...                                                                                        \n\
Handle(Geom_BSplineCurve) SPL1 = GeomAPI_PointsToBSpline(array1).Curve();                  \n\
Handle(Geom_BSplineCurve) SPL2 = GeomAPI_PointsToBSpline(array2).Curve();                  \n\
Handle(Geom_BSplineCurve) SPL3 = GeomAPI_PointsToBSpline(array3).Curve();                  \n\
                                                                                           \n\
Handle(GeomAdaptor_HCurve) SPL1Adaptor = new GeomAdaptor_HCurve(SPL1);                     \n\
Handle(GeomFill_SimpleBound) B1 =                                                          \n\
   new GeomFill_SimpleBound(SPL1Adaptor,Precision::Approximation(),Precision::Angular());  \n\
Handle(GeomAdaptor_HCurve) SPL2Adaptor = new GeomAdaptor_HCurve(SPL2);                     \n\
Handle(GeomFill_SimpleBound) B2 =                                                          \n\
   new GeomFill_SimpleBound(SPL2Adaptor,Precision::Approximation(),Precision::Angular());  \n\
Handle(GeomAdaptor_HCurve) SPL3Adaptor = new GeomAdaptor_HCurve(SPL3);                     \n\
Handle(GeomFill_SimpleBound) B3 =                                                          \n\
   new GeomFill_SimpleBound(SPL3Adaptor,Precision::Approximation(),Precision::Angular());  \n\
Standard_Boolean NoCheck= Standard_False;                                                  \n\
                                                                                           \n\
Standard_Integer MaxDeg = 8;                                                               \n");
Message += "\
Standard_Integer MaxSeg = 2;                                                               \n\
GeomFill_ConstrainedFilling aConstrainedFilling(MaxDeg, MaxSeg);                           \n\
                                                                                           \n\
aConstrainedFilling.Init(B1,B2,B3,NoCheck);                                                \n\
                                                                                           \n\
Handle(Geom_BSplineSurface) aBSplineSurface = aConstrainedFilling.Surface();               \n\
                                                                                           \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    TCollection_AsciiString aString;

    DisplaySurface(aDoc,aBSplineSurface,Quantity_NOC_YELLOW);

    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);
    DisplayCurve(aDoc,SPL2,Quantity_NOC_GREEN ,false);
    DisplayCurve(aDoc,SPL3,Quantity_NOC_BLUE1 ,false);

    Message += "SPL1                      is Red; \n";
    Message += "SPL2                      is Green; \n";
    Message += "SPL3                      is Blue; \n";

    Message += "aBSplineSurface  is Yellow; \n";   


    PostProcess(aDoc,ID_BUTTON_Test_39,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest40(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                   
TColgp_Array1OfPnt array1 (1,5); // sizing array                   
array1.SetValue(1,gp_Pnt (-4,0,2 ));                               
array1.SetValue(2,gp_Pnt (-5,1,0 ));                               
array1.SetValue(3,gp_Pnt (-6,2,-2 ));                              
array1.SetValue(4,gp_Pnt (-5,4,-7));                               
array1.SetValue(5,gp_Pnt (-3,5,-12));                              
                                                                   
Handle(Geom_BSplineCurve) SPL1 =                                   
    GeomAPI_PointsToBSpline(array1).Curve();                       
                                                                   
GeomFill_Pipe aPipe(SPL1,1);                                       
aPipe.Perform();                                                   
Handle(Geom_Surface) aSurface= aPipe.Surface();                    
Standard_CString aSurfaceEntityTypeName="Not Computed";            
if (!aSurface.IsNull())                                            
   aSurfaceEntityTypeName = aSurface->DynamicType()->Name();       
                                                                   
Handle(Geom_Ellipse) E = GC_MakeEllipse( gp::XOY() ,3,1).Value();  
GeomFill_Pipe aPipe2(SPL1,E);                                      
aPipe2.Perform();                                                  
Handle(Geom_Surface) aSurface2= aPipe2.Surface();                  
Standard_CString aSurfaceEntityTypeName2="Not Computed";           
if (!aSurface2.IsNull())  {                                        
    aSurfaceEntityTypeName2 = aSurface2->DynamicType()->Name();    
    aSurface2->Translate(gp_Vec(5,0,0));  }                        
                                                                   
Handle(Geom_TrimmedCurve) TC1 =                                    
    GC_MakeSegment(gp_Pnt(1,1,1),gp_Pnt(5,5,5));                   
Handle(Geom_TrimmedCurve) TC2 =                                    
    GC_MakeSegment(gp_Pnt(1,1,0),gp_Pnt(4,5,6));                   
GeomFill_Pipe aPipe3(SPL1,TC1,TC2);                                
aPipe3.Perform();                                                  
Handle(Geom_Surface) aSurface3 = aPipe3.Surface();                 
Standard_CString aSurfaceEntityTypeName3="Not Computed";           
if (!aSurface3.IsNull())                                           
  {                                                                
    aSurfaceEntityTypeName3 = aSurface3->DynamicType()->Name();    
        aSurface3->Translate(gp_Vec(10,0,0));                      
  }                                                                
                                                                   
//==============================================================
    TCollection_AsciiString Message (" \
                                                                   \n\
                                                                   \n\
TColgp_Array1OfPnt array1 (1,5); // sizing array                   \n\
array1.SetValue(1,gp_Pnt (-4,0,2 ));                               \n\
array1.SetValue(2,gp_Pnt (-5,1,0 ));                               \n\
array1.SetValue(3,gp_Pnt (-6,2,-2 ));                              \n\
array1.SetValue(4,gp_Pnt (-5,4,-7));                               \n\
array1.SetValue(5,gp_Pnt (-3,5,-12));                              \n\
                                                                   \n\
Handle(Geom_BSplineCurve) SPL1 =                                   \n\
    GeomAPI_PointsToBSpline(array1).Curve();                       \n\
                                                                   \n\
GeomFill_Pipe aPipe(SPL1,1);                                       \n\
aPipe.Perform();                                                   \n\
Handle(Geom_Surface) aSurface= aPipe.Surface();                    \n\
Standard_CString aSurfaceEntityTypeName=\"Not Computed\";            \n\
if (!aSurface.IsNull())                                            \n\
   aSurfaceEntityTypeName = aSurface->DynamicType()->Name();       \n\
                                                                   \n\
Handle(Geom_Ellipse) E = GC_MakeEllipse( gp::XOY() ,3,1).Value();  \n\
GeomFill_Pipe aPipe2(SPL1,E);                                      \n\
aPipe2.Perform();                                                  \n");
Message += "\
Handle(Geom_Surface) aSurface2= aPipe2.Surface();                  \n\
Standard_CString aSurfaceEntityTypeName2=\"Not Computed\";           \n\
if (!aSurface2.IsNull())  {                                        \n\
    aSurfaceEntityTypeName2 = aSurface2->DynamicType()->Name();    \n\
    aSurface2->Translate(gp_Vec(5,0,0));  }                        \n\
                                                                   \n\
Handle(Geom_TrimmedCurve) TC1 =                                    \n\
    GC_MakeSegment(gp_Pnt(1,1,1),gp_Pnt(5,5,5));                   \n\
Handle(Geom_TrimmedCurve) TC2 =                                    \n\
    GC_MakeSegment(gp_Pnt(1,1,0),gp_Pnt(4,5,6));                   \n\
GeomFill_Pipe aPipe3(SPL1,TC1,TC2);                                \n\
aPipe3.Perform();                                                  \n\
Handle(Geom_Surface) aSurface3 = aPipe3.Surface();                 \n\
Standard_CString aSurfaceEntityTypeName3=\"Not Computed\";           \n\
if (!aSurface3.IsNull())                                           \n\
  {                                                                \n\
    aSurfaceEntityTypeName3 = aSurface3->DynamicType()->Name();    \n\
        aSurface3->Translate(gp_Vec(10,0,0));                      \n\
  }                                                                \n\
                                                                 \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------


    if (!aSurface.IsNull())
    {
        DisplaySurface(aDoc,aSurface,Quantity_NOC_YELLOW);
    }
    if (!aSurface2.IsNull())
    {
        DisplaySurface(aDoc,aSurface2,Quantity_NOC_YELLOW);
    }
    if (!aSurface3.IsNull())
    {
        DisplaySurface(aDoc,aSurface3,Quantity_NOC_YELLOW);
    }

    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);

    Message += "SPL1                      is Red; \n";

    
      TCollection_AsciiString Message2(aSurfaceEntityTypeName);
      TCollection_AsciiString Message3(aSurfaceEntityTypeName2);
      TCollection_AsciiString Message4(aSurfaceEntityTypeName3);
      
      Message += " aSurfaceEntityTypeName     = ";Message+= Message2; Message += "\n";
    Message += " aSurfaceEntityTypeName2     = ";Message+= Message3; Message += "\n";
    Message += " aSurfaceEntityTypeName3     = ";Message+= Message4; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_40,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest41(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                   
TColgp_Array1OfPnt array1 (1,5);                                   
array1.SetValue(1,gp_Pnt (-4,0,2 ));                               
array1.SetValue(2,gp_Pnt (-5,1,0 ));                               
array1.SetValue(3,gp_Pnt (-6,2,-2 ));                              
array1.SetValue(4,gp_Pnt (-5,4,-7));                               
array1.SetValue(5,gp_Pnt (-3,5,-12));                              
                                                                   
Handle(Geom_BSplineCurve) SPL1 =                                   
    GeomAPI_PointsToBSpline(array1).Curve();                       
Handle(Geom_Curve) FirstSect =                                     
    GC_MakeSegment(gp_Pnt(-4,0,2),gp_Pnt(-4,0,10)).Value();        
                                                                   
GeomFill_Pipe aPipe(SPL1,FirstSect);                               
aPipe.Perform();                                                   
                                                                   
Handle(Geom_BSplineSurface) aPipeSurface =                         
    Handle(Geom_BSplineSurface)::DownCast(aPipe.Surface());        
Handle(Geom_BSplineSurface) anotherBSplineSurface =                
    GeomConvert::SplitBSplineSurface(aPipeSurface,1,2,3,6);        
                                                                   
//==============================================================
    TCollection_AsciiString Message (" \
                                                                   \n\
TColgp_Array1OfPnt array1 (1,5);                                   \n\
array1.SetValue(1,gp_Pnt (-4,0,2 ));                               \n\
array1.SetValue(2,gp_Pnt (-5,1,0 ));                               \n\
array1.SetValue(3,gp_Pnt (-6,2,-2 ));                              \n\
array1.SetValue(4,gp_Pnt (-5,4,-7));                               \n\
array1.SetValue(5,gp_Pnt (-3,5,-12));                              \n\
                                                                   \n\
Handle(Geom_BSplineCurve) SPL1 =                                   \n\
    GeomAPI_PointsToBSpline(array1).Curve();                       \n\
Handle(Geom_Curve) FirstSect =                                     \n\
    GC_MakeSegment(gp_Pnt(-4,0,2),gp_Pnt(-4,0,10)).Value();        \n\
                                                                   \n\
GeomFill_Pipe aPipe(SPL1,FirstSect);                               \n\
aPipe.Perform();                                                   \n\
                                                                   \n\
Handle(Geom_BSplineSurface) aPipeSurface =                         \n\
    Handle(Geom_BSplineSurface)::DownCast(aPipe.Surface());        \n\
Handle(Geom_BSplineSurface) anotherBSplineSurface =                \n\
    GeomConvert::SplitBSplineSurface(aPipeSurface,1,2,3,6);        \n\
                                                                   \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

                                                                                        
    if (!aPipeSurface.IsNull())
    {
        DisplaySurface(aDoc,aPipeSurface,Quantity_NOC_YELLOW);
    }

    if (!anotherBSplineSurface.IsNull())
    {
        DisplaySurface(aDoc,anotherBSplineSurface,Quantity_NOC_HOTPINK);
    }

    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);
    DisplayCurve(aDoc,FirstSect,Quantity_NOC_GREEN ,false);

    Message += "SPL1                              is Red; \n";
    Message += "SPL2                              is Green; \n";
    Message += "SPL3                              is Blue; \n";
    Message += "aBSplineSurface            is Yellow; \n";   
    Message += "anotherBSplineSurface  is Hot Pink; \n";   

    PostProcess(aDoc,ID_BUTTON_Test_41,TheDisplayType,Message.ToCString());
}


void GeomSources::gpTest42(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
TColgp_Array2OfPnt array1(1,3,1,3);                              
TColgp_Array2OfPnt array2(1,3,1,3);                              
TColgp_Array2OfPnt array3(1,3,1,3);                              
TColgp_Array2OfPnt array4(1,3,1,3);                              

array1.SetValue(1,1,gp_Pnt(1,1,1));
array1.SetValue(1,2,gp_Pnt(2,1,2));
array1.SetValue(1,3,gp_Pnt(3,1,1));
array1.SetValue(2,1,gp_Pnt(1,2,1));
array1.SetValue(2,2,gp_Pnt(2,2,2));
array1.SetValue(2,3,gp_Pnt(3,2,0));
array1.SetValue(3,1,gp_Pnt(1,3,2));
array1.SetValue(3,2,gp_Pnt(2,3,1));
array1.SetValue(3,3,gp_Pnt(3,3,0));

array2.SetValue(1,1,gp_Pnt(3,1,1));
array2.SetValue(1,2,gp_Pnt(4,1,1));
array2.SetValue(1,3,gp_Pnt(5,1,2));
array2.SetValue(2,1,gp_Pnt(3,2,0));
array2.SetValue(2,2,gp_Pnt(4,2,1));
array2.SetValue(2,3,gp_Pnt(5,2,2));
array2.SetValue(3,1,gp_Pnt(3,3,0));
array2.SetValue(3,2,gp_Pnt(4,3,0));
array2.SetValue(3,3,gp_Pnt(5,3,1));

array3.SetValue(1,1,gp_Pnt(1,3,2));
array3.SetValue(1,2,gp_Pnt(2,3,1));
array3.SetValue(1,3,gp_Pnt(3,3,0));
array3.SetValue(2,1,gp_Pnt(1,4,1));
array3.SetValue(2,2,gp_Pnt(2,4,0));
array3.SetValue(2,3,gp_Pnt(3,4,1));
array3.SetValue(3,1,gp_Pnt(1,5,1));
array3.SetValue(3,2,gp_Pnt(2,5,1));
array3.SetValue(3,3,gp_Pnt(3,5,2));

array4.SetValue(1,1,gp_Pnt(3,3,0));
array4.SetValue(1,2,gp_Pnt(4,3,0));
array4.SetValue(1,3,gp_Pnt(5,3,1));
array4.SetValue(2,1,gp_Pnt(3,4,1));
array4.SetValue(2,2,gp_Pnt(4,4,1));
array4.SetValue(2,3,gp_Pnt(5,4,1));
array4.SetValue(3,1,gp_Pnt(3,5,2));
array4.SetValue(3,2,gp_Pnt(4,5,2));
array4.SetValue(3,3,gp_Pnt(5,5,1));

Handle(Geom_BezierSurface) BZ1 =                                  
    new Geom_BezierSurface(array1);
Handle(Geom_BezierSurface) BZ2 =                                  
    new Geom_BezierSurface(array2);
Handle(Geom_BezierSurface) BZ3 =                                  
    new Geom_BezierSurface(array3);
Handle(Geom_BezierSurface) BZ4 =                                  
    new Geom_BezierSurface(array4);
                                                                  
TColGeom_Array2OfBezierSurface bezierarray(1,2,1,2);              
bezierarray.SetValue(1,1,BZ1);                                    
bezierarray.SetValue(1,2,BZ2);                                    
bezierarray.SetValue(2,1,BZ3);                                    
bezierarray.SetValue(2,2,BZ4);                                    
                                                                  
GeomConvert_CompBezierSurfacesToBSplineSurface BB (bezierarray);  
   Handle(Geom_BSplineSurface) BSPLSURF ;                         
if (BB.IsDone()){                                                 
   BSPLSURF = new Geom_BSplineSurface(                            
        BB.Poles()->Array2(),                                     
        BB.UKnots()->Array1(),                                    
        BB.VKnots()->Array1(),                                    
        BB.UMultiplicities()->Array1(),                           
        BB.VMultiplicities()->Array1(),                           
        BB.UDegree(),                                             
        BB.VDegree() );     
    BSPLSURF->Translate(gp_Vec(0,0,2));                      
    }                                                             
                                                                  
//==============================================================


    TCollection_AsciiString Message (" \
                                                                  \n\
TColgp_Array2OfPnt array1(1,3,1,3);                               \n\
TColgp_Array2OfPnt array2(1,3,1,3);                               \n\
TColgp_Array2OfPnt array3(1,3,1,3);                               \n\
TColgp_Array2OfPnt array4(1,3,1,3);                               \n\
                                                                  \n\
// array1.SetValue(  ...                                          \n\
                                                                  \n\
Handle(Geom_BezierSurface) BZ1 =                                  \n\
    new Geom_BezierSurface(array1);                               \n\
Handle(Geom_BezierSurface) BZ2 =                                  \n\
    new Geom_BezierSurface(array2);                               \n\
Handle(Geom_BezierSurface) BZ3 =                                  \n\
    new Geom_BezierSurface(array3);                               \n\
Handle(Geom_BezierSurface) BZ4 =                                  \n\
    new Geom_BezierSurface(array4);                               \n\
                                                                  \n\
TColGeom_Array2OfBezierSurface bezierarray(1,2,1,2);              \n\
bezierarray.SetValue(1,1,BZ1);                                    \n\
bezierarray.SetValue(1,2,BZ2);                                    \n\
bezierarray.SetValue(2,1,BZ3);                                    \n\
bezierarray.SetValue(2,2,BZ4);                                    \n\
                                                                  \n\
GeomConvert_CompBezierSurfacesToBSplineSurface BB (bezierarray);  \n\
   Handle(Geom_BSplineSurface) BSPLSURF ;                         \n\
if (BB.IsDone()){                                                 \n\
   BSPLSURF = new Geom_BSplineSurface(                            \n\
        BB.Poles()->Array2(),                                     \n\
        BB.UKnots()->Array1(),                                    \n");
        Message += "\
        BB.VKnots()->Array1(),                                    \n\
        BB.UMultiplicities()->Array1(),                           \n\
        BB.VMultiplicities()->Array1(),                           \n\
        BB.UDegree(),                                             \n\
        BB.VDegree() );                                           \n\
    BSPLSURF->Translate(gp_Vec(0,0,2));                           \n\
    }                                                             \n\
                                                                  \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
        
    DisplaySurface(aDoc,BZ1,Quantity_NOC_RED);
    DisplaySurface(aDoc,BZ2,Quantity_NOC_GREEN);
    DisplaySurface(aDoc,BZ3,Quantity_NOC_BLUE1);
    DisplaySurface(aDoc,BZ4,Quantity_NOC_BROWN);

    if (BB.IsDone()){
        DisplaySurface(aDoc,BSPLSURF,Quantity_NOC_HOTPINK);
    }

    Message += "BZ1              is Red; \n";
    Message += "BZ2              is Green; \n";
    Message += "BZ3              is Blue; \n";
    Message += "BZ4              is Brown; \n";
    Message += "BSPLSURF  is Hot Pink; \n";   

    PostProcess(aDoc,ID_BUTTON_Test_42,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest43(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                                 
TColgp_Array1OfPnt array1 (1,5);                                                 
array1.SetValue(1,gp_Pnt (-4,5,5 ));                                             
array1.SetValue(2,gp_Pnt (-3,6,6 ));                                             
array1.SetValue(3,gp_Pnt (-1,7,7 ));                                             
array1.SetValue(4,gp_Pnt (0,8,8));                                               
array1.SetValue(5,gp_Pnt (2,9,9));                                               
Handle(Geom_BSplineCurve) SPL1 =                                                 
      GeomAPI_PointsToBSpline(array1).Curve();                                     
                                                                                 
TColgp_Array1OfPnt array2 (1,5);                                                 
array2.SetValue(1,gp_Pnt (-4,5,2 ));                                             
array2.SetValue(2,gp_Pnt (-3,6,3 ));                                             
array2.SetValue(3,gp_Pnt (-1,7,4 ));                                             
array2.SetValue(4,gp_Pnt (0,8,5));                                               
array2.SetValue(5,gp_Pnt (2,9,6));                                               
Handle(Geom_BSplineCurve) SPL2 =                                                 
      GeomAPI_PointsToBSpline(array2).Curve();                                     
                                                                                 
GeomFill_FillingStyle Type = GeomFill_StretchStyle;                              
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                               
Handle(Geom_BSplineSurface) aGeomSurface = aGeomFill1.Surface();                 
Standard_Real offset = 1;                                                        
Handle(Geom_OffsetSurface) GOS = new Geom_OffsetSurface(aGeomSurface, offset);   
 offset = 2;                                                                     
Handle(Geom_OffsetSurface) GOS1 = new Geom_OffsetSurface(aGeomSurface, offset);  
offset = 3;                                                                      
Handle(Geom_OffsetSurface) GOS2 = new Geom_OffsetSurface(aGeomSurface, offset);  
                                                                                 
//==============================================================
    TCollection_AsciiString Message (" \
                                                                                 \n\
TColgp_Array1OfPnt array1 (1,5);                                                 \n\
//array1.SetValue( ...                                                           \n\
Handle(Geom_BSplineCurve) SPL1 =                                                 \n\
      GeomAPI_PointsToBSpline(array1).Curve();                                     \n\
                                                                                 \n\
TColgp_Array1OfPnt array2 (1,5);                                                 \n\
// array2.SetValue( ...                                                          \n\
                                                                                 \n\
Handle(Geom_BSplineCurve) SPL2 =                                                 \n\
      GeomAPI_PointsToBSpline(array2).Curve();                                     \n\
                                                                                 \n\
GeomFill_FillingStyle Type = GeomFill_StretchStyle;                              \n\
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                               \n\
Handle(Geom_BSplineSurface) aGeomSurface = aGeomFill1.Surface();                 \n\
Standard_Real offset = 1;                                                        \n\
Handle(Geom_OffsetSurface) GOS = new Geom_OffsetSurface(aGeomSurface, offset);   \n\
 offset = 2;                                                                     \n\
Handle(Geom_OffsetSurface) GOS1 = new Geom_OffsetSurface(aGeomSurface, offset);  \n\
offset = 3;                                                                      \n\
Handle(Geom_OffsetSurface) GOS2 = new Geom_OffsetSurface(aGeomSurface, offset);  \n\
                                                                                 \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplaySurface(aDoc,aGeomSurface,Quantity_NOC_BLUE1);
    DisplaySurface(aDoc,GOS,Quantity_NOC_GREEN);
    DisplaySurface(aDoc,GOS1,Quantity_NOC_GREEN);
    DisplaySurface(aDoc,GOS2,Quantity_NOC_GREEN);

    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);
    DisplayCurve(aDoc,SPL2,Quantity_NOC_HOTPINK ,false);

    Message += "aGeomSurface  is Blue; \n";
    Message += "GOS              are Green; \n";

    PostProcess(aDoc,ID_BUTTON_Test_43,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest44(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                           
gp_Pnt P1(0,0,1);                                          
gp_Pnt P2(1,2,2);                                          
gp_Pnt P3(2,3,3);                                          
gp_Pnt P4(4,3,4);                                          
gp_Pnt P5(5,5,5);                                          
TColgp_Array1OfPnt array (1,5);                            
array.SetValue(1,P1);                                      
array.SetValue(2,P2);                                      
array.SetValue(3,P3);                                      
array.SetValue(4,P4);                                      
array.SetValue(5,P5);                                      
Handle(Geom_BSplineCurve) aCurve =                         
      GeomAPI_PointsToBSpline(array).Curve();                
gp_Dir aDir(1,2,3);                                        
Handle(Geom_SurfaceOfLinearExtrusion) SOLE =               
      new Geom_SurfaceOfLinearExtrusion(aCurve,aDir);        
                                                           
Handle(Geom_RectangularTrimmedSurface) aTrimmedSurface =   
   new Geom_RectangularTrimmedSurface(SOLE,-10,10,false);  
                                                           
Standard_CString SOLEEntityTypeName="Not Computed";        
if (!SOLE.IsNull())                                        
  {                                                        
    SOLEEntityTypeName = SOLE->DynamicType()->Name();      
  }                                                        
                                                           
//==============================================================
    TCollection_AsciiString Message (" \
                                                           \n\
gp_Pnt P1(0,0,1);                                          \n\
gp_Pnt P2(1,2,2);                                          \n\
gp_Pnt P3(2,3,3);                                          \n\
gp_Pnt P4(4,3,4);                                          \n\
gp_Pnt P5(5,5,5);                                          \n\
TColgp_Array1OfPnt array (1,5);                            \n\
array.SetValue(1,P1);                                      \n\
array.SetValue(2,P2);                                      \n\
array.SetValue(3,P3);                                      \n\
array.SetValue(4,P4);                                      \n\
array.SetValue(5,P5);                                      \n\
Handle(Geom_BSplineCurve) aCurve =                         \n\
      GeomAPI_PointsToBSpline(array).Curve();                \n\
gp_Dir aDir(1,2,3);                                        \n\
Handle(Geom_SurfaceOfLinearExtrusion) SOLE =               \n\
      new Geom_SurfaceOfLinearExtrusion(aCurve,aDir);        \n\
                                                           \n\
Handle(Geom_RectangularTrimmedSurface) aTrimmedSurface =   \n\
   new Geom_RectangularTrimmedSurface(SOLE,-10,10,false);  \n\
                                                           \n\
Standard_CString SOLEEntityTypeName=\"Not Computed\";        \n\
if (!SOLE.IsNull())                                        \n\
  {                                                        \n\
    SOLEEntityTypeName = SOLE->DynamicType()->Name();      \n\
  }                                                        \n\
                                                           \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplaySurface(aDoc,aTrimmedSurface,Quantity_NOC_GREEN);
    DisplayCurve(aDoc,aCurve,Quantity_NOC_RED ,false);

    Message += "aCurve   is Red; \n";
    Message += "aTrimmedSurface       is Green; \n";

      TCollection_AsciiString Message2 (SOLEEntityTypeName);

    Message += " SOLEEntityTypeName     = ";Message+= Message2; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_44,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest45(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                     
TColgp_Array1OfPnt array (1,5);                      
array.SetValue(1,gp_Pnt (0,0,1));                     
array.SetValue(2,gp_Pnt (1,2,2));                    
array.SetValue(3,gp_Pnt (2,3,3));                    
array.SetValue(4,gp_Pnt (4,3,4));                    
array.SetValue(5,gp_Pnt (5,5,5));                    
Handle(Geom_BSplineCurve) aCurve =                   
    GeomAPI_PointsToBSpline(array).Curve();          
Handle(Geom_SurfaceOfRevolution) SOR =               
    new Geom_SurfaceOfRevolution(aCurve,gp::OX());   
                                                     
Standard_CString SOREntityTypeName="Not Computed";   
if (!SOR.IsNull())                                   
    SOREntityTypeName = SOR->DynamicType()->Name();  
                                                     
//==============================================================
    TCollection_AsciiString Message (" \
                                                     \n\
TColgp_Array1OfPnt array (1,5);                      \n\
array.SetValue(1,gp_Pnt 0,0,1));                     \n\
array.SetValue(2,gp_Pnt (1,2,2));                    \n\
array.SetValue(3,gp_Pnt (2,3,3));                    \n\
array.SetValue(4,gp_Pnt (4,3,4));                    \n\
array.SetValue(5,gp_Pnt (5,5,5));                    \n\
Handle(Geom_BSplineCurve) aCurve =                   \n\
    GeomAPI_PointsToBSpline(array).Curve();          \n\
Handle(Geom_SurfaceOfRevolution) SOR =               \n\
    new Geom_SurfaceOfRevolution(aCurve,gp::OX());   \n\
                                                     \n\
Standard_CString SOREntityTypeName=\"Not Computed\";   \n\
if (!SOR.IsNull())                                   \n\
    SOREntityTypeName = SOR->DynamicType()->Name();  \n\
                                                     \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------
    DisplaySurface(aDoc,SOR,Quantity_NOC_GREEN);
    DisplayCurve(aDoc,aCurve,Quantity_NOC_RED ,false);

    Message += "aCurve   is Red; \n";
    Message += "SOR       is Green; \n";
      TCollection_AsciiString Message2 (SOREntityTypeName);
    Message += " SOREntityTypeName     = ";Message+= Message2; Message += "\n";

    PostProcess(aDoc,ID_BUTTON_Test_45,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest46(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 
TColgp_Array1OfPnt array1 (1,5);                                  
array1.SetValue(1,gp_Pnt (-4,5,5 ));                              
array1.SetValue(2,gp_Pnt (-3,6,6 ));                              
array1.SetValue(3,gp_Pnt (-1,6,7 ));                              
array1.SetValue(4,gp_Pnt (0,8,8));                                
array1.SetValue(5,gp_Pnt (2,9,9));                                
Handle(Geom_BSplineCurve) SPL1 =                                  
      GeomAPI_PointsToBSpline(array1).Curve();                      
                                                                  
TColgp_Array1OfPnt array2 (1,5);                                  
array2.SetValue(1,gp_Pnt (-4,5,2 ));                              
array2.SetValue(2,gp_Pnt (-3,6,3 ));                              
array2.SetValue(3,gp_Pnt (-1,7,4 ));                              
array2.SetValue(4,gp_Pnt (0,8,5));                                
array2.SetValue(5,gp_Pnt (2,9,6));                                
Handle(Geom_BSplineCurve) SPL2 =                                  
      GeomAPI_PointsToBSpline(array2).Curve();                      
                                                                  
GeomFill_FillingStyle Type = GeomFill_StretchStyle;               
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                
Handle(Geom_BSplineSurface) aGeomSurface = aGeomFill1.Surface();  
                                                                  
Handle(Geom_BSplineSurface) aTranslatedGeomSurface =              
   Handle(Geom_BSplineSurface)::DownCast(aGeomSurface->Copy());   
                                                                  
Standard_Real extension = 3;                                      
Standard_Integer continuity = 2;                                  
Standard_Boolean Udirection = Standard_True;                      
Standard_Boolean after = Standard_True;                           
GeomLib::ExtendSurfByLength (aTranslatedGeomSurface,              
      extension,continuity,Udirection,after);                       
                                                                 
//==============================================================
    TCollection_AsciiString Message (" \
                                                                  \n\
TColgp_Array1OfPnt array1 (1,5);                                  \n\
// ...                                                            \n\
Handle(Geom_BSplineCurve) SPL1 =                                  \n\
      GeomAPI_PointsToBSpline(array1).Curve();                      \n\
                                                                  \n\
TColgp_Array1OfPnt array2 (1,5);                                  \n\
// ...                                                            \n\
Handle(Geom_BSplineCurve) SPL2 =                                  \n\
      GeomAPI_PointsToBSpline(array2).Curve();                      \n\
                                                                  \n\
GeomFill_FillingStyle Type = GeomFill_StretchStyle;               \n\
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                \n\
Handle(Geom_BSplineSurface) aGeomSurface = aGeomFill1.Surface();  \n\
                                                                  \n\
Handle(Geom_BSplineSurface) aTranslatedGeomSurface =              \n\
   Handle(Geom_BSplineSurface)::DownCast(aGeomSurface->Copy());   \n\
                                                                  \n\
Standard_Real extension = 3;                                      \n\
Standard_Integer continuity = 2;                                  \n\
Standard_Boolean Udirection = Standard_True;                      \n\
Standard_Boolean after = Standard_True;                           \n\
GeomLib::ExtendSurfByLength (aTranslatedGeomSurface,              \n\
      extension,continuity,Udirection,after);                       \n\
                                                                  \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    if (!aGeomSurface.IsNull())
    {
        DisplaySurface(aDoc,aGeomSurface,Quantity_NOC_HOTPINK);
    }

    if (!aTranslatedGeomSurface.IsNull())
    {
        DisplaySurface(aDoc,aTranslatedGeomSurface,Quantity_NOC_BLUE1);
    }

    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);
    DisplayCurve(aDoc,SPL2,Quantity_NOC_GREEN ,false);

    Message += "aGeomSurface                    is Hot Pink; \n";
    Message += "aTranslatedGeomSurface   is Blue; \n";
    Message += "SPL1                                   is Red; \n";
    Message += "SPL2                                   is Green; \n";

    PostProcess(aDoc,ID_BUTTON_Test_46,TheDisplayType,Message.ToCString());
}


void GeomSources::gpTest47(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                                 

TColgp_Array1OfPnt array1 (1,5);                           
array1.SetValue(1,gp_Pnt (-5,1,2)); 
array1.SetValue(2,gp_Pnt (-5,2,2));             
array1.SetValue(3,gp_Pnt (-5.3,3,1)); 
array1.SetValue(4,gp_Pnt (-5,4,1));             
array1.SetValue(5,gp_Pnt (-5,5,2));                                                  
Handle(Geom_BSplineCurve) SPL1 = 
      GeomAPI_PointsToBSpline(array1).Curve();             
                                                                                      
TColgp_Array1OfPnt array2 (1,5);                                     
array2.SetValue(1,gp_Pnt (4,1,2)); 
array2.SetValue(2,gp_Pnt (4,2,2));             
array2.SetValue(3,gp_Pnt (3.7,3,1)); 
array2.SetValue(4,gp_Pnt (4,4,1));             
array2.SetValue(5,gp_Pnt (4,5,2));                                                  
Handle(Geom_BSplineCurve) SPL2 = 
      GeomAPI_PointsToBSpline(array2).Curve();    
             
GeomFill_FillingStyle Type = GeomFill_StretchStyle;                                   

GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);                                    
Handle(Geom_BSplineSurface) aSurf1 = aGeomFill1.Surface();    
     
TColgp_Array2OfPnt array3 (1,5,1,5);                           
array3.SetValue(1,1,gp_Pnt (-4,-4,5)); 
array3.SetValue(1,2,gp_Pnt (-4,-2,5));             
array3.SetValue(1,3,gp_Pnt (-4,0,4)); 
array3.SetValue(1,4,gp_Pnt (-4,2,5));             
array3.SetValue(1,5,gp_Pnt (-4,4,5));            
                                                                
array3.SetValue(2,1,gp_Pnt (-2,-4,4)); 
array3.SetValue(2,2,gp_Pnt (-2,-2,4));             
array3.SetValue(2,3,gp_Pnt (-2,0,4)); 
array3.SetValue(2,4,gp_Pnt (-2,2,4));             
array3.SetValue(2,5,gp_Pnt (-2,5,4)); 
                        
array3.SetValue(3,1,gp_Pnt (0,-4,3.5)); 
array3.SetValue(3,2,gp_Pnt (0,-2,3.5));             
array3.SetValue(3,3,gp_Pnt (0,0,3.5)); 
array3.SetValue(3,4,gp_Pnt (0,2,3.5));             
array3.SetValue(3,5,gp_Pnt (0,5,3.5)); 
                                
array3.SetValue(4,1,gp_Pnt (2,-4,4)); 
array3.SetValue(4,2,gp_Pnt (2,-2,4));             
array3.SetValue(4,3,gp_Pnt (2,0,3.5)); 
array3.SetValue(4,4,gp_Pnt (2,2,5));             
array3.SetValue(4,5,gp_Pnt (2,5,4));                             
                                                                                                                        
array3.SetValue(5,1,gp_Pnt (4,-4,5)); 
array3.SetValue(5,2,gp_Pnt (4,-2,5));             
array3.SetValue(5,3,gp_Pnt (4,0,5)); 
array3.SetValue(5,4,gp_Pnt (4,2,6));             
array3.SetValue(5,5,gp_Pnt (4,5,5));  
                       
Handle(Geom_BSplineSurface) aSurf2 = 
      GeomAPI_PointsToBSplineSurface(array3).Surface();                                                
                                                                                      
GeomAPI_ExtremaSurfaceSurface ESS(aSurf1,aSurf2);
Quantity_Length dist = ESS.LowerDistance();
gp_Pnt P1,P2;     
ESS.NearestPoints(P1,P2);

gp_Pnt P3,P4;
Handle(Geom_Curve) aCurve;
Standard_Integer NbExtrema = ESS.NbExtrema();
for(Standard_Integer k=1;k<=NbExtrema;k++){
    ESS.Points(k,P3,P4);                                      
    aCurve= GC_MakeSegment(P3,P4).Value();
    DisplayCurve(aDoc,aCurve,Quantity_NOC_YELLOW3,false);
}

                                                                 
//==============================================================
    TCollection_AsciiString Message ("                         \n\
GeomFill_FillingStyle Type = GeomFill_StretchStyle;            \n\
                                                               \n\
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);             \n\
Handle(Geom_BSplineSurface) aSurf1 = aGeomFill1.Surface();     \n\
                                                               \n\
Handle(Geom_BSplineSurface) aSurf2 =                           \n\
      GeomAPI_PointsToBSplineSurface(array3).Surface();          \n\
                                                               \n\
GeomAPI_ExtremaSurfaceSurface ESS(aSurf1,aSurf2);              \n\
Quantity_Length dist = ESS.LowerDistance();                    \n\
gp_Pnt P1,P2;                                                  \n\
ESS.NearestPoints(P1,P2);                                      \n\
                                                               \n"); 

    AddSeparator(aDoc,Message);
    Message += "aSurf1   is Green; \n";
    Message += "aSurf2   is Hot Pink; \n";
    Message += "Nearest points P1 and P2 are shown; \n";

    //--------------------------------------------------------------

//mfa

    DisplaySurface(aDoc,aSurf1,Quantity_NOC_GREEN);
    DisplaySurface(aDoc,aSurf2,Quantity_NOC_HOTPINK);
    DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false);
    DisplayCurve(aDoc,SPL2,Quantity_NOC_AZURE ,false);
 
    DisplayPoint(aDoc,P1,Standard_CString("P1"));
    DisplayPoint(aDoc,P2,Standard_CString("P2"));

    PostProcess(aDoc,ID_BUTTON_Test_47,TheDisplayType,Message.ToCString());
}

void GeomSources::gpTest48(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = a2DNo3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================

Standard_Real radius = 3;                                    
Handle(Geom2d_Circle) circle =                                    
    new Geom2d_Circle(gp_Ax22d(gp_Pnt2d(-7,2),gp_Dir2d(1,0)),radius);   
    
Handle(Geom2d_TrimmedCurve) C = new Geom2d_TrimmedCurve(circle,1,5);    
                     
Geom2dAdaptor_Curve GAC (C);                                 


TColgp_Array1OfPnt2d array (1,5); // sizing array                    
array.SetValue(1,gp_Pnt2d (0,0));                                    
array.SetValue(2,gp_Pnt2d (1,2));                                    
array.SetValue(3,gp_Pnt2d (2,3));                                    
array.SetValue(4,gp_Pnt2d (4,3));                                    
array.SetValue(5,gp_Pnt2d (5,5));                                    
Handle(Geom2d_BSplineCurve) SPL1 =                                   
    Geom2dAPI_PointsToBSpline(array);                                
                                                                 

Handle(TColgp_HArray1OfPnt2d) harray =                              
    new TColgp_HArray1OfPnt2d (1,5); // sizing harray                
harray->SetValue(1,gp_Pnt2d (13+ 0,0));                             
harray->SetValue(2,gp_Pnt2d (13+ 1,2));                             
harray->SetValue(3,gp_Pnt2d (13+ 2,3));                             
harray->SetValue(4,gp_Pnt2d (13+ 4,3));                             
harray->SetValue(5,gp_Pnt2d (13+ 5,5));                             
Geom2dAPI_Interpolate anInterpolation(harray,Standard_True,0.01);  
anInterpolation.Perform();                                          
Handle(Geom2d_BSplineCurve) SPL2 = anInterpolation.Curve();      
                                                                    
Bnd_Box2d aCBox;                                                    
Geom2dAdaptor_Curve GACC (C);                                       
BndLib_Add2dCurve::Add (GACC,Precision::Approximation(),aCBox);     
                                                                    
Standard_Real aCXmin, aCYmin, aCXmax, aCYmax;                       
aCBox.Get(  aCXmin, aCYmin, aCXmax,aCYmax);                         
                                                                    
Bnd_Box2d aSPL1Box;                                                 
Geom2dAdaptor_Curve GAC1 (SPL1);                                    
BndLib_Add2dCurve::Add (GAC1,Precision::Approximation(),aSPL1Box);  
                                                                    
Standard_Real aSPL1Xmin,aSPL1Ymin,aSPL1Xmax,aSPL1Ymax;              
aSPL1Box.Get(  aSPL1Xmin, aSPL1Ymin, aSPL1Xmax,aSPL1Ymax);          
                                                                    
Bnd_Box2d aSPL2Box;                                                 
Geom2dAdaptor_Curve GAC2 (SPL2);                                    
BndLib_Add2dCurve::Add (GAC2,Precision::Approximation(),aSPL2Box);  
                                                                    
Standard_Real aSPL2Xmin,aSPL2Ymin,aSPL2Xmax,aSPL2Ymax;              
aSPL2Box.Get(  aSPL2Xmin, aSPL2Ymin, aSPL2Xmax,aSPL2Ymax);          
                                                                    
//==============================================================
    TCollection_AsciiString Message (" \
                                                                       \n\
Standard_Real radius = 3;                                              \n\
Handle(Geom2d_Circle) circle =                                         \n\
    new Geom2d_Circle(gp_Ax22d(gp_Pnt2d(-7,2),gp_Dir2d(1,0)),radius);  \n\
                                                                       \n\
Handle(Geom2d_TrimmedCurve) C = new Geom2d_TrimmedCurve(circle,1,5);   \n\
Geom2dAdaptor_Curve GAC (C);                                           \n\
                                                                       \n\
Handle(Geom2d_BSplineCurve) SPL1 ; // SPL1 = ...                       \n\
                                                                       \n\
Handle(Geom2d_BSplineCurve) SPL2 ; // SPL2 = ...                       \n\
                                                                       \n\
Bnd_Box2d aCBox;                                                       \n\
Geom2dAdaptor_Curve GACC (C);                                          \n\
BndLib_Add2dCurve::Add (GACC,Precision::Approximation(),aCBox);        \n\
                                                                       \n\
Standard_Real aCXmin, aCYmin, aCXmax, aCYmax;                          \n\
aCBox.Get(  aCXmin, aCYmin, aCXmax,aCYmax);                            \n\
                                                                       \n\
Bnd_Box2d aSPL1Box;                                                    \n\
Geom2dAdaptor_Curve GAC1 (SPL1);                                       \n\
BndLib_Add2dCurve::Add (GAC1,Precision::Approximation(),aSPL1Box);     \n\
                                                                       \n\
Standard_Real aSPL1Xmin,aSPL1Ymin,aSPL1Xmax,aSPL1Ymax;                 \n\
aSPL1Box.Get(  aSPL1Xmin, aSPL1Ymin, aSPL1Xmax,aSPL1Ymax);             \n");
Message += "\
                                                                       \n\
Bnd_Box2d aSPL2Box;                                                    \n\
Geom2dAdaptor_Curve GAC2 (SPL2);                                       \n\
BndLib_Add2dCurve::Add (GAC2,Precision::Approximation(),aSPL2Box);     \n\
                                                                       \n\
Standard_Real aSPL2Xmin,aSPL2Ymin,aSPL2Xmax,aSPL2Ymax;                 \n\
aSPL2Box.Get(  aSPL2Xmin, aSPL2Ymin, aSPL2Xmax,aSPL2Ymax);             \n\
                                                                       \n";
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayCurve(aDoc,C ,5);
    DisplayCurve(aDoc,SPL1,6 );
    DisplayCurve(aDoc,SPL2,7 );

    DisplayPoint(aDoc,gp_Pnt2d(aCXmin,aCYmax),Standard_CString("aCXmin,aCYmax"));
    DisplayPoint(aDoc,gp_Pnt2d(aCXmax,aCYmax),Standard_CString("aCXmax,aCYmax"));
    DisplayPoint(aDoc,gp_Pnt2d(aCXmin,aCYmin),Standard_CString("aCXmin,aCYmin"));
    DisplayPoint(aDoc,gp_Pnt2d(aCXmax,aCYmin),Standard_CString("aCXmax,aCYmin"));

    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aCXmin,aCYmax),gp_Pnt2d(aCXmax,aCYmax)) ,4); // X,Ymax
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aCXmin,aCYmin),gp_Pnt2d(aCXmax,aCYmin)) ,4); // X,Ymin
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aCXmin,aCYmin),gp_Pnt2d(aCXmin,aCYmax)) ,4); // Xmin,Y
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aCXmax,aCYmin),gp_Pnt2d(aCXmax,aCYmax)) ,4); // Xmax,Y

    DisplayPoint(aDoc,gp_Pnt2d(aSPL1Xmin,aSPL1Ymax),Standard_CString("aSPL1Xmin,aSPL1Ymax"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL1Xmax,aSPL1Ymax),Standard_CString("aSPL1Xmax,aSPL1Ymax"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL1Xmin,aSPL1Ymin),Standard_CString("aSPL1Xmin,aSPL1Ymin"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL1Xmax,aSPL1Ymin),Standard_CString("aSPL1Xmax,aSPL1Ymin"));

    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL1Xmin,aSPL1Ymax),gp_Pnt2d(aSPL1Xmax,aSPL1Ymax)) ,4); // X,Ymax
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL1Xmin,aSPL1Ymin),gp_Pnt2d(aSPL1Xmax,aSPL1Ymin)) ,4); // X,Ymin
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL1Xmin,aSPL1Ymin),gp_Pnt2d(aSPL1Xmin,aSPL1Ymax)) ,4); // Xmin,Y
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL1Xmax,aSPL1Ymin),gp_Pnt2d(aSPL1Xmax,aSPL1Ymax)) ,4); // Xmax,Y

    DisplayPoint(aDoc,gp_Pnt2d(aSPL2Xmin,aSPL2Ymax),Standard_CString("aSPL2Xmin,aSPL2Ymax"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL2Xmax,aSPL2Ymax),Standard_CString("aSPL2Xmax,aSPL2Ymax"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL2Xmin,aSPL2Ymin),Standard_CString("aSPL2Xmin,aSPL2Ymin"));
    DisplayPoint(aDoc,gp_Pnt2d(aSPL2Xmax,aSPL2Ymin),Standard_CString("aSPL2Xmax,aSPL2Ymin"));

    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL2Xmin,aSPL2Ymax),gp_Pnt2d(aSPL2Xmax,aSPL2Ymax)) ,4); // X,Ymax
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL2Xmin,aSPL2Ymin),gp_Pnt2d(aSPL2Xmax,aSPL2Ymin)) ,4); // X,Ymin
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL2Xmin,aSPL2Ymin),gp_Pnt2d(aSPL2Xmin,aSPL2Ymax)) ,4); // Xmin,Y
    DisplayCurve(aDoc,GCE2d_MakeSegment(gp_Pnt2d(aSPL2Xmax,aSPL2Ymin),gp_Pnt2d(aSPL2Xmax,aSPL2Ymax)) ,4); // Xmax,Y

    PostProcess(aDoc,ID_BUTTON_Test_48,TheDisplayType,Message.ToCString());
}


void GeomSources::gpTest49(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                               
Bnd_Box aBox;                                                  
Standard_Real radius = 100;                                      
gp_Ax2 anAxis(gp_Pnt(0,0,0),gp_Dir(1,2,-5));                   
                                                               
Handle(Geom_Circle) C =                                        
    new Geom_Circle(anAxis,radius);                            
GeomAdaptor_Curve GAC (C);                                     
BndLib_Add3dCurve::Add (GAC,Precision::Approximation(),aBox);  
                                                               
Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ;       
aBox.Get(  aXmin, aYmin,aZmin, aXmax,aYmax,aZmax);             
                                                               
//==============================================================
    TCollection_AsciiString Message (" \
                                                               \n\
Bnd_Box aBox;                                                  \n\
Standard_Real radius = 100;                                    \n\
gp_Ax2 anAxis(gp_Pnt(0,0,0),gp_Dir(1,2,-5));                   \n\
                                                               \n\
Handle(Geom_Circle) C =                                        \n\
    new Geom_Circle(anAxis,radius);                            \n\
GeomAdaptor_Curve GAC (C);                                     \n\
BndLib_Add3dCurve::Add (GAC,Precision::Approximation(),aBox);  \n\
                                                               \n\
Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ;       \n\
aBox.Get(  aXmin, aYmin,aZmin, aXmax,aYmax,aZmax);             \n\
                                                               \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    DisplayCurve(aDoc,C,Quantity_NOC_BLUE1 ,false);

    DisplayPoint(aDoc,gp_Pnt(aXmin,aYmax,aZmin),Standard_CString("aXmin,aYmax,aZmin"));
    DisplayPoint(aDoc,gp_Pnt(aXmax,aYmax,aZmin),Standard_CString("aXmax,aYmax,aZmin"));
    DisplayPoint(aDoc,gp_Pnt(aXmin,aYmin,aZmin),Standard_CString("aXmin,aYmin,aZmin"));
    DisplayPoint(aDoc,gp_Pnt(aXmax,aYmin,aZmin),Standard_CString("aXmax,aYmin,aZmin"));

    DisplayPoint(aDoc,gp_Pnt(aXmin,aYmax,aZmax),Standard_CString("aXmin,aYmax,aZmax"));
    DisplayPoint(aDoc,gp_Pnt(aXmax,aYmax,aZmax),Standard_CString("aXmax,aYmax,aZmax"));
    DisplayPoint(aDoc,gp_Pnt(aXmin,aYmin,aZmax),Standard_CString("aXmin,aYmin,aZmax"));
    DisplayPoint(aDoc,gp_Pnt(aXmax,aYmin,aZmax),Standard_CString("aXmax,aYmin,aZmax"));

    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmin)) ,Quantity_NOC_RED); // X,Ymax,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmin,aZmin)) ,Quantity_NOC_RED); // X,Ymin,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmin,aYmax,aZmin)) ,Quantity_NOC_RED); // Xmin,Y,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmin)) ,Quantity_NOC_RED); // Xmax,Y,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmax),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // X,Ymax,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmax),
                                     gp_Pnt(aXmax,aYmin,aZmax)) ,Quantity_NOC_RED); // X,Ymin,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmax),
                                     gp_Pnt(aXmin,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmin,Y,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmax),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmax,Y,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmin,aYmin,aZmax)) ,Quantity_NOC_RED); // Xmin,Ymin,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmin,aZmax)) ,Quantity_NOC_RED); // Xmax,Ymin,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmin),
                                     gp_Pnt(aXmin,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmin,Ymax,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmax,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmax,Ymax,Z
/*
      Handle(AIS_Trihedron) aTrihedron;
      Handle(Geom_Axis2Placement) aTrihedronAxis=new Geom_Axis2Placement(gp::XOY());
      aTrihedron=new AIS_Trihedron(aTrihedronAxis);
      aDoc->GetAISContext()->Display(aTrihedron);
*/
    PostProcess(aDoc,ID_BUTTON_Test_49,TheDisplayType,Message.ToCString());
}

            
void GeomSources::gpTest50(CGeometryDoc* aDoc)
{
    DisplayType TheDisplayType = No2D3D;
    PreProcess(aDoc,TheDisplayType);
//==============================================================
                                                               
TColgp_Array1OfPnt array1 (1,5);                               
array1.SetValue(1,gp_Pnt (-40,00,20 ));                           
array1.SetValue(2,gp_Pnt (-70,20,20 ));                           
array1.SetValue(3,gp_Pnt (-60,30,10 ));                           
array1.SetValue(4,gp_Pnt (-40,30,-10));                           
array1.SetValue(5,gp_Pnt (-30,50,-20));                           
Handle(Geom_BSplineCurve) SPL1 =                               
      GeomAPI_PointsToBSpline(array1).Curve();                   
                                                               
TColgp_Array1OfPnt array2 (1,5);                               
array2.SetValue(1,gp_Pnt (-40,0, 20));                           
array2.SetValue(2,gp_Pnt (-20,20,0 ));                           
array2.SetValue(3,gp_Pnt (20 ,30,-10));                           
array2.SetValue(4,gp_Pnt (30 ,70,-20));                           
array2.SetValue(5,gp_Pnt (40 ,90,-10));                           
Handle(Geom_BSplineCurve) SPL2 =                               
      GeomAPI_PointsToBSpline(array2).Curve();                   
                                                               
GeomFill_FillingStyle Type = GeomFill_StretchStyle;            
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);             
Handle(Geom_BSplineSurface) aSurf = aGeomFill1.Surface();      
GeomAdaptor_Surface GAS (aSurf);                               
Bnd_Box aBox;                                                  
BndLib_AddSurface::Add (GAS,Precision::Approximation(),aBox);  
                                                               
Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ;       
aBox.Get(  aXmin, aYmin,aZmin, aXmax,aYmax,aZmax);             
                                                               
//==============================================================
    TCollection_AsciiString Message (" \
                                                               \n\
TColgp_Array1OfPnt array1 (1,5);                               \n\
array1.SetValue(1,gp_Pnt (-40,  0, 20));                           \n\
array1.SetValue(2,gp_Pnt (-70, 20, 20));                           \n\
array1.SetValue(3,gp_Pnt (-60, 30, 10));                           \n\
array1.SetValue(4,gp_Pnt (-40, 30,-10));                           \n\
array1.SetValue(5,gp_Pnt (-30, 50,-20));                           \n\
Handle(Geom_BSplineCurve) SPL1 =                               \n\
      GeomAPI_PointsToBSpline(array1).Curve();                   \n\
                                                               \n\
TColgp_Array1OfPnt array2 (1,5);                               \n\
array2.SetValue(1,gp_Pnt (-40,  0, 20));                           \n\
array2.SetValue(2,gp_Pnt (-20, 20,  0));                           \n\
array2.SetValue(3,gp_Pnt ( 20, 30,-10));                           \n\
array2.SetValue(4,gp_Pnt ( 30, 70,-20));                           \n\
array2.SetValue(5,gp_Pnt ( 40, 90,-10));                           \n\
Handle(Geom_BSplineCurve) SPL2 =                               \n\
      GeomAPI_PointsToBSpline(array2).Curve();                   \n\
                                                               \n\
GeomFill_FillingStyle Type = GeomFill_StretchStyle;            \n\
GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);             \n\
Handle(Geom_BSplineSurface) aSurf = aGeomFill1.Surface();      \n\
GeomAdaptor_Surface GAS (aSurf);                               \n\
Bnd_Box aBox;                                                  \n\
BndLib_AddSurface::Add (GAS,Precision::Approximation(),aBox);  \n\
                                                               \n\
Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ;       \n\
aBox.Get(  aXmin, aYmin,aZmin, aXmax,aYmax,aZmax);             \n\
                                                               \n");
    AddSeparator(aDoc,Message);
    //--------------------------------------------------------------

    Quantity_NameOfColor aNameOfColor= Quantity_NOC_GREEN;
    Handle(ISession_Surface) aGraphicalSurface = new ISession_Surface(aSurf);
    aDoc->GetAISContext()->SetColor(aGraphicalSurface,aNameOfColor);
    aGraphicalSurface->Attributes()->FreeBoundaryAspect()->SetColor(aNameOfColor);
    aGraphicalSurface->Attributes()->UIsoAspect()->SetColor(aNameOfColor);
    aGraphicalSurface->Attributes()->VIsoAspect()->SetColor(aNameOfColor);

    aDoc->GetAISContext()->SetDisplayMode(aGraphicalSurface,1);
    aDoc->GetAISContext()->Display(aGraphicalSurface,false);
    //   DisplaySurface(aDoc,aSurf,Quantity_NOC_GREEN);

    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmin)) ,Quantity_NOC_RED); // X,Ymax,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmin,aZmin)) ,Quantity_NOC_RED); // X,Ymin,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmin,aYmax,aZmin)) ,Quantity_NOC_RED); // Xmin,Y,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmin)) ,Quantity_NOC_RED); // Xmax,Y,ZMin
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmax),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // X,Ymax,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmax),
                                     gp_Pnt(aXmax,aYmin,aZmax)) ,Quantity_NOC_RED); // X,Ymin,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmax),
                                     gp_Pnt(aXmin,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmin,Y,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmax),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmax,Y,ZMax
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmin,aZmin),
                                     gp_Pnt(aXmin,aYmin,aZmax)) ,Quantity_NOC_RED); // Xmin,Ymin,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmin,aZmin),
                                     gp_Pnt(aXmax,aYmin,aZmax)) ,Quantity_NOC_RED); // Xmax,Ymin,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmin,aYmax,aZmin),
                                     gp_Pnt(aXmin,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmin,Ymax,Z
    DisplayCurve(aDoc,GC_MakeSegment(gp_Pnt(aXmax,aYmax,aZmin),
                                     gp_Pnt(aXmax,aYmax,aZmax)) ,Quantity_NOC_RED); // Xmax,Ymax,Z
/*
      Handle(AIS_Trihedron) aTrihedron;
      Handle(Geom_Axis2Placement) aTrihedronAxis=new Geom_Axis2Placement(gp::XOY());
      aTrihedron=new AIS_Trihedron(aTrihedronAxis);
      aDoc->GetAISContext()->Display(aTrihedron);
*/
    PostProcess(aDoc,ID_BUTTON_Test_50,TheDisplayType,Message.ToCString());
}



Generated by  Doxygen 1.6.0   Back to index