diff --git a/.gitignore b/.gitignore index 5c04544c31..63daa70aeb 100644 --- a/.gitignore +++ b/.gitignore @@ -15,6 +15,12 @@ win32 win64 +# standard names of directories for objects and binaries for samples +bin +obj +Debug +Release + # project files and artifacts /adm/msvc /adm/wnt @@ -23,6 +29,7 @@ win64 /adm/make /adm/cmake *.vcproj*user +*.csproj*user *.ncb *.suo *.sdf diff --git a/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj b/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj index aba0eca726..b4385ec57d 100644 --- a/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj +++ b/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Geometry.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -155,7 +155,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Geometry.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -198,7 +198,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Geometry.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -242,7 +242,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../..\win64\vc10\bind/Geometry.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -457,24 +457,6 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - true - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - true - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -599,14 +581,13 @@ - + - @@ -614,7 +595,7 @@ - + diff --git a/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj.filters b/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj.filters index ac4ea16e81..812b3b1160 100644 --- a/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj.filters +++ b/samples/mfc/standard/01_Geometry/adm/win/vc10/Geometry.vcxproj.filters @@ -54,9 +54,6 @@ Source Files\ISession2d - - Source Files\ISession2d - Source Files\ISession2d @@ -88,7 +85,7 @@ Header Files - + Header Files @@ -109,9 +106,6 @@ Header Files - - Header Files - Header Files @@ -133,7 +127,7 @@ Header Files - + Header Files diff --git a/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj b/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj index 84f33ebed4..368497488d 100644 --- a/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj +++ b/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Geometry.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -159,7 +159,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Geometry.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -202,7 +202,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Geometry.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -246,7 +246,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKMesh.lib;%(AdditionalDependencies) ../../../..\win64\vc11\bind/Geometry.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -461,24 +461,6 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - true - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - true - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -603,14 +585,13 @@ - + - @@ -618,7 +599,7 @@ - + diff --git a/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj.filters b/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj.filters index ac4ea16e81..812b3b1160 100644 --- a/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj.filters +++ b/samples/mfc/standard/01_Geometry/adm/win/vc11/Geometry.vcxproj.filters @@ -54,9 +54,6 @@ Source Files\ISession2d - - Source Files\ISession2d - Source Files\ISession2d @@ -88,7 +85,7 @@ Header Files - + Header Files @@ -109,9 +106,6 @@ Header Files - - Header Files - Header Files @@ -133,7 +127,7 @@ Header Files - + Header Files diff --git a/samples/mfc/standard/01_Geometry/adm/win/vc8/Geometry.vcproj b/samples/mfc/standard/01_Geometry/adm/win/vc8/Geometry.vcproj index 2bb157a274..234bba341a 100644 --- a/samples/mfc/standard/01_Geometry/adm/win/vc8/Geometry.vcproj +++ b/samples/mfc/standard/01_Geometry/adm/win/vc8/Geometry.vcproj @@ -81,7 +81,7 @@ /> - - - - - - - - - - - - - - @@ -1350,7 +1302,7 @@ > - - @@ -1410,7 +1358,7 @@ > - - - - - - - - - - - - - - @@ -1347,7 +1299,7 @@ > - - @@ -1407,7 +1355,7 @@ > GetFirstDocTemplatePosition(); - CDocTemplate* DocT=AfxGetApp()->GetNextDocTemplate(pos); - POSITION p=DocT->GetFirstDocPosition(); - DocT->GetNextDoc(p); - if(p==NULL) - nCmdShow = SW_SHOWMAXIMIZED; -*/ - CMDIChildWnd::ActivateFrame(nCmdShow); + // TODO: Add your specialized code here and/or call the base class + + static BOOL first=true; + if(first){ + first=false; + CMDIChildWnd::ActivateFrame(SW_SHOWMAXIMIZED); + return; + } + /* + POSITION pos=AfxGetApp()->GetFirstDocTemplatePosition(); + CDocTemplate* DocT=AfxGetApp()->GetNextDocTemplate(pos); + POSITION p=DocT->GetFirstDocPosition(); + DocT->GetNextDoc(p); + if(p==NULL) + nCmdShow = SW_SHOWMAXIMIZED; + */ + CMDIChildWnd::ActivateFrame(nCmdShow); } int CChildFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) { - if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1) - return -1; - - if (!m_wndToolBar.Create(this) || !m_wndToolBar.LoadToolBar(IDR_3dCHILDFRAME)) - { - TRACE0("Failed to create toolbar\n"); - return -1; // fail to create - } + if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1) + return -1; - m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); - m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); - EnableDocking(CBRS_ALIGN_ANY); - DockControlBar(&m_wndToolBar); + if (!m_wndToolBar.Create(this) || !m_wndToolBar.LoadToolBar(IDR_3dCHILDFRAME)) + { + TRACE0("Failed to create toolbar\n"); + return -1; // fail to create + } - return 0; + m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); + EnableDocking(CBRS_ALIGN_ANY); + DockControlBar(&m_wndToolBar); + + return 0; } - - BOOL CChildFrame::DestroyWindow() { - // TODO: Add your specialized code here and/or call the base class - - return CMDIChildWnd::DestroyWindow(); + // TODO: Add your specialized code here and/or call the base class + + return CMDIChildWnd::DestroyWindow(); } diff --git a/samples/mfc/standard/01_Geometry/src/ChildFrm.h b/samples/mfc/standard/01_Geometry/src/ChildFrm.h index 596852c081..85b38d511c 100755 --- a/samples/mfc/standard/01_Geometry/src/ChildFrm.h +++ b/samples/mfc/standard/01_Geometry/src/ChildFrm.h @@ -8,32 +8,32 @@ class CChildFrame : public OCC_BaseChildFrame { - DECLARE_DYNCREATE(CChildFrame) + DECLARE_DYNCREATE(CChildFrame) public: - CChildFrame(); + CChildFrame(); -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CChildFrame) - public: - virtual void ActivateFrame(int nCmdShow = -1); - virtual BOOL DestroyWindow(); - //}}AFX_VIRTUAL - -// Implementation + // Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CChildFrame) public: - virtual ~CChildFrame(); + virtual void ActivateFrame(int nCmdShow = -1); + virtual BOOL DestroyWindow(); + //}}AFX_VIRTUAL + + // Implementation +public: + virtual ~CChildFrame(); #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif -// Generated message map functions + // Generated message map functions protected: - //{{AFX_MSG(CChildFrame) - afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //{{AFX_MSG(CChildFrame) + afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/01_Geometry/src/ChildFrm2d.cpp b/samples/mfc/standard/01_Geometry/src/ChildFrm2d.cpp index 16b773dfa1..a26eecba61 100755 --- a/samples/mfc/standard/01_Geometry/src/ChildFrm2d.cpp +++ b/samples/mfc/standard/01_Geometry/src/ChildFrm2d.cpp @@ -1,25 +1,23 @@ // ChildFrm2D.cpp : implementation of the CChildFrame2D class/ #include "stdafx.h" - #include "ChildFrm2d.h" - #include "GeometryApp.h" IMPLEMENT_DYNCREATE(CChildFrame2D, CMDIChildWnd) BEGIN_MESSAGE_MAP(CChildFrame2D, CMDIChildWnd) - //{{AFX_MSG_MAP(CChildFrame2D) - ON_WM_CREATE() - //}}AFX_MSG_MAP + //{{AFX_MSG_MAP(CChildFrame2D) + ON_WM_CREATE() + //}}AFX_MSG_MAP END_MESSAGE_MAP() static UINT indicators[] = { - ID_SEPARATOR, // status line indicator - ID_INDICATOR_CAPS, - ID_INDICATOR_NUM, - ID_INDICATOR_SCRL, + ID_SEPARATOR, // status line indicator + ID_INDICATOR_CAPS, + ID_INDICATOR_NUM, + ID_INDICATOR_SCRL, }; @@ -28,8 +26,8 @@ static UINT indicators[] = CChildFrame2D::CChildFrame2D() { - // TODO: add member initialization code here - + // TODO: add member initialization code here + } CChildFrame2D::~CChildFrame2D() @@ -42,12 +40,12 @@ CChildFrame2D::~CChildFrame2D() #ifdef _DEBUG void CChildFrame2D::AssertValid() const { - CMDIChildWnd::AssertValid(); + CMDIChildWnd::AssertValid(); } void CChildFrame2D::Dump(CDumpContext& dc) const { - CMDIChildWnd::Dump(dc); + CMDIChildWnd::Dump(dc); } #endif //_DEBUG @@ -57,35 +55,35 @@ void CChildFrame2D::Dump(CDumpContext& dc) const int CChildFrame2D::OnCreate(LPCREATESTRUCT lpCreateStruct) { - - if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1) - return -1; - - if (!m_wndToolBar.Create(this) || - !m_wndToolBar.LoadToolBar(IDR_2dCHILDFRAME)) - { - TRACE0("Failed to create toolbar\n"); - return -1; // fail to create - } - // TODO: Remove this if you don't want tool tips or a resizeable toolbar - m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | - CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1) + return -1; - // TODO: Delete these three lines if you don't want the toolbar to - // be dockable - m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); - EnableDocking(CBRS_ALIGN_ANY); - DockControlBar(&m_wndToolBar); - - return 0; + if (!m_wndToolBar.Create(this) || + !m_wndToolBar.LoadToolBar(IDR_2dCHILDFRAME)) + { + TRACE0("Failed to create toolbar\n"); + return -1; // fail to create + } + + // TODO: Remove this if you don't want tool tips or a resizeable toolbar + m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | + CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + + // TODO: Delete these three lines if you don't want the toolbar to + // be dockable + m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); + EnableDocking(CBRS_ALIGN_ANY); + DockControlBar(&m_wndToolBar); + + return 0; } void CChildFrame2D::ActivateFrame(int nCmdShow) { - // TODO: Add your specialized code here and/or call the base class - - CMDIChildWnd::ActivateFrame(nCmdShow); + // TODO: Add your specialized code here and/or call the base class + + CMDIChildWnd::ActivateFrame(nCmdShow); } diff --git a/samples/mfc/standard/01_Geometry/src/ChildFrm2d.h b/samples/mfc/standard/01_Geometry/src/ChildFrm2d.h index 2cf26c62bc..525912f9fc 100755 --- a/samples/mfc/standard/01_Geometry/src/ChildFrm2d.h +++ b/samples/mfc/standard/01_Geometry/src/ChildFrm2d.h @@ -8,38 +8,38 @@ class CChildFrame2D : public OCC_BaseChildFrame { - DECLARE_DYNCREATE(CChildFrame2D) + DECLARE_DYNCREATE(CChildFrame2D) public: - CChildFrame2D(); + CChildFrame2D(); -// Attributes + // Attributes public: -// Operations + // Operations public: -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CChildFrame2D) - public: - virtual void ActivateFrame(int nCmdShow = -1); - //}}AFX_VIRTUAL - -// Implementation + // Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CChildFrame2D) public: - virtual ~CChildFrame2D(); + virtual void ActivateFrame(int nCmdShow = -1); + //}}AFX_VIRTUAL + + // Implementation +public: + virtual ~CChildFrame2D(); #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif -// Generated message map functions + // Generated message map functions protected: - //CToolBar m_wndToolBar; - //{{AFX_MSG(CChildFrame2D) - afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //CToolBar m_wndToolBar; + //{{AFX_MSG(CChildFrame2D) + afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.cxx b/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.cxx index 48dd6c4115..a7e3552638 100755 --- a/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.cxx +++ b/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.cxx @@ -34,7 +34,7 @@ //============================================================================= GeoAlgo_Sol::GeoAlgo_Sol():myIsDone(Standard_False) { - + } @@ -115,7 +115,6 @@ void GeoAlgo_Sol::Build(const TColgp_SequenceOfXYZ& seqOfXYZ) //============================================================================= Handle(Geom_BSplineSurface) GeoAlgo_Sol::Surface() const { - return myGround; } @@ -139,15 +138,15 @@ Standard_Boolean GeoAlgo_Sol::IsDone() const //============================================================================= Handle(Geom_BSplineSurface) GeoAlgo_Sol::Read(const Standard_CString aGroundName) { -// This methods read a file of points ans build a surface using plate algorithm + // This methods read a file of points ans build a surface using plate algorithm myIsDone = Standard_True; Standard_Integer nbPnt=0; -// Read points from the file + // Read points from the file filebuf fic; istream in(&fic); - + if (!fic.open(aGroundName,ios::in)){ cout << " impossible to open a file : "<> x && in >> y && in >> z){ - pntXYZ.SetX(x); - pntXYZ.SetY(y); - pntXYZ.SetZ(z); + pntXYZ.SetX(x); + pntXYZ.SetY(y); + pntXYZ.SetZ(z); nbPnt++; seqOfXYZ.Append(pntXYZ); } @@ -169,12 +168,4 @@ Handle(Geom_BSplineSurface) GeoAlgo_Sol::Read(const Standard_CString aGroundName fic.close(); Build(seqOfXYZ); return myGround; - } - - - - - - - diff --git a/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.hxx b/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.hxx index b14e8f5d7c..334300e8c6 100755 --- a/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.hxx +++ b/samples/mfc/standard/01_Geometry/src/GeoAlgo_Sol.hxx @@ -33,32 +33,19 @@ class Geom_BSplineSurface; #include #endif -class GeoAlgo_Sol { +class GeoAlgo_Sol +{ public: // Methods PUBLIC // -Standard_EXPORT GeoAlgo_Sol(); -Standard_EXPORT GeoAlgo_Sol(const Standard_CString aGroundName); -Standard_EXPORT void Build(const Standard_CString aGroundName) ; -Standard_EXPORT void Build(const TColgp_SequenceOfXYZ& aSeqofPoints) ; -Standard_EXPORT Handle_Geom_BSplineSurface Surface() const; -Standard_EXPORT Standard_Boolean IsDone() const; - - - - - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - + Standard_EXPORT GeoAlgo_Sol(); + Standard_EXPORT GeoAlgo_Sol(const Standard_CString aGroundName); + Standard_EXPORT void Build(const Standard_CString aGroundName) ; + Standard_EXPORT void Build(const TColgp_SequenceOfXYZ& aSeqofPoints) ; + Standard_EXPORT Handle_Geom_BSplineSurface Surface() const; + Standard_EXPORT Standard_Boolean IsDone() const; private: @@ -66,14 +53,11 @@ private: // Standard_EXPORT Handle_Geom_BSplineSurface Read(const Standard_CString aGroundName) ; - - // Fields PRIVATE // Handle_Geom_BSplineSurface myGround; Standard_Boolean myIsDone; - }; diff --git a/samples/mfc/standard/01_Geometry/src/GeomSources.cpp b/samples/mfc/standard/01_Geometry/src/GeomSources.cpp index 12b8f81b01..6ac43ba82b 100755 --- a/samples/mfc/standard/01_Geometry/src/GeomSources.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeomSources.cpp @@ -6,7 +6,6 @@ #include "GeomSources.h" #include "GeometryApp.h" #include "MainFrm.h" -//#include "Geom_Axis2Placement.hxx" GeomSources::GeomSources() { @@ -15,47 +14,43 @@ GeomSources::GeomSources() GeomSources::~GeomSources() { } - - void GeomSources::PreProcess(CGeometryDoc* aDoc,DisplayType aDisplayType) { - if (aDisplayType == No2D3D ) - { - aDoc->GetAISContext()->EraseAll(Standard_False); - aDoc->Put3DOnTop(); - } + if (aDisplayType == No2D3D ) + { + aDoc->GetAISContext()->EraseAll(Standard_False); + aDoc->Put3DOnTop(); + } - if (aDisplayType == a2DNo3D) - { - aDoc->GetISessionContext()->EraseAll(); - aDoc->Put2DOnTop(); - } + if (aDisplayType == a2DNo3D) + { + aDoc->GetISessionContext()->EraseAll(); + aDoc->Put2DOnTop(); + } - if (aDisplayType != No2D3D && aDisplayType != a2D3D) - { - aDoc->Minimize3D(); - } + if (aDisplayType != No2D3D && aDisplayType != a2D3D) + { + aDoc->Minimize3D(); + } - if (aDisplayType != a2DNo3D && aDisplayType != a2D3D) - { - aDoc->Minimize2D(); - } + if (aDisplayType != a2DNo3D && aDisplayType != a2D3D) + { + aDoc->Minimize2D(); + } - if (aDisplayType == a2D3D) - { - aDoc->GetAISContext()->EraseAll(Standard_False); - aDoc->GetISessionContext()->EraseAll(); - aDoc->Put3DOnTop(false); - aDoc->Put2DOnTop(false); + 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(); + // 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); + } } void GeomSources::PostProcess(CGeometryDoc* aDoc, @@ -65,52 +60,48 @@ void GeomSources::PostProcess(CGeometryDoc* aDoc, Quantity_Coefficient Coef /* = -1 */ /* double Zoom = -1 */) { - if (aDisplayType == No2D3D || aDisplayType == a2D3D) - { - aDoc->Fit3DViews(Coef); - //if (Zoom != -1) aDoc->Set3DViewsZoom(Zoom); - } + if (aDisplayType == No2D3D || aDisplayType == a2D3D) + { + aDoc->Fit3DViews(Coef); + } - 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); - } + if (aDisplayType == a2DNo3D || aDisplayType == a2D3D) + { + aDoc->Fit2DViews(); + } - TCollection_AsciiString Message("Results are "); + TCollection_AsciiString Message("Results are "); switch (aDisplayType) { - case No2DNo3D: Message = "All results are in this box \n"; + case No2DNo3D: Message = "All results are in this box \n"; break; - case No2D3D: Message += "only in 3D \n"; + case No2D3D: Message += "only in 3D \n"; break; - case a2DNo3D: Message += "only in 2d \n"; + case a2DNo3D: Message += "only in 2d \n"; break; - case a2D3D: Message += "in both 2D and 3D \n"; + 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); + } + Message += "====================================\n"; + Message += aString; - CString text(Message.ToCString()); - aDoc->myCResultDialog.SetText(text); + CString text(Message.ToCString()); + aDoc->myCResultDialog.SetText(text); - CString s; - if (! s.LoadString( anID )) - AfxMessageBox("Error Loading String: "); + CString s; + if (! s.LoadString( anID )) + AfxMessageBox("Error Loading String: "); - CString Title = s.Left( s.Find( '\n' )); + CString Title = s.Left( s.Find( '\n' )); - aDoc->myCResultDialog.SetTitle(Title); - aDoc->SetTitle(Title); + aDoc->myCResultDialog.SetTitle(Title); + aDoc->SetTitle(Title); } void GeomSources::AddSeparator(CGeometryDoc* aDoc,TCollection_AsciiString& aMessage) { - aMessage+= "------------------------------------------------------------------------\n"; + aMessage+= "------------------------------------------------------------------------\n"; } void GeomSources::DisplayPoint(CGeometryDoc* aDoc, gp_Pnt2d& aPoint, @@ -120,11 +111,11 @@ void GeomSources::DisplayPoint(CGeometryDoc* aDoc, 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); + 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, @@ -136,11 +127,11 @@ void GeomSources::DisplayPoint(CGeometryDoc* aDoc, 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); + 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, @@ -148,9 +139,9 @@ void GeomSources::DisplayCurve(CGeometryDoc* aDoc, Standard_Integer aColorIndex, Standard_Boolean UpdateViewer) { - Handle(ISession2D_Curve) aGraphicCurve = new ISession2D_Curve(aCurve); - aGraphicCurve->SetColorIndex(aColorIndex) ; - aDoc->GetISessionContext()->Display(aGraphicCurve,UpdateViewer); + Handle(ISession2D_Curve) aGraphicCurve = new ISession2D_Curve(aCurve); + aGraphicCurve->SetColorIndex(aColorIndex) ; + aDoc->GetISessionContext()->Display(aGraphicCurve,UpdateViewer); } void GeomSources::DisplayCurveAndCurvature(CGeometryDoc* aDoc, @@ -158,11 +149,11 @@ void GeomSources::DisplayCurveAndCurvature(CGeometryDoc* aDoc, 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); + 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, @@ -170,10 +161,10 @@ void GeomSources::DisplayCurve(CGeometryDoc* aDoc, 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); + 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, @@ -192,20 +183,20 @@ void GeomSources::DisplaySurface(CGeometryDoc* aDoc, 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); + 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); + Handle(ISession_Surface) aGraphicalSurface = new ISession_Surface(aSurface); + aDoc->GetAISContext()->Display(aGraphicalSurface,UpdateViewer); } // Function name : GeomSources::gpTest1 @@ -216,34 +207,33 @@ 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); + //============================================================== + + 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 ("\ + 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); + 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); + TCollection_AsciiString Message2 (result); - Message+= " result = "; - Message+= Message2; - - PostProcess(aDoc,ID_BUTTON_Test_1,TheDisplayType,Message.ToCString()); + Message+= " result = "; + Message+= Message2; + PostProcess(aDoc,ID_BUTTON_Test_1,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest2 @@ -256,17 +246,17 @@ void GeomSources::gpTest2(CGeometryDoc* aDoc) PreProcess(aDoc,TheDisplayType); //============================================================== -gp_Pnt P1(1,2,3); + gp_Pnt P1(1,2,3); //============================================================== -TCollection_AsciiString Message ("\ + TCollection_AsciiString Message ("\ \n\ gp_Pnt P1(1,2,3); \n\ \n"); -AddSeparator(aDoc,Message); + AddSeparator(aDoc,Message); //-------------------------------------------------------------- -DisplayPoint(aDoc,P1,"P1 (1,2,3)",false,0.5); -PostProcess(aDoc,ID_BUTTON_Test_2,TheDisplayType,Message.ToCString(),1.0); + DisplayPoint(aDoc,P1,"P1 (1,2,3)",false,0.5); + PostProcess(aDoc,ID_BUTTON_Test_2,TheDisplayType,Message.ToCString(),1.0); } @@ -276,24 +266,23 @@ PostProcess(aDoc,ID_BUTTON_Test_2,TheDisplayType,Message.ToCString(),1.0); // Argument : CGeometryDoc* aDoc void GeomSources::gpTest3(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); + DisplayType TheDisplayType = No2D3D; + PreProcess(aDoc,TheDisplayType); //============================================================== -gp_XYZ A(1,2,3); -gp_Pnt P2(A); + gp_XYZ A(1,2,3); + gp_Pnt P2(A); //============================================================== - TCollection_AsciiString Message ("\ + TCollection_AsciiString Message ("\ \n\ gp_XYZ A(1,2,3); \n\ gp_Pnt P2(A); \n\ \n"); -AddSeparator(aDoc,Message); + 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*/); + DisplayPoint(aDoc,P2,"P2 (1,2,3)",false,0.5); + PostProcess(aDoc,ID_BUTTON_Test_3,TheDisplayType,Message.ToCString(),1.0 /*0.02*/); } @@ -303,14 +292,14 @@ PostProcess(aDoc,ID_BUTTON_Test_3,TheDisplayType,Message.ToCString(),1.0 /*0.02* // Argument : CGeometryDoc* aDoc void GeomSources::gpTest4(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); + 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(); + gp_Pnt P3 = gp::Origin(); + Standard_Real TheX = P3.X(); + Standard_Real TheY = P3.Y(); + Standard_Real TheZ = P3.Z(); //============================================================== @@ -321,23 +310,23 @@ Standard_Real TheX = P3.X(); \n\ Standard_Real TheY = P3.Y(); \n\ Standard_Real TheZ = P3.Z(); \n\ \n"); -AddSeparator(aDoc,Message); + AddSeparator(aDoc,Message); //-------------------------------------------------------------- -DisplayPoint(aDoc,P3,"P3 = gp::Origin()",false,0.5); + 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; + TCollection_AsciiString Message2 (TheX); + TCollection_AsciiString Message3 (TheY); + TCollection_AsciiString Message4 (TheZ); -PostProcess(aDoc,ID_BUTTON_Test_4,TheDisplayType,Message.ToCString(),1.0 /*0.02*/); + 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*/); } @@ -347,19 +336,19 @@ PostProcess(aDoc,ID_BUTTON_Test_4,TheDisplayType,Message.ToCString(),1.0 /*0.02* // Argument : CGeometryDoc* aDoc void GeomSources::gpTest5(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); + 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); + 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 ("\ + TCollection_AsciiString Message ("\ \n\ gp_Pnt P1(1,2,3); \n\ gp_Pnt P2(3,4,5); \n\ @@ -369,27 +358,25 @@ Standard_Real beta = 7; \n\ PB.BaryCenter(alpha,P2,beta); \n\ \n"); - AddSeparator(aDoc,Message); + 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); + 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()); + 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()); + Message += " PB ( "; + Message += Message2; + Message += " , "; + Message += Message3; + Message += " , "; + Message += Message4; + Message += " ); "; + PostProcess(aDoc,ID_BUTTON_Test_5,TheDisplayType,Message.ToCString()); } @@ -399,43 +386,45 @@ PB.BaryCenter(alpha,P2,beta); \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest6(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); + 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; + 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); -if (PE.IsPoint()){ - IsPoint = true; + 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; - } + } + else + { + IsPoint = false; + } -if (PE.IsLinear()){ /*... */ } -if (PE.IsPlanar()){ /*... */ } -if (PE.IsSpace()) { /*... */ } + if (PE.IsLinear()){ /*... */ } + if (PE.IsPlanar()){ /*... */ } + if (PE.IsSpace()) { /*... */ } //============================================================== - TCollection_AsciiString Message ("\ + TCollection_AsciiString Message ("\ \n\ \n\ // Compute a 3d point P as BaryCenter of an array of point \n\ @@ -463,39 +452,55 @@ if (PE.IsLinear()){ /*... */ } \n\ if (PE.IsPlanar()){ /*... */ } \n\ if (PE.IsSpace()) { /*... */ } \n\ \n"); - AddSeparator(aDoc,Message); + AddSeparator(aDoc,Message); //-------------------------------------------------------------- - TCollection_AsciiString PointName("P"); + 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); - } + { + 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()); + 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 += " 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"; + 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()); } @@ -506,29 +511,29 @@ if (PE.IsSpace()) { /*... */ } \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest7(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = a2DNo3D; - PreProcess(aDoc,TheDisplayType); + 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 = + 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 + 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); + gp_Pnt2d P; + gp_Vec2d V; + C->D1(param,P,V); // we recover point P and the vector V //============================================================== - TCollection_AsciiString Message ("\ + TCollection_AsciiString Message ("\ \n\ \n\ gp_Pnt2d P1(0,5); \n\ @@ -549,17 +554,16 @@ gp_Vec2d V; \n\ C->D1(param,P,V); \n\ // we recover point P and the vector V \n\ \n"); + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + DisplayCurve(aDoc,C); + Handle(ISession_Direction) aDirection = new ISession_Direction(P,V); + aDoc->GetISessionContext()->Display(aDirection, Standard_False); - 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); - DisplayPoint(aDoc,P,"P",false,0.5); - - PostProcess(aDoc,ID_BUTTON_Test_7,TheDisplayType,Message.ToCString()); + PostProcess(aDoc,ID_BUTTON_Test_7,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest8 @@ -568,22 +572,22 @@ C->D1(param,P,V); \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest8(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = a2DNo3D; - PreProcess(aDoc,TheDisplayType); + DisplayType TheDisplayType = a2DNo3D; + PreProcess(aDoc,TheDisplayType); //============================================================== -Standard_Real radius = 5; -Handle(Geom2d_Circle) C = + Standard_Real radius = 5; + Handle(Geom2d_Circle) C = new Geom2d_Circle(gp::OX2d(),radius); -Standard_Real param = 1.2*M_PI; -Geom2dLProp_CLProps2d CLP + Standard_Real param = 1.2*M_PI; + Geom2dLProp_CLProps2d CLP (C,param,2,Precision::PConfusion()); - gp_Dir2d D; -CLP.Tangent(D); + gp_Dir2d D; + CLP.Tangent(D); // D is the Tangent direction at parameter 1.2*PI //============================================================== - TCollection_AsciiString Message (" \ + TCollection_AsciiString Message (" \ \n\ Standard_Real radius = 5; \n\ Handle(Geom2d_Circle) C = \n\ @@ -595,53 +599,50 @@ Geom2dLProp_CLProps2d CLP \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()); - + 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); - - Message += " D ( "; - Message += Message2; Message += " , "; - Message += Message3; Message += " ); \n"; + TCollection_AsciiString Message2 (D.X()); + TCollection_AsciiString Message3 (D.Y()); - PostProcess(aDoc,ID_BUTTON_Test_8,TheDisplayType,Message.ToCString()); + 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); - //============================================================== + DisplayType TheDisplayType = a2DNo3D; + PreProcess(aDoc,TheDisplayType); + + //============================================================== -Standard_Real radius = 5; -Handle(Geom2d_Circle) C = + Standard_Real radius = 5; + Handle(Geom2d_Circle) C = new Geom2d_Circle(gp::OX2d(),radius); -Geom2dAdaptor_Curve GAC (C); -Standard_Real startparam = 10*M_PI/180; -Standard_Real abscissa = 45*M_PI/180; -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\ + Geom2dAdaptor_Curve GAC (C); + Standard_Real startparam = 10*M_PI/180; + Standard_Real abscissa = 45*M_PI/180; + 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\ @@ -659,66 +660,64 @@ 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); + 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()); - + DisplayPoint(aDoc,P1,"P1"); + if (AP.IsDone()) DisplayPoint(aDoc,P2,"P2"); - Message += " P1 ( "; - Message += Message2; Message += " , "; - Message += Message3; Message += " ); \n"; + TCollection_AsciiString Message2 (P1.X()); + TCollection_AsciiString Message3 (P1.Y()); - Message += " P2 ( "; - Message += Message4; Message += " , "; - Message += Message5; Message += " ); \n"; - PostProcess(aDoc,ID_BUTTON_Test_9,TheDisplayType,Message.ToCString()); + 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); -//============================================================== + 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()) + 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 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(); + } + Standard_Real Abscissa = UA.Abscissa(); -//============================================================== - TCollection_AsciiString Message (" \ + //============================================================== + TCollection_AsciiString Message (" \ \n\ gp_Pnt2d P; \n\ Standard_Real radius = 5; \n\ @@ -742,56 +741,58 @@ if (UA.IsDone()) \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); + 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)); + TCollection_AsciiString aString; + for (Standard_Integer i=1;i<= aSequence.Length();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() ); + TCollection_AsciiString Message2 (i); + TCollection_AsciiString Message3 (UA.Parameter(i)); - DisplayPoint(aDoc,aSequence(i),aString.ToCString(),false,0.5,YOffset,0.04); - } - - TCollection_AsciiString Message3 (Abscissa); + aString = "P"; + aString += Message2; + aString +=": Parameter : "; + aString += Message3; - Message += "Abscissa = "; Message += Message3; Message += " \n"; - PostProcess(aDoc,ID_BUTTON_Test_10,TheDisplayType,Message.ToCString()); + // 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); - + 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\ @@ -802,51 +803,52 @@ Standard_Real u = 2; \n\ Standard_Real v = 3; \n\ gp_Pnt P = SP->Value(u,v); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplaySurface(aDoc,SP); - DisplayPoint(aDoc,P,"P",false,0.5); - TCollection_AsciiString Message2 (P.X()); - TCollection_AsciiString Message3 (P.Y()); + 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"; - Message += " P ( "; - Message += Message2; - Message += " , "; - Message += Message3; - Message += " ); \n"; - PostProcess(aDoc,ID_BUTTON_Test_11,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -866,37 +868,36 @@ if(NbResults>0){ \n\ AddSeparator(aDoc,Message); //-------------------------------------------------------------- - TCollection_AsciiString aString; + TCollection_AsciiString aString; - DisplayPoint(aDoc,P,"P",false,0.5); - - TCollection_AsciiString Message2 (PPC.LowerDistance()); + DisplayPoint(aDoc,P,"P",false,0.5); - aString = "N : at Distance : "; - aString += Message2; - - DisplayPoint(aDoc,N,aString.ToCString(),false,0.5,0,-0.5); + TCollection_AsciiString Message2 (PPC.LowerDistance()); - DisplayCurve(aDoc,C,false); + aString = "N : at Distance : "; + aString += Message2; - 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); + DisplayPoint(aDoc,N,aString.ToCString(),false,0.5,0,-0.5); + DisplayCurve(aDoc,C,false); - aString = "Q"; - aString += Message3; - aString +=": at Distance : "; - aString += Message4; - DisplayPoint(aDoc,Q,aString.ToCString(),false,0.5); - } - } + 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); - PostProcess(aDoc,ID_BUTTON_Test_12,TheDisplayType,Message.ToCString()); + 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 @@ -905,26 +906,29 @@ if(NbResults>0){ \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest13(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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 + } + } -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\ @@ -942,43 +946,42 @@ if(NbResults>0){ \n\ } \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- - TCollection_AsciiString aString; + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- + TCollection_AsciiString aString; - DisplayPoint(aDoc,P,"P",false,0.5); - TCollection_AsciiString Message2 (PPS.LowerDistance()); + 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); + 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++) + { - 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); + Q = PPS.Point(i); + distance = PPS.Distance(i); + TCollection_AsciiString Message3 (i); + TCollection_AsciiString Message4 (distance); - 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; - 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()); + DisplayPoint(aDoc,Q,aString.ToCString(),false,0.5); + } + } + PostProcess(aDoc,ID_BUTTON_Test_13,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest14 @@ -987,30 +990,30 @@ if(NbResults>0){ \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest14(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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 + 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()){ + if (ICQ.IsDone()){ Standard_Integer NbResults = ICQ.NbPoints(); if (NbResults>0){ - for(Standard_Integer i = 1;i<=NbResults;i++){ + for(Standard_Integer i = 1;i<=NbResults;i++){ P = ICQ.Point(i); // do something with P here - } - } -} + } + } + } -//============================================================== - TCollection_AsciiString Message (" \ + //============================================================== + TCollection_AsciiString Message (" \ \n\ gp_Pnt P; \n\ gp_Pln PL (gp_Ax3(gp::XOY())); \n\ @@ -1029,35 +1032,37 @@ if (ICQ.IsDone()){ \n\ } \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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_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); + Handle(Geom_Ellipse) anEllips = GC_MakeEllipse(EL).Value(); + DisplayCurve(aDoc,anEllips,false); - TCollection_AsciiString aString; + 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); - } - } - } + if (ICQ.IsDone()) + { + Standard_Integer NbResults = ICQ.NbPoints(); + if (NbResults>0) + { + for(Standard_Integer i = 1;i<=NbResults;i++) + { - PostProcess(aDoc,ID_BUTTON_Test_14,TheDisplayType,Message.ToCString()); + 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 @@ -1066,18 +1071,18 @@ if (ICQ.IsDone()){ \n\ // 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); - -//============================================================== + 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\ @@ -1087,41 +1092,40 @@ gp_Trsf TRSF; \n\ TRSF.SetMirror(P2); \n\ P1Copy.Transform(TRSF); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayPoint(aDoc,P1Copy,"P1Copy",false,0.5); - DisplayPoint(aDoc,P1,"P1",false,0.5); - DisplayPoint(aDoc,P2,"P2",false,0.5); + 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()); + 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); + 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 + 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 (" \ + TCollection_AsciiString Message (" \ \n\ gp_Pnt P1(1,2,3); \n\ gp_Pnt P2(5,4,6); \n\ @@ -1135,24 +1139,24 @@ Standard_Boolean result = \n\ V1.IsOpposite(V2,Precision::Angular()); \n\ // result should be true \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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) 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); + 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"; + Message += "result = "; + if (result) Message += "True \n"; else Message += "False \n"; - PostProcess(aDoc,ID_BUTTON_Test_16,TheDisplayType,Message.ToCString()); + PostProcess(aDoc,ID_BUTTON_Test_16,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest17 @@ -1161,45 +1165,45 @@ V1.IsOpposite(V2,Precision::Angular()); \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest17(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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] -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 (" \ + //============================================================== + 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); - //-------------------------------------------------------------- + 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) 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) : "<GetAISContext()->Display(aDirection2, Standard_False); - TCollection_AsciiString Message2 (ang); - TCollection_AsciiString Message3 (ang/M_PI/180); - - Message += " ang = "; - Message += Message2; - Message += " radian \n"; - Message += " ang/PI180 = "; - Message += Message3; - Message += " degree \n"; + cout<<" D1.Angle(D2) : "<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); + 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()); + 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 @@ -1255,29 +1259,29 @@ gp_Parab2d Para(A,6); \n\ // 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 (" \ + 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\ @@ -1296,38 +1300,44 @@ Standard_Boolean IsDirectA2 = A2.Direct(); \n\ gp_Dir A2XDirection = A2.XDirection() ; \n\ gp_Dir A2YDirection = A2.YDirection() ; \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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); + 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); + 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); + 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 += "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"; + Message += "IsDirectA2 = "; + if(IsDirectA2) + Message += "True = Right Handed \n"; + else + Message += "False = Left Handed \n"; - PostProcess(aDoc,ID_BUTTON_Test_19,TheDisplayType,Message.ToCString()); + PostProcess(aDoc,ID_BUTTON_Test_19,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest20 @@ -1336,44 +1346,44 @@ gp_Dir A2YDirection = A2.YDirection() ; \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest20(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = a2DNo3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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); -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 (" \ + 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\ @@ -1397,7 +1407,7 @@ Handle(Geom2d_BSplineCurve) SPL2 = anInterpolation.Curve(); \n\ \n\ Handle(TColgp_HArray1OfPnt2d) harray2 = \n\ new TColgp_HArray1OfPnt2d (1,5); // sizing harray \n"); - Message += "\ + 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\ @@ -1408,81 +1418,85 @@ anInterpolation2.Perform(); \n\ Handle(Geom2d_BSplineCurve) SPL3 = anInterpolation2.Curve(); \n\ // redefined C++ operator allows these assignments \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- - TCollection_AsciiString aString; + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- + TCollection_AsciiString aString; Standard_Integer i; - for(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( int 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); - } + for(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( int 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 (!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 (!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); + 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); - Message += " SPL1 is Red \n"; - Message += " SPL2 is Blue \n"; - Message += " SPL3 is Yellow \n"; + 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); - PostProcess(aDoc,ID_BUTTON_Test_20,TheDisplayType,Message.ToCString()); + 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*M_PI/180); -B.SetAngle2(44*M_PI/180); -FairCurve_AnalysisCode anAnalysisCode; -B.Compute(anAnalysisCode); -Handle(Geom2d_BSplineCurve) C = B.Curve(); - -//============================================================== - TCollection_AsciiString Message (" \ + 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*M_PI/180); + B.SetAngle2(44*M_PI/180); + 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\ @@ -1494,34 +1508,35 @@ FairCurve_AnalysisCode anAnalysisCode; \n\ B.Compute(anAnalysisCode); \n\ Handle(Geom2d_BSplineCurve) C = B.Curve(); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayCurveAndCurvature(aDoc,C,6,Standard_False); + DisplayCurveAndCurvature(aDoc,C,6,Standard_False); - PostProcess(aDoc,ID_BUTTON_Test_21,TheDisplayType,Message.ToCString()); + PostProcess(aDoc,ID_BUTTON_Test_21,TheDisplayType,Message.ToCString()); } void GeomSources::gpTest22(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = a2DNo3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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*M_PI/180); -MV.SetAngle2(44*M_PI/180); - -FairCurve_AnalysisCode anAnalysisCode; -MV.Compute(anAnalysisCode); - -Handle(Geom2d_BSplineCurve) C = MV.Curve(); - -//============================================================== - TCollection_AsciiString Message (" \ + gp_Pnt2d P1(-184, 41); + gp_Pnt2d P2(20 ,24); + Standard_Real aheight = 1; + FairCurve_MinimalVariation MV (P1,P2,aheight); + MV.SetAngle1(22*M_PI/180); + MV.SetAngle2(44*M_PI/180); + + 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\ @@ -1535,42 +1550,40 @@ MV.Compute(anAnalysisCode); \n\ \n\ Handle(Geom2d_BSplineCurve) C = MV.Curve(); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayCurveAndCurvature(aDoc,C,7,Standard_False); - DisplayPoint(aDoc,P1,"P1",false,0.5); - DisplayPoint(aDoc,P2,"P2",false,0.5); + 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()); + 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 (" \ + 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\ @@ -1585,61 +1598,59 @@ Handle(Geom2d_TrimmedCurve) TC = new Geom2d_TrimmedCurve(E,-1,2); \n\ Handle(Geom2d_BSplineCurve) SPL = \n\ Geom2dConvert::CurveToBSplineCurve(TC); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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) 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); + Handle(ISession2D_Curve) aCurve2 = new ISession2D_Curve(SPL); + aDoc->GetISessionContext()->Display(aCurve2, Standard_False); - PostProcess(aDoc,ID_BUTTON_Test_23,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -1668,90 +1679,90 @@ 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); + 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); + Handle(Geom_Plane) aProjectionPlane = GC_MakePlane(ProjectionPlane).Value(); + Handle(Geom_RectangularTrimmedSurface) aProjectionPlaneSurface= + new Geom_RectangularTrimmedSurface(aProjectionPlane,-8.,8.,-12.,12.); - Standard_CString aC3DEntityTypeName = C3D->DynamicType()->Name(); - Standard_CString aC2DEntityTypeName = C2D->DynamicType()->Name(); + DisplaySurface(aDoc,aProjectionPlaneSurface); - Message += " C3D->DynamicType()->Name() = "; - Message += aC3DEntityTypeName; Message += " \n"; - Message += " C2D->DynamicType()->Name() = "; - Message += aC2DEntityTypeName; Message += " \n"; + Standard_CString aC3DEntityTypeName = C3D->DynamicType()->Name(); + Standard_CString aC2DEntityTypeName = C2D->DynamicType()->Name(); - DisplayCurve(aDoc,circ2d,4,false); - DisplayCurve(aDoc,C3D,false); - DisplayCurve(aDoc,C2D,5,false); + Message += " C3D->DynamicType()->Name() = "; + Message += aC3DEntityTypeName; Message += " \n"; + Message += " C2D->DynamicType()->Name() = "; + Message += aC2DEntityTypeName; Message += " \n"; - Handle(ISession_Direction) aC3DCircleXAxisDirection = new ISession_Direction((gp_Pnt)C3DCircleXAxis.Location(), - (gp_Dir)C3DCircleXAxis.Direction(), - 5.2); - aDoc->GetAISContext()->Display(aC3DCircleXAxisDirection, Standard_False); + DisplayCurve(aDoc,circ2d,4,false); + DisplayCurve(aDoc,C3D,false); + DisplayCurve(aDoc,C2D,5,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) aC3DCircleXAxisDirection = new ISession_Direction((gp_Pnt)C3DCircleXAxis.Location(), + (gp_Dir)C3DCircleXAxis.Direction(), + 5.2); + aDoc->GetAISContext()->Display(aC3DCircleXAxisDirection, 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); + 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()); + 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 (" \ + 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\ @@ -1781,38 +1792,38 @@ for (Standard_Integer k = 1;k<=NbPoints;k++) \n\ // do something with each intersection point \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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"; - } + 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; - PostProcess(aDoc,ID_BUTTON_Test_25,TheDisplayType,Message.ToCString()); + 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 @@ -1821,46 +1832,50 @@ for (Standard_Integer k = 1;k<=NbPoints;k++) \n\ // 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 (" \ + 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\ @@ -1895,60 +1910,66 @@ 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); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - TCollection_AsciiString aString; - for(int 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); - } + TCollection_AsciiString aString; + for(int 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); + 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); + 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(int i=1;i <= NbExtrema; i++) + { + gp_Pnt2d P1 =aSolutionArray(i,1); - for(int 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); + 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); - } + gp_Pnt2d P2 = aSolutionArray(i,2); - 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"; + Handle(Geom2d_TrimmedCurve) SolutionCurve = + GCE2d_MakeSegment(P1,P2); + Handle(ISession2D_Curve) aSolutionCurve = new ISession2D_Curve(SolutionCurve); + aDoc->GetISessionContext()->Display(aSolutionCurve, Standard_False); + } - PostProcess(aDoc,ID_BUTTON_Test_26,TheDisplayType,Message.ToCString()); + 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 @@ -1957,28 +1978,27 @@ for(int i=1;i <= NbExtrema; i++) { \n\ // 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 (" \ + 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\ @@ -1996,29 +2016,33 @@ 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); + 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"; + 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()); + PostProcess(aDoc,ID_BUTTON_Test_27,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest28 @@ -2027,34 +2051,34 @@ Standard_Boolean result2 = OC2->IsCN(2); \n\ // 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 (" \ + 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); + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-3,8); - Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aLine); - aDoc->GetISessionContext()->Display(aCurve, Standard_False); + DisplayPoint(aDoc,P1,"P1",false,0.5); + DisplayPoint(aDoc,P2,"P2",false,0.5); - PostProcess(aDoc,ID_BUTTON_Test_28,TheDisplayType,Message.ToCString()); + 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 @@ -2063,21 +2087,22 @@ gp_Lin2d L = gce_MakeLin2d(P1,P2); \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest29(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = a2DNo3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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 (" \ + 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\ @@ -2088,22 +2113,22 @@ if (B.IsDone()) \n\ L = B.ThisSolution(); \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayPoint(aDoc,P1,"P1",false,0.5); - DisplayPoint(aDoc,P2,"P2",false,0.5); + 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()) + { + 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()); + 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 @@ -2112,30 +2137,31 @@ if (B.IsDone()) \n\ // 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 (" \ + 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\ @@ -2155,81 +2181,81 @@ if (LT.IsDone()) \n\ } \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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); - 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"; + 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); - PostProcess(aDoc,ID_BUTTON_Test_30,TheDisplayType,Message.ToCString()); + 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 = "\ + 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\ @@ -2250,7 +2276,7 @@ if (TR.IsDone()) \n Standard_Integer NbSol = TR.NbSolutions(); \n\ for (Standard_Integer k=1; k<=NbSol; k++) \n\ { \n"; - Message += "\ + Message += "\ circ = TR.ThisSolution(k); \n\ // find the solution circle \n\ TR.Tangency1(k,parsol,pararg,tangentpoint1); \n\ @@ -2260,46 +2286,47 @@ if (TR.IsDone()) \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); + AddSeparator(aDoc,Message); - Handle(Geom2d_Circle) aCircle = new Geom2d_Circle(C); - Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aCircle); - aCurve->SetColorIndex(3); + //-------------------------------------------------------------- + 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); - 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); + Handle(Geom2d_Circle) aCircle = new Geom2d_Circle(C); + Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aCircle); + aCurve->SetColorIndex(3); - 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); + 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); - // 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()); + 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 @@ -2308,18 +2335,19 @@ if (TR.IsDone()) \n // 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,M_PI/4); - -//============================================================== - TCollection_AsciiString Message (" \ + 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,M_PI/4); + + //============================================================== + TCollection_AsciiString Message (" \ \n\ Standard_Real major = 12; \n\ Standard_Real minor = 4; \n\ @@ -2327,19 +2355,20 @@ 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 (M_PI); - Message += " PI = ";Message+= Message2; - PostProcess(aDoc,ID_BUTTON_Test_32,TheDisplayType,Message.ToCString()); + 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 (M_PI); + Message += " PI = ";Message+= Message2; + + PostProcess(aDoc,ID_BUTTON_Test_32,TheDisplayType,Message.ToCString()); } // Function name : GeomSources::gpTest33 @@ -2348,42 +2377,43 @@ Handle(Geom2d_TrimmedCurve) arc = GCE2d_MakeArcOfEllipse(EE,0.0,PI/4); \n\ // 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 (" \ + 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\ @@ -2405,7 +2435,7 @@ harray->SetValue(4,P4.Translated(gp_Vec(4,0,0))); harray->SetValue(5,P5.Translated(gp_Vec(4,0,0))); \n\ Handle(Geom_BSplineCurve) SPL1 = \n\ GeomAPI_PointsToBSpline(array).Curve(); \n"); - Message += "\ + Message += "\ \n\ GeomAPI_Interpolate anInterpolation(harray,Standard_False,Precision::Approximation()); \n\ anInterpolation.Perform(); \n\ @@ -2416,36 +2446,41 @@ if (anInterpolation.IsDone()) 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);\ - - } + AddSeparator(aDoc,Message); - 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()); + 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 @@ -2454,27 +2489,34 @@ else // Argument : CGeometryDoc* aDoc void GeomSources::gpTest34(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== + 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()) + {/* ... */} -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 (" \ + //============================================================== + TCollection_AsciiString Message (" \ \n\ TColgp_Array1OfPnt array (1,5); // sizing array \n\ array.SetValue(1,gp_Pnt(0,0,1)); \n\ @@ -2491,35 +2533,49 @@ 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); - } + 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); - Message += " PE.IsPoint() = "; if (PE.IsPoint()) Message += "True \n"; else Message += "False\n"; + aString = "P"; + aString += Message2; + DisplayPoint(aDoc,P,aString.ToCString(),false,0.5); + } - 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.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"; + Message += " PE.IsPlanar() = "; + if (PE.IsPlanar()) + Message += "True \n"; + else + Message += "False\n"; - PostProcess(aDoc,ID_BUTTON_Test_34,TheDisplayType,Message.ToCString()); + 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 @@ -2528,43 +2584,44 @@ if (PE.IsSpace()) { /* ... */ } \n\ // 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 (int k=1; k<=NbPoints; k++) - { - gp_Pnt aPoint=CS.Point(k); - // do something with the point - } - } - -//============================================================== - TCollection_AsciiString Message (" \ + 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 (int 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\ @@ -2597,46 +2654,47 @@ if(CS.IsDone()) \n\ } \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + + //-------------------------------------------------------------- - Handle(ISession_Curve) aCurve2 = new ISession_Curve(aCurve); - aDoc->GetAISContext()->Display(aCurve2, Standard_False); + 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); + Handle(Geom_RectangularTrimmedSurface) aTrimmedSurface= new Geom_RectangularTrimmedSurface(aSurface,-50.,50.,false); - DisplaySurface(aDoc,aTrimmedSurface); + DisplaySurface(aDoc,aTrimmedSurface); - TCollection_AsciiString aString; - Standard_Integer k; - if(CS.IsDone()) - { - Standard_Integer NbSeg = CS.NbSegments(); - for (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); + TCollection_AsciiString aString; + Standard_Integer k; + if(CS.IsDone()) + { + Standard_Integer NbSeg = CS.NbSegments(); + for (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); + } - Message += "NbSeg = "; Message += Message2 ; Message += "\n"; - Message += "NbPoints = "; Message += Message3 ; Message += "\n"; + 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); - PostProcess(aDoc,ID_BUTTON_Test_35,TheDisplayType,Message.ToCString()); + Message += "NbSeg = "; Message += Message2 ; Message += "\n"; + Message += "NbPoints = "; Message += Message3 ; Message += "\n"; + + PostProcess(aDoc,ID_BUTTON_Test_35,TheDisplayType,Message.ToCString()); } //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ @@ -2647,38 +2705,38 @@ if(CS.IsDone()) \n\ // Argument : CGeometryDoc* aDoc void GeomSources::gpTest36(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); + 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(),M_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(); - + + 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(),M_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\ @@ -2711,50 +2769,48 @@ Standard_CString aTranslatedEntityTypeName = aTranslatedEntity->DynamicType()->N gp_Mat matrix = TR.HVectorialPart(); \n\ Standard_Real value = matrix.Determinant(); \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayPoint(aDoc,centre,"centre",false,0.5); - DisplayPoint(aDoc,axispoint,"axispoint",false,0.5); - DisplayPoint(aDoc,scalepoint,"scalepoint",false,0.5); + 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); + 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 (M_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 Message0 (M_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); + 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"; - Message += " aRotatedEntityTypeName = ";Message+= Message6; Message += "\n"; - Message += " aMirroredEntityTypeName = ";Message+= Message7; Message += "\n"; - Message += " aScaledEntityTypeName = ";Message+= Message8; Message += "\n"; - Message += " aTranslatedEntityTypeName = ";Message+= Message9; 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); - PostProcess(aDoc,ID_BUTTON_Test_36,TheDisplayType,Message.ToCString()); + 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 @@ -2763,29 +2819,29 @@ Standard_Real value = matrix.Determinant(); // 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()) { /* ... */ } - -//============================================================== + 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\ @@ -2806,72 +2862,72 @@ if (PE.IsLinear()) { /* ... */ } \n\ if (PE.IsPlanar()) { P = PE.Plane();} \n\ if (PE.IsSpace()) { /* ... */ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); - } + 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"; + 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.); + 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); + DisplaySurface(aDoc,aSurface); - } - else + } + else Message += " PE.IsPlanar() = False \n"; - Message += " PE.IsSpace() = "; if (PE.IsSpace() ) 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_37,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -2901,79 +2957,79 @@ GeomFill_BSplineCurves aGeomFill3( Handle(Geom_BSplineCurve)::DownCast(SPL2->Translated(gp_Vec(20,0,0))),Type); \n\ Handle(Geom_BSplineSurface) aBSplineSurface3 = aGeomFill3.Surface(); \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + // Trace des frontieres. -> FreeBoundaryAspect + // Trace des isoparametriques. --> UIsoAspect() - 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); - } + DisplaySurface(aDoc,aBSplineSurface1,Quantity_NOC_YELLOW); + DisplaySurface(aDoc,aBSplineSurface2,Quantity_NOC_SALMON); + DisplaySurface(aDoc,aBSplineSurface3,Quantity_NOC_HOTPINK); - 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"; + 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); + } - PostProcess(aDoc,ID_BUTTON_Test_38,TheDisplayType,Message.ToCString()); + 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(); - + 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\ @@ -3003,74 +3059,72 @@ aConstrainedFilling.Init(B1,B2,B3,NoCheck); \n\ Handle(Geom_BSplineSurface) aBSplineSurface = aConstrainedFilling.Surface(); \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - TCollection_AsciiString aString; + TCollection_AsciiString aString; - DisplaySurface(aDoc,aBSplineSurface,Quantity_NOC_YELLOW); + 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); - 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 += "SPL1 is Red; \n"; - Message += "SPL2 is Green; \n"; - Message += "SPL3 is Blue; \n"; + Message += "aBSplineSurface is Yellow; \n"; - Message += "aBSplineSurface is Yellow; \n"; - - - PostProcess(aDoc,ID_BUTTON_Test_39,TheDisplayType,Message.ToCString()); + 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)); - } - -//============================================================== + 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\ @@ -3115,67 +3169,66 @@ if (!aSurface3.IsNull()) \n\ aSurface3->Translate(gp_Vec(10,0,0)); \n\ } \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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"; - 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); - } + TCollection_AsciiString Message2(aSurfaceEntityTypeName); + TCollection_AsciiString Message3(aSurfaceEntityTypeName2); + TCollection_AsciiString Message4(aSurfaceEntityTypeName3); - DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false); + Message += " aSurfaceEntityTypeName = ";Message+= Message2; Message += "\n"; + Message += " aSurfaceEntityTypeName2 = ";Message+= Message3; Message += "\n"; + Message += " aSurfaceEntityTypeName3 = ";Message+= Message4; Message += "\n"; - 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()); + 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 (" \ + 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\ @@ -3197,117 +3250,117 @@ Handle(Geom_BSplineSurface) aPipeSurface = \n\ Handle(Geom_BSplineSurface) anotherBSplineSurface = \n\ GeomConvert::SplitBSplineSurface(aPipeSurface,1,2,3,6); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - - if (!aPipeSurface.IsNull()) - { - DisplaySurface(aDoc,aPipeSurface,Quantity_NOC_YELLOW); - } + if(!aPipeSurface.IsNull()) + { + DisplaySurface(aDoc,aPipeSurface,Quantity_NOC_YELLOW); + } - if (!anotherBSplineSurface.IsNull()) - { - DisplaySurface(aDoc,anotherBSplineSurface,Quantity_NOC_HOTPINK); - } + if(!anotherBSplineSurface.IsNull()) + { + DisplaySurface(aDoc,anotherBSplineSurface,Quantity_NOC_HOTPINK); + } - DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false); - DisplayCurve(aDoc,FirstSect,Quantity_NOC_GREEN ,false); + 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"; + 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()); + 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); + DisplayType TheDisplayType = No2D3D; + PreProcess(aDoc,TheDisplayType); -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)); + 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); -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)); + 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)); -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)); + 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)); -Handle(Geom_BezierSurface) BZ1 = + 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 = + Handle(Geom_BezierSurface) BZ2 = new Geom_BezierSurface(array2); -Handle(Geom_BezierSurface) BZ3 = + Handle(Geom_BezierSurface) BZ3 = new Geom_BezierSurface(array3); -Handle(Geom_BezierSurface) BZ4 = + 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)); - } - -//============================================================== + 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); - TCollection_AsciiString Message (" \ + 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\ @@ -3346,63 +3399,63 @@ if (BB.IsDone()){ \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); + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - if (BB.IsDone()){ - DisplaySurface(aDoc,BSPLSURF,Quantity_NOC_HOTPINK); - } + DisplaySurface(aDoc,BZ1,Quantity_NOC_RED); + DisplaySurface(aDoc,BZ2,Quantity_NOC_GREEN); + DisplaySurface(aDoc,BZ3,Quantity_NOC_BLUE1); + DisplaySurface(aDoc,BZ4,Quantity_NOC_BROWN); - 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"; + if (BB.IsDone()){ + DisplaySurface(aDoc,BSPLSURF,Quantity_NOC_HOTPINK); + } - PostProcess(aDoc,ID_BUTTON_Test_42,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -3425,57 +3478,58 @@ Handle(Geom_OffsetSurface) GOS1 = new Geom_OffsetSurface(aGeomSurface, offset); offset = 3; \n\ Handle(Geom_OffsetSurface) GOS2 = new Geom_OffsetSurface(aGeomSurface, offset); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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); + DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false); + DisplayCurve(aDoc,SPL2,Quantity_NOC_HOTPINK ,false); - Message += "aGeomSurface is Blue; \n"; - Message += "GOS are Green; \n"; + Message += "aGeomSurface is Blue; \n"; + Message += "GOS are Green; \n"; - PostProcess(aDoc,ID_BUTTON_Test_43,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -3503,45 +3557,46 @@ if (!SOLE.IsNull()) \n\ SOLEEntityTypeName = SOLE->DynamicType()->Name(); \n\ } \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplaySurface(aDoc,aTrimmedSurface,Quantity_NOC_GREEN); - DisplayCurve(aDoc,aCurve,Quantity_NOC_RED ,false); + DisplaySurface(aDoc,aTrimmedSurface,Quantity_NOC_GREEN); + DisplayCurve(aDoc,aCurve,Quantity_NOC_RED ,false); - Message += "aCurve is Red; \n"; - Message += "aTrimmedSurface is Green; \n"; + Message += "aCurve is Red; \n"; + Message += "aTrimmedSurface is Green; \n"; - TCollection_AsciiString Message2 (SOLEEntityTypeName); + TCollection_AsciiString Message2 (SOLEEntityTypeName); - Message += " SOLEEntityTypeName = ";Message+= Message2; Message += "\n"; + Message += " SOLEEntityTypeName = ";Message+= Message2; Message += "\n"; - PostProcess(aDoc,ID_BUTTON_Test_44,TheDisplayType,Message.ToCString()); + 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 (" \ + 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\ @@ -3558,58 +3613,59 @@ 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); + AddSeparator(aDoc,Message); - Message += "aCurve is Red; \n"; - Message += "SOR is Green; \n"; - TCollection_AsciiString Message2 (SOREntityTypeName); - Message += " SOREntityTypeName = ";Message+= Message2; Message += "\n"; + //-------------------------------------------------------------- + DisplaySurface(aDoc,SOR,Quantity_NOC_GREEN); + DisplayCurve(aDoc,aCurve,Quantity_NOC_RED ,false); - PostProcess(aDoc,ID_BUTTON_Test_45,TheDisplayType,Message.ToCString()); + 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); - -//============================================================== + 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\ @@ -3636,111 +3692,111 @@ Standard_Boolean after = Standard_True; \n\ GeomLib::ExtendSurfByLength (aTranslatedGeomSurface, \n\ extension,continuity,Udirection,after); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - if (!aGeomSurface.IsNull()) - { - DisplaySurface(aDoc,aGeomSurface,Quantity_NOC_HOTPINK); - } + if (!aGeomSurface.IsNull()) + { + DisplaySurface(aDoc,aGeomSurface,Quantity_NOC_HOTPINK); + } - if (!aTranslatedGeomSurface.IsNull()) - { - DisplaySurface(aDoc,aTranslatedGeomSurface,Quantity_NOC_BLUE1); - } + if (!aTranslatedGeomSurface.IsNull()) + { + DisplaySurface(aDoc,aTranslatedGeomSurface,Quantity_NOC_BLUE1); + } - DisplayCurve(aDoc,SPL1,Quantity_NOC_RED ,false); - DisplayCurve(aDoc,SPL2,Quantity_NOC_GREEN ,false); + 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"; + 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()); + PostProcess(aDoc,ID_BUTTON_Test_46,TheDisplayType,Message.ToCString()); } - void GeomSources::gpTest47(CGeometryDoc* aDoc) { - DisplayType TheDisplayType = No2D3D; - PreProcess(aDoc,TheDisplayType); -//============================================================== - + 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); + 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\ @@ -3756,84 +3812,84 @@ 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"; + 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")); + 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); - PostProcess(aDoc,ID_BUTTON_Test_47,TheDisplayType,Message.ToCString()); + 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); -//============================================================== + 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); + 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); - + 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); - -//============================================================== + + 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\ @@ -3869,66 +3925,68 @@ BndLib_Add2dCurve::Add (GAC2,Precision::Approximation(),aSPL2Box); \n\ Standard_Real aSPL2Xmin,aSPL2Ymin,aSPL2Xmax,aSPL2Ymax; \n\ aSPL2Box.Get( aSPL2Xmin, aSPL2Ymin, aSPL2Xmax,aSPL2Ymax); \n\ \n"; - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayCurve(aDoc,C ,5); - DisplayCurve(aDoc,SPL1,6 ); - DisplayCurve(aDoc,SPL2,7 ); + 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")); + 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 + 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")); + 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 + 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")); + 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 + 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()); + 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); - -//============================================================== + 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\ @@ -3943,91 +4001,85 @@ BndLib_Add3dCurve::Add (GAC,Precision::Approximation(),aBox); \n\ Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ; \n\ aBox.Get( aXmin, aYmin,aZmin, aXmax,aYmax,aZmax); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + AddSeparator(aDoc,Message); + //-------------------------------------------------------------- - DisplayCurve(aDoc,C,Quantity_NOC_BLUE1 ,false); + 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,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")); + 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()); + 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 + + 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 (" \ + 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\ @@ -4057,51 +4109,44 @@ BndLib_AddSurface::Add (GAS,Precision::Approximation(),aBox); \n\ Standard_Real aXmin, aYmin, aZmin, aXmax, aYmax, aZmax ; \n\ aBox.Get( aXmin, aYmin,aZmin, aXmax,aYmax,aZmax); \n\ \n"); - AddSeparator(aDoc,Message); - //-------------------------------------------------------------- + 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); + 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); + 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()); + 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 + + PostProcess(aDoc,ID_BUTTON_Test_50,TheDisplayType,Message.ToCString()); } - - diff --git a/samples/mfc/standard/01_Geometry/src/GeomSources.h b/samples/mfc/standard/01_Geometry/src/GeomSources.h index a445f1a584..fd1fce10af 100755 --- a/samples/mfc/standard/01_Geometry/src/GeomSources.h +++ b/samples/mfc/standard/01_Geometry/src/GeomSources.h @@ -16,110 +16,110 @@ class GeomSources { public: - Standard_EXPORT static void gpTest1(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest2(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest3(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest4(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest5(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest6(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest7(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest8(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest9(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest10(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest11(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest12(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest13(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest14(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest15(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest16(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest17(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest18(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest19(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest20(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest21(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest22(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest23(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest24(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest25(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest26(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest27(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest28(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest29(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest30(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest31(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest32(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest33(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest34(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest35(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest36(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest37(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest38(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest39(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest40(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest41(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest42(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest43(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest44(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest45(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest46(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest47(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest48(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest49(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest50(CGeometryDoc* aDoc); - Standard_EXPORT static void gpTest51(CGeometryDoc* aDoc); - GeomSources(); - virtual ~GeomSources(); + Standard_EXPORT static void gpTest1(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest2(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest3(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest4(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest5(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest6(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest7(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest8(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest9(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest10(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest11(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest12(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest13(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest14(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest15(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest16(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest17(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest18(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest19(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest20(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest21(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest22(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest23(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest24(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest25(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest26(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest27(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest28(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest29(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest30(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest31(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest32(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest33(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest34(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest35(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest36(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest37(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest38(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest39(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest40(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest41(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest42(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest43(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest44(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest45(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest46(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest47(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest48(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest49(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest50(CGeometryDoc* aDoc); + Standard_EXPORT static void gpTest51(CGeometryDoc* aDoc); + GeomSources(); + virtual ~GeomSources(); private: enum DisplayType{No2DNo3D, // 0 0 0 - No2D3D , // 0 0 1 - a2DNo3D , // 0 1 0 - a2D3D }; // 1 1 1 + No2D3D , // 0 0 1 + a2DNo3D , // 0 1 0 + a2D3D }; // 1 1 1 static void PreProcess (CGeometryDoc* aDoc,DisplayType aDisplayType); static void PostProcess(CGeometryDoc* aDoc,UINT anID,DisplayType aDisplayType,const char* aString="",Quantity_Coefficient Coef = -1/*double zoom =-1*/); static void DisplayPoint(CGeometryDoc* aDoc, - gp_Pnt2d& aPoint, - const char* aText, - Standard_Boolean UpdateViewer = Standard_False, - Standard_Real anXoffset =0, - Standard_Real anYoffset =0, - Standard_Real TextScale = 0.05); + gp_Pnt2d& aPoint, + const char* aText, + Standard_Boolean UpdateViewer = Standard_False, + Standard_Real anXoffset =0, + Standard_Real anYoffset =0, + Standard_Real TextScale = 0.05); static void DisplayPoint(CGeometryDoc* aDoc, - gp_Pnt& aPoint, - const char* aText, - Standard_Boolean UpdateViewer = Standard_False, - Standard_Real anXoffset = 0, - Standard_Real anYoffset = 0, - Standard_Real aZoffset = 0, - Standard_Real TextScale = 0.05); + gp_Pnt& aPoint, + const char* aText, + Standard_Boolean UpdateViewer = Standard_False, + Standard_Real anXoffset = 0, + Standard_Real anYoffset = 0, + Standard_Real aZoffset = 0, + Standard_Real TextScale = 0.05); - static void DisplayCurve(CGeometryDoc* aDoc, - Handle(Geom2d_Curve) aCurve, - Standard_Integer aColorIndex = 4, - Standard_Boolean UpdateViewer = false); - static void DisplayCurveAndCurvature(CGeometryDoc* aDoc, - Handle(Geom2d_Curve) aCurve, - Standard_Integer aColorIndex = 4, - Standard_Boolean UpdateViewer = false); + static void DisplayCurve(CGeometryDoc* aDoc, + Handle(Geom2d_Curve) aCurve, + Standard_Integer aColorIndex = 4, + Standard_Boolean UpdateViewer = false); + static void DisplayCurveAndCurvature(CGeometryDoc* aDoc, + Handle(Geom2d_Curve) aCurve, + Standard_Integer aColorIndex = 4, + Standard_Boolean UpdateViewer = false); - static void DisplayCurve(CGeometryDoc* aDoc, - Handle(Geom_Curve) aCurve, - Quantity_NameOfColor aNameOfColor, - Standard_Boolean UpdateViewer = false); + static void DisplayCurve(CGeometryDoc* aDoc, + Handle(Geom_Curve) aCurve, + Quantity_NameOfColor aNameOfColor, + Standard_Boolean UpdateViewer = false); - static void DisplayCurve(CGeometryDoc* aDoc, - Handle(Geom_Curve) aCurve, - Standard_Boolean UpdateViewer = false); + static void DisplayCurve(CGeometryDoc* aDoc, + Handle(Geom_Curve) aCurve, + Standard_Boolean UpdateViewer = false); - static void DisplaySurface (CGeometryDoc* aDoc, - Handle(Geom_Surface) aSurface, - Quantity_NameOfColor aNameOfColor, - Standard_Boolean UpdateViewer = false); + static void DisplaySurface (CGeometryDoc* aDoc, + Handle(Geom_Surface) aSurface, + Quantity_NameOfColor aNameOfColor, + Standard_Boolean UpdateViewer = false); - static void DisplaySurface (CGeometryDoc* aDoc, - Handle(Geom_Surface) aSurface, - Standard_Boolean UpdateViewer = false); + static void DisplaySurface (CGeometryDoc* aDoc, + Handle(Geom_Surface) aSurface, + Standard_Boolean UpdateViewer = false); diff --git a/samples/mfc/standard/01_Geometry/src/GeometryApp.cpp b/samples/mfc/standard/01_Geometry/src/GeometryApp.cpp index 96bfed141b..b00b7c8422 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryApp.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeometryApp.cpp @@ -15,15 +15,14 @@ ///////////////////////////////////////////////////////////////////////////// // CGeometryApp construction -CGeometryApp::CGeometryApp() +CGeometryApp::CGeometryApp() : OCC_App() { - SampleName = "Geometry"; //for about dialog - + SampleName = "Geometry"; //for about dialog } CGeometryApp::~CGeometryApp() { - delete pDocTemplateForView2d; + delete pDocTemplateForView2d; } ///////////////////////////////////////////////////////////////////////////// // The one and only CGeometryApp object @@ -35,58 +34,57 @@ CGeometryApp theApp; BOOL CGeometryApp::InitInstance() { - AfxInitRichEdit(); - AfxEnableControlContainer(); + AfxInitRichEdit(); + AfxEnableControlContainer(); - // Standard initialization - // If you are not using these features and wish to reduce the size - // of your final executable, you should remove from the following - // the specific initialization routines you do not need. + // Standard initialization + // If you are not using these features and wish to reduce the size + // of your final executable, you should remove from the following + // the specific initialization routines you do not need. - // Change the registry key under which our settings are stored. - // You should modify this string to be something appropriate - // such as the name of your company or organization. - SetRegistryKey(_T("Local AppWizard-Generated Applications")); + // Change the registry key under which our settings are stored. + // You should modify this string to be something appropriate + // such as the name of your company or organization. + SetRegistryKey(_T("Local AppWizard-Generated Applications")); - LoadStdProfileSettings(); // Load standard INI file options (including MRU) + LoadStdProfileSettings(); // Load standard INI file options (including MRU) - // Register the application's document templates. Document templates - // serve as the connection between documents, frame windows and views. + // Register the application's document templates. Document templates + // serve as the connection between documents, frame windows and views. - pDocTemplateForView3d = new CMultiDocTemplate( - IDR_3DTYPE, - RUNTIME_CLASS(CGeometryDoc), - RUNTIME_CLASS(CChildFrame), // custom MDI child frame - RUNTIME_CLASS(CGeometryView)); - AddDocTemplate(pDocTemplateForView3d); - - pDocTemplateForView2d = new CMultiDocTemplate( - IDR_2DTYPE, - RUNTIME_CLASS(CGeometryDoc), - RUNTIME_CLASS(CChildFrame2D), // custom MDI child frame - RUNTIME_CLASS(CGeometryView2D)); - //AddDocTemplate(pDocTemplateForView2d); + pDocTemplateForView3d = new CMultiDocTemplate( + IDR_3DTYPE, + RUNTIME_CLASS(CGeometryDoc), + RUNTIME_CLASS(CChildFrame), // custom MDI child frame + RUNTIME_CLASS(CGeometryView)); + AddDocTemplate(pDocTemplateForView3d); - // create main MDI Frame window - CMainFrame* pMainFrame = new CMainFrame; - if (!pMainFrame->LoadFrame(IDR_MAINFRAME)) - return FALSE; - m_pMainWnd = pMainFrame; + pDocTemplateForView2d = new CMultiDocTemplate( + IDR_2DTYPE, + RUNTIME_CLASS(CGeometryDoc), + RUNTIME_CLASS(CChildFrame2D), // custom MDI child frame + RUNTIME_CLASS(CGeometryView2D)); + //AddDocTemplate(pDocTemplateForView2d); - // Parse command line for standard shell commands, DDE, file open - CCommandLineInfo cmdInfo; - ParseCommandLine(cmdInfo); + // create main MDI Frame window + CMainFrame* pMainFrame = new CMainFrame; + if (!pMainFrame->LoadFrame(IDR_MAINFRAME)) + return FALSE; + m_pMainWnd = pMainFrame; - // Dispatch commands specified on the command line - if (!ProcessShellCommand(cmdInfo)) - return FALSE; + // Parse command line for standard shell commands, DDE, file open + CCommandLineInfo cmdInfo; + ParseCommandLine(cmdInfo); - // The main window has been initialized, so show and update it. - pMainFrame->ShowWindow(m_nCmdShow); - pMainFrame->UpdateWindow(); + // Dispatch commands specified on the command line + if (!ProcessShellCommand(cmdInfo)) + return FALSE; + // The main window has been initialized, so show and update it. + pMainFrame->ShowWindow(m_nCmdShow); + pMainFrame->UpdateWindow(); - return TRUE; + return TRUE; } ///////////////////////////////////////////////////////////////////////////// @@ -117,10 +115,10 @@ BOOL CGeometryApp::IsViewExisting(CDocument * pDoc, CRuntimeClass * pViewClass, CView* pCurrentView = pDoc->GetNextView(position); ASSERT_VALID(pCurrentView); if (pCurrentView->IsKindOf(pViewClass)) - { + { pView = pCurrentView; - return TRUE; - } + return TRUE; + } } return FALSE; } diff --git a/samples/mfc/standard/01_Geometry/src/GeometryApp.h b/samples/mfc/standard/01_Geometry/src/GeometryApp.h index 6240bf0ac6..eb98f40266 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryApp.h +++ b/samples/mfc/standard/01_Geometry/src/GeometryApp.h @@ -8,29 +8,29 @@ #pragma once #endif // _MSC_VER >= 1000 -#include +#include #include -class CGeometryApp : public OCC_3dApp +class CGeometryApp : public OCC_App { public: - CGeometryApp(); - ~CGeometryApp(); - // ========================================= - CFrameWnd* CreateView2D(CGeometryDoc* pDoc); - // ========================================= - // ========================================= + CGeometryApp(); + ~CGeometryApp(); + // ========================================= + CFrameWnd* CreateView2D(CGeometryDoc* pDoc); + // ========================================= + // ========================================= -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CGeometryApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL + // Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CGeometryApp) +public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL private : - BOOL IsViewExisting(CDocument* pDoc,CRuntimeClass* pViewClass,CView*& pView); - CMultiDocTemplate* pDocTemplateForView3d; - CMultiDocTemplate* pDocTemplateForView2d; + BOOL IsViewExisting(CDocument* pDoc,CRuntimeClass* pViewClass,CView*& pView); + CMultiDocTemplate* pDocTemplateForView3d; + CMultiDocTemplate* pDocTemplateForView2d; }; diff --git a/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp b/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp index 7ed933551a..a5c5e994e6 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp @@ -32,111 +32,111 @@ static char THIS_FILE[] = __FILE__; IMPLEMENT_DYNCREATE(CGeometryDoc, CDocument) BEGIN_MESSAGE_MAP(CGeometryDoc, CDocument) - //{{AFX_MSG_MAP(CGeometryDoc) - ON_COMMAND(ID_WINDOW_NEW2D, OnWindowNew2d) - ON_COMMAND(ID_BUTTON_Test_1, OnBUTTONTest1) - ON_COMMAND(ID_BUTTON_Test_2, OnBUTTONTest2) - ON_COMMAND(ID_BUTTON_Test_3, OnBUTTONTest3) - ON_COMMAND(ID_BUTTON_Test_4, OnBUTTONTest4) - ON_COMMAND(ID_BUTTON_Test_5, OnBUTTONTest5) - ON_COMMAND(ID_BUTTON_Test_6, OnBUTTONTest6) - ON_COMMAND(ID_BUTTON_Test_7, OnBUTTONTest7) - ON_COMMAND(ID_BUTTON_Test_8, OnBUTTONTest8) - ON_COMMAND(ID_BUTTON_Test_9, OnBUTTONTest9) - ON_COMMAND(ID_BUTTON_Test_23, OnBUTTONTest23) - ON_COMMAND(ID_BUTTON_Test_22, OnBUTTONTest22) - ON_COMMAND(ID_BUTTON_Test_10, OnBUTTONTest10) - ON_COMMAND(ID_BUTTON_Test_11, OnBUTTONTest11) - ON_COMMAND(ID_BUTTON_Test_12, OnBUTTONTest12) - ON_COMMAND(ID_BUTTON_Test_13, OnBUTTONTest13) - ON_COMMAND(ID_BUTTON_Test_14, OnBUTTONTest14) - ON_COMMAND(ID_BUTTON_Test_15, OnBUTTONTest15) - ON_COMMAND(ID_BUTTON_Test_16, OnBUTTONTest16) - ON_COMMAND(ID_BUTTON_Test_17, OnBUTTONTest17) - ON_COMMAND(ID_BUTTON_Test_18, OnBUTTONTest18) - ON_COMMAND(ID_BUTTON_Test_19, OnBUTTONTest19) - ON_COMMAND(ID_BUTTON_Test_20, OnBUTTONTest20) - ON_COMMAND(ID_BUTTON_Test_21, OnBUTTONTest21) - ON_COMMAND(ID_BUTTON_Test_24, OnBUTTONTest24) - ON_COMMAND(ID_BUTTON_Test_25, OnBUTTONTest25) - ON_COMMAND(ID_BUTTON_Test_26, OnBUTTONTest26) - ON_COMMAND(ID_BUTTON_Test_27, OnBUTTONTest27) - ON_COMMAND(ID_BUTTON_Test_28, OnBUTTONTest28) - ON_COMMAND(ID_BUTTON_Test_29, OnBUTTONTest29) - ON_COMMAND(ID_BUTTON_Test_30, OnBUTTONTest30) - ON_COMMAND(ID_BUTTON_Test_31, OnBUTTONTest31) - ON_COMMAND(ID_BUTTON_Test_32, OnBUTTONTest32) - ON_COMMAND(ID_BUTTON_Test_33, OnBUTTONTest33) - ON_COMMAND(ID_BUTTON_Test_34, OnBUTTONTest34) - ON_COMMAND(ID_BUTTON_Test_35, OnBUTTONTest35) - ON_COMMAND(ID_BUTTON_Test_36, OnBUTTONTest36) - ON_COMMAND(ID_BUTTON_Test_37, OnBUTTONTest37) - ON_COMMAND(ID_BUTTON_Test_38, OnBUTTONTest38) - ON_COMMAND(ID_BUTTON_Test_39, OnBUTTONTest39) - ON_COMMAND(ID_BUTTON_Test_40, OnBUTTONTest40) - ON_COMMAND(ID_BUTTON_Test_41, OnBUTTONTest41) - ON_COMMAND(ID_BUTTON_Test_42, OnBUTTONTest42) - ON_COMMAND(ID_BUTTON_Test_43, OnBUTTONTest43) - ON_COMMAND(ID_BUTTON_Test_44, OnBUTTONTest44) - ON_COMMAND(ID_BUTTON_Test_45, OnBUTTONTest45) - ON_COMMAND(ID_BUTTON_Test_46, OnBUTTONTest46) - ON_COMMAND(ID_BUTTON_Test_47, OnBUTTONTest47) - ON_COMMAND(ID_BUTTON_Test_48, OnBUTTONTest48) - ON_COMMAND(ID_BUTTON_Test_49, OnBUTTONTest49) - ON_COMMAND(ID_BUTTON_Test_50, OnBUTTONTest50) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_1 , OnUpdateBUTTONTest1 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_2 , OnUpdateBUTTONTest2 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_3 , OnUpdateBUTTONTest3 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_4 , OnUpdateBUTTONTest4 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_5 , OnUpdateBUTTONTest5 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_6 , OnUpdateBUTTONTest6 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_7 , OnUpdateBUTTONTest7 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_8 , OnUpdateBUTTONTest8 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_9 , OnUpdateBUTTONTest9 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_10 , OnUpdateBUTTONTest10 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_11 , OnUpdateBUTTONTest11 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_12 , OnUpdateBUTTONTest12 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_13 , OnUpdateBUTTONTest13 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_14 , OnUpdateBUTTONTest14 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_15 , OnUpdateBUTTONTest15 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_16 , OnUpdateBUTTONTest16 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_17 , OnUpdateBUTTONTest17 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_18 , OnUpdateBUTTONTest18 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_19 , OnUpdateBUTTONTest19 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_20 , OnUpdateBUTTONTest20 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_21 , OnUpdateBUTTONTest21 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_22 , OnUpdateBUTTONTest22 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_23 , OnUpdateBUTTONTest23 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_24 , OnUpdateBUTTONTest24 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_25 , OnUpdateBUTTONTest25 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_26 , OnUpdateBUTTONTest26 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_27 , OnUpdateBUTTONTest27 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_28 , OnUpdateBUTTONTest28 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_29 , OnUpdateBUTTONTest29 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_30 , OnUpdateBUTTONTest30 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_31 , OnUpdateBUTTONTest31 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_32 , OnUpdateBUTTONTest32 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_33 , OnUpdateBUTTONTest33 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_34 , OnUpdateBUTTONTest34 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_35 , OnUpdateBUTTONTest35 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_36 , OnUpdateBUTTONTest36 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_37 , OnUpdateBUTTONTest37 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_38 , OnUpdateBUTTONTest38 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_39 , OnUpdateBUTTONTest39 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_40 , OnUpdateBUTTONTest40 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_41 , OnUpdateBUTTONTest41 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_42 , OnUpdateBUTTONTest42 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_43 , OnUpdateBUTTONTest43 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_44 , OnUpdateBUTTONTest44 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_45 , OnUpdateBUTTONTest45 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_46 , OnUpdateBUTTONTest46 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_47 , OnUpdateBUTTONTest47 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_48 , OnUpdateBUTTONTest48 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_49 , OnUpdateBUTTONTest49 ) - ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_50 , OnUpdateBUTTONTest50 ) - ON_COMMAND(ID_Create_Sol, OnCreateSol) - ON_COMMAND(ID_BUTTON_Simplify, OnSimplify) - //}}AFX_MSG_MAP + //{{AFX_MSG_MAP(CGeometryDoc) + ON_COMMAND(ID_WINDOW_NEW2D, OnWindowNew2d) + ON_COMMAND(ID_BUTTON_Test_1, OnBUTTONTest1) + ON_COMMAND(ID_BUTTON_Test_2, OnBUTTONTest2) + ON_COMMAND(ID_BUTTON_Test_3, OnBUTTONTest3) + ON_COMMAND(ID_BUTTON_Test_4, OnBUTTONTest4) + ON_COMMAND(ID_BUTTON_Test_5, OnBUTTONTest5) + ON_COMMAND(ID_BUTTON_Test_6, OnBUTTONTest6) + ON_COMMAND(ID_BUTTON_Test_7, OnBUTTONTest7) + ON_COMMAND(ID_BUTTON_Test_8, OnBUTTONTest8) + ON_COMMAND(ID_BUTTON_Test_9, OnBUTTONTest9) + ON_COMMAND(ID_BUTTON_Test_23, OnBUTTONTest23) + ON_COMMAND(ID_BUTTON_Test_22, OnBUTTONTest22) + ON_COMMAND(ID_BUTTON_Test_10, OnBUTTONTest10) + ON_COMMAND(ID_BUTTON_Test_11, OnBUTTONTest11) + ON_COMMAND(ID_BUTTON_Test_12, OnBUTTONTest12) + ON_COMMAND(ID_BUTTON_Test_13, OnBUTTONTest13) + ON_COMMAND(ID_BUTTON_Test_14, OnBUTTONTest14) + ON_COMMAND(ID_BUTTON_Test_15, OnBUTTONTest15) + ON_COMMAND(ID_BUTTON_Test_16, OnBUTTONTest16) + ON_COMMAND(ID_BUTTON_Test_17, OnBUTTONTest17) + ON_COMMAND(ID_BUTTON_Test_18, OnBUTTONTest18) + ON_COMMAND(ID_BUTTON_Test_19, OnBUTTONTest19) + ON_COMMAND(ID_BUTTON_Test_20, OnBUTTONTest20) + ON_COMMAND(ID_BUTTON_Test_21, OnBUTTONTest21) + ON_COMMAND(ID_BUTTON_Test_24, OnBUTTONTest24) + ON_COMMAND(ID_BUTTON_Test_25, OnBUTTONTest25) + ON_COMMAND(ID_BUTTON_Test_26, OnBUTTONTest26) + ON_COMMAND(ID_BUTTON_Test_27, OnBUTTONTest27) + ON_COMMAND(ID_BUTTON_Test_28, OnBUTTONTest28) + ON_COMMAND(ID_BUTTON_Test_29, OnBUTTONTest29) + ON_COMMAND(ID_BUTTON_Test_30, OnBUTTONTest30) + ON_COMMAND(ID_BUTTON_Test_31, OnBUTTONTest31) + ON_COMMAND(ID_BUTTON_Test_32, OnBUTTONTest32) + ON_COMMAND(ID_BUTTON_Test_33, OnBUTTONTest33) + ON_COMMAND(ID_BUTTON_Test_34, OnBUTTONTest34) + ON_COMMAND(ID_BUTTON_Test_35, OnBUTTONTest35) + ON_COMMAND(ID_BUTTON_Test_36, OnBUTTONTest36) + ON_COMMAND(ID_BUTTON_Test_37, OnBUTTONTest37) + ON_COMMAND(ID_BUTTON_Test_38, OnBUTTONTest38) + ON_COMMAND(ID_BUTTON_Test_39, OnBUTTONTest39) + ON_COMMAND(ID_BUTTON_Test_40, OnBUTTONTest40) + ON_COMMAND(ID_BUTTON_Test_41, OnBUTTONTest41) + ON_COMMAND(ID_BUTTON_Test_42, OnBUTTONTest42) + ON_COMMAND(ID_BUTTON_Test_43, OnBUTTONTest43) + ON_COMMAND(ID_BUTTON_Test_44, OnBUTTONTest44) + ON_COMMAND(ID_BUTTON_Test_45, OnBUTTONTest45) + ON_COMMAND(ID_BUTTON_Test_46, OnBUTTONTest46) + ON_COMMAND(ID_BUTTON_Test_47, OnBUTTONTest47) + ON_COMMAND(ID_BUTTON_Test_48, OnBUTTONTest48) + ON_COMMAND(ID_BUTTON_Test_49, OnBUTTONTest49) + ON_COMMAND(ID_BUTTON_Test_50, OnBUTTONTest50) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_1 , OnUpdateBUTTONTest1 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_2 , OnUpdateBUTTONTest2 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_3 , OnUpdateBUTTONTest3 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_4 , OnUpdateBUTTONTest4 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_5 , OnUpdateBUTTONTest5 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_6 , OnUpdateBUTTONTest6 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_7 , OnUpdateBUTTONTest7 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_8 , OnUpdateBUTTONTest8 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_9 , OnUpdateBUTTONTest9 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_10 , OnUpdateBUTTONTest10 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_11 , OnUpdateBUTTONTest11 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_12 , OnUpdateBUTTONTest12 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_13 , OnUpdateBUTTONTest13 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_14 , OnUpdateBUTTONTest14 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_15 , OnUpdateBUTTONTest15 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_16 , OnUpdateBUTTONTest16 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_17 , OnUpdateBUTTONTest17 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_18 , OnUpdateBUTTONTest18 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_19 , OnUpdateBUTTONTest19 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_20 , OnUpdateBUTTONTest20 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_21 , OnUpdateBUTTONTest21 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_22 , OnUpdateBUTTONTest22 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_23 , OnUpdateBUTTONTest23 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_24 , OnUpdateBUTTONTest24 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_25 , OnUpdateBUTTONTest25 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_26 , OnUpdateBUTTONTest26 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_27 , OnUpdateBUTTONTest27 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_28 , OnUpdateBUTTONTest28 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_29 , OnUpdateBUTTONTest29 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_30 , OnUpdateBUTTONTest30 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_31 , OnUpdateBUTTONTest31 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_32 , OnUpdateBUTTONTest32 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_33 , OnUpdateBUTTONTest33 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_34 , OnUpdateBUTTONTest34 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_35 , OnUpdateBUTTONTest35 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_36 , OnUpdateBUTTONTest36 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_37 , OnUpdateBUTTONTest37 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_38 , OnUpdateBUTTONTest38 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_39 , OnUpdateBUTTONTest39 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_40 , OnUpdateBUTTONTest40 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_41 , OnUpdateBUTTONTest41 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_42 , OnUpdateBUTTONTest42 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_43 , OnUpdateBUTTONTest43 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_44 , OnUpdateBUTTONTest44 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_45 , OnUpdateBUTTONTest45 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_46 , OnUpdateBUTTONTest46 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_47 , OnUpdateBUTTONTest47 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_48 , OnUpdateBUTTONTest48 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_49 , OnUpdateBUTTONTest49 ) + ON_UPDATE_COMMAND_UI(ID_BUTTON_Test_50 , OnUpdateBUTTONTest50 ) + ON_COMMAND(ID_Create_Sol, OnCreateSol) + ON_COMMAND(ID_BUTTON_Simplify, OnSimplify) + //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// @@ -144,43 +144,44 @@ END_MESSAGE_MAP() CGeometryDoc::CGeometryDoc() { - FitMode = false; + FitMode = false; + AfxInitRichEdit(); - AfxInitRichEdit(); + // TODO: add one-time construction code here + Handle(Graphic3d_GraphicDriver) aGraphicDriver = + ((CGeometryApp*)AfxGetApp())->GetGraphicDriver(); - // TODO: add one-time construction code here - Handle(Graphic3d_WNTGraphicDevice) theGraphicDevice = - ((CGeometryApp*)AfxGetApp())->GetGraphicDevice(); + TCollection_ExtendedString a3DName("Visu3D"); + myViewer = new V3d_Viewer(aGraphicDriver,a3DName.ToExtString()); + myViewer->SetDefaultLights(); + myViewer->SetLightOn(); - TCollection_ExtendedString a3DName("Visu3D"); - myViewer = new V3d_Viewer(theGraphicDevice,a3DName.ToExtString()); - myViewer->SetDefaultLights(); - myViewer->SetLightOn(); + myAISContext =new AIS_InteractiveContext(myViewer); + myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber(11); + myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(11); - myAISContext =new AIS_InteractiveContext(myViewer); - myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber(11); - myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(11); + TCollection_ExtendedString a2DName("Visu2D"); + myViewer2D = new V3d_Viewer(aGraphicDriver,a2DName.ToExtString()); + myViewer2D->SetCircularGridValues(0,0,1,8,0); + myViewer2D->SetRectangularGridValues(0,0,1,1,0); + //set view projection + myViewer2D->SetDefaultViewProj(V3d_Zpos); + myAISContext2D = new AIS_InteractiveContext(myViewer2D); + myCResultDialog.Create(CResultDialog::IDD,NULL); - TCollection_ExtendedString a2DName("Visu2D"); - myViewer2D = new V2d_Viewer(theGraphicDevice,a2DName.ToExtString()); - myViewer2D->SetCircularGridValues(0,0,1,8,0); - myViewer2D->SetRectangularGridValues(0,0,1,1,0); - myISessionContext= new ISession2D_InteractiveContext(myViewer2D); - myCResultDialog.Create(CResultDialog::IDD,NULL); + RECT dlgrect; + myCResultDialog.GetWindowRect(&dlgrect); + LONG width = dlgrect.right-dlgrect.left; + LONG height = dlgrect.bottom-dlgrect.top; + RECT MainWndRect; + AfxGetApp()->m_pMainWnd->GetWindowRect(&MainWndRect); + LONG left = MainWndRect.left+3; + LONG top = MainWndRect.top + 138; + myCResultDialog.MoveWindow(left,top,width,height); - RECT dlgrect; - myCResultDialog.GetWindowRect(&dlgrect); - LONG width = dlgrect.right-dlgrect.left; - LONG height = dlgrect.bottom-dlgrect.top; - RECT MainWndRect; - AfxGetApp()->m_pMainWnd->GetWindowRect(&MainWndRect); - LONG left = MainWndRect.left+3; - LONG top = MainWndRect.top + 138; - myCResultDialog.MoveWindow(left,top,width,height); - - ((CGeometryApp*)AfxGetApp())->CreateView2D(this); - Minimize2D(); - Put3DOnTop(); + ((CGeometryApp*)AfxGetApp())->CreateView2D(this); + Minimize2D(); + Put3DOnTop(); } CGeometryDoc::~CGeometryDoc() @@ -189,22 +190,21 @@ CGeometryDoc::~CGeometryDoc() BOOL CGeometryDoc::OnNewDocument() { - if (!CDocument::OnNewDocument()) - return FALSE; - - // TODO: add reinitialization code here - // (SDI documents will reuse this document) - // compute a graphic device --> the same for all Views + if (!CDocument::OnNewDocument()) + return FALSE; - return TRUE; + // TODO: add reinitialization code here + // (SDI documents will reuse this document) + // compute a graphic device --> the same for all Views + + return TRUE; } void CGeometryDoc::OnWindowNew2d() { - - ((CGeometryApp*)AfxGetApp())->CreateView2D(this); + ((CGeometryApp*)AfxGetApp())->CreateView2D(this); } ///////////////////////////////////////////////////////////////////////////// @@ -212,14 +212,14 @@ void CGeometryDoc::OnWindowNew2d() void CGeometryDoc::Serialize(CArchive& ar) { - if (ar.IsStoring()) - { - // TODO: add storing code here - } - else - { - // TODO: add loading code here - } + if (ar.IsStoring()) + { + // TODO: add storing code here + } + else + { + // TODO: add loading code here + } } ///////////////////////////////////////////////////////////////////////////// @@ -228,12 +228,12 @@ void CGeometryDoc::Serialize(CArchive& ar) #ifdef _DEBUG void CGeometryDoc::AssertValid() const { - CDocument::AssertValid(); + CDocument::AssertValid(); } void CGeometryDoc::Dump(CDumpContext& dc) const { - CDocument::Dump(dc); + CDocument::Dump(dc); } #endif //_DEBUG @@ -244,9 +244,9 @@ void CGeometryDoc::Dump(CDumpContext& dc) const // //----------------------------------------------------------------------------------------- void CGeometryDoc::DragEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState , - const Handle(V2d_View)& aView ) + const Standard_Integer y , + const Standard_Integer TheState , + const Handle(V3d_View)& aView ) { } @@ -255,38 +255,45 @@ void CGeometryDoc::DragEvent2D(const Standard_Integer x , // //----------------------------------------------------------------------------------------- void CGeometryDoc::InputEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Handle(V2d_View)& aView ) + const Standard_Integer y , + const Handle(V3d_View)& aView ) { - myISessionContext->Pick(aView,x,y); + myAISContext2D->Select(Standard_True); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- -void CGeometryDoc::MoveEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Handle(V2d_View)& aView ) +void CGeometryDoc::MoveEvent2D(const Standard_Integer x, + const Standard_Integer y, + const Handle(V3d_View)& aView) { - myISessionContext->Move(aView,x,y); + if(aView->Viewer()->Grid()->IsActive()) + { + Quantity_Length aGridX=0,aGridY=0,aGridZ=0; + aView->ConvertToGrid(x,y,aGridX,aGridY,aGridZ); + //View is not updated automatically in ConvertToGrid + aView->Update(); + } + this->myAISContext2D->MoveTo(x, y, aView); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- -void CGeometryDoc::ShiftMoveEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Handle(V2d_View)& aView ) +void CGeometryDoc::ShiftMoveEvent2D(const Standard_Integer x, + const Standard_Integer y , + const Handle(V3d_View)& aView) { } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- -void CGeometryDoc::ShiftDragEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState , - const Handle(V2d_View)& aView ) +void CGeometryDoc::ShiftDragEvent2D(const Standard_Integer x, + const Standard_Integer y, + const Standard_Integer TheState, + const Handle(V3d_View)& aView) { } @@ -294,9 +301,9 @@ void CGeometryDoc::ShiftDragEvent2D(const Standard_Integer x , //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- -void CGeometryDoc::ShiftInputEvent2D(const Standard_Integer x , - const Standard_Integer y , - const Handle(V2d_View)& aView ) +void CGeometryDoc::ShiftInputEvent2D(const Standard_Integer x, + const Standard_Integer y, + const Handle(V3d_View)& aView) { } @@ -304,25 +311,23 @@ void CGeometryDoc::ShiftInputEvent2D(const Standard_Integer x , // //----------------------------------------------------------------------------------------- void CGeometryDoc::Popup2D(const Standard_Integer x, - const Standard_Integer y , - const Handle(V2d_View)& aView ) + const Standard_Integer y , + const Handle(V3d_View)& aView) { - - CMenu menu; - VERIFY(menu.LoadMenu(IDR_Popup3D)); - CMenu* pPopup; - - pPopup = menu.GetSubMenu(0); - - ASSERT(pPopup != NULL); - - POINT winCoord = { x , y }; - Handle(WNT_Window) aWNTWindow= - Handle(WNT_Window)::DownCast(aView->Driver()->Window()); - ClientToScreen ( (HWND)(aWNTWindow->HWindow()),&winCoord); - pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON , winCoord.x, winCoord.y , - AfxGetMainWnd()); - + CMenu menu; + VERIFY(menu.LoadMenu(IDR_Popup3D)); + CMenu* pPopup; + + pPopup = menu.GetSubMenu(0); + + ASSERT(pPopup != NULL); + + POINT winCoord = { x , y }; + Handle(WNT_Window) aWNTWindow= + Handle(WNT_Window)::DownCast(aView->Window()); + ClientToScreen ( (HWND)(aWNTWindow->HWindow()),&winCoord); + pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON , winCoord.x, winCoord.y , + AfxGetMainWnd()); } void CGeometryDoc::Put2DOnTop(bool isMax) @@ -331,17 +336,20 @@ void CGeometryDoc::Put2DOnTop(bool isMax) while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) { - ASSERT_VALID(pCurrentView); - CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); - ASSERT(pParentFrm != (CFrameWnd *)NULL); - // simply make the frame window visible - if(isMax) { - pParentFrm->ActivateFrame(SW_SHOWMAXIMIZED); - } else { - pParentFrm->ActivateFrame(SW_SHOW); - } + ASSERT_VALID(pCurrentView); + CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); + ASSERT(pParentFrm != (CFrameWnd *)NULL); + // simply make the frame window visible + if(isMax) + { + pParentFrm->ActivateFrame(SW_SHOWMAXIMIZED); + } + else + { + pParentFrm->ActivateFrame(SW_SHOW); + } } } } @@ -352,16 +360,15 @@ void CGeometryDoc::Minimize2D() while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) { - ASSERT_VALID(pCurrentView); - CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); - ASSERT(pParentFrm != (CFrameWnd *)NULL); - // simply make the frame window visible - pParentFrm->ActivateFrame(SW_HIDE); + ASSERT_VALID(pCurrentView); + CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); + ASSERT(pParentFrm != (CFrameWnd *)NULL); + // simply make the frame window visible + pParentFrm->ActivateFrame(SW_HIDE); } } - } void CGeometryDoc::Fit2DViews() @@ -370,14 +377,13 @@ void CGeometryDoc::Fit2DViews() while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView2D ) ) ) { - ASSERT_VALID(pCurrentView); - CGeometryView2D* aCGeometryView2D = (CGeometryView2D*)pCurrentView; - aCGeometryView2D->FitAll(); + ASSERT_VALID(pCurrentView); + CGeometryView2D* aCGeometryView2D = (CGeometryView2D*)pCurrentView; + aCGeometryView2D->FitAll(); } } - } void CGeometryDoc::Put3DOnTop(bool isMax) { @@ -385,555 +391,702 @@ void CGeometryDoc::Put3DOnTop(bool isMax) while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) { - ASSERT_VALID(pCurrentView); - CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); - ASSERT(pParentFrm != (CFrameWnd *)NULL); - // simply make the frame window visible - if(isMax) { - pParentFrm->ActivateFrame(SW_SHOWMAXIMIZED); - } else { - pParentFrm->ActivateFrame(SW_SHOW); - } + ASSERT_VALID(pCurrentView); + CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); + ASSERT(pParentFrm != (CFrameWnd *)NULL); + // simply make the frame window visible + if(isMax) + { + pParentFrm->ActivateFrame(SW_SHOWMAXIMIZED); + } + else + { + pParentFrm->ActivateFrame(SW_SHOW); + } } } } + void CGeometryDoc::Minimize3D() { POSITION position = GetFirstViewPosition(); while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) { - ASSERT_VALID(pCurrentView); - CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); - ASSERT(pParentFrm != (CFrameWnd *)NULL); - // simply make the frame window visible - pParentFrm->ActivateFrame(SW_HIDE); + ASSERT_VALID(pCurrentView); + CFrameWnd* pParentFrm = pCurrentView->GetParentFrame(); + ASSERT(pParentFrm != (CFrameWnd *)NULL); + // simply make the frame window visible + pParentFrm->ActivateFrame(SW_HIDE); } } - } - void CGeometryDoc::Fit3DViews(Quantity_Coefficient Coef) { POSITION position = GetFirstViewPosition(); while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) { - ASSERT_VALID(pCurrentView); - CGeometryView* aCGeometryView = (CGeometryView*)pCurrentView; - aCGeometryView->FitAll(Coef); + ASSERT_VALID(pCurrentView); + CGeometryView* aCGeometryView = (CGeometryView*)pCurrentView; + aCGeometryView->FitAll(Coef); } } - } -void CGeometryDoc::Set3DViewsZoom(const Quantity_Factor& Coef ) + +void CGeometryDoc::Set3DViewsZoom(const Quantity_Factor& Coef) { POSITION position = GetFirstViewPosition(); while (position != (POSITION)NULL) { CView* pCurrentView = (CView*)GetNextView(position); - if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) + if(pCurrentView->IsKindOf( RUNTIME_CLASS( CGeometryView ) ) ) { - ASSERT_VALID(pCurrentView); - CGeometryView* aCGeometryView = (CGeometryView*)pCurrentView; - aCGeometryView->SetZoom( Coef ); + ASSERT_VALID(pCurrentView); + CGeometryView* aCGeometryView = (CGeometryView*)pCurrentView; + aCGeometryView->SetZoom( Coef ); } } - } void CGeometryDoc::OnBUTTONTest1() { Current = 1; - GeomSources::gpTest1(this); } +GeomSources::gpTest1(this); } void CGeometryDoc::OnBUTTONTest2() { Current = 2; - GeomSources::gpTest2(this); } +GeomSources::gpTest2(this); } void CGeometryDoc::OnBUTTONTest3() { Current = 3; - GeomSources::gpTest3(this); } +GeomSources::gpTest3(this); } void CGeometryDoc::OnBUTTONTest4() { Current = 4; - GeomSources::gpTest4(this); } +GeomSources::gpTest4(this); } void CGeometryDoc::OnBUTTONTest5() { Current = 5; - GeomSources::gpTest5(this); } +GeomSources::gpTest5(this); } void CGeometryDoc::OnBUTTONTest6() { Current = 6; - GeomSources::gpTest6(this); } +GeomSources::gpTest6(this); } void CGeometryDoc::OnBUTTONTest7() { Current = 7; - GeomSources::gpTest7(this); } +GeomSources::gpTest7(this); } void CGeometryDoc::OnBUTTONTest8() { Current = 8; - GeomSources::gpTest8(this); } +GeomSources::gpTest8(this); } void CGeometryDoc::OnBUTTONTest9() { Current = 9; - GeomSources::gpTest9(this); } +GeomSources::gpTest9(this); } void CGeometryDoc::OnBUTTONTest10() { Current = 10; - GeomSources::gpTest10(this); } +GeomSources::gpTest10(this); } void CGeometryDoc::OnBUTTONTest11() { Current = 11; - GeomSources::gpTest11(this); } +GeomSources::gpTest11(this); } void CGeometryDoc::OnBUTTONTest12() { Current = 12; - GeomSources::gpTest12(this); } +GeomSources::gpTest12(this); } void CGeometryDoc::OnBUTTONTest13() { Current = 13; - GeomSources::gpTest13(this); } +GeomSources::gpTest13(this); } void CGeometryDoc::OnBUTTONTest14() { Current = 14; - GeomSources::gpTest14(this); } +GeomSources::gpTest14(this); } void CGeometryDoc::OnBUTTONTest15() { Current = 15; - GeomSources::gpTest15(this); } +GeomSources::gpTest15(this); } void CGeometryDoc::OnBUTTONTest16() { Current = 16; - GeomSources::gpTest16(this); } +GeomSources::gpTest16(this); } void CGeometryDoc::OnBUTTONTest17() { Current = 17; - GeomSources::gpTest17(this); } +GeomSources::gpTest17(this); } void CGeometryDoc::OnBUTTONTest18() { Current = 18; - GeomSources::gpTest18(this); } +GeomSources::gpTest18(this); } void CGeometryDoc::OnBUTTONTest19() { Current = 19; - GeomSources::gpTest19(this); } +GeomSources::gpTest19(this); } void CGeometryDoc::OnBUTTONTest20() { Current = 20; - GeomSources::gpTest20(this); } +GeomSources::gpTest20(this); } void CGeometryDoc::OnBUTTONTest21() { Current = 21; - GeomSources::gpTest21(this); } +GeomSources::gpTest21(this); } void CGeometryDoc::OnBUTTONTest22() { Current = 22; - GeomSources::gpTest22(this); } +GeomSources::gpTest22(this); } void CGeometryDoc::OnBUTTONTest23() { Current = 23; - GeomSources::gpTest23(this); } +GeomSources::gpTest23(this); } void CGeometryDoc::OnBUTTONTest24() { Current = 24; - GeomSources::gpTest24(this); } +GeomSources::gpTest24(this); } void CGeometryDoc::OnBUTTONTest25() { Current = 25; - GeomSources::gpTest25(this); } +GeomSources::gpTest25(this); } void CGeometryDoc::OnBUTTONTest26() { Current = 26; - GeomSources::gpTest26(this); } +GeomSources::gpTest26(this); } void CGeometryDoc::OnBUTTONTest27() { Current = 27; - GeomSources::gpTest27(this); } +GeomSources::gpTest27(this); } void CGeometryDoc::OnBUTTONTest28() { Current = 28; - GeomSources::gpTest28(this); } +GeomSources::gpTest28(this); } void CGeometryDoc::OnBUTTONTest29() { Current = 29; - GeomSources::gpTest29(this); } +GeomSources::gpTest29(this); } void CGeometryDoc::OnBUTTONTest30() { Current = 30; - GeomSources::gpTest30(this); } +GeomSources::gpTest30(this); } void CGeometryDoc::OnBUTTONTest31() { Current = 31; - GeomSources::gpTest31(this); } +GeomSources::gpTest31(this); } void CGeometryDoc::OnBUTTONTest32() { Current = 32; - GeomSources::gpTest32(this); } +GeomSources::gpTest32(this); } void CGeometryDoc::OnBUTTONTest33() { Current = 33; - GeomSources::gpTest33(this); } +GeomSources::gpTest33(this); } void CGeometryDoc::OnBUTTONTest34() { Current = 34; - GeomSources::gpTest34(this); } +GeomSources::gpTest34(this); } void CGeometryDoc::OnBUTTONTest35() { Current = 35; - GeomSources::gpTest35(this); } +GeomSources::gpTest35(this); } void CGeometryDoc::OnBUTTONTest36() { Current = 36; - GeomSources::gpTest36(this); } +GeomSources::gpTest36(this); } void CGeometryDoc::OnBUTTONTest37() { Current = 37; - GeomSources::gpTest37(this); } +GeomSources::gpTest37(this); } void CGeometryDoc::OnBUTTONTest38() { Current = 38; - GeomSources::gpTest38(this); } +GeomSources::gpTest38(this); } void CGeometryDoc::OnBUTTONTest39() { Current = 39; - GeomSources::gpTest39(this); } +GeomSources::gpTest39(this); } void CGeometryDoc::OnBUTTONTest40() { Current = 40; - GeomSources::gpTest40(this); } +GeomSources::gpTest40(this); } void CGeometryDoc::OnBUTTONTest41() { Current = 41; - GeomSources::gpTest41(this); } +GeomSources::gpTest41(this); } void CGeometryDoc::OnBUTTONTest42() { Current = 42; - GeomSources::gpTest42(this); } +GeomSources::gpTest42(this); } void CGeometryDoc::OnBUTTONTest43() { Current = 43; - GeomSources::gpTest43(this); } +GeomSources::gpTest43(this); } void CGeometryDoc::OnBUTTONTest44() { Current = 44; - GeomSources::gpTest44(this); } +GeomSources::gpTest44(this); } void CGeometryDoc::OnBUTTONTest45() { Current = 45; - GeomSources::gpTest45(this); } +GeomSources::gpTest45(this); } void CGeometryDoc::OnBUTTONTest46() { Current = 46; - GeomSources::gpTest46(this); } +GeomSources::gpTest46(this); } void CGeometryDoc::OnBUTTONTest47() { Current = 47; - GeomSources::gpTest47(this); } +GeomSources::gpTest47(this); } void CGeometryDoc::OnBUTTONTest48() { Current = 48; - GeomSources::gpTest48(this); } +GeomSources::gpTest48(this); } void CGeometryDoc::OnBUTTONTest49() { Current = 49; - GeomSources::gpTest49(this); } +GeomSources::gpTest49(this); } void CGeometryDoc::OnBUTTONTest50() { Current = 50; - GeomSources::gpTest50(this); } +GeomSources::gpTest50(this); } void CGeometryDoc::OnUpdateBUTTONTest1(CCmdUI* pCmdUI) -{ if (Current == 1) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 1) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest2(CCmdUI* pCmdUI) -{ if (Current == 2) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 2) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest3(CCmdUI* pCmdUI) -{ if (Current == 3) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 3) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest4(CCmdUI* pCmdUI) -{ if (Current == 4) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 4) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest5(CCmdUI* pCmdUI) -{ if (Current == 5) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 5) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest6(CCmdUI* pCmdUI) -{ if (Current == 6) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 6) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest7(CCmdUI* pCmdUI) -{ if (Current == 7) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 7) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest8(CCmdUI* pCmdUI) -{ if (Current == 8) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 8) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest9(CCmdUI* pCmdUI) -{ if (Current == 9) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 9) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest10(CCmdUI* pCmdUI) -{ if (Current == 10) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 10) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest11(CCmdUI* pCmdUI) -{ if (Current == 11) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 11) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest12(CCmdUI* pCmdUI) -{ if (Current == 12) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 12) + pCmdUI->SetCheck(true); + else pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest13(CCmdUI* pCmdUI) -{ if (Current == 13) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 13) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } void CGeometryDoc::OnUpdateBUTTONTest14(CCmdUI* pCmdUI) -{ if (Current == 14) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +{ + if (Current == 14) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest15(CCmdUI* pCmdUI) -{ if (Current == 15) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest15(CCmdUI* pCmdUI) +{ + if(Current == 15) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest16(CCmdUI* pCmdUI) -{ if (Current == 16) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest16(CCmdUI* pCmdUI) +{ + if (Current == 16) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest17(CCmdUI* pCmdUI) -{ if (Current == 17) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest17(CCmdUI* pCmdUI) +{ + if (Current == 17) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest18(CCmdUI* pCmdUI) -{ if (Current == 18) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest18(CCmdUI* pCmdUI) +{ + if (Current == 18) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest19(CCmdUI* pCmdUI) -{ if (Current == 19) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest19(CCmdUI* pCmdUI) +{ + if (Current == 19) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest20(CCmdUI* pCmdUI) -{ if (Current == 20) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest20(CCmdUI* pCmdUI) +{ + if (Current == 20) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest21(CCmdUI* pCmdUI) -{ if (Current == 21) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest21(CCmdUI* pCmdUI) +{ + if (Current == 21) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest22(CCmdUI* pCmdUI) -{ if (Current == 22) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest22(CCmdUI* pCmdUI) +{ + if (Current == 22) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest23(CCmdUI* pCmdUI) -{ if (Current == 23) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest23(CCmdUI* pCmdUI) +{ + if (Current == 23) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest24(CCmdUI* pCmdUI) -{ if (Current == 24) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest24(CCmdUI* pCmdUI) +{ + if (Current == 24) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest25(CCmdUI* pCmdUI) -{ if (Current == 25) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest25(CCmdUI* pCmdUI) +{ + if (Current == 25) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest26(CCmdUI* pCmdUI) -{ if (Current == 26) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest26(CCmdUI* pCmdUI) +{ + if (Current == 26) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest27(CCmdUI* pCmdUI) -{ if (Current == 27) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest27(CCmdUI* pCmdUI) +{ + if (Current == 27) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest28(CCmdUI* pCmdUI) -{ if (Current == 28) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest28(CCmdUI* pCmdUI) +{ + if (Current == 28) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest29(CCmdUI* pCmdUI) -{ if (Current == 29) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest29(CCmdUI* pCmdUI) +{ + if (Current == 29) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest30(CCmdUI* pCmdUI) -{ if (Current == 30) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest30(CCmdUI* pCmdUI) +{ + if (Current == 30) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest31(CCmdUI* pCmdUI) -{ if (Current == 31) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest31(CCmdUI* pCmdUI) +{ + if (Current == 31) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest32(CCmdUI* pCmdUI) -{ if (Current == 32) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest32(CCmdUI* pCmdUI) +{ + if (Current == 32) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest33(CCmdUI* pCmdUI) -{ if (Current == 33) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest33(CCmdUI* pCmdUI) +{ + if (Current == 33) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest34(CCmdUI* pCmdUI) -{ if (Current == 34) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest34(CCmdUI* pCmdUI) +{ + if (Current == 34) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest35(CCmdUI* pCmdUI) -{ if (Current == 35) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest35(CCmdUI* pCmdUI) +{ + if (Current == 35) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest36(CCmdUI* pCmdUI) -{ if (Current == 36) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest36(CCmdUI* pCmdUI) +{ + if (Current == 36) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest37(CCmdUI* pCmdUI) -{ if (Current == 37) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest37(CCmdUI* pCmdUI) +{ + if (Current == 37) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest38(CCmdUI* pCmdUI) -{ if (Current == 38) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest38(CCmdUI* pCmdUI) +{ + if (Current == 38) + pCmdUI->SetCheck(true); +else +pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest39(CCmdUI* pCmdUI) -{ if (Current == 39) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest39(CCmdUI* pCmdUI) +{ + if (Current == 39) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest40(CCmdUI* pCmdUI) -{ if (Current == 40) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest40(CCmdUI* pCmdUI) +{ + if (Current == 40) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest41(CCmdUI* pCmdUI) -{ if (Current == 41) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest41(CCmdUI* pCmdUI) +{ + if (Current == 41) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest42(CCmdUI* pCmdUI) -{ if (Current == 42) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest42(CCmdUI* pCmdUI) +{ + if (Current == 42) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest43(CCmdUI* pCmdUI) -{ if (Current == 43) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest43(CCmdUI* pCmdUI) +{ + if (Current == 43) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest44(CCmdUI* pCmdUI) -{ if (Current == 44) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest44(CCmdUI* pCmdUI) +{ + if (Current == 44) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest45(CCmdUI* pCmdUI) -{ if (Current == 45) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest45(CCmdUI* pCmdUI) +{ + if (Current == 45) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest46(CCmdUI* pCmdUI) -{ if (Current == 46) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest46(CCmdUI* pCmdUI) +{ + if (Current == 46) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest47(CCmdUI* pCmdUI) -{ if (Current == 47) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest47(CCmdUI* pCmdUI) +{ + if (Current == 47) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest48(CCmdUI* pCmdUI) -{ if (Current == 48) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest48(CCmdUI* pCmdUI) +{ + if (Current == 48) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest49(CCmdUI* pCmdUI) -{ if (Current == 49) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest49(CCmdUI* pCmdUI) +{ + if (Current == 49) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } -void CGeometryDoc::OnUpdateBUTTONTest50(CCmdUI* pCmdUI) -{ if (Current == 50) pCmdUI->SetCheck(true); - else pCmdUI->SetCheck(false); +void CGeometryDoc::OnUpdateBUTTONTest50(CCmdUI* pCmdUI) +{ + if (Current == 50) + pCmdUI->SetCheck(true); + else + pCmdUI->SetCheck(false); } - - - - void CGeometryDoc::OnCloseDocument() { - // TODO: Add your specialized code here and/or call the base class - - CDocument::OnCloseDocument(); + // TODO: Add your specialized code here and/or call the base class + CDocument::OnCloseDocument(); } void CGeometryDoc::Fit() { - CMDIFrameWnd *pFrame = (CMDIFrameWnd*)AfxGetApp()->m_pMainWnd; - CMDIChildWnd *pChild = (CMDIChildWnd *) pFrame->GetActiveFrame(); - OCC_3dView *pView = (OCC_3dView *) pChild->GetActiveView(); - pView->FitAll(); + CMDIFrameWnd *pFrame = (CMDIFrameWnd*)AfxGetApp()->m_pMainWnd; + CMDIChildWnd *pChild = (CMDIChildWnd *) pFrame->GetActiveFrame(); + OCC_3dView *pView = (OCC_3dView *) pChild->GetActiveView(); + pView->FitAll(); } void CGeometryDoc::OnCreateSol() { - // TODO: Add your command handler code here - // Creation d'un sol - CFileDialog dlg(TRUE, - NULL, - NULL, - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - "Points Files (*.dat)|*.dat; |All Files (*.*)|*.*||", - NULL ); + // TODO: Add your command handler code here + // Creation d'un sol + CFileDialog dlg(TRUE, + NULL, + NULL, + OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, + "Points Files (*.dat)|*.dat; |All Files (*.*)|*.*||", + NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); - initdir += "\\Data\\SurfaceFromPoints"; + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); + initdir += "\\Data\\SurfaceFromPoints"; - dlg.m_ofn.lpstrInitialDir = initdir; + dlg.m_ofn.lpstrInitialDir = initdir; - if (dlg.DoModal() == IDOK) - { - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); - CString filename = dlg.GetPathName(); + if (dlg.DoModal() == IDOK) + { + SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); + CString filename = dlg.GetPathName(); - filebuf fic; - istream in(&fic); - if (!fic.open((Standard_CString)(LPCTSTR)filename,ios::in)) - MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : Unable to open file","CasCade Error",MB_ICONERROR); - TColgp_SequenceOfXYZ seqOfXYZ; - gp_XYZ pntXYZ; - Standard_Integer nbPnt=0; - Standard_Real x,y,z; - BRep_Builder B; - TopoDS_Compound C; - B.MakeCompound(C); - while (!in.fail()|| !in.eof()){ - if (in >> x && in >> y && in >> z){ - pntXYZ.SetX(x); - pntXYZ.SetY(y); - pntXYZ.SetZ(z); - nbPnt++; - seqOfXYZ.Append(pntXYZ); - BRepBuilderAPI_MakeVertex V(gp_Pnt(x, y, z)); - B.Add(C,V.Vertex()); - } - } - fic.close(); - Handle(AIS_Shape) anAISCompound = new AIS_Shape(C); - myAISContext->Display(anAISCompound, Standard_False); - Fit(); - Sleep(1000); - GeoAlgo_Sol sol; - sol.Build(seqOfXYZ); - - if (sol.IsDone() == Standard_True){ - Handle(Geom_BSplineSurface) GeomSol = sol.Surface(); - TopoDS_Face aface = BRepBuilderAPI_MakeFace(GeomSol, Precision::Confusion()); - if (!BRepAlgo::IsValid(aface)) - MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : The plate surface is not valid!","CasCade Error",MB_ICONERROR); - Handle_AIS_Shape anAISShape=new AIS_Shape(aface); - myAISContext->Display(anAISShape, Standard_False); - Fit(); - } - else - MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : Computation has failed","CasCade Error",MB_ICONERROR); - } + filebuf fic; + istream in(&fic); + if (!fic.open((Standard_CString)(LPCTSTR)filename,ios::in)) + MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : Unable to open file","CasCade Error",MB_ICONERROR); + TColgp_SequenceOfXYZ seqOfXYZ; + gp_XYZ pntXYZ; + Standard_Integer nbPnt=0; + Standard_Real x,y,z; + BRep_Builder B; + TopoDS_Compound C; + B.MakeCompound(C); + while (!in.fail()|| !in.eof()) + { + if (in >> x && in >> y && in >> z){ + pntXYZ.SetX(x); + pntXYZ.SetY(y); + pntXYZ.SetZ(z); + nbPnt++; + seqOfXYZ.Append(pntXYZ); + BRepBuilderAPI_MakeVertex V(gp_Pnt(x, y, z)); + B.Add(C,V.Vertex()); + } + } + fic.close(); + Handle(AIS_Shape) anAISCompound = new AIS_Shape(C); + myAISContext->Display(anAISCompound, Standard_False); + Fit(); + Sleep(1000); + GeoAlgo_Sol sol; + sol.Build(seqOfXYZ); + + if (sol.IsDone() == Standard_True) + { + Handle(Geom_BSplineSurface) GeomSol = sol.Surface(); + TopoDS_Face aface = BRepBuilderAPI_MakeFace(GeomSol, Precision::Confusion()); + if (!BRepAlgo::IsValid(aface)) + MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : The plate surface is not valid!","CasCade Error",MB_ICONERROR); + Handle_AIS_Shape anAISShape=new AIS_Shape(aface); + myAISContext->Display(anAISShape, Standard_False); + Fit(); + } + else + MessageBox(AfxGetApp()->m_pMainWnd->m_hWnd,"Error : Computation has failed","CasCade Error",MB_ICONERROR); + } } /********************************************************************************************* @@ -964,7 +1117,7 @@ static Standard_Boolean fixParam(Standard_Real& theParam) void CGeometryDoc::OnSimplify() { - CString initfile(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initfile(((OCC_App*) AfxGetApp())->GetInitDataDir()); initfile += "\\..\\..\\Data\\"; initfile += "shell1.brep"; @@ -972,9 +1125,6 @@ void CGeometryDoc::OnSimplify() TopoDS_Shape aShape; BRep_Builder aBld; - //Standard_Boolean isRead = BRepTools::Read (aShape, aPath.ToCString(), aBld); - //if (!isRead) -// isRead = BRepTools::Read (aShape, bPath.ToCString(), aBld); Standard_Boolean isRead = BRepTools::Read (aShape, Path.ToCString(), aBld); if (!isRead) { @@ -982,9 +1132,7 @@ void CGeometryDoc::OnSimplify() myCResultDialog.SetText((CString)Path.ToCString()); return; } - myAISContext->SetDisplayMode(AIS_Shaded); - simplify(aShape); } @@ -1150,178 +1298,178 @@ void CGeometryDoc::simplify(const TopoDS_Shape& aShape) " if (aFixedFace.IsNull()) " EOL " return;" EOL); - // define parameter triangulation - Standard_Real aDeflection = 0.1; - - // removes all the triangulations of the faces , - //and all the polygons on the triangulations of the edges - BRepTools::Clean(aShape); - // adds a triangulation of the shape aShape with the deflection aDeflection - BRepMesh::Mesh(aShape,aDeflection); + // define parameter triangulation + Standard_Real aDeflection = 0.1; - Standard_Integer aIndex = 1, nbNodes = 0; - - // define two sequence of points - TColgp_SequenceOfPnt aPoints, aPoints1; - - // triangulation - for(TopExp_Explorer aExpFace(aShape,TopAbs_FACE); aExpFace.More(); aExpFace.Next()) - { - TopoDS_Face aFace = TopoDS::Face(aExpFace.Current()); - TopLoc_Location aLocation; + // removes all the triangulations of the faces , + //and all the polygons on the triangulations of the edges + BRepTools::Clean(aShape); + // adds a triangulation of the shape aShape with the deflection aDeflection + BRepMesh::Mesh(aShape,aDeflection); - // takes the triangulation of the face aFace - Handle_Poly_Triangulation aTr = BRep_Tool::Triangulation(aFace,aLocation); + Standard_Integer aIndex = 1, nbNodes = 0; - if(!aTr.IsNull()) - { - // takes the array of nodes for this triangulation - const TColgp_Array1OfPnt& aNodes = aTr->Nodes(); - nbNodes = aNodes.Length(); + // define two sequence of points + TColgp_SequenceOfPnt aPoints, aPoints1; - for( Standard_Integer i = 1; i <= nbNodes; i++) - { - // create seguence of node points in absolute coordinate system - gp_Pnt aPnt = aNodes(i).Transformed(aLocation); - aPoints.Append(aPnt); - + // triangulation + for(TopExp_Explorer aExpFace(aShape,TopAbs_FACE); aExpFace.More(); aExpFace.Next()) + { + TopoDS_Face aFace = TopoDS::Face(aExpFace.Current()); + TopLoc_Location aLocation; + + // takes the triangulation of the face aFace + Handle_Poly_Triangulation aTr = BRep_Tool::Triangulation(aFace,aLocation); + + if(!aTr.IsNull()) + { + // takes the array of nodes for this triangulation + const TColgp_Array1OfPnt& aNodes = aTr->Nodes(); + nbNodes = aNodes.Length(); + + for( Standard_Integer i = 1; i <= nbNodes; i++) + { + // create seguence of node points in absolute coordinate system + gp_Pnt aPnt = aNodes(i).Transformed(aLocation); + aPoints.Append(aPnt); + + } } } - } - - // remove double points - nbNodes = aPoints.Length(); - Standard_Integer i; - for( i = 1; i <= nbNodes; i++) - { - gp_Pnt aPi = aPoints(i); - Standard_Integer j; - for( j = i + 1; j < nbNodes; j++) + + // remove double points + nbNodes = aPoints.Length(); + Standard_Integer i; + for( i = 1; i <= nbNodes; i++) { - gp_Pnt aPj = aPoints(j); - if(!aPi.IsEqual(aPj,0.9)) - aIndex++; - } - if(aIndex == j - 1) - aPoints1.Append(aPi); - - aIndex = i + 1; - } - - // find max point - aIndex = 0; - gp_Pnt aPntMax = aPoints1(1); - nbNodes = aPoints1.Length(); - for(i = 2; i <= nbNodes; i++) - { - if(aPoints1(i).X() > aPntMax.X()) - { - aIndex = i; - aPntMax = aPoints1(aIndex); - } - } - - // clear seguence - aPoints.Clear(); - - Standard_Integer nbLeftNodes = nbNodes; - - // ascending sort - fill aPoints with ascending - // by X coordinate points from aPoints1 - for(i = 1; i < nbNodes; i++) - { - Standard_Real aMin = aPntMax.X(); - aIndex = 1; - for( Standard_Integer j = 1; j <= nbLeftNodes; j++) - { - if(aPoints1(j).X() < aMin) + gp_Pnt aPi = aPoints(i); + Standard_Integer j; + for( j = i + 1; j < nbNodes; j++) { - aMin = aPoints1(j).X(); - aIndex = j; + gp_Pnt aPj = aPoints(j); + if(!aPi.IsEqual(aPj,0.9)) + aIndex++; + } + if(aIndex == j - 1) + aPoints1.Append(aPi); + + aIndex = i + 1; + } + + // find max point + aIndex = 0; + gp_Pnt aPntMax = aPoints1(1); + nbNodes = aPoints1.Length(); + for(i = 2; i <= nbNodes; i++) + { + if(aPoints1(i).X() > aPntMax.X()) + { + aIndex = i; + aPntMax = aPoints1(aIndex); } } - aPoints.Append(aPoints1(aIndex)); - aPoints1.Remove(aIndex); - nbLeftNodes = aPoints1.Length(); - } - aPoints.Append(aPntMax); - // define parameters GeomPlate_BuildPlateSurface - Standard_Integer Degree = 3; - Standard_Integer NbPtsOnCur = 10; - Standard_Integer NbIter = 3; - Standard_Integer Order = 0; - Standard_Integer MaxSeg = 9; - Standard_Integer MaxDegree = 5; - Standard_Real dmax, anApproxTol = 0.001; - Standard_Real aConstrTol = Precision::Confusion(); - - // define object BuildPlateSurface - GeomPlate_BuildPlateSurface BPSurf(Degree,NbPtsOnCur,NbIter); - - // add point constraints to GeomPlate_BuildPlateSurface object - nbNodes = aPoints.Length(); - for (i = 1; i <= nbNodes; i++) - BPSurf.Add(new GeomPlate_PointConstraint(aPoints(i), Order, aConstrTol)); + // clear seguence + aPoints.Clear(); - BPSurf.Perform(); + Standard_Integer nbLeftNodes = nbNodes; - // make PlateSurface - Handle(GeomPlate_Surface) PSurf; - Handle(Geom_Surface) aSurf; - - if (BPSurf.IsDone()) - { - PSurf = BPSurf.Surface(); + // ascending sort - fill aPoints with ascending + // by X coordinate points from aPoints1 + for(i = 1; i < nbNodes; i++) + { + Standard_Real aMin = aPntMax.X(); + aIndex = 1; + for( Standard_Integer j = 1; j <= nbLeftNodes; j++) + { + if(aPoints1(j).X() < aMin) + { + aMin = aPoints1(j).X(); + aIndex = j; + } + } + aPoints.Append(aPoints1(aIndex)); + aPoints1.Remove(aIndex); + nbLeftNodes = aPoints1.Length(); + } + aPoints.Append(aPntMax); - // define parameter approximation - dmax = Max(0.01,10*BPSurf.G0Error()); + // define parameters GeomPlate_BuildPlateSurface + Standard_Integer Degree = 3; + Standard_Integer NbPtsOnCur = 10; + Standard_Integer NbIter = 3; + Standard_Integer Order = 0; + Standard_Integer MaxSeg = 9; + Standard_Integer MaxDegree = 5; + Standard_Real dmax, anApproxTol = 0.001; + Standard_Real aConstrTol = Precision::Confusion(); - // make approximation - GeomPlate_MakeApprox Mapp(PSurf,anApproxTol, MaxSeg,MaxDegree,dmax); - aSurf = Mapp.Surface(); - } - else - return; + // define object BuildPlateSurface + GeomPlate_BuildPlateSurface BPSurf(Degree,NbPtsOnCur,NbIter); - ShapeAnalysis_FreeBounds aFreeBounds(aShape, Standard_False, Standard_True); - TopoDS_Compound aClosedWires = aFreeBounds.GetClosedWires(); - TopTools_IndexedMapOfShape aWires; - TopExp::MapShapes(aClosedWires, TopAbs_WIRE, aWires); - TopoDS_Wire aWire; - Standard_Integer nbWires = aWires.Extent(); - if (nbWires) - aWire = TopoDS::Wire(aWires(1)); - else - return; + // add point constraints to GeomPlate_BuildPlateSurface object + nbNodes = aPoints.Length(); + for (i = 1; i <= nbNodes; i++) + BPSurf.Add(new GeomPlate_PointConstraint(aPoints(i), Order, aConstrTol)); - BRep_Builder B; - TopoDS_Face aFace; - B.MakeFace(aFace, aSurf, Precision::Confusion()); - B.Add(aFace, aWire); - Handle_ShapeFix_Shape sfs = new ShapeFix_Shape(aFace); - sfs->Perform(); - TopoDS_Shape aFixedFace = sfs->Shape(); - if (aFixedFace.IsNull()) - return; + BPSurf.Perform(); - // output surface, make it half transparent - Handle_AIS_InteractiveObject aSurfIO = drawSurface( - aSurf, Quantity_NOC_LEMONCHIFFON3, Standard_False); - aSurfIO->SetTransparency(0.5); - myAISContext->Display(aSurfIO,Standard_False); - Fit(); + // make PlateSurface + Handle(GeomPlate_Surface) PSurf; + Handle(Geom_Surface) aSurf; - if(WAIT_A_LITTLE) return; + if (BPSurf.IsDone()) + { + PSurf = BPSurf.Surface(); - // output points - for(i = 1; i <= nbNodes; i++) - drawPoint(aPoints(i)); + // define parameter approximation + dmax = Max(0.01,10*BPSurf.G0Error()); - if(WAIT_A_LITTLE) return; - - // output resulting face - drawShape(aFixedFace); + // make approximation + GeomPlate_MakeApprox Mapp(PSurf,anApproxTol, MaxSeg,MaxDegree,dmax); + aSurf = Mapp.Surface(); + } + else + return; + + ShapeAnalysis_FreeBounds aFreeBounds(aShape, Standard_False, Standard_True); + TopoDS_Compound aClosedWires = aFreeBounds.GetClosedWires(); + TopTools_IndexedMapOfShape aWires; + TopExp::MapShapes(aClosedWires, TopAbs_WIRE, aWires); + TopoDS_Wire aWire; + Standard_Integer nbWires = aWires.Extent(); + if (nbWires) + aWire = TopoDS::Wire(aWires(1)); + else + return; + + BRep_Builder B; + TopoDS_Face aFace; + B.MakeFace(aFace, aSurf, Precision::Confusion()); + B.Add(aFace, aWire); + Handle_ShapeFix_Shape sfs = new ShapeFix_Shape(aFace); + sfs->Perform(); + TopoDS_Shape aFixedFace = sfs->Shape(); + if (aFixedFace.IsNull()) + return; + + // output surface, make it half transparent + Handle_AIS_InteractiveObject aSurfIO = drawSurface( + aSurf, Quantity_NOC_LEMONCHIFFON3, Standard_False); + aSurfIO->SetTransparency(0.5); + myAISContext->Display(aSurfIO,Standard_False); + Fit(); + + if(WAIT_A_LITTLE) return; + + // output points + for(i = 1; i <= nbNodes; i++) + drawPoint(aPoints(i)); + + if(WAIT_A_LITTLE) return; + + // output resulting face + drawShape(aFixedFace); } Handle_AIS_InteractiveObject CGeometryDoc::drawSurface @@ -1341,15 +1489,17 @@ Handle_AIS_InteractiveObject CGeometryDoc::drawSurface myAISContext->SetMaterial(aGraphicSurface, Graphic3d_NOM_PLASTIC, toDisplay); myAISContext->SetColor(aGraphicSurface, theColor, toDisplay); - if (toDisplay) { - if (FitMode){ - myAISContext->Display (aGraphicSurface, Standard_False); - Fit(); - } - else - myAISContext->Display (aGraphicSurface); + if (toDisplay) + { + if (FitMode) + { + myAISContext->Display (aGraphicSurface, Standard_False); + Fit(); + } + else + myAISContext->Display (aGraphicSurface); } - + return aGraphicSurface; } @@ -1382,8 +1532,9 @@ Handle_AIS_Point CGeometryDoc::drawPoint Handle(AIS_Point) aGraphicPoint = new AIS_Point (new Geom_CartesianPoint(aPnt)); myAISContext->SetColor (aGraphicPoint, theColor, toDisplay); - if (toDisplay) { - myAISContext->Display (aGraphicPoint); + if (toDisplay) + { + myAISContext->Display (aGraphicPoint); //COCCDemoDoc::Fit(); } @@ -1398,13 +1549,15 @@ Handle_AIS_Shape CGeometryDoc::drawShape Handle_AIS_Shape aGraphicShape = new AIS_Shape(theShape); myAISContext->SetMaterial(aGraphicShape, theMaterial, toDisplay); - if (toDisplay) { - if (FitMode){ - myAISContext->Display (aGraphicShape, Standard_False); - Fit(); - } - else - myAISContext->Display (aGraphicShape); + if (toDisplay) + { + if (FitMode) + { + myAISContext->Display (aGraphicShape, Standard_False); + Fit(); + } + else + myAISContext->Display (aGraphicShape); } return aGraphicShape; diff --git a/samples/mfc/standard/01_Geometry/src/GeometryDoc.h b/samples/mfc/standard/01_Geometry/src/GeometryDoc.h index b90fa3e1a7..3b286b9900 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryDoc.h +++ b/samples/mfc/standard/01_Geometry/src/GeometryDoc.h @@ -9,7 +9,6 @@ #pragma once #endif // _MSC_VER >= 1000 -#include "ISession2D_InteractiveContext.h" #include "ResultDialog.h" class Handle_AIS_Point; @@ -17,225 +16,224 @@ class Handle_AIS_Point; class CGeometryDoc : public CDocument { public: - void Put2DOnTop(bool isMax = true); - void Put3DOnTop(bool isMax = true); - void Fit2DViews(); - void Set3DViewsZoom(const Quantity_Factor& Coef ); - void Fit3DViews(Quantity_Coefficient Coef); - void simplify(const TopoDS_Shape& aShape); + void Put2DOnTop(bool isMax = true); + void Put3DOnTop(bool isMax = true); + void Fit2DViews(); + void Set3DViewsZoom(const Quantity_Factor& Coef ); + void Fit3DViews(Quantity_Coefficient Coef); + void simplify(const TopoDS_Shape& aShape); - static void Fit(); + static void Fit(); - // 2D + // 2D + void DragEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Standard_Integer TheState, + const Handle_V3d_View& aView ); + void InputEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Handle_V3d_View& aView ); + void MoveEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Handle_V3d_View& aView ); + void ShiftMoveEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Handle_V3d_View& aView ); + void ShiftDragEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Standard_Integer TheState, + const Handle_V3d_View& aView ); + void ShiftInputEvent2D (const Standard_Integer x , + const Standard_Integer y , + const Handle_V3d_View& aView ); + void Popup2D (const Standard_Integer x , + const Standard_Integer y , + const Handle_V3d_View& aView ); - void DragEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState, - const Handle_V2d_View& aView ); - void InputEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Handle_V2d_View& aView ); - void MoveEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Handle_V2d_View& aView ); - void ShiftMoveEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Handle_V2d_View& aView ); - void ShiftDragEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState, - const Handle_V2d_View& aView ); - void ShiftInputEvent2D (const Standard_Integer x , - const Standard_Integer y , - const Handle_V2d_View& aView ); - void Popup2D (const Standard_Integer x , - const Standard_Integer y , - const Handle_V2d_View& aView ); + Handle_AIS_InteractiveObject drawSurface + (const Handle_Geom_Surface& theSurface, + const Quantity_Color& theColor, + const Standard_Boolean toDisplay); - Handle_AIS_InteractiveObject drawSurface - (const Handle_Geom_Surface& theSurface, - const Quantity_Color& theColor, - const Standard_Boolean toDisplay); + Standard_Boolean WaitForInput (unsigned long aMilliSeconds); + // Waits for a user input or a period of time has been elapsed - Standard_Boolean WaitForInput (unsigned long aMilliSeconds); - // Waits for a user input or a period of time has been elapsed + Handle_AIS_Point drawPoint (const gp_Pnt& thePnt, + const Quantity_Color& theColor = Quantity_Color(Quantity_NOC_GREEN), + const Standard_Boolean toDisplay = Standard_True); + // creates a presentation of the given point + // and displays it in the viewer if toDisplay = Standard_True - Handle_AIS_Point drawPoint (const gp_Pnt& thePnt, - const Quantity_Color& theColor = Quantity_Color(Quantity_NOC_GREEN), - const Standard_Boolean toDisplay = Standard_True); - // creates a presentation of the given point - // and displays it in the viewer if toDisplay = Standard_True - - Handle_AIS_Shape drawShape (const TopoDS_Shape& theShape, - const Graphic3d_NameOfMaterial theMaterial = Graphic3d_NOM_BRASS, - const Standard_Boolean toDisplay = Standard_True); - // creates a presentation of the given shape with the given material - // (color is default for a given material) - // and displays it in the viewer if toDisplay = Standard_True + Handle_AIS_Shape drawShape (const TopoDS_Shape& theShape, + const Graphic3d_NameOfMaterial theMaterial = Graphic3d_NOM_BRASS, + const Standard_Boolean toDisplay = Standard_True); + // creates a presentation of the given shape with the given material + // (color is default for a given material) + // and displays it in the viewer if toDisplay = Standard_True protected: // create from serialization only - CGeometryDoc(); - DECLARE_DYNCREATE(CGeometryDoc) + CGeometryDoc(); + DECLARE_DYNCREATE(CGeometryDoc) -// Attributes + // Attributes public: -// Operations + // Operations public: -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CGeometryDoc) - public: - virtual BOOL OnNewDocument(); - virtual void Serialize(CArchive& ar); - virtual void OnCloseDocument(); - //}}AFX_VIRTUAL - -// Implementation + // Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CGeometryDoc) public: - virtual ~CGeometryDoc(); + virtual BOOL OnNewDocument(); + virtual void Serialize(CArchive& ar); + virtual void OnCloseDocument(); + //}}AFX_VIRTUAL + + // Implementation +public: + virtual ~CGeometryDoc(); #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif protected: -// Generated message map functions + // Generated message map functions protected: - //{{AFX_MSG(CGeometryDoc) - afx_msg void OnWindowNew2d(); - afx_msg void OnBUTTONTest1(); - afx_msg void OnBUTTONTest2(); - afx_msg void OnBUTTONTest3(); - afx_msg void OnBUTTONTest4(); - afx_msg void OnBUTTONTest5(); - afx_msg void OnBUTTONTest6(); - afx_msg void OnBUTTONTest7(); - afx_msg void OnBUTTONTest8(); - afx_msg void OnBUTTONTest9(); - afx_msg void OnBUTTONTest10(); - afx_msg void OnBUTTONTest11(); - afx_msg void OnBUTTONTest12(); - afx_msg void OnBUTTONTest13(); - afx_msg void OnBUTTONTest14(); - afx_msg void OnBUTTONTest15(); - afx_msg void OnBUTTONTest16(); - afx_msg void OnBUTTONTest17(); - afx_msg void OnBUTTONTest18(); - afx_msg void OnBUTTONTest19(); - afx_msg void OnBUTTONTest20(); - afx_msg void OnBUTTONTest21(); - afx_msg void OnBUTTONTest22(); - afx_msg void OnBUTTONTest23(); - afx_msg void OnBUTTONTest24(); - afx_msg void OnBUTTONTest25(); - afx_msg void OnBUTTONTest26(); - afx_msg void OnBUTTONTest27(); - afx_msg void OnBUTTONTest28(); - afx_msg void OnBUTTONTest29(); - afx_msg void OnBUTTONTest30(); - afx_msg void OnBUTTONTest31(); - afx_msg void OnBUTTONTest32(); - afx_msg void OnBUTTONTest33(); - afx_msg void OnBUTTONTest34(); - afx_msg void OnBUTTONTest35(); - afx_msg void OnBUTTONTest36(); - afx_msg void OnBUTTONTest37(); - afx_msg void OnBUTTONTest38(); - afx_msg void OnBUTTONTest39(); - afx_msg void OnBUTTONTest40(); - afx_msg void OnBUTTONTest41(); - afx_msg void OnBUTTONTest42(); - afx_msg void OnBUTTONTest43(); - afx_msg void OnBUTTONTest44(); - afx_msg void OnBUTTONTest45(); - afx_msg void OnBUTTONTest46(); - afx_msg void OnBUTTONTest47(); - afx_msg void OnBUTTONTest48(); - afx_msg void OnBUTTONTest49(); - afx_msg void OnBUTTONTest50(); - afx_msg void OnUpdateBUTTONTest1(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest2(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest3(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest4(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest5(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest6(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest7(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest8(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest9(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest10(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest11(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest12(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest13(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest14(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest15(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest16(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest17(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest18(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest19(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest20(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest21(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest22(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest23(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest24(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest25(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest26(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest27(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest28(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest29(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest30(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest31(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest32(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest33(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest34(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest35(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest36(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest37(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest38(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest39(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest40(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest41(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest42(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest43(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest44(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest45(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest46(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest47(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest48(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest49(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONTest50(CCmdUI* pCmdUI); - afx_msg void OnCreateSol(); - afx_msg void OnSimplify(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //{{AFX_MSG(CGeometryDoc) + afx_msg void OnWindowNew2d(); + afx_msg void OnBUTTONTest1(); + afx_msg void OnBUTTONTest2(); + afx_msg void OnBUTTONTest3(); + afx_msg void OnBUTTONTest4(); + afx_msg void OnBUTTONTest5(); + afx_msg void OnBUTTONTest6(); + afx_msg void OnBUTTONTest7(); + afx_msg void OnBUTTONTest8(); + afx_msg void OnBUTTONTest9(); + afx_msg void OnBUTTONTest10(); + afx_msg void OnBUTTONTest11(); + afx_msg void OnBUTTONTest12(); + afx_msg void OnBUTTONTest13(); + afx_msg void OnBUTTONTest14(); + afx_msg void OnBUTTONTest15(); + afx_msg void OnBUTTONTest16(); + afx_msg void OnBUTTONTest17(); + afx_msg void OnBUTTONTest18(); + afx_msg void OnBUTTONTest19(); + afx_msg void OnBUTTONTest20(); + afx_msg void OnBUTTONTest21(); + afx_msg void OnBUTTONTest22(); + afx_msg void OnBUTTONTest23(); + afx_msg void OnBUTTONTest24(); + afx_msg void OnBUTTONTest25(); + afx_msg void OnBUTTONTest26(); + afx_msg void OnBUTTONTest27(); + afx_msg void OnBUTTONTest28(); + afx_msg void OnBUTTONTest29(); + afx_msg void OnBUTTONTest30(); + afx_msg void OnBUTTONTest31(); + afx_msg void OnBUTTONTest32(); + afx_msg void OnBUTTONTest33(); + afx_msg void OnBUTTONTest34(); + afx_msg void OnBUTTONTest35(); + afx_msg void OnBUTTONTest36(); + afx_msg void OnBUTTONTest37(); + afx_msg void OnBUTTONTest38(); + afx_msg void OnBUTTONTest39(); + afx_msg void OnBUTTONTest40(); + afx_msg void OnBUTTONTest41(); + afx_msg void OnBUTTONTest42(); + afx_msg void OnBUTTONTest43(); + afx_msg void OnBUTTONTest44(); + afx_msg void OnBUTTONTest45(); + afx_msg void OnBUTTONTest46(); + afx_msg void OnBUTTONTest47(); + afx_msg void OnBUTTONTest48(); + afx_msg void OnBUTTONTest49(); + afx_msg void OnBUTTONTest50(); + afx_msg void OnUpdateBUTTONTest1(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest2(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest3(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest4(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest5(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest6(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest7(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest8(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest9(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest10(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest11(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest12(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest13(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest14(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest15(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest16(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest17(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest18(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest19(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest20(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest21(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest22(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest23(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest24(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest25(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest26(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest27(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest28(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest29(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest30(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest31(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest32(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest33(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest34(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest35(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest36(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest37(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest38(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest39(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest40(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest41(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest42(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest43(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest44(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest45(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest46(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest47(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest48(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest49(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONTest50(CCmdUI* pCmdUI); + afx_msg void OnCreateSol(); + afx_msg void OnSimplify(); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() private: - Handle_V3d_Viewer myViewer; - Handle_V3d_Viewer myViewerCollector; - Handle_AIS_InteractiveContext myAISContext; + Handle_V3d_Viewer myViewer; + Handle_V3d_Viewer myViewerCollector; + Handle_AIS_InteractiveContext myAISContext; public : - Handle_AIS_InteractiveContext& GetAISContext(){ return myAISContext; }; - Handle_V3d_Viewer GetViewer() { return myViewer; }; - Handle_V3d_Viewer GetViewerCollector() { return myViewerCollector; }; + Handle_AIS_InteractiveContext& GetAISContext(){ return myAISContext; }; + Handle_V3d_Viewer GetViewer() { return myViewer; }; + Handle_V3d_Viewer GetViewerCollector() { return myViewerCollector; }; private: - Handle_V2d_Viewer myViewer2D; - Handle_ISession2D_InteractiveContext myISessionContext; + Handle_V3d_Viewer myViewer2D; + Handle_AIS_InteractiveContext myAISContext2D; public : - int Current; - void Minimize3D(); - void Minimize2D(); - Handle_V2d_Viewer GetViewer2D() { return myViewer2D; }; - Handle_ISession2D_InteractiveContext& GetISessionContext(){ return myISessionContext; }; - BOOL FitMode; + int Current; + void Minimize3D(); + void Minimize2D(); + Handle_V3d_Viewer GetViewer2D() { return myViewer2D; }; + Handle_AIS_InteractiveContext& GetISessionContext(){ return myAISContext2D; }; + BOOL FitMode; public : - CResultDialog myCResultDialog; + CResultDialog myCResultDialog; }; diff --git a/samples/mfc/standard/01_Geometry/src/GeometryView.cpp b/samples/mfc/standard/01_Geometry/src/GeometryView.cpp index fb7383d479..0f1f35af39 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryView.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeometryView.cpp @@ -21,24 +21,24 @@ static char THIS_FILE[] = __FILE__; IMPLEMENT_DYNCREATE(CGeometryView, OCC_3dView) BEGIN_MESSAGE_MAP(CGeometryView, OCC_3dView) - //{{AFX_MSG_MAP(CGeometryView) - ON_COMMAND(ID_FILE_EXPORT_IMAGE, OnFileExportImage) - ON_WM_SIZE() - ON_WM_LBUTTONDOWN() - ON_WM_LBUTTONUP() - ON_WM_MBUTTONDOWN() - ON_WM_MBUTTONUP() - ON_WM_MOUSEMOVE() - ON_WM_RBUTTONDOWN() - ON_WM_RBUTTONUP() - ON_UPDATE_COMMAND_UI(ID_BUTTONHlrOff, OnUpdateBUTTONHlrOff) - ON_UPDATE_COMMAND_UI(ID_BUTTONHlrOn, OnUpdateBUTTONHlrOn) - ON_UPDATE_COMMAND_UI(ID_BUTTONPanGlo, OnUpdateBUTTONPanGlo) - ON_UPDATE_COMMAND_UI(ID_BUTTONPan, OnUpdateBUTTONPan) - ON_UPDATE_COMMAND_UI(ID_BUTTONZoomProg, OnUpdateBUTTONZoomProg) - ON_UPDATE_COMMAND_UI(ID_BUTTONZoomWin, OnUpdateBUTTONZoomWin) - ON_UPDATE_COMMAND_UI(ID_BUTTONRot, OnUpdateBUTTONRot) - //}}AFX_MSG_MAP + //{{AFX_MSG_MAP(CGeometryView) + ON_COMMAND(ID_FILE_EXPORT_IMAGE, OnFileExportImage) + ON_WM_SIZE() + ON_WM_LBUTTONDOWN() + ON_WM_LBUTTONUP() + ON_WM_MBUTTONDOWN() + ON_WM_MBUTTONUP() + ON_WM_MOUSEMOVE() + ON_WM_RBUTTONDOWN() + ON_WM_RBUTTONUP() + ON_UPDATE_COMMAND_UI(ID_BUTTONHlrOff, OnUpdateBUTTONHlrOff) + ON_UPDATE_COMMAND_UI(ID_BUTTONHlrOn, OnUpdateBUTTONHlrOn) + ON_UPDATE_COMMAND_UI(ID_BUTTONPanGlo, OnUpdateBUTTONPanGlo) + ON_UPDATE_COMMAND_UI(ID_BUTTONPan, OnUpdateBUTTONPan) + ON_UPDATE_COMMAND_UI(ID_BUTTONZoomProg, OnUpdateBUTTONZoomProg) + ON_UPDATE_COMMAND_UI(ID_BUTTONZoomWin, OnUpdateBUTTONZoomWin) + ON_UPDATE_COMMAND_UI(ID_BUTTONRot, OnUpdateBUTTONRot) + //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// @@ -58,18 +58,18 @@ CGeometryView::~CGeometryView() #ifdef _DEBUG void CGeometryView::AssertValid() const { - CView::AssertValid(); + CView::AssertValid(); } void CGeometryView::Dump(CDumpContext& dc) const { - CView::Dump(dc); + CView::Dump(dc); } CGeometryDoc* CGeometryView::GetDocument() // non-debug version is inline { - ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CGeometryDoc))); - return (CGeometryDoc*)m_pDocument; + ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CGeometryDoc))); + return (CGeometryDoc*)m_pDocument; } #endif //_DEBUG @@ -79,25 +79,29 @@ CGeometryDoc* CGeometryView::GetDocument() // non-debug version is inline void CGeometryView::OnFileExportImage() { - CFileDialog dlg(FALSE,_T("*.BMP"),NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - _T("BMP Files (*.BMP)|*.bmp |GIF Files (*.GIF)|*.gif | PNG Files (*.PNG)|*.png" - "|JPEG Files (*.JPEG)|*.jpeg | PPM Files (*.PPM)|*.ppm | TIFF Files (*.TIFF)" - "|*.tiff | TGA Files (*.TGA)|*.tga | EXR Files (*.EXR)|*.exr||"), - NULL ); - - if (dlg.DoModal() == IDOK) + CFileDialog aDlg (FALSE, "*.BMP", NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, + "BMP Files (*.BMP)|*.bmp|" + "GIF Files (*.GIF)|*.gif|" + "PNG Files (*.PNG)|*.png|" + "JPEG Files (*.JPG)|*.jpg|" + "PPM Files (*.PPM)|*.ppm|" + "TIFF Files (*.TIFF)|*.tiff|" + "TGA Files (*.TGA)|*.tga|" + "EXR Files (*.EXR)|*.exr||", NULL); + if (aDlg.DoModal() != IDOK) { - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); - CString aFileName = dlg.GetPathName(); - myView->Dump(aFileName); - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW)); + return; } + + SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); + myView->Dump (aDlg.GetPathName()); + SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW)); } void CGeometryView::OnSize(UINT nType, int cx, int cy) { if (!myView.IsNull()) - myView->MustBeResized(); + myView->MustBeResized(); } void CGeometryView::OnLButtonDown(UINT nFlags, CPoint point) @@ -107,277 +111,277 @@ void CGeometryView::OnLButtonDown(UINT nFlags, CPoint point) myXmax=point.x; myYmax=point.y; if ( nFlags & MK_CONTROL ) - { - // Button MB1 down Control :start zomming - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction3d_Nothing : // start a drag - if (nFlags & MK_SHIFT) - ShiftDragEvent(myXmax,myYmax,-1); - else - DragEvent(myXmax,myYmax,-1); - break; - break; - case CurAction3d_DynamicZooming : // noting - // SetCursor(AfxGetApp()->LoadStandardCursor()); - break; - case CurAction3d_WindowZooming : - break; - case CurAction3d_DynamicPanning :// noting - // SetCursor(AfxGetApp()->LoadStandardCursor()); - break; - case CurAction3d_GlobalPanning :// noting - // SetCursor(AfxGetApp()->LoadStandardCursor()); - break; - case CurAction3d_DynamicRotation : - // SetCursor(AfxGetApp()->LoadStandardCursor()); - if (!myDegenerateModeIsOn) - myView->SetDegenerateModeOn(); - myView->StartRotation(point.x,point.y); - break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); - break; - } + { + // Button MB1 down Control :start zomming + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction3d_Nothing : // start a drag + if (nFlags & MK_SHIFT) + ShiftDragEvent(myXmax,myYmax,-1); + else + DragEvent(myXmax,myYmax,-1); + break; + break; + case CurAction3d_DynamicZooming : // noting + // SetCursor(AfxGetApp()->LoadStandardCursor()); + break; + case CurAction3d_WindowZooming : + break; + case CurAction3d_DynamicPanning :// noting + // SetCursor(AfxGetApp()->LoadStandardCursor()); + break; + case CurAction3d_GlobalPanning :// noting + // SetCursor(AfxGetApp()->LoadStandardCursor()); + break; + case CurAction3d_DynamicRotation : + // SetCursor(AfxGetApp()->LoadStandardCursor()); + if (!myDegenerateModeIsOn) + myView->SetDegenerateModeOn(); + myView->StartRotation(point.x,point.y); + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; } + } } void CGeometryView::OnLButtonUp(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - return; - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction3d_Nothing : - if (point.x == myXmin && point.y == myYmin) - { // no offset between down and up --> selectEvent - myXmax=point.x; - myYmax=point.y; - if (nFlags & MK_SHIFT ) - ShiftInputEvent(point.x,point.y); - else - InputEvent (point.x,point.y); - } else - { - myXmax=point.x; myYmax=point.y; - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False); - if (nFlags & MK_SHIFT) - ShiftDragEvent(point.x,point.y,1); - else - DragEvent(point.x,point.y,1); - } - break; - case CurAction3d_DynamicZooming : - // SetCursor(AfxGetApp()->LoadStandardCursor()); - myCurrentMode = CurAction3d_Nothing; - break; - case CurAction3d_WindowZooming : - myXmax=point.x; myYmax=point.y; - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); - if ((abs(myXmin-myXmax)>ValZWMin) || (abs(myYmin-myYmax)>ValZWMin)) - // Test if the zoom window is greater than a minimale window. - { - // Do the zoom window between Pmin and Pmax - myView->WindowFitAll(myXmin,myYmin,myXmax,myYmax); - } - myCurrentMode = CurAction3d_Nothing; - break; - case CurAction3d_DynamicPanning : - myCurrentMode = CurAction3d_Nothing; - break; - case CurAction3d_GlobalPanning : - myView->Place(point.x,point.y,myCurZoom); - myCurrentMode = CurAction3d_Nothing; - break; - case CurAction3d_DynamicRotation : - myCurrentMode = CurAction3d_Nothing; - break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); - break; - } //switch (myCurrentMode) - } // else // if ( Ctrl ) + if ( nFlags & MK_CONTROL ) + { + return; + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction3d_Nothing : + if (point.x == myXmin && point.y == myYmin) + { // no offset between down and up --> selectEvent + myXmax=point.x; + myYmax=point.y; + if (nFlags & MK_SHIFT ) + ShiftInputEvent(point.x,point.y); + else + InputEvent (point.x,point.y); + } else + { + myXmax=point.x; myYmax=point.y; + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False); + if (nFlags & MK_SHIFT) + ShiftDragEvent(point.x,point.y,1); + else + DragEvent(point.x,point.y,1); + } + break; + case CurAction3d_DynamicZooming : + // SetCursor(AfxGetApp()->LoadStandardCursor()); + myCurrentMode = CurAction3d_Nothing; + break; + case CurAction3d_WindowZooming : + myXmax=point.x; myYmax=point.y; + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); + if ((abs(myXmin-myXmax)>ValZWMin) || (abs(myYmin-myYmax)>ValZWMin)) + // Test if the zoom window is greater than a minimale window. + { + // Do the zoom window between Pmin and Pmax + myView->WindowFitAll(myXmin,myYmin,myXmax,myYmax); + } + myCurrentMode = CurAction3d_Nothing; + break; + case CurAction3d_DynamicPanning : + myCurrentMode = CurAction3d_Nothing; + break; + case CurAction3d_GlobalPanning : + myView->Place(point.x,point.y,myCurZoom); + myCurrentMode = CurAction3d_Nothing; + break; + case CurAction3d_DynamicRotation : + myCurrentMode = CurAction3d_Nothing; + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; + } //switch (myCurrentMode) + } // else // if ( Ctrl ) } void CGeometryView::OnMButtonDown(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - // Button MB2 down Control : panning init - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } + if ( nFlags & MK_CONTROL ) + { + // Button MB2 down Control : panning init + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } } void CGeometryView::OnMButtonUp(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - // Button MB2 down Control : panning init - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } + if ( nFlags & MK_CONTROL ) + { + // Button MB2 down Control : panning init + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } } void CGeometryView::OnRButtonDown(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - // SetCursor(AfxGetApp()->LoadStandardCursor()); - if (!myDegenerateModeIsOn) - myView->SetDegenerateModeOn(); - myView->StartRotation(point.x,point.y); - } - else // if ( Ctrl ) - { - Popup(point.x,point.y); - } + if ( nFlags & MK_CONTROL ) + { + // SetCursor(AfxGetApp()->LoadStandardCursor()); + if (!myDegenerateModeIsOn) + myView->SetDegenerateModeOn(); + myView->StartRotation(point.x,point.y); + } + else // if ( Ctrl ) + { + Popup(point.x,point.y); + } } void CGeometryView::OnRButtonUp(UINT nFlags, CPoint point) { - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); - if (!myDegenerateModeIsOn) - { - myView->SetDegenerateModeOff(); - myDegenerateModeIsOn = Standard_False; - } else - { - myView->SetDegenerateModeOn(); - myDegenerateModeIsOn = Standard_True; - } - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW)); + SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); + if (!myDegenerateModeIsOn) + { + myView->SetDegenerateModeOff(); + myDegenerateModeIsOn = Standard_False; + } else + { + myView->SetDegenerateModeOn(); + myDegenerateModeIsOn = Standard_True; + } + SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW)); } void CGeometryView::OnMouseMove(UINT nFlags, CPoint point) { - // ============================ LEFT BUTTON ======================= + // ============================ LEFT BUTTON ======================= if ( nFlags & MK_LBUTTON) + { + if ( nFlags & MK_CONTROL ) { - if ( nFlags & MK_CONTROL ) - { - // move with MB1 and Control : on the dynamic zooming - // Do the zoom in function of mouse's coordinates - myView->Zoom(myXmax,myYmax,point.x,point.y); - // save the current mouse coordinate in min - myXmax = point.x; - myYmax = point.y; - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction3d_Nothing : - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False); - myXmax = point.x; - myYmax = point.y; - if (nFlags & MK_SHIFT) - ShiftDragEvent(myXmax,myYmax,0); - else - DragEvent(myXmax,myYmax,0); - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_True); - break; - case CurAction3d_DynamicZooming : - myView->Zoom(myXmax,myYmax,point.x,point.y); - // save the current mouse coordinate in min \n"; - myXmax=point.x; myYmax=point.y; - break; - case CurAction3d_WindowZooming : - myXmax = point.x; myYmax = point.y; - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); - DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_True,LongDash); - break; - case CurAction3d_DynamicPanning : - myView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning - myXmax = point.x; myYmax = point.y; - break; - case CurAction3d_GlobalPanning : // nothing + // move with MB1 and Control : on the dynamic zooming + // Do the zoom in function of mouse's coordinates + myView->Zoom(myXmax,myYmax,point.x,point.y); + // save the current mouse coordinate in min + myXmax = point.x; + myYmax = point.y; + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction3d_Nothing : + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False); + myXmax = point.x; + myYmax = point.y; + if (nFlags & MK_SHIFT) + ShiftDragEvent(myXmax,myYmax,0); + else + DragEvent(myXmax,myYmax,0); + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_True); break; - case CurAction3d_DynamicRotation : - myView->Rotation(point.x,point.y); - myView->Redraw(); + case CurAction3d_DynamicZooming : + myView->Zoom(myXmax,myYmax,point.x,point.y); + // save the current mouse coordinate in min \n"; + myXmax=point.x; myYmax=point.y; break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); + case CurAction3d_WindowZooming : + myXmax = point.x; myYmax = point.y; + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); + DrawRectangle(myXmin,myYmin,myXmax,myYmax,Standard_True,LongDash); break; - }// switch (myCurrentMode) - }// if ( nFlags & MK_CONTROL ) else - } else // if ( nFlags & MK_LBUTTON) + case CurAction3d_DynamicPanning : + myView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning + myXmax = point.x; myYmax = point.y; + break; + case CurAction3d_GlobalPanning : // nothing + break; + case CurAction3d_DynamicRotation : + myView->Rotation(point.x,point.y); + myView->Redraw(); + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; + }// switch (myCurrentMode) + }// if ( nFlags & MK_CONTROL ) else + } else // if ( nFlags & MK_LBUTTON) // ============================ MIDDLE BUTTON ======================= if ( nFlags & MK_MBUTTON) { - if ( nFlags & MK_CONTROL ) - { - myView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning - myXmax = point.x; myYmax = point.y; + if ( nFlags & MK_CONTROL ) + { + myView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning + myXmax = point.x; myYmax = point.y; - } + } } else // if ( nFlags & MK_MBUTTON) - // ============================ RIGHT BUTTON ======================= - if ( nFlags & MK_RBUTTON) - { - if ( nFlags & MK_CONTROL ) - { - myView->Rotation(point.x,point.y); - } - }else //if ( nFlags & MK_RBUTTON) - // ============================ NO BUTTON ======================= - { // No buttons - myXmax = point.x; myYmax = point.y; - if (nFlags & MK_SHIFT) - ShiftMoveEvent(point.x,point.y); - else - MoveEvent(point.x,point.y); - } + // ============================ RIGHT BUTTON ======================= + if ( nFlags & MK_RBUTTON) + { + if ( nFlags & MK_CONTROL ) + { + myView->Rotation(point.x,point.y); + } + }else //if ( nFlags & MK_RBUTTON) + // ============================ NO BUTTON ======================= + { // No buttons + myXmax = point.x; myYmax = point.y; + if (nFlags & MK_SHIFT) + ShiftMoveEvent(point.x,point.y); + else + MoveEvent(point.x,point.y); + } } void CGeometryView::OnUpdateBUTTONHlrOff(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myDegenerateModeIsOn); - pCmdUI->Enable (!myDegenerateModeIsOn); + pCmdUI->SetCheck (myDegenerateModeIsOn); + pCmdUI->Enable (!myDegenerateModeIsOn); } void CGeometryView::OnUpdateBUTTONHlrOn(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (!myDegenerateModeIsOn); - pCmdUI->Enable (myDegenerateModeIsOn); + pCmdUI->SetCheck (!myDegenerateModeIsOn); + pCmdUI->Enable (myDegenerateModeIsOn); } void CGeometryView::OnUpdateBUTTONPanGlo(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myCurrentMode == CurAction3d_GlobalPanning); - pCmdUI->Enable (myCurrentMode != CurAction3d_GlobalPanning); - + pCmdUI->SetCheck (myCurrentMode == CurAction3d_GlobalPanning); + pCmdUI->Enable (myCurrentMode != CurAction3d_GlobalPanning); + } void CGeometryView::OnUpdateBUTTONPan(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicPanning); - pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicPanning ); + pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicPanning); + pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicPanning ); } void CGeometryView::OnUpdateBUTTONZoomProg(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicZooming ); - pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicZooming); + pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicZooming ); + pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicZooming); } void CGeometryView::OnUpdateBUTTONZoomWin(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myCurrentMode == CurAction3d_WindowZooming); - pCmdUI->Enable (myCurrentMode != CurAction3d_WindowZooming); + pCmdUI->SetCheck (myCurrentMode == CurAction3d_WindowZooming); + pCmdUI->Enable (myCurrentMode != CurAction3d_WindowZooming); } void CGeometryView::OnUpdateBUTTONRot(CCmdUI* pCmdUI) { - pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicRotation); - pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicRotation); + pCmdUI->SetCheck (myCurrentMode == CurAction3d_DynamicRotation); + pCmdUI->Enable (myCurrentMode != CurAction3d_DynamicRotation); } //========================================================================================== @@ -388,72 +392,72 @@ void CGeometryView::OnUpdateBUTTONRot(CCmdUI* pCmdUI) // //----------------------------------------------------------------------------------------- void CGeometryView::DragEvent(const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState ) + const Standard_Integer y , + const Standard_Integer TheState ) { - // TheState == -1 button down - // TheState == 0 move - // TheState == 1 button up + // TheState == -1 button down + // TheState == 0 move + // TheState == 1 button up - static Standard_Integer theButtonDownX=0; - static Standard_Integer theButtonDownY=0; + static Standard_Integer theButtonDownX=0; + static Standard_Integer theButtonDownY=0; - if (TheState == -1) - { - theButtonDownX=x; - theButtonDownY=y; - } + if (TheState == -1) + { + theButtonDownX=x; + theButtonDownY=y; + } - if (TheState == 0) - GetDocument()->GetAISContext()->Select(theButtonDownX,theButtonDownY,x,y,myView); + if (TheState == 0) + GetDocument()->GetAISContext()->Select(theButtonDownX,theButtonDownY,x,y,myView); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- void CGeometryView::InputEvent(const Standard_Integer x , - const Standard_Integer y ) + const Standard_Integer y ) { - GetDocument()->GetAISContext()->Select(); + GetDocument()->GetAISContext()->Select(); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- void CGeometryView::MoveEvent(const Standard_Integer x , - const Standard_Integer y ) + const Standard_Integer y ) { - GetDocument()->GetAISContext()->MoveTo(x,y,myView); + GetDocument()->GetAISContext()->MoveTo(x,y,myView); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- void CGeometryView::ShiftMoveEvent(const Standard_Integer x , - const Standard_Integer y ) + const Standard_Integer y ) { - GetDocument()->GetAISContext()->MoveTo(x,y,myView); + GetDocument()->GetAISContext()->MoveTo(x,y,myView); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- void CGeometryView::ShiftDragEvent(const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState ) + const Standard_Integer y , + const Standard_Integer TheState ) { - static Standard_Integer theButtonDownX=0; - static Standard_Integer theButtonDownY=0; + static Standard_Integer theButtonDownX=0; + static Standard_Integer theButtonDownY=0; - if (TheState == -1) - { - theButtonDownX=x; - theButtonDownY=y; - } + if (TheState == -1) + { + theButtonDownX=x; + theButtonDownY=y; + } - if (TheState == 0) - GetDocument()->GetAISContext()->ShiftSelect(theButtonDownX,theButtonDownY,x,y,myView); + if (TheState == 0) + GetDocument()->GetAISContext()->ShiftSelect(theButtonDownX,theButtonDownY,x,y,myView); } @@ -461,16 +465,16 @@ void CGeometryView::ShiftDragEvent(const Standard_Integer x , // //----------------------------------------------------------------------------------------- void CGeometryView::ShiftInputEvent(const Standard_Integer x , - const Standard_Integer y ) + const Standard_Integer y ) { - GetDocument()->GetAISContext()->ShiftSelect(); + GetDocument()->GetAISContext()->ShiftSelect(); } //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- void CGeometryView::Popup(const Standard_Integer x, - const Standard_Integer y ) + const Standard_Integer y ) { Standard_Integer PopupMenuNumber=0; GetDocument()->GetAISContext()->InitCurrent(); @@ -481,13 +485,13 @@ void CGeometryView::Popup(const Standard_Integer x, VERIFY(menu.LoadMenu(IDR_Popup3D)); CMenu* pPopup = menu.GetSubMenu(PopupMenuNumber); ASSERT(pPopup != NULL); - + POINT winCoord = { x , y }; Handle(WNT_Window) aWNTWindow= - Handle(WNT_Window)::DownCast(myView->Window()); + Handle(WNT_Window)::DownCast(myView->Window()); ClientToScreen ( &winCoord); pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON , winCoord.x, winCoord.y , - AfxGetMainWnd()); + AfxGetMainWnd()); } diff --git a/samples/mfc/standard/01_Geometry/src/GeometryView.h b/samples/mfc/standard/01_Geometry/src/GeometryView.h index b9913d2962..fad98464ea 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryView.h +++ b/samples/mfc/standard/01_Geometry/src/GeometryView.h @@ -15,72 +15,77 @@ class CGeometryView : public OCC_3dView { protected: // create from serialization only public: - CGeometryView(); - DECLARE_DYNCREATE(CGeometryView) + CGeometryView(); + DECLARE_DYNCREATE(CGeometryView) -// Attributes + // Attributes public: - CGeometryDoc* GetDocument(); + CGeometryDoc* GetDocument(); -// Operations + // Operations public: -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CGeometryView) - public: - //}}AFX_VIRTUAL - -// Implementation + // Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CGeometryView) public: - virtual ~CGeometryView(); - void FitAll(Quantity_Coefficient Coef) { if (Coef != -1) myView->FitAll(Coef); - else myView->FitAll(); - myView->ZFitAll(); }; + //}}AFX_VIRTUAL + + // Implementation +public: + virtual ~CGeometryView(); + void FitAll(Quantity_Coefficient Coef) + { + if (Coef != -1) + myView->FitAll(Coef); + else myView->FitAll(); + myView->ZFitAll(); + }; + #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif // Generated message map functions protected: - //{{AFX_MSG(CGeometryView) - afx_msg void OnFileExportImage(); - afx_msg void OnSize(UINT nType, int cx, int cy); - afx_msg void OnLButtonDown(UINT nFlags, CPoint point); - afx_msg void OnLButtonUp(UINT nFlags, CPoint point); - afx_msg void OnMButtonDown(UINT nFlags, CPoint point); - afx_msg void OnMButtonUp(UINT nFlags, CPoint point); - afx_msg void OnMouseMove(UINT nFlags, CPoint point); - afx_msg void OnRButtonDown(UINT nFlags, CPoint point); - afx_msg void OnRButtonUp(UINT nFlags, CPoint point); - afx_msg void OnUpdateBUTTONHlrOff(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONHlrOn(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONPanGlo(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONPan(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONZoomProg(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONZoomWin(CCmdUI* pCmdUI); - afx_msg void OnUpdateBUTTONRot(CCmdUI* pCmdUI); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //{{AFX_MSG(CGeometryView) + afx_msg void OnFileExportImage(); + afx_msg void OnSize(UINT nType, int cx, int cy); + afx_msg void OnLButtonDown(UINT nFlags, CPoint point); + afx_msg void OnLButtonUp(UINT nFlags, CPoint point); + afx_msg void OnMButtonDown(UINT nFlags, CPoint point); + afx_msg void OnMButtonUp(UINT nFlags, CPoint point); + afx_msg void OnMouseMove(UINT nFlags, CPoint point); + afx_msg void OnRButtonDown(UINT nFlags, CPoint point); + afx_msg void OnRButtonUp(UINT nFlags, CPoint point); + afx_msg void OnUpdateBUTTONHlrOff(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONHlrOn(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONPanGlo(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONPan(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONZoomProg(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONZoomWin(CCmdUI* pCmdUI); + afx_msg void OnUpdateBUTTONRot(CCmdUI* pCmdUI); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() private: - void DragEvent (const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState); - void InputEvent (const Standard_Integer x , - const Standard_Integer y ); - void MoveEvent (const Standard_Integer x , - const Standard_Integer y ); - void ShiftMoveEvent (const Standard_Integer x , - const Standard_Integer y ); - void ShiftDragEvent (const Standard_Integer x , - const Standard_Integer y , - const Standard_Integer TheState); - void ShiftInputEvent(const Standard_Integer x , - const Standard_Integer y ); - void Popup (const Standard_Integer x , - const Standard_Integer y ); + void DragEvent (const Standard_Integer x , + const Standard_Integer y , + const Standard_Integer TheState); + void InputEvent (const Standard_Integer x , + const Standard_Integer y ); + void MoveEvent (const Standard_Integer x , + const Standard_Integer y ); + void ShiftMoveEvent (const Standard_Integer x , + const Standard_Integer y ); + void ShiftDragEvent (const Standard_Integer x , + const Standard_Integer y , + const Standard_Integer TheState); + void ShiftInputEvent(const Standard_Integer x , + const Standard_Integer y ); + void Popup (const Standard_Integer x , + const Standard_Integer y ); }; diff --git a/samples/mfc/standard/01_Geometry/src/GeometryView2D.cpp b/samples/mfc/standard/01_Geometry/src/GeometryView2D.cpp index 3f77e2d9bf..5e4919299b 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryView2D.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeometryView2D.cpp @@ -14,16 +14,16 @@ IMPLEMENT_DYNCREATE(CGeometryView2D, CView) BEGIN_MESSAGE_MAP(CGeometryView2D, OCC_2dView) - //{{AFX_MSG_MAP(CGeometryView2D) - ON_WM_LBUTTONDOWN() - ON_WM_LBUTTONUP() - ON_WM_MBUTTONDOWN() - ON_WM_MBUTTONUP() - ON_WM_RBUTTONDOWN() - ON_WM_RBUTTONUP() - ON_WM_MOUSEMOVE() - ON_WM_SIZE() - //}}AFX_MSG_MAP + //{{AFX_MSG_MAP(CGeometryView2D) + ON_WM_LBUTTONDOWN() + ON_WM_LBUTTONUP() + ON_WM_MBUTTONDOWN() + ON_WM_MBUTTONUP() + ON_WM_RBUTTONDOWN() + ON_WM_RBUTTONUP() + ON_WM_MOUSEMOVE() + ON_WM_SIZE() + //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// @@ -41,11 +41,11 @@ CGeometryView2D::~CGeometryView2D() void CGeometryView2D::OnDraw(CDC* pDC) { - CGeometryDoc* pDoc = GetDocument(); - ASSERT_VALID(pDoc); + CGeometryDoc* pDoc = GetDocument(); + ASSERT_VALID(pDoc); - if (!myV2dView.IsNull()) - myV2dView->Update(); + if (!myV2dView.IsNull()) + myV2dView->Update(); } ///////////////////////////////////////////////////////////////////////////// @@ -54,18 +54,18 @@ void CGeometryView2D::OnDraw(CDC* pDC) #ifdef _DEBUG void CGeometryView2D::AssertValid() const { - CView::AssertValid(); + CView::AssertValid(); } void CGeometryView2D::Dump(CDumpContext& dc) const { - CView::Dump(dc); + CView::Dump(dc); } CGeometryDoc* CGeometryView2D::GetDocument() // non-debug version is inline { - ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CGeometryDoc))); - return (CGeometryDoc*)m_pDocument; + ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CGeometryDoc))); + return (CGeometryDoc*)m_pDocument; } #endif //_DEBUG @@ -83,233 +83,227 @@ void CGeometryView2D::OnLButtonDown(UINT nFlags, CPoint point) myXmax=point.x; myYmax=point.y; if ( nFlags & MK_CONTROL ) - { - // Button MB1 down Control :start zomming - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction2d_Nothing : // start a drag - GetDocument()->DragEvent2D(point.x,point.y,-1,myV2dView); - break; - case CurAction2d_DynamicZooming : // noting - break; - case CurAction2d_WindowZooming : - break; - case CurAction2d_DynamicPanning :// noting - break; - case CurAction2d_GlobalPanning :// noting - break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); - break; - } + { + // Button MB1 down Control :start zomming + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction2d_Nothing : // start a drag + GetDocument()->DragEvent2D(point.x,point.y,-1,myV2dView); + break; + case CurAction2d_DynamicZooming : // noting + break; + case CurAction2d_WindowZooming : + break; + case CurAction2d_DynamicPanning :// noting + break; + case CurAction2d_GlobalPanning :// noting + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; } + } } void CGeometryView2D::OnLButtonUp(UINT nFlags, CPoint point) { - // TODO: Add your message handler code here and/or call default - if ( nFlags & MK_CONTROL ) - { - return; - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction2d_Nothing : - if (point.x == myXmin && point.y == myYmin) - { // no offset between down and up --> selectEvent - myXmax=point.x; - myYmax=point.y; - if (nFlags & MK_SHIFT ) - GetDocument()->ShiftInputEvent2D(point.x,point.y,myV2dView); - else - GetDocument()->InputEvent2D (point.x,point.y,myV2dView); - } else - { - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False); - myXmax=point.x; - myYmax=point.y; - if (nFlags & MK_SHIFT) - GetDocument()->ShiftDragEvent2D(point.x,point.y,1,myV2dView); - else - GetDocument()->DragEvent2D(point.x,point.y,1,myV2dView); - } - break; - case CurAction2d_DynamicZooming : - // SetCursor(AfxGetApp()->LoadStandardCursor()); - myCurrentMode = CurAction2d_Nothing; - break; - case CurAction2d_WindowZooming : - myXmax=point.x; myYmax=point.y; - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); - if ((abs(myXmin-myXmax)>ValZWMin) || (abs(myYmin-myYmax)>ValZWMin)) - // Test if the zoom window is greater than a minimale window. - { - // Do the zoom window between Pmin and Pmax - myV2dView->WindowFit(myXmin,myYmin,myXmax,myYmax); - } - myCurrentMode = CurAction2d_Nothing; - break; - case CurAction2d_DynamicPanning : - myCurrentMode = CurAction2d_Nothing; - break; - case CurAction2d_GlobalPanning : - myV2dView->Place(point.x,point.y,myCurZoom); - myCurrentMode = CurAction2d_Nothing; - break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); - break; - } //switch (myCurrentMode) - } // else // if ( Ctrl ) - + // TODO: Add your message handler code here and/or call default + if ( nFlags & MK_CONTROL ) + { + return; + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction2d_Nothing : + if (point.x == myXmin && point.y == myYmin) + { // no offset between down and up --> selectEvent + myXmax=point.x; + myYmax=point.y; + if (nFlags & MK_SHIFT ) + GetDocument()->ShiftInputEvent2D(point.x,point.y,myV2dView); + else + GetDocument()->InputEvent2D (point.x,point.y,myV2dView); + } else + { + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False); + myXmax=point.x; + myYmax=point.y; + if (nFlags & MK_SHIFT) + GetDocument()->ShiftDragEvent2D(point.x,point.y,1,myV2dView); + else + GetDocument()->DragEvent2D(point.x,point.y,1,myV2dView); + } + break; + case CurAction2d_DynamicZooming : + // SetCursor(AfxGetApp()->LoadStandardCursor()); + myCurrentMode = CurAction2d_Nothing; + break; + case CurAction2d_WindowZooming : + myXmax=point.x; myYmax=point.y; + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); + if ((abs(myXmin-myXmax)>ValZWMin) || (abs(myYmin-myYmax)>ValZWMin)) + // Test if the zoom window is greater than a minimale window. + { + // Do the zoom window between Pmin and Pmax + myV2dView->WindowFit(myXmin,myYmin,myXmax,myYmax); + } + myCurrentMode = CurAction2d_Nothing; + break; + case CurAction2d_DynamicPanning : + myCurrentMode = CurAction2d_Nothing; + break; + case CurAction2d_GlobalPanning : + myV2dView->Place(point.x,point.y,myCurZoom); + myCurrentMode = CurAction2d_Nothing; + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; + } //switch (myCurrentMode) + } // else // if ( Ctrl ) + } void CGeometryView2D::OnMButtonDown(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - // Button MB2 down Control : panning init - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } - + if ( nFlags & MK_CONTROL ) + { + // Button MB2 down Control : panning init + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } } void CGeometryView2D::OnMButtonUp(UINT nFlags, CPoint point) { - if ( nFlags & MK_CONTROL ) - { - // Button MB2 up Control : panning stop - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } - + if ( nFlags & MK_CONTROL ) + { + // Button MB2 up Control : panning stop + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } } void CGeometryView2D::OnRButtonDown(UINT nFlags, CPoint point) { - // TODO: Add your message handler code here and/or call default - if ( nFlags & MK_CONTROL ) - { - // SetCursor(AfxGetApp()->LoadStandardCursor()); - } - else // if ( Ctrl ) - { - GetDocument()->Popup2D(point.x,point.y,myV2dView); - } - + // TODO: Add your message handler code here and/or call default + if ( nFlags & MK_CONTROL ) + { + // SetCursor(AfxGetApp()->LoadStandardCursor()); + } + else // if ( Ctrl ) + { + GetDocument()->Popup2D(point.x,point.y,myV2dView); + } } void CGeometryView2D::OnRButtonUp(UINT nFlags, CPoint point) { - OCC_2dView::Popup2D(point.x,point.y); + OCC_2dView::Popup2D(point.x,point.y); } void CGeometryView2D::OnMouseMove(UINT nFlags, CPoint point) { - // ============================ LEFT BUTTON ======================= + // ============================ LEFT BUTTON ======================= if ( nFlags & MK_LBUTTON) + { + if ( nFlags & MK_CONTROL ) { - if ( nFlags & MK_CONTROL ) - { - // move with MB1 and Control : on the dynamic zooming - // Do the zoom in function of mouse's coordinates - myV2dView->Zoom(myXmax,myYmax,point.x,point.y); - // save the current mouse coordinate in min - myXmax = point.x; + // move with MB1 and Control : on the dynamic zooming + // Do the zoom in function of mouse's coordinates + myV2dView->Zoom(myXmax,myYmax,point.x,point.y); + // save the current mouse coordinate in min + myXmax = point.x; + myYmax = point.y; + } + else // if ( Ctrl ) + { + switch (myCurrentMode) + { + case CurAction2d_Nothing : + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False); + myXmax = point.x; myYmax = point.y; - } - else // if ( Ctrl ) - { - switch (myCurrentMode) - { - case CurAction2d_Nothing : - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False); - myXmax = point.x; - myYmax = point.y; - GetDocument()->DragEvent2D(myXmax,myYmax,0,myV2dView); - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_True); - break; - case CurAction2d_DynamicZooming : - myV2dView->Zoom(myXmax,myYmax,point.x,point.y); - // save the current mouse coordinate in min \n"; - myXmax=point.x; myYmax=point.y; - break; - case CurAction2d_WindowZooming : - myXmax = point.x; myYmax = point.y; - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); - DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_True,LongDash); - break; - case CurAction2d_DynamicPanning : - myV2dView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning - myXmax = point.x; myYmax = point.y; - break; - case CurAction2d_GlobalPanning : // nothing + GetDocument()->DragEvent2D(myXmax,myYmax,0,myV2dView); + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_True); break; - default : - Standard_Failure::Raise(" incompatible Current Mode "); + case CurAction2d_DynamicZooming : + myV2dView->Zoom(myXmax,myYmax,point.x,point.y); + // save the current mouse coordinate in min \n"; + myXmax=point.x; myYmax=point.y; break; - }// switch (myCurrentMode) - }// if ( nFlags & MK_CONTROL ) else - } else // if ( nFlags & MK_LBUTTON) + case CurAction2d_WindowZooming : + myXmax = point.x; myYmax = point.y; + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_False,LongDash); + DrawRectangle2D(myXmin,myYmin,myXmax,myYmax,Standard_True,LongDash); + break; + case CurAction2d_DynamicPanning : + myV2dView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning + myXmax = point.x; myYmax = point.y; + break; + case CurAction2d_GlobalPanning : // nothing + break; + default : + Standard_Failure::Raise(" incompatible Current Mode "); + break; + }// switch (myCurrentMode) + }// if ( nFlags & MK_CONTROL ) else + } else // if ( nFlags & MK_LBUTTON) // ============================ MIDDLE BUTTON ======================= if ( nFlags & MK_MBUTTON) { - if ( nFlags & MK_CONTROL ) - { - myV2dView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning - myXmax = point.x; myYmax = point.y; + if ( nFlags & MK_CONTROL ) + { + myV2dView->Pan(point.x-myXmax,myYmax-point.y); // Realize the panning + myXmax = point.x; myYmax = point.y; - } + } } else // if ( nFlags & MK_MBUTTON) - // ============================ RIGHT BUTTON ======================= - if ( nFlags & MK_RBUTTON) - { - }else //if ( nFlags & MK_RBUTTON) - // ============================ NO BUTTON ======================= - { // No buttons - myXmax = point.x; myYmax = point.y; - if (nFlags & MK_SHIFT) - GetDocument()->ShiftMoveEvent2D(point.x,point.y,myV2dView); - else - GetDocument()->MoveEvent2D(point.x,point.y,myV2dView); - } + // ============================ RIGHT BUTTON ======================= + if ( nFlags & MK_RBUTTON) + { + }else //if ( nFlags & MK_RBUTTON) + // ============================ NO BUTTON ======================= + { // No buttons + myXmax = point.x; myYmax = point.y; + if (nFlags & MK_SHIFT) + GetDocument()->ShiftMoveEvent2D(point.x,point.y,myV2dView); + else + GetDocument()->MoveEvent2D(point.x,point.y,myV2dView); + } } void CGeometryView2D::OnSize(UINT nType, int cx, int cy) { - if (!myV2dView.IsNull()) - { - myV2dView->MustBeResized(V2d_TOWRE_ENLARGE_SPACE); // added sro - } - + if (!myV2dView.IsNull()) + { + myV2dView->MustBeResized(); // added sro + } } void CGeometryView2D::OnInitialUpdate() - { - Handle(WNT_Window) aWNTWindow; - aWNTWindow = new WNT_Window(((CGeometryApp*)AfxGetApp())->GetGraphicDevice(),GetSafeHwnd()); - aWNTWindow->SetBackground(Quantity_NOC_BLACK); + Handle(WNT_Window) aWNTWindow; + aWNTWindow = new WNT_Window(GetSafeHwnd()); - Handle(WNT_WDriver) aDriver= new WNT_WDriver(aWNTWindow); - myV2dView = new V2d_View(aDriver, GetDocument()->GetViewer2D(),0,0,50); + myV2dView = GetDocument()->GetViewer2D()->CreateView(); + myV2dView->SetWindow(aWNTWindow); + myV2dView->SetBackgroundColor(Quantity_NOC_BLACK); - // initialyse the grids dialogs - TheRectangularGridDialog.Create(CRectangularGrid::IDD, NULL); - TheCircularGridDialog.Create(CCircularGrid::IDD, NULL); - TheRectangularGridDialog.SetViewer (GetDocument()->GetViewer2D()); - TheCircularGridDialog.SetViewer (GetDocument()->GetViewer2D()); - - Standard_Integer w=100 , h=100 ; /* Debug Matrox */ - aWNTWindow->Size (w,h) ; /* Keeps me unsatisfied (rlb)..... */ - /* Resize is not supposed to be done on */ - /* Matrox */ - /* I suspect another problem elsewhere */ - ::PostMessage ( GetSafeHwnd () , WM_SIZE , SIZE_RESTORED , w + h*65536 ) ; + // initialyse the grids dialogs + TheRectangularGridDialog.Create(CRectangularGrid::IDD, NULL); + TheCircularGridDialog.Create(CCircularGrid::IDD, NULL); + TheRectangularGridDialog.SetViewer (GetDocument()->GetViewer2D()); + TheCircularGridDialog.SetViewer (GetDocument()->GetViewer2D()); + Standard_Integer w=100 , h=100 ; /* Debug Matrox */ + aWNTWindow->Size (w,h) ; /* Keeps me unsatisfied (rlb)..... */ + /* Resize is not supposed to be done on */ + /* Matrox */ + /* I suspect another problem elsewhere */ + ::PostMessage ( GetSafeHwnd () , WM_SIZE , SIZE_RESTORED , w + h*65536 ) ; } \ No newline at end of file diff --git a/samples/mfc/standard/01_Geometry/src/GeometryView2D.h b/samples/mfc/standard/01_Geometry/src/GeometryView2D.h index 5e14541246..1361ab40df 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryView2D.h +++ b/samples/mfc/standard/01_Geometry/src/GeometryView2D.h @@ -12,62 +12,46 @@ #include ///////////////////////////////////////////////////////////////////////////// -/* -enum CurrentAction2d { - CurAction_Nothing, - CurAction_DynamicZooming, - CurAction_WindowZooming, - CurAction_DynamicPanning, - CurAction_GlobalPanning, -}; -*/ + #define ValZWMin 1 - - class CGeometryView2D : public OCC_2dView { protected: // create from serialization only - CGeometryView2D(); - DECLARE_DYNCREATE(CGeometryView2D) + CGeometryView2D(); + DECLARE_DYNCREATE(CGeometryView2D) -// Attributes + // Attributes public: - CGeometryDoc* GetDocument(); + CGeometryDoc* GetDocument(); public: - -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CNSGViewBib) - public: - virtual void OnDraw(CDC* pDC); // overridden to draw this view - virtual void OnInitialUpdate(); // called first time after construct - - //}}AFX_VIRTUAL - - - -// Implementation + // Overrides + // ClassWizard generated virtual function overrides public: - virtual ~CGeometryView2D(); + virtual void OnDraw(CDC* pDC); // overridden to draw this view + virtual void OnInitialUpdate(); // called first time after construct + + // Implementation +public: + virtual ~CGeometryView2D(); #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif -// Generated message map functions + // Generated message map functions protected: - //{{AFX_MSG(CGeometryView2D) - afx_msg void OnLButtonDown(UINT nFlags, CPoint point); - afx_msg void OnLButtonUp(UINT nFlags, CPoint point); - afx_msg void OnMButtonDown(UINT nFlags, CPoint point); - afx_msg void OnMButtonUp(UINT nFlags, CPoint point); - afx_msg void OnRButtonDown(UINT nFlags, CPoint point); - afx_msg void OnRButtonUp(UINT nFlags, CPoint point); - afx_msg void OnMouseMove(UINT nFlags, CPoint point); - afx_msg void OnSize(UINT nType, int cx, int cy); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //{{AFX_MSG(CGeometryView2D) + afx_msg void OnLButtonDown(UINT nFlags, CPoint point); + afx_msg void OnLButtonUp(UINT nFlags, CPoint point); + afx_msg void OnMButtonDown(UINT nFlags, CPoint point); + afx_msg void OnMButtonUp(UINT nFlags, CPoint point); + afx_msg void OnRButtonDown(UINT nFlags, CPoint point); + afx_msg void OnRButtonUp(UINT nFlags, CPoint point); + afx_msg void OnMouseMove(UINT nFlags, CPoint point); + afx_msg void OnSize(UINT nType, int cx, int cy); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() }; #ifndef _DEBUG // debug version in NSGViewBibliotheque.cpp diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.cpp index a80db0abd6..4a42399b0e 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.cpp @@ -6,37 +6,12 @@ IMPLEMENT_STANDARD_HANDLE(ISession2D_Curve,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession2D_Curve,AIS_InteractiveObject) -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - ISession2D_Curve::ISession2D_Curve(const Handle_Geom2d_Curve aGeom2dCurve, - const Aspect_TypeOfLine aTypeOfLine, - const Aspect_WidthOfLine aWidthOfLine, - const Standard_Integer aColorIndex) - :AIS_InteractiveObject() +ISession2D_Curve::ISession2D_Curve(const Handle_Geom2d_Curve aGeom2dCurve, + const Aspect_TypeOfLine aTypeOfLine, + const Aspect_WidthOfLine aWidthOfLine, + const Standard_Integer aColorIndex) + :AIS_InteractiveObject() { myGeom2dCurve = aGeom2dCurve; myTypeOfLine = aTypeOfLine ; @@ -49,51 +24,52 @@ IMPLEMENT_STANDARD_RTTIEXT(ISession2D_Curve,AIS_InteractiveObject) myradiusratio = 1; } -void ISession2D_Curve::Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer aMode) +void ISession2D_Curve::Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, + const Handle(Prs3d_Presentation)& aPresentation, + const Standard_Integer aMode) { - Handle(Graphic2d_SetOfCurves) segment; - segment = new Graphic2d_SetOfCurves(aGrObj); - - - segment->Add(myGeom2dCurve); - - segment->SetColorIndex (myColorIndex); - segment->SetWidthIndex (myWidthOfLine + 1); - segment->SetTypeIndex (myTypeOfLine + 1); Geom2dAdaptor_Curve anAdaptor(myGeom2dCurve); + GCPnts_QuasiUniformDeflection anEdgeDistrib(anAdaptor,1.e-2); + if(anEdgeDistrib.IsDone()) + { + Handle(Graphic3d_ArrayOfPolylines) aCurve = + new Graphic3d_ArrayOfPolylines(anEdgeDistrib.NbPoints()); + for(Standard_Integer i=1;i<=anEdgeDistrib.NbPoints();++i) + aCurve->AddVertex(anEdgeDistrib.Value(i)); + + Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(aCurve); + } + if (myDisplayPole) - { + { if (anAdaptor.GetType() == GeomAbs_BezierCurve ) { Handle(Geom2d_BezierCurve) aBezier = anAdaptor.Bezier(); - Graphic2d_Array1OfVertex anArrayOfVertex(1,aBezier->NbPoles()); + Handle(Graphic3d_ArrayOfPolylines) anArrayOfVertex = new Graphic3d_ArrayOfPolylines(aBezier->NbPoles()); for(int i=1;i<=aBezier->NbPoles();i++) - { - gp_Pnt2d CurrentPoint = aBezier->Pole(i); - Graphic2d_Vertex aVertex(CurrentPoint.X(),CurrentPoint.Y()); - anArrayOfVertex(i)=aVertex; - } - Handle(Graphic2d_Polyline) aPolyline = new Graphic2d_Polyline(aGrObj,anArrayOfVertex); + { + gp_Pnt2d CurrentPoint = aBezier->Pole(i); + anArrayOfVertex->AddVertex(CurrentPoint.X(),CurrentPoint.Y(),0.); } + Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(anArrayOfVertex); + } if (anAdaptor.GetType() == GeomAbs_BSplineCurve ) { Handle(Geom2d_BSplineCurve) aBSpline = anAdaptor.BSpline(); - Graphic2d_Array1OfVertex anArrayOfVertex(1,aBSpline->NbPoles()); + Handle(Graphic3d_ArrayOfPolylines) anArrayOfVertex = + new Graphic3d_ArrayOfPolylines(aBSpline->NbPoles()); for(int i=1;i<=aBSpline->NbPoles();i++) - { - gp_Pnt2d CurrentPoint = aBSpline->Pole(i); - Graphic2d_Vertex aVertex(CurrentPoint.X(),CurrentPoint.Y()); - anArrayOfVertex(i)=aVertex; - } - Handle(Graphic2d_Polyline) aPolyline = new Graphic2d_Polyline(aGrObj,anArrayOfVertex); + { + gp_Pnt2d CurrentPoint = aBSpline->Pole(i); + anArrayOfVertex->AddVertex(CurrentPoint.X(),CurrentPoint.Y(),0.); } + Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(anArrayOfVertex); } + } if (myDisplayCurbure && (anAdaptor.GetType() != GeomAbs_Line)) { @@ -106,37 +82,39 @@ void ISession2D_Curve::Compute(const Handle(PrsMgr_PresentationManager2d)& aPres gp_Pnt2d P1, P2; for (intrv = 1; intrv <= nbintv; intrv++) - { - Standard_Real t = TI(intrv); - Standard_Real step = (TI(intrv+1) - t) / GetDiscretisation(); - Standard_Real LRad, ratio; - for (ii = 1; ii <= myDiscretisation; ii++) - { - LProp.SetParameter(t); + { + Standard_Real t = TI(intrv); + Standard_Real step = (TI(intrv+1) - t) / GetDiscretisation(); + Standard_Real LRad, ratio; + for (ii = 1; ii <= myDiscretisation; ii++) + { + LProp.SetParameter(t); if (LProp.IsTangentDefined()) - { - Curvature = Abs(LProp.Curvature()); - if ( Curvature > Resolution) - { - myGeom2dCurve->D0(t, P1); - LRad = 1./Curvature; - ratio = ( ( LRad > myradiusmax) ? myradiusmax/LRad : 1 ); - ratio *= myradiusratio; - LProp.CentreOfCurvature(P2); - gp_Vec2d V(P1, P2); - gp_Pnt2d P3 = P1.Translated(ratio*V); - Handle(Graphic2d_Segment) aSegment = new Graphic2d_Segment(aGrObj,P1.X(),P1.Y(),P3.X(),P3.Y()); - } - } - t += step; - } + { + Curvature = Abs(LProp.Curvature()); + if ( Curvature > Resolution) + { + myGeom2dCurve->D0(t, P1); + LRad = 1./Curvature; + ratio = ( ( LRad > myradiusmax) ? myradiusmax/LRad : 1 ); + ratio *= myradiusratio; + LProp.CentreOfCurvature(P2); + gp_Vec2d V(P1, P2); + gp_Pnt2d P3 = P1.Translated(ratio*V); + Handle(Graphic3d_ArrayOfPolylines) aSegment = new Graphic3d_ArrayOfPolylines(2); + aSegment->AddVertex(P1.X(),P1.Y(),0.); + aSegment->AddVertex(P3.X(),P3.Y(),0.); + Prs3d_Root::CurrentGroup(aPresentation)->AddPrimitiveArray(aSegment); + } + } + t += step; + } } } } - void ISession2D_Curve::ComputeSelection(const Handle(SelectMgr_Selection)& aSelection, - const Standard_Integer aMode) + const Standard_Integer aMode) { } diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.h index 429c434db1..8c13b9e2ee 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_Curve.h @@ -10,9 +10,7 @@ #include #include #include -#include -#include -#include +#include #include #include #include @@ -21,7 +19,6 @@ class TColGeom2d_HSequenceOfCurve; class PrsMgr_PresentationManager2d; class Graphic2d_GraphicObject; class SelectMgr_Selection; -class ISession2D_ObjectOwner; #include "Geom2d_Curve.hxx" @@ -32,81 +29,56 @@ class ISession2D_Curve : public AIS_InteractiveObject { public: - // Methods PUBLIC - // + // Methods PUBLIC + // - ISession2D_Curve - (const Handle_Geom2d_Curve aGeom2dCurve, - const Aspect_TypeOfLine aTypeOfline = Aspect_TOL_SOLID, - const Aspect_WidthOfLine aWidthOfLine = Aspect_WOL_MEDIUM, - const Standard_Integer aColorIndex = 4); + ISession2D_Curve + (const Handle_Geom2d_Curve aGeom2dCurve, + const Aspect_TypeOfLine aTypeOfline = Aspect_TOL_SOLID, + const Aspect_WidthOfLine aWidthOfLine = Aspect_WOL_MEDIUM, + const Standard_Integer aColorIndex = 4); -inline Standard_Integer NbPossibleSelection() const; + inline Standard_Integer NbPossibleSelection() const; -inline Aspect_TypeOfLine GetTypeOfLine - () const; -inline void SetTypeOfLine - (const Aspect_TypeOfLine aNewTypeOfLine) ; -inline Aspect_WidthOfLine GetWidthOfLine - () const; -inline void SetWidthOfLine - (const Aspect_WidthOfLine aNewWidthOfLine) ; -inline Standard_Integer GetColorIndex - () const; -inline void SetColorIndex - (const Standard_Integer aNewColorIndex) ; + inline Aspect_TypeOfLine GetTypeOfLine() const; + inline void SetTypeOfLine(const Aspect_TypeOfLine aNewTypeOfLine); -inline Standard_Boolean GetDisplayPole - () const; -inline void SetDisplayPole - (const Standard_Boolean aNewDisplayPole) ; + inline Aspect_WidthOfLine GetWidthOfLine() const; + inline void SetWidthOfLine(const Aspect_WidthOfLine aNewWidthOfLine); -inline Standard_Boolean ISession2D_Curve::GetDisplayCurbure - () const; -inline void ISession2D_Curve::SetDisplayCurbure - (const Standard_Boolean aNewDisplayCurbure); + inline Standard_Integer GetColorIndex() const; + inline void SetColorIndex(const Standard_Integer aNewColorIndex) ; + inline Standard_Boolean GetDisplayPole() const; + inline void SetDisplayPole(const Standard_Boolean aNewDisplayPole) ; -inline Standard_Real GetDiscretisation - () const; -inline void SetDiscretisation - (const Standard_Real aNewDiscretisation) ; + inline Standard_Boolean ISession2D_Curve::GetDisplayCurbure() const; + inline void ISession2D_Curve::SetDisplayCurbure + (const Standard_Boolean aNewDisplayCurbure); + inline Standard_Real GetDiscretisation() const; + inline void SetDiscretisation(const Standard_Real aNewDiscretisation) ; -DEFINE_STANDARD_RTTI(ISession2D_Curve) - - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - + DEFINE_STANDARD_RTTI(ISession2D_Curve) private: - // Methods PRIVATE - // -virtual void Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager,const Handle(Graphic2d_GraphicObject)& aGrObj,const Standard_Integer aMode = 0) ; -void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; - - - // Fields PRIVATE - // -Handle_Geom2d_Curve myGeom2dCurve; -Aspect_TypeOfLine myTypeOfLine; -Aspect_WidthOfLine myWidthOfLine; -Standard_Integer myColorIndex; -Standard_Boolean myDisplayPole; -Standard_Boolean myDisplayCurbure; -Standard_Real myDiscretisation; -Standard_Real myradiusmax ; -Standard_Real myradiusratio ; - + // Methods PRIVATE + // + virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0) ; + void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; + // Fields PRIVATE + // + Handle_Geom2d_Curve myGeom2dCurve; + Aspect_TypeOfLine myTypeOfLine; + Aspect_WidthOfLine myWidthOfLine; + Standard_Integer myColorIndex; + Standard_Boolean myDisplayPole; + Standard_Boolean myDisplayCurbure; + Standard_Real myDiscretisation; + Standard_Real myradiusmax ; + Standard_Real myradiusratio ; }; @@ -116,14 +88,14 @@ Standard_Real myradiusratio ; inline Standard_Integer ISession2D_Curve::NbPossibleSelection() const { -return 1; + return 1; } inline Aspect_TypeOfLine ISession2D_Curve::GetTypeOfLine() const { return myTypeOfLine ; } - + inline void ISession2D_Curve::SetTypeOfLine(const Aspect_TypeOfLine aNewTypeOfLine) { myTypeOfLine = aNewTypeOfLine; @@ -150,37 +122,37 @@ inline void ISession2D_Curve::SetColorIndex(const Standard_Integer aNewColorInd } inline Standard_Boolean ISession2D_Curve::GetDisplayPole - () const +() const { -return myDisplayPole; + return myDisplayPole; } inline void ISession2D_Curve::SetDisplayPole - (const Standard_Boolean aNewDisplayPole) +(const Standard_Boolean aNewDisplayPole) { -myDisplayPole = aNewDisplayPole; + myDisplayPole = aNewDisplayPole; } inline Standard_Boolean ISession2D_Curve::GetDisplayCurbure - () const +() const { -return myDisplayCurbure; + return myDisplayCurbure; } inline void ISession2D_Curve::SetDisplayCurbure - (const Standard_Boolean aNewDisplayCurbure) +(const Standard_Boolean aNewDisplayCurbure) { -myDisplayCurbure = aNewDisplayCurbure; + myDisplayCurbure = aNewDisplayCurbure; } - + inline Standard_Real ISession2D_Curve::GetDiscretisation - () const +() const { -return myDiscretisation; + return myDiscretisation; } inline void ISession2D_Curve::SetDiscretisation - (const Standard_Real aNewDiscretisation) +(const Standard_Real aNewDiscretisation) { -myDiscretisation = aNewDiscretisation; + myDiscretisation = aNewDiscretisation; } diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.cpp deleted file mode 100755 index 7372b96d37..0000000000 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.cpp +++ /dev/null @@ -1,166 +0,0 @@ -#include "stdafx.h" - -#include - -IMPLEMENT_STANDARD_HANDLE(ISession2D_InteractiveContext,MMgt_TShared) -IMPLEMENT_STANDARD_RTTIEXT(ISession2D_InteractiveContext,MMgt_TShared) - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - - ISession2D_InteractiveContext::ISession2D_InteractiveContext() -{ -} - - ISession2D_InteractiveContext::ISession2D_InteractiveContext(const Handle(V2d_Viewer)& aViewer) -{ - Initialize(aViewer); -} - -void ISession2D_InteractiveContext::Initialize(const Handle(V2d_Viewer)& aViewer) -{ - myViewer = aViewer; - myPrsmgr = new PrsMgr_PresentationManager2d(myViewer->View()); - mySelectionManager = new SelectMgr_SelectionManager(); - mySelector = new StdSelect_ViewerSelector2d(); - - mySelector->Set(3); - // set Sensitivity very very important for SensitiveCurve !! - mySelector->SetSensitivity (0.5); // en mm - mySelectionManager->Add(mySelector); - -} - -void ISession2D_InteractiveContext::Display(const Handle(AIS_InteractiveObject)& anObject, - const Standard_Boolean Redraw) -{ - myMapOfObject.Add(anObject); - myPrsmgr->Display(anObject);//,anObject->DisplayMode()); - - mySelectionManager->Load(anObject,mySelector); - mySelectionManager->Activate(anObject,0,mySelector); - - if (Redraw) myViewer->Update(); -} - -void ISession2D_InteractiveContext::Erase(const Handle(AIS_InteractiveObject)& anObject, - const Standard_Boolean Redraw) -{ - if (!anObject.IsNull()) - { - myPrsmgr->Erase(anObject);//,anObject->DisplayMode()); - mySelectionManager - ->Deactivate(anObject,mySelector); - if (Redraw) myViewer->Update(); - } -} - -void ISession2D_InteractiveContext::Move(const Handle(V2d_View)& aView, - const Standard_Integer x1, - const Standard_Integer y1) -{ - if (!aBuffer.IsNull()) - { - aBuffer->UnPost(); - aBuffer->Clear(); - } - - if (myViewer->IsActive()) // A propos de la grille !!! - { - aView->ShowHit(x1,y1); - } - - aBuffer =new Graphic2d_Buffer(aView->View(),0,0,3,5); - mySelector->Pick(x1,y1,aView); - - Handle(SelectMgr_SelectableObject) aSelectableObject; - - mySelector->Init(); - - while (mySelector->More()) - { - aSelectableObject = Handle(SelectMgr_SelectableObject)::DownCast(mySelector->Picked()->Selectable()); - - myPrsmgr->Dump(aBuffer,aSelectableObject) ; - aBuffer->Post(); - - mySelector->Next(); - } -} - -void ISession2D_InteractiveContext::Pick(const Handle(V2d_View)& aView, - const Standard_Integer x1, - const Standard_Integer y1) -{ - - if (myViewer->IsActive()) // A propos de la grille !!! - { - aView->ShowHit(x1,y1); - } - - mySelector->Pick(x1,y1,aView); - - Handle(SelectMgr_SelectableObject) aSelectableObject; - mySelector->Init(); - while (mySelector->More()) - { - Handle(SelectMgr_EntityOwner) aOwn= mySelector->Picked(); - aSelectableObject = Handle(SelectMgr_SelectableObject)::DownCast(aOwn->Selectable()); - myPrsmgr->ColorHighlight(aSelectableObject,5,0) ; - mySelector->Next(); - } - - if (myViewer->IsActive()) // A propos de la grille !!! - { - aView->ShowHit(x1,y1); - } -} - - -void ISession2D_InteractiveContext::DisplayAreas() -{ - myViewer->InitActiveViews(); - while(myViewer->MoreActiveViews()) - { - Handle(V2d_View) aView = myViewer->ActiveView(); - mySelector->DisplayAreas(aView); - myViewer->NextActiveViews(); - } - myViewer->Update(); -} - -void ISession2D_InteractiveContext::ClearAreas() -{ - mySelector->ClearAreas(); - myViewer->Update(); -} - -void ISession2D_InteractiveContext::EraseAll() -{ - TColStd_MapIteratorOfMapOfTransient anIterator(myMapOfObject); - for (;anIterator.More();anIterator.Next()) - { - Handle(Standard_Transient) aTransient = anIterator.Key(); - Handle(AIS_InteractiveObject) anObject = Handle(AIS_InteractiveObject)::DownCast(aTransient); - - if (!anObject.IsNull()) - { - myPrsmgr->Erase(anObject); - mySelectionManager - ->Deactivate(Handle(AIS_InteractiveObject)::DownCast(anObject),mySelector); - } - else - { - Standard_CString ObjectTypeName = aTransient->DynamicType()->Name(); - } - } - myViewer->Update(); -} diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.h deleted file mode 100755 index 76ca1b3840..0000000000 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_InteractiveContext.h +++ /dev/null @@ -1,98 +0,0 @@ -// File generated by CPPExt (Transient) -// -// Copyright (C) 1991,1995 by -// -// MATRA DATAVISION, FRANCE -// -// This software is furnished in accordance with the terms and conditions -// of the contract and with the inclusion of the above copyright notice. -// This software or any other copy thereof may not be provided or otherwise -// be made available to any other person. No title to an ownership of the -// software is hereby transferred. -// -// At the termination of the contract, the software and all copies of this -// software must be deleted. -// -#ifndef _ISession2D_InteractiveContext_HeaderFile -#define _ISession2D_InteractiveContext_HeaderFile - -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include - -class V2d_Viewer; -class PrsMgr_PresentationManager2d; -class SelectMgr_SelectionManager; -#include -class SelectMgr_SelectableObject; -class V2d_View; -#include "TColStd_MapOfTransient.hxx" -DEFINE_STANDARD_HANDLE(ISession2D_InteractiveContext,MMgt_TShared) -class ISession2D_InteractiveContext : public MMgt_TShared { - -public: - void EraseAll(); - - // Methods PUBLIC - // -ISession2D_InteractiveContext(); -ISession2D_InteractiveContext(const Handle(V2d_Viewer)& aViewer); -void Initialize(const Handle(V2d_Viewer)& aViewer) ; -void Display(const Handle(AIS_InteractiveObject)& anObject,const Standard_Boolean Redraw = Standard_True) ; -void Erase(const Handle(AIS_InteractiveObject)& anObject,const Standard_Boolean Redraw = Standard_True) ; -virtual void Move(const Handle(V2d_View)& aView,const Standard_Integer x1,const Standard_Integer y1) ; -void Pick(const Handle(V2d_View)& aView, - const Standard_Integer x1, - const Standard_Integer y1); - -void DisplayAreas() ; -void ClearAreas() ; - -DEFINE_STANDARD_RTTI(ISession2D_InteractiveContext) - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - - -private: - TColStd_MapOfTransient myMapOfObject; - - // Methods PRIVATE - // - - - // Fields PRIVATE - // -Handle(V2d_Viewer) myViewer; -Handle_PrsMgr_PresentationManager2d myPrsmgr; -Handle_SelectMgr_SelectionManager mySelectionManager; -Handle_StdSelect_ViewerSelector2d mySelector; - - -// for dynamic selection -Handle(Graphic2d_Buffer) aBuffer; - - -}; - - -// other inline functions and methods (like "C++: function call" methods) -// - - -#endif diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.cpp index 01758fa183..ea39087579 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.cpp @@ -4,17 +4,8 @@ #include -IMPLEMENT_STANDARD_HANDLE(ISession2D_SensitiveCurve,Select2D_SensitiveEntity) -IMPLEMENT_STANDARD_RTTIEXT(ISession2D_SensitiveCurve,Select2D_SensitiveEntity) - -#include -#include -#include -#include -#include -#include -#include "GCPnts_TangentialDeflection.hxx" -#include "Geom2dAdaptor_Curve.hxx" +IMPLEMENT_STANDARD_HANDLE(ISession2D_SensitiveCurve,Select3D_SensitiveEntity) +IMPLEMENT_STANDARD_RTTIEXT(ISession2D_SensitiveCurve,Select3D_SensitiveEntity) //===================================================== // Function : Create @@ -27,7 +18,7 @@ ISession2D_SensitiveCurve(const Handle(SelectBasics_EntityOwner)& OwnerId, const Handle(Geom2d_Curve)& C, const Standard_Real CDeflect, const Standard_Integer MaxRect): -Select2D_SensitiveEntity(OwnerId), +Select3D_SensitiveEntity(OwnerId), myMaxRect(MaxRect), myCurve(C), myCDeflect(CDeflect) diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.h index f30ceae72b..6daa3b4501 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession2D_SensitiveCurve.h @@ -21,8 +21,8 @@ #include #include -#include -#include +#include +#include #include #include class SelectBasics_EntityOwner; @@ -32,57 +32,38 @@ class gp_Pnt2d; #include -DEFINE_STANDARD_HANDLE(ISession2D_SensitiveCurve,Select2D_SensitiveEntity) -class ISession2D_SensitiveCurve : public Select2D_SensitiveEntity { +DEFINE_STANDARD_HANDLE(ISession2D_SensitiveCurve,Select3D_SensitiveEntity) +class ISession2D_SensitiveCurve : public Select3D_SensitiveEntity { public: // Methods PUBLIC // -Standard_EXPORT ISession2D_SensitiveCurve(const Handle(SelectBasics_EntityOwner)& OwnerId, - const Handle(Geom2d_Curve)& C, - const Standard_Real CDeflect, - const Standard_Integer MaxRect = 3); -inline void SetMaxBoxes(const Standard_Integer MaxRect) ; -inline virtual Standard_Integer MaxBoxes() const; + Standard_EXPORT ISession2D_SensitiveCurve(const Handle(SelectBasics_EntityOwner)& OwnerId, + const Handle(Geom2d_Curve)& C, + const Standard_Real CDeflect, + const Standard_Integer MaxRect = 3); + inline void SetMaxBoxes(const Standard_Integer MaxRect) ; + inline virtual Standard_Integer MaxBoxes() const; -inline void SetCurve(const Handle(Geom2d_Curve) aCurve) ; -inline Handle(Geom2d_Curve) GetCurve() ; + inline void SetCurve(const Handle(Geom2d_Curve) aCurve) ; + inline Handle(Geom2d_Curve) GetCurve() ; -void Compute(); + void Compute(); + Standard_EXPORT void Areas(SelectBasics_ListOfBox2d& aSeq) ; + Standard_EXPORT Standard_Boolean Matches(const Standard_Real XMin,const Standard_Real YMin,const Standard_Real XMax,const Standard_Real YMax,const Standard_Real aTol) ; + Standard_EXPORT Standard_Boolean Matches(const Standard_Real X,const Standard_Real Y,const Standard_Real aTol,Standard_Real& DMin) ; + Handle(TColgp_HArray1OfPnt2d) SensitivePolygon(); -Standard_EXPORT void Areas(SelectBasics_ListOfBox2d& aSeq) ; - -Standard_EXPORT Standard_Boolean Matches(const Standard_Real XMin,const Standard_Real YMin,const Standard_Real XMax,const Standard_Real YMax,const Standard_Real aTol) ; -Standard_EXPORT Standard_Boolean Matches(const Standard_Real X,const Standard_Real Y,const Standard_Real aTol,Standard_Real& DMin) ; - -Handle(TColgp_HArray1OfPnt2d) SensitivePolygon(); - -DEFINE_STANDARD_RTTI(ISession2D_SensitiveCurve) - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - + DEFINE_STANDARD_RTTI(ISession2D_SensitiveCurve) private: - - // Methods PRIVATE - // - - // Fields PRIVATE // -Standard_Real myCDeflect; -Standard_Integer myMaxRect; -Handle(Geom2d_Curve) myCurve; - +Standard_Real myCDeflect; +Standard_Integer myMaxRect; +Handle(Geom2d_Curve) myCurve; Handle(TColgp_HArray1OfPnt2d) myPolyP2d; }; @@ -102,8 +83,4 @@ inline Handle(Geom2d_Curve) ISession2D_SensitiveCurve:: GetCurve() {return myCurve;} -// other inline functions and methods (like "C++: function call" methods) -// - - #endif diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.cpp index 646581857d..1672c91961 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.cpp @@ -9,9 +9,6 @@ IMPLEMENT_STANDARD_HANDLE(ISession_Curve,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession_Curve,AIS_InteractiveObject) -#include "StdPrs_Curve.hxx" -#include "GeomAdaptor_Curve.hxx" -#include "StdPrs_PoleCurve.hxx" #ifdef _DEBUG #undef THIS_FILE static char THIS_FILE[]=__FILE__; diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.h index b5f2c9b258..eaed619246 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Curve.h @@ -16,16 +16,18 @@ DEFINE_STANDARD_HANDLE(ISession_Curve,AIS_InteractiveObject) class ISession_Curve : public AIS_InteractiveObject { public: - ISession_Curve(Handle(Geom_Curve)& aCurve); - virtual ~ISession_Curve(); -DEFINE_STANDARD_RTTI(ISession_Curve) + ISession_Curve(Handle(Geom_Curve)& aCurve); + virtual ~ISession_Curve(); + + DEFINE_STANDARD_RTTI(ISession_Curve) + private: -Standard_EXPORT virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0) ; -Standard_EXPORT virtual void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Prs3d_Presentation)& aPresentation) ; -void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; + Standard_EXPORT virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0) ; + Standard_EXPORT virtual void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Prs3d_Presentation)& aPresentation) ; + void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; -Handle(Geom_Curve) myCurve; + Handle(Geom_Curve) myCurve; }; #endif // !defined(AFX_ISESSION_CURVE_H__F981CB93_A3CC_11D1_8DA3_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.cpp index 9091678613..1fa107de3c 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.cpp @@ -14,11 +14,6 @@ static char THIS_FILE[]=__FILE__; IMPLEMENT_STANDARD_HANDLE(ISession_Direction,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession_Direction,AIS_InteractiveObject) -#include "Graphic2d_SetOfSegments.hxx" -#include "gp_Vec2d.hxx" -#include "DsgPrs_LengthPresentation.hxx" -#include "Prs3d_ArrowAspect.hxx" - ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// @@ -84,31 +79,6 @@ void ISession_Direction::Compute(const Handle(Prs3d_Projector)& aProjector, { } -void ISession_Direction::Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer aMode) -{ - Handle(Graphic2d_SetOfSegments) segment; - segment = new Graphic2d_SetOfSegments(aGrObj); - - segment->Add(myPnt.X(), - myPnt.Y(), - myPnt.X()+myLength*myDir.X(), - myPnt.Y()+myLength*myDir.Y()); - - gp_Dir2d aFirstDir = gp_Dir2d(myDir.X(),myDir.Y()).Rotated (200*M_PI/180) ; - segment->Add(myPnt.X()+myLength*myDir.X(), - myPnt.Y()+myLength*myDir.Y(), - myPnt.X()+myLength*myDir.X()+ myLength*aFirstDir.X()/5 , - myPnt.Y()+myLength*myDir.Y()+ myLength*aFirstDir.Y()/5 ); - - gp_Dir2d aSecondDir = gp_Dir2d(myDir.X(),myDir.Y()).Rotated (-200*M_PI/180) ; - segment->Add(myPnt.X()+myLength*myDir.X(), - myPnt.Y()+myLength*myDir.Y(), - myPnt.X()+myLength*myDir.X()+ myLength*aSecondDir.X()/5 , - myPnt.Y()+myLength*myDir.Y()+ myLength*aSecondDir.Y()/5 ); - -} void ISession_Direction::ComputeSelection(const Handle(SelectMgr_Selection)& aSelection, const Standard_Integer aMode) { diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.h index 76e760cce0..5871c8de1b 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Direction.h @@ -14,17 +14,17 @@ DEFINE_STANDARD_HANDLE(ISession_Direction,AIS_InteractiveObject) class ISession_Direction : public AIS_InteractiveObject { public: - TCollection_ExtendedString myText; - void SetText(TCollection_ExtendedString& aText); - ISession_Direction(); - ISession_Direction(gp_Pnt& aPnt,gp_Dir& aDir,Standard_Real aLength=1,Standard_Real anArrowLength=1); - ISession_Direction(gp_Pnt& aPnt,gp_Vec& aVec,Standard_Real anArrowLength=1); + TCollection_ExtendedString myText; + void SetText(TCollection_ExtendedString& aText); + ISession_Direction(); + ISession_Direction(gp_Pnt& aPnt,gp_Dir& aDir,Standard_Real aLength=1,Standard_Real anArrowLength=1); + ISession_Direction(gp_Pnt& aPnt,gp_Vec& aVec,Standard_Real anArrowLength=1); - ISession_Direction(gp_Pnt2d& aPnt2d,gp_Dir2d& aDir2d,Standard_Real aLength=1); - ISession_Direction(gp_Pnt2d& aPnt2d,gp_Vec2d& aVec2d); + ISession_Direction(gp_Pnt2d& aPnt2d,gp_Dir2d& aDir2d,Standard_Real aLength=1); + ISession_Direction(gp_Pnt2d& aPnt2d,gp_Vec2d& aVec2d); - virtual ~ISession_Direction(); - DEFINE_STANDARD_RTTI(ISession_Direction) + virtual ~ISession_Direction(); + DEFINE_STANDARD_RTTI(ISession_Direction) private: @@ -33,9 +33,6 @@ private: const Standard_Integer aMode); void Compute (const Handle(Prs3d_Projector)& aProjector, const Handle(Prs3d_Presentation)& aPresentation) ; - virtual void Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer aMode = 0) ; void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; gp_Pnt myPnt; diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.cpp index 73f8dab8f7..d522177c01 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.cpp @@ -14,9 +14,6 @@ static char THIS_FILE[]=__FILE__; IMPLEMENT_STANDARD_HANDLE(ISession_Point,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession_Point,AIS_InteractiveObject) -#include "Graphic2d_CircleMarker.hxx" -#include "StdPrs_Point.hxx" -#include "Geom_CartesianPoint.hxx" ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// @@ -58,14 +55,6 @@ void ISession_Point::Compute(const Handle(Prs3d_Projector)& aProjector, { } -void ISession_Point::Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer unMode) -{ - Handle(Graphic2d_CircleMarker) aCircleMarker; - aCircleMarker = new Graphic2d_CircleMarker(aGrObj,myPoint.X(),myPoint.Y(),0,0,1); -} - void ISession_Point::ComputeSelection(const Handle(SelectMgr_Selection)& aSelection, const Standard_Integer unMode) { diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.h index b80e9cdf78..d372fb1c5a 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Point.h @@ -17,28 +17,25 @@ DEFINE_STANDARD_HANDLE(ISession_Point,AIS_InteractiveObject) class ISession_Point : public AIS_InteractiveObject { public: - ISession_Point(); - ISession_Point(Standard_Real X,Standard_Real Y ,Standard_Real Z); - ISession_Point(gp_Pnt2d& aPoint,Standard_Real Elevation = 0); - ISession_Point(gp_Pnt& aPoint); - - virtual ~ISession_Point(); - DEFINE_STANDARD_RTTI(ISession_Point) + ISession_Point(); + ISession_Point(Standard_Real X,Standard_Real Y ,Standard_Real Z); + ISession_Point(gp_Pnt2d& aPoint,Standard_Real Elevation = 0); + ISession_Point(gp_Pnt& aPoint); + virtual ~ISession_Point(); + DEFINE_STANDARD_RTTI(ISession_Point) private : -void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, - const Handle(Prs3d_Presentation)& aPresentation, - const Standard_Integer aMode); -void Compute (const Handle(Prs3d_Projector)& aProjector, - const Handle(Prs3d_Presentation)& aPresentation) ; -void Compute (const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer unMode = 0) ; -void ComputeSelection (const Handle(SelectMgr_Selection)& aSelection, - const Standard_Integer unMode) ; + void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, + const Handle(Prs3d_Presentation)& aPresentation, + const Standard_Integer aMode); + void Compute (const Handle(Prs3d_Projector)& aProjector, + const Handle(Prs3d_Presentation)& aPresentation); -gp_Pnt myPoint; + void ComputeSelection (const Handle(SelectMgr_Selection)& aSelection, + const Standard_Integer unMode); + + gp_Pnt myPoint; }; diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.cpp index 52bc60a974..f53d06a652 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.cpp @@ -14,15 +14,6 @@ static char THIS_FILE[]=__FILE__; IMPLEMENT_STANDARD_HANDLE(ISession_Surface,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession_Surface,AIS_InteractiveObject) -#include "GeomAdaptor_Surface.hxx" -#include "StdPrs_WFSurface.hxx" -#include "StdPrs_WFPoleSurface.hxx" -#include "GeomAdaptor_HSurface.hxx" -#include "AIS_Drawer.hxx" -#include "Prs3d_IsoAspect.hxx" -#include "StdPrs_WFDeflectionShape.hxx" -#include "StdPrs_ShadedSurface.hxx" - ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.h index 1844d8741f..c8c2b13ac2 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Surface.h @@ -23,9 +23,9 @@ public: DEFINE_STANDARD_RTTI(ISession_Surface) private: -Standard_EXPORT virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0) ; -Standard_EXPORT virtual void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Prs3d_Presentation)& aPresentation) ; -void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ; +Standard_EXPORT virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,const Handle(Prs3d_Presentation)& aPresentation,const Standard_Integer aMode = 0); +Standard_EXPORT virtual void Compute(const Handle(Prs3d_Projector)& aProjector,const Handle(Prs3d_Presentation)& aPresentation); +void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode); Handle(Geom_Surface) mySurface; diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.cpp b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.cpp index b7434b8dc8..5d010a53a6 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.cpp +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.cpp @@ -14,20 +14,6 @@ static char THIS_FILE[]=__FILE__; IMPLEMENT_STANDARD_HANDLE(ISession_Text,AIS_InteractiveObject) IMPLEMENT_STANDARD_RTTIEXT(ISession_Text,AIS_InteractiveObject) -#include -#include -#include -#include -#include -#include -#include "PrsMgr_PresentationManager2d.hxx" -#include "SelectMgr_Selection.hxx" -#include "Graphic2d_Array1OfVertex.hxx" -#include "Graphic2d_Polyline.hxx" -#include "Graphic2d_Vertex.hxx" -#include "Graphic2d_DisplayList.hxx" -#include "Prs3d_Text.hxx" - ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// @@ -37,7 +23,6 @@ ISession_Text::ISession_Text() } - ISession_Text::ISession_Text (const TCollection_AsciiString& aText, const Standard_Real anX , // = 0 @@ -52,7 +37,9 @@ ISession_Text::ISession_Text :AIS_InteractiveObject(),MyText(aText),MyX(anX),MyY(anY),MyZ(aZ), MyTypeOfText(aType),MyAngle(anAngle),MySlant(aslant),MyFontIndex(aFontIndex), MyColorIndex(aColorIndex),MyScale(aScale),MyWidth(0),MyHeight(0) -{} +{ + +} ISession_Text::ISession_Text (const TCollection_AsciiString& aText, @@ -66,9 +53,9 @@ ISession_Text::ISession_Text :AIS_InteractiveObject(),MyText(aText),MyX(aPoint.X()),MyY(aPoint.Y()),MyZ(aPoint.Z()), MyTypeOfText(aType),MyAngle(anAngle),MySlant(aslant),MyFontIndex(aFontIndex), MyColorIndex(aColorIndex),MyScale(aScale),MyWidth(0),MyHeight(0) -{} - +{ +} ISession_Text::~ISession_Text() { @@ -87,25 +74,6 @@ void ISession_Text::Compute(const Handle(Prs3d_Projector)& aProjector, { } -void ISession_Text::Compute(const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer unMode) -{ - Handle(Graphic2d_Text) text; - text = new Graphic2d_Text(aGrObj, MyText, MyX, MyY, MyAngle,MyTypeOfText,MyScale); - text->SetFontIndex(MyFontIndex); - - text->SetColorIndex(MyColorIndex); - - text->SetSlant(MySlant); - text->SetUnderline(Standard_False); - text->SetZoomable(Standard_True); - aGrObj->Display(); - Quantity_Length anXoffset,anYoffset; - text->TextSize(MyWidth, MyHeight,anXoffset,anYoffset); - -} - void ISession_Text::ComputeSelection(const Handle(SelectMgr_Selection)& aSelection, const Standard_Integer unMode) { diff --git a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.h b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.h index a195ac2e9e..b7e6ccbd43 100755 --- a/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.h +++ b/samples/mfc/standard/01_Geometry/src/ISession2D/ISession_Text.h @@ -11,24 +11,20 @@ #include #include - #include #include #include #include #include #include -#include -#include -#include +#include +#include #include #include #include #include class TCollection_AsciiString; -class PrsMgr_PresentationManager2d; -class Graphic2d_GraphicObject; class SelectMgr_Selection; DEFINE_STANDARD_HANDLE(ISession_Text,AIS_InteractiveObject) @@ -80,32 +76,15 @@ inline void SetScale (const Quantity_Factor aNewScale) ; DEFINE_STANDARD_RTTI(ISession_Text) - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - - private: - // Methods PRIVATE - // - -void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, - const Handle(Prs3d_Presentation)& aPresentation, - const Standard_Integer aMode); -void Compute (const Handle(Prs3d_Projector)& aProjector, - const Handle(Prs3d_Presentation)& aPresentation); -void Compute (const Handle(PrsMgr_PresentationManager2d)& aPresentationManager, - const Handle(Graphic2d_GraphicObject)& aGrObj, - const Standard_Integer unMode = 0) ; -void ComputeSelection (const Handle(SelectMgr_Selection)& aSelection, - const Standard_Integer unMode) ; + void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, + const Handle(Prs3d_Presentation)& aPresentation, + const Standard_Integer aMode); + void Compute (const Handle(Prs3d_Projector)& aProjector, + const Handle(Prs3d_Presentation)& aPresentation); + void ComputeSelection (const Handle(SelectMgr_Selection)& aSelection, + const Standard_Integer unMode) ; // Fields PRIVATE diff --git a/samples/mfc/standard/01_Geometry/src/MainFrm.cpp b/samples/mfc/standard/01_Geometry/src/MainFrm.cpp index 4b69f36c40..fe5757a1bf 100755 --- a/samples/mfc/standard/01_Geometry/src/MainFrm.cpp +++ b/samples/mfc/standard/01_Geometry/src/MainFrm.cpp @@ -18,17 +18,17 @@ static char THIS_FILE[] = __FILE__; IMPLEMENT_DYNAMIC(CMainFrame, CMDIFrameWnd) BEGIN_MESSAGE_MAP(CMainFrame, CMDIFrameWnd) - //{{AFX_MSG_MAP(CMainFrame) - ON_WM_CREATE() - //}}AFX_MSG_MAP + //{{AFX_MSG_MAP(CMainFrame) + ON_WM_CREATE() + //}}AFX_MSG_MAP END_MESSAGE_MAP() static UINT indicators[] = { - ID_SEPARATOR, // status line indicator - ID_INDICATOR_CAPS, - ID_INDICATOR_NUM, - ID_INDICATOR_SCRL, + ID_SEPARATOR, // status line indicator + ID_INDICATOR_CAPS, + ID_INDICATOR_NUM, + ID_INDICATOR_SCRL, }; ///////////////////////////////////////////////////////////////////////////// @@ -36,8 +36,6 @@ static UINT indicators[] = CMainFrame::CMainFrame() { - // TODO: add member initialization code here - } CMainFrame::~CMainFrame() @@ -46,58 +44,57 @@ CMainFrame::~CMainFrame() int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) { - if (CMDIFrameWnd::OnCreate(lpCreateStruct) == -1) - return -1; - - if (!m_wndToolBar.Create(this) || - !m_wndToolBar.LoadToolBar(IDR_MAINFRAME)) - { - TRACE0("Failed to create toolbar\n"); - return -1; // fail to create - } - if (!m_wndToolBar2.Create(this) || - !m_wndToolBar2.LoadToolBar(IDR_MAINFRAME2)) - { - TRACE0("Failed to create toolbar\n"); - return -1; // fail to create - } + if (CMDIFrameWnd::OnCreate(lpCreateStruct) == -1) + return -1; - if (!m_wndStatusBar.Create(this) || - !m_wndStatusBar.SetIndicators(indicators, - sizeof(indicators)/sizeof(UINT))) - { - TRACE0("Failed to create status bar\n"); - return -1; // fail to create - } + if (!m_wndToolBar.Create(this) || + !m_wndToolBar.LoadToolBar(IDR_MAINFRAME)) + { + TRACE0("Failed to create toolbar\n"); + return -1; // fail to create + } + if (!m_wndToolBar2.Create(this) || + !m_wndToolBar2.LoadToolBar(IDR_MAINFRAME2)) + { + TRACE0("Failed to create toolbar\n"); + return -1; // fail to create + } - // TODO: Remove this if you don't want tool tips or a resizeable toolbar - m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | - CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + if (!m_wndStatusBar.Create(this) || + !m_wndStatusBar.SetIndicators(indicators, + sizeof(indicators)/sizeof(UINT))) + { + TRACE0("Failed to create status bar\n"); + return -1; // fail to create + } - // TODO: Delete these three lines if you don't want the toolbar to - // be dockable - m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); - EnableDocking(CBRS_ALIGN_ANY); - DockControlBar(&m_wndToolBar); + // TODO: Remove this if you don't want tool tips or a resizeable toolbar + m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle() | + CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); - // TODO: Remove this if you don't want tool tips or a resizeable toolbar - m_wndToolBar2.SetBarStyle(m_wndToolBar2.GetBarStyle() | - CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + // TODO: Delete these three lines if you don't want the toolbar to + // be dockable + m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY); + EnableDocking(CBRS_ALIGN_ANY); + DockControlBar(&m_wndToolBar); - // TODO: Delete these three lines if you don't want the toolbar to - // be dockable - m_wndToolBar2.EnableDocking(CBRS_ALIGN_ANY); - EnableDocking(CBRS_ALIGN_ANY); - DockControlBar(&m_wndToolBar2); - return 0; + // TODO: Remove this if you don't want tool tips or a resizeable toolbar + m_wndToolBar2.SetBarStyle(m_wndToolBar2.GetBarStyle() | + CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC); + + // TODO: Delete these three lines if you don't want the toolbar to + // be dockable + m_wndToolBar2.EnableDocking(CBRS_ALIGN_ANY); + EnableDocking(CBRS_ALIGN_ANY); + DockControlBar(&m_wndToolBar2); + return 0; } BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs) { - // TODO: Modify the Window class or styles here by modifying - // the CREATESTRUCT cs - - return CMDIFrameWnd::PreCreateWindow(cs); + // TODO: Modify the Window class or styles here by modifying + // the CREATESTRUCT cs + return CMDIFrameWnd::PreCreateWindow(cs); } ///////////////////////////////////////////////////////////////////////////// @@ -106,12 +103,12 @@ BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs) #ifdef _DEBUG void CMainFrame::AssertValid() const { - CMDIFrameWnd::AssertValid(); + CMDIFrameWnd::AssertValid(); } void CMainFrame::Dump(CDumpContext& dc) const { - CMDIFrameWnd::Dump(dc); + CMDIFrameWnd::Dump(dc); } #endif //_DEBUG diff --git a/samples/mfc/standard/01_Geometry/src/MainFrm.h b/samples/mfc/standard/01_Geometry/src/MainFrm.h index 3ddc1e6cae..de34ccb4ba 100755 --- a/samples/mfc/standard/01_Geometry/src/MainFrm.h +++ b/samples/mfc/standard/01_Geometry/src/MainFrm.h @@ -11,41 +11,39 @@ class CMainFrame : public CMDIFrameWnd { - DECLARE_DYNAMIC(CMainFrame) + DECLARE_DYNAMIC(CMainFrame) public: - CMainFrame(); + CMainFrame(); -// Attributes + // Attributes public: -// Operations + // Operations public: -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CMainFrame) - virtual BOOL PreCreateWindow(CREATESTRUCT& cs); - //}}AFX_VIRTUAL + // Overrides + // ClassWizard generated virtual function overrides + virtual BOOL PreCreateWindow(CREATESTRUCT& cs); -// Implementation + // Implementation public: - virtual ~CMainFrame(); + virtual ~CMainFrame(); #ifdef _DEBUG - virtual void AssertValid() const; - virtual void Dump(CDumpContext& dc) const; + virtual void AssertValid() const; + virtual void Dump(CDumpContext& dc) const; #endif protected: // control bar embedded members - CStatusBar m_wndStatusBar; - CToolBar m_wndToolBar; - CToolBar m_wndToolBar2; + CStatusBar m_wndStatusBar; + CToolBar m_wndToolBar; + CToolBar m_wndToolBar2; -// Generated message map functions + // Generated message map functions protected: - //{{AFX_MSG(CMainFrame) - afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + //{{AFX_MSG(CMainFrame) + afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); + //}}AFX_MSG + DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/01_Geometry/src/StdAfx.h b/samples/mfc/standard/01_Geometry/src/StdAfx.h index be68658145..a63cc69cf2 100755 --- a/samples/mfc/standard/01_Geometry/src/StdAfx.h +++ b/samples/mfc/standard/01_Geometry/src/StdAfx.h @@ -83,181 +83,193 @@ #include #include -//#include +#include +#include +#include +#include +#include + #include #include +#include +#include #include -#include -#include -#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include #include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + #include #include #include - -#include -#include -#include -#include -#include -//#include -//#include -//#include -//#include -#include - -#include "WNT_WDriver.hxx" -#include "V2d_View.hxx" -#include "V2d_Viewer.hxx" - - -//#include "UnitsAPI.hxx" - - -#include "GProp_PEquation.hxx" -#include "gp.hxx" -#include "TColgp_Array1OfPnt.hxx" -#include "Geom2d_Circle.hxx" -#include "gp_Vec2d.hxx" -#include "Geom2d_Circle.hxx" -#include "Geom2dLProp_Curve2dTool.hxx" - -#include "Geom2dLProp_CLProps2d.hxx" -#include "gp_Dir.hxx" -#include "Precision.hxx" -#include "GCPnts_AbscissaPoint.hxx" -#include "Geom2dAdaptor_Curve.hxx" -#include "GCPnts_UniformAbscissa.hxx" -#include "Geom_SphericalSurface.hxx" -#include "Geom_Circle.hxx" -#include "GC_MakeTranslation.hxx" -#include "Geom_Transformation.hxx" -#include "GC_MakeCircle.hxx" -#include "gp_Mat.hxx" -#include "GeomAPI_IntCS.hxx" -#include "GC_MakeSegment.hxx" -#include "GC_MakeConicalSurface.hxx" -#include "gp_Lin.hxx" -#include "Geom2d_Ellipse.hxx" -#include "GCE2d_MakeEllipse.hxx" -#include "GCE2d_MakeArcOfEllipse.hxx" -#include "TColgp_HArray1OfPnt.hxx" -#include "Geom_BSplineCurve.hxx" -#include "GeomAPI_PointsToBSpline.hxx" -#include "GeomAPI_Interpolate.hxx" -#include "GccEnt_QualifiedLin.hxx" -#include "GccAna_Circ2d2TanRad.hxx" -#include "gce_MakeCirc2d.hxx" -#include "GccEnt.hxx" -#include "GccAna_Lin2d2Tan.hxx" -#include "GccEnt_QualifiedCirc.hxx" -#include "gce_MakeLin2d.hxx" -#include "Geom2d_OffsetCurve.hxx" -#include "Geom2dAPI_InterCurveCurve.hxx" -#include "Geom2dAPI_ExtremaCurveCurve.hxx" -#include "GeomAPI.hxx" -#include "Geom2d_TrimmedCurve.hxx" -#include "GCE2d_MakeSegment.hxx" -#include "Geom2dConvert.hxx" -#include "TColgp_Array1OfPnt2d.hxx" -#include "TColgp_HArray1OfPnt2d.hxx" -#include "gp_Parab2d.hxx" -#include "gp_Trsf.hxx" -#include "gp_Pln.hxx" -#include "gp_Elips.hxx" -#include "IntAna_IntConicQuad.hxx" -#include "GeomAPI_ProjectPointOnSurf.hxx" -#include "GeomAPI_ProjectPointOnCurve.hxx" -#include "Geom2dAPI_PointsToBSpline.hxx" -#include "Geom2dAPI_Interpolate.hxx" -#include "GccAna_Pnt2dBisec.hxx" -#include "BRepBuilderAPI_MakeVertex.hxx" -#include "BRepBuilderAPI_MakeFace.hxx" - -////////////////////////////////////////////////////////////////////// -// Construction/Destruction -////////////////////////////////////////////////////////////////////// -#include "GeomTools.hxx" - -#include "TColgp_SequenceOfPnt2d.hxx" -#include "GC_MakePlane.hxx" -#include "GC_MakeEllipse.hxx" -#include "Geom_Plane.hxx" -#include "Geom2d_Line.hxx" -#include "Geom_Circle.hxx" -#include "AIS_Drawer.hxx" -#include "Prs3d_IsoAspect.hxx" -#include "GCE2d_MakeArcOfCircle.hxx" -#include "Geom_Line.hxx" -#include "Geom2d_BSplineCurve.hxx" -#include "TColgp_Array2OfPnt2d.hxx" -#include "Geom_RectangularTrimmedSurface.hxx" -#include "GeomFill_FillingStyle.hxx" -#include "GeomFill_BSplineCurves.hxx" -#include "TopoDS_Vertex.hxx" -#include "TopoDS_Shape.hxx" -#include "TopoDS_Face.hxx" - -#include "GeomAdaptor_HCurve.hxx" -#include "GeomFill_SimpleBound.hxx" -#include "GeomFill_Pipe.hxx" -#include "GeomConvert.hxx" -#include "TColgp_Array2OfPnt.hxx" -#include "Geom_BezierSurface.hxx" -#include "TColGeom_Array2OfBezierSurface.hxx" -#include "GeomConvert_CompBezierSurfacesToBSplineSurface.hxx" -#include "TColStd_HArray1OfInteger.hxx" -#include "Geom_OffsetSurface.hxx" -#include "Geom_SurfaceOfLinearExtrusion.hxx" -#include "Geom_SurfaceOfRevolution.hxx" -#include "GeomLib.hxx" -#include "Geom_BSplineSurface.hxx" -#include "Geom2d_Parabola.hxx" -#include "GCE2d_MakeParabola.hxx" -#include "Geom_TrimmedCurve.hxx" -#include "GeomFill_ConstrainedFilling.hxx" - -#include "Geom_Curve.hxx" -#include "Geom_Surface.hxx" -#include "BndLib_Add2dCurve.hxx" -#include "BndLib.hxx" -#include "FairCurve_Batten.hxx" -#include "FairCurve_MinimalVariation.hxx" -#include "Geom2d_Parabola.hxx" -#include "GCE2d_MakeParabola.hxx" -#include "Geom_TrimmedCurve.hxx" -#include "GeomFill_ConstrainedFilling.hxx" -#include -#include -#include -#include -#include -#include -#include "Prs3d_TextAspect.hxx" -#include "Prs3d_ArrowAspect.hxx" -#include "Prs3d_PointAspect.hxx" -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - #include "ISession2D_Curve.h" #include "ISession_Direction.h" -#include "ISession2D_InteractiveContext.h" #include "ISession_Curve.h" #include "ISession_Surface.h" #include "ISession_Text.h" diff --git a/samples/mfc/standard/02_Modeling/adm/win/vc10/Modeling.vcxproj b/samples/mfc/standard/02_Modeling/adm/win/vc10/Modeling.vcxproj index 420b48e91e..05c235d832 100644 --- a/samples/mfc/standard/02_Modeling/adm/win/vc10/Modeling.vcxproj +++ b/samples/mfc/standard/02_Modeling/adm/win/vc10/Modeling.vcxproj @@ -111,7 +111,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Modeling.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -153,7 +153,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/Modeling.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -196,7 +196,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Modeling.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -238,7 +238,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Modeling.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/02_Modeling/adm/win/vc11/Modeling.vcxproj b/samples/mfc/standard/02_Modeling/adm/win/vc11/Modeling.vcxproj index 14ea833ce7..0b258cf15e 100644 --- a/samples/mfc/standard/02_Modeling/adm/win/vc11/Modeling.vcxproj +++ b/samples/mfc/standard/02_Modeling/adm/win/vc11/Modeling.vcxproj @@ -115,7 +115,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Modeling.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -157,7 +157,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/Modeling.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -200,7 +200,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Modeling.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -242,7 +242,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;TKBO.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Modeling.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/02_Modeling/adm/win/vc8/Modeling.vcproj b/samples/mfc/standard/02_Modeling/adm/win/vc8/Modeling.vcproj index b80aaea03c..53e191c134 100644 --- a/samples/mfc/standard/02_Modeling/adm/win/vc8/Modeling.vcproj +++ b/samples/mfc/standard/02_Modeling/adm/win/vc8/Modeling.vcproj @@ -80,7 +80,7 @@ /> = 1000 -#include +#include -class CModelingApp : public OCC_3dApp +class CModelingApp : public OCC_App { public: - CModelingApp(); -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CModelingApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL -private: - CToolBar *m_pToolBar2; -}; + CModelingApp(); + +// Overrides + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CModelingApp) + public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL + +private: + + CToolBar *m_pToolBar2; +}; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/02_Modeling/src/ModelingDoc.cpp b/samples/mfc/standard/02_Modeling/src/ModelingDoc.cpp index c4f4a182cf..f4ab37af4c 100755 --- a/samples/mfc/standard/02_Modeling/src/ModelingDoc.cpp +++ b/samples/mfc/standard/02_Modeling/src/ModelingDoc.cpp @@ -4936,7 +4936,7 @@ void CModelingDoc::InputEvent(const Standard_Integer x , "Points Files (*.pass)|*.pass; |All Files (*.*)|*.*||", NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); initdir += "\\Data\\TangentSurface"; dlg.m_ofn.lpstrInitialDir = initdir; diff --git a/samples/mfc/standard/03_Viewer2d/README.txt b/samples/mfc/standard/03_Viewer2d/README.txt new file mode 100644 index 0000000000..9d5df752b4 --- /dev/null +++ b/samples/mfc/standard/03_Viewer2d/README.txt @@ -0,0 +1,16 @@ +Viewer2d sample demonstrates how the functionality of TKV3d package can be used +for 2D visualization. It provides samples of 2D objects visualization, +dynamic selection and highlighting. +It illustratea how to: +1) implement 2D view behavior with V3d_View class, with interactive zooming and +panning of the 2D scene; +2) draw 2D primitives like rectangles, lines, curves; +3) draw different types of markers; +4) draw text defined by its font, height, style, angle; +5) display 2D curves of a face' edges and group them using orientation +criterion; +6) display zoomable images; +6) display circular and rectangular grids . + +Viewer2d support zooming ,panning of displayed objects and +circular and rectangular grids. \ No newline at end of file diff --git a/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj b/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj index 2d730414b9..297402ff45 100644 --- a/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj +++ b/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Viewer2d.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Viewer2d.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -195,7 +195,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Viewer2d.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -237,7 +237,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/Viewer2d.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -248,102 +248,6 @@ - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -364,22 +268,6 @@ %(PreprocessorDefinitions) Create - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -412,22 +300,6 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -458,18 +330,10 @@ - - - - - - - - diff --git a/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj.filters b/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj.filters index 111bd2ceae..77f8789975 100644 --- a/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj.filters +++ b/samples/mfc/standard/03_Viewer2d/adm/win/vc10/Viewer2d.vcxproj.filters @@ -15,39 +15,15 @@ - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - Source Files - - Source Files - Source Files Source Files - - Source Files - Source Files @@ -58,42 +34,18 @@ - - Header Files - - - Header Files - - - Header Files - - - Header Files - - - Header Files - - - Header Files - Header Files Header Files - - Header Files - Header Files Header Files - - Header Files - diff --git a/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj b/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj index e4af76ed6c..1a05483c87 100644 --- a/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj +++ b/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Viewer2d.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Viewer2d.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -199,7 +199,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Viewer2d.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -241,7 +241,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/Viewer2d.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -252,102 +252,6 @@ - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -368,22 +272,6 @@ %(PreprocessorDefinitions) Create - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -416,22 +304,6 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - Disabled %(AdditionalIncludeDirectories) @@ -462,18 +334,10 @@ - - - - - - - - diff --git a/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj.filters b/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj.filters index 111bd2ceae..77f8789975 100644 --- a/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj.filters +++ b/samples/mfc/standard/03_Viewer2d/adm/win/vc11/Viewer2d.vcxproj.filters @@ -15,39 +15,15 @@ - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - Source Files - - Source Files - Source Files Source Files - - Source Files - Source Files @@ -58,42 +34,18 @@ - - Header Files - - - Header Files - - - Header Files - - - Header Files - - - Header Files - - - Header Files - Header Files Header Files - - Header Files - Header Files Header Files - - Header Files - diff --git a/samples/mfc/standard/03_Viewer2d/adm/win/vc8/Viewer2d.vcproj b/samples/mfc/standard/03_Viewer2d/adm/win/vc8/Viewer2d.vcproj index 41c459741c..be06fdacea 100644 --- a/samples/mfc/standard/03_Viewer2d/adm/win/vc8/Viewer2d.vcproj +++ b/samples/mfc/standard/03_Viewer2d/adm/win/vc8/Viewer2d.vcproj @@ -81,7 +81,7 @@ /> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -740,52 +464,6 @@ /> - - - - - - - - - - - - - - @@ -918,52 +596,6 @@ /> - - - - - - - - - - - - - - @@ -1015,30 +647,6 @@ Name="Header Files" Filter="h;hpp;hxx;hm;inl" > - - - - - - - - - - - - @@ -1047,10 +655,6 @@ RelativePath="..\..\..\src\StdAfx.h" > - - @@ -1059,10 +663,6 @@ RelativePath="..\..\..\src\Viewer2dDoc.h" > - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -737,52 +461,6 @@ /> - - - - - - - - - - - - - - @@ -915,52 +593,6 @@ /> - - - - - - - - - - - - - - @@ -1012,30 +644,6 @@ Name="Header Files" Filter="h;hpp;hxx;hm;inl" > - - - - - - - - - - - - @@ -1044,10 +652,6 @@ RelativePath="..\..\..\src\StdAfx.h" > - - @@ -1056,10 +660,6 @@ RelativePath="..\..\..\src\Viewer2dDoc.h" > - - = 1000 -#pragma once -#endif // _MSC_VER >= 1000 - -#include "Aspect_ColorMap.hxx" -///////////////////////////////////////////////////////////////////////////// -// CColorNewColorCubeColorMapDialog dialog - -class CColorNewColorCubeColorMapDialog : public CDialog -{ -private : - Handle(Aspect_ColorMap) myColorMap; - -// Construction -public: - CColorNewColorCubeColorMapDialog(CWnd* pParent = NULL); // standard constructor - Handle(Aspect_ColorMap) ColorMap() {return myColorMap;}; -// Dialog Data - //{{AFX_DATA(CColorNewColorCubeColorMapDialog) - enum { IDD = IDD_DIALOG_NewColorCube }; - int m_base_pixel; - int m_redmax; - int m_redmult; - int m_greenmax; - int m_greenmult; - int m_bluemax; - int m_bluemult; - //}}AFX_DATA - - -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CColorNewColorCubeColorMapDialog) - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - - // Generated message map functions - //{{AFX_MSG(CColorNewColorCubeColorMapDialog) - virtual void OnOK(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_COLORNEWCOLORCUBECOLORMAPDIALOG_H__67E9AE93_D9F9_11D1_8DE3_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorNewColorRampColorMapDialog.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/ColorNewColorRampColorMapDialog.cpp deleted file mode 100755 index 32c289da8d..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorNewColorRampColorMapDialog.cpp +++ /dev/null @@ -1,144 +0,0 @@ -// ColorNewColorRampColorMapDialog.cpp : implementation file -// - -#include "stdafx.h" - -#include "ColorNewColorRampColorMapDialog.h" -#include "Quantity_Color.hxx" -#include "Aspect_ColorRampColorMap.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CColorNewColorRampColorMapDialog dialog - - -CColorNewColorRampColorMapDialog::CColorNewColorRampColorMapDialog(CWnd* pParent /*=NULL*/) - : CDialog(CColorNewColorRampColorMapDialog::IDD, pParent) -{ - //{{AFX_DATA_INIT(CColorNewColorRampColorMapDialog) - m_base_pixel = 0; - m_dimension = 16; - m_Red = 1.0; - m_Green = 0.0; - m_Blue = 0.0; - //}}AFX_DATA_INIT -} - -void CColorNewColorRampColorMapDialog::DoDataExchange(CDataExchange* pDX) -{ - CDialog::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CColorNewColorRampColorMapDialog) - DDX_Control(pDX, IDC_NewColorMap_COMBO_NewEntryColorName, m_ColorList); - DDX_Text(pDX, IDC_NewColorRamp_EDIT_base_pixel, m_base_pixel); - DDX_Text(pDX, IDC_NewColorramp_EDIT_dimension, m_dimension); - DDX_Text(pDX, IDC_NewColorMapRamp_EDIT_ColorRed, m_Red); - DDX_Text(pDX, IDC_NewColorMapRamp_EDIT_ColorGreen, m_Green); - DDX_Text(pDX, IDC_NewColorMapRamp_EDIT_ColorBlue, m_Blue); - //}}AFX_DATA_MAP -} - - -BEGIN_MESSAGE_MAP(CColorNewColorRampColorMapDialog, CDialog) - //{{AFX_MSG_MAP(CColorNewColorRampColorMapDialog) - ON_BN_CLICKED(IDC_NewColorMapRamp_BUTTON_EditColor, OnColorMapRampBUTTONEditColor) - ON_EN_CHANGE(IDC_NewColorMapRamp_EDIT_ColorRed, OnChangeColorMapRampEDITColorRed) - ON_EN_CHANGE(IDC_NewColorMapRamp_EDIT_ColorGreen, OnChangeColorMapRampEDITColorGreen) - ON_EN_CHANGE(IDC_NewColorMapRamp_EDIT_ColorBlue, OnChangeColorMapRampEDITColorBlue) - ON_CBN_SELCHANGE(IDC_NewColorMap_COMBO_NewEntryColorName, OnSelchangeColorMapCOMBONewEntryColorName) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CColorNewColorRampColorMapDialog message handlers -BOOL CColorNewColorRampColorMapDialog::OnInitDialog() -{ - CDialog::OnInitDialog(); - for (int i = 0 ;i< 517 ; i++) - { - Standard_CString TheColorName = Quantity_Color::StringName((Quantity_NameOfColor)i); - // update the CComboBox to add the enumeration possibilities. - m_ColorList.AddString( TheColorName ); - } - Quantity_Color aColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - m_ColorList.SetCurSel(aColor.Name()); - - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - - -void CColorNewColorRampColorMapDialog::OnColorMapRampBUTTONEditColor() -{ - UpdateData(true); - COLORREF m_clr ; - m_clr = RGB(m_Red*255,m_Green*255,m_Blue*255); - CColorDialog dlgColor(m_clr); - if (dlgColor.DoModal() == IDOK) - { - m_clr = dlgColor.GetColor(); - m_Red = GetRValue(m_clr)/255.; - m_Green = GetGValue(m_clr)/255.; - m_Blue = GetBValue(m_clr)/255.; - } - Quantity_Color aColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - m_ColorList.SetCurSel(aColor.Name()); - UpdateData(false); -} - - -void CColorNewColorRampColorMapDialog::OnChangeColorMapRampEDITColorRed() -{ - UpdateData(true); - if (m_Red<0) m_Red=0; - if (m_Red>1) m_Red=1; - - Quantity_Color aColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - m_ColorList.SetCurSel(aColor.Name()); - UpdateData(false); -} - -void CColorNewColorRampColorMapDialog::OnChangeColorMapRampEDITColorGreen() -{ - UpdateData(true); - if (m_Green<0) m_Green=0; - if (m_Green>1) m_Green=1; - Quantity_Color aColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - m_ColorList.SetCurSel(aColor.Name()); - UpdateData(false); -} -void CColorNewColorRampColorMapDialog::OnChangeColorMapRampEDITColorBlue() -{ - UpdateData(true); - if (m_Blue<0) m_Blue=0; - if (m_Blue>1) m_Blue=1; - Quantity_Color aColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - m_ColorList.SetCurSel(aColor.Name()); - UpdateData(false); -} - -void CColorNewColorRampColorMapDialog::OnSelchangeColorMapCOMBONewEntryColorName() -{ - // TODO: Add your control notification handler code here - UpdateData(true); - int CurSel = m_ColorList.GetCurSel(); - Quantity_NameOfColor SelectedNameOfColor = (Quantity_NameOfColor)CurSel; - Quantity_Color TheSelectedEquivalentColor(SelectedNameOfColor); - - Quantity_Parameter Red,Green,Blue; - TheSelectedEquivalentColor.Values(Red,Green,Blue,Quantity_TOC_RGB); - m_Red = Red; - m_Green = Green; - m_Blue = Blue; - UpdateData(false); -} - - -void CColorNewColorRampColorMapDialog::OnOK() -{ - UpdateData(true); - Quantity_Color TheColor(m_Red,m_Green,m_Blue,Quantity_TOC_RGB); - myColorMap = - new Aspect_ColorRampColorMap(m_base_pixel, - m_dimension, - TheColor ); - CDialog::OnOK(); -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.cpp deleted file mode 100755 index 21a442d2f2..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.cpp +++ /dev/null @@ -1,286 +0,0 @@ -// ColorPropertyPage.cpp : implementation file -// - -#include "stdafx.h" - -#include "ColorPropertyPage.h" -#include "ColorNewColorCubeColorMapDialog.h" -#include "ColorNewColorRampColorMapDialog.h" -#include "Aspect_ColorMapEntry.hxx" -#include "V2d_DefaultMap.hxx" -#include "Aspect_GenericColorMap.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CColorPropertyPage property page - -IMPLEMENT_DYNCREATE(CColorPropertyPage, CPropertyPage) - -CColorPropertyPage::CColorPropertyPage() - : CPropertyPage(CColorPropertyPage::IDD) -{ - //{{AFX_DATA_INIT(CColorPropertyPage) - m_ColorMapSize = _T("Computing..."); - m_ColorMapType = _T("Computing..."); - m_CurrentEntryRed = _T("9.999"); - m_CurrentEntryGreen = _T("9.999"); - m_CurrentEntryBlue = _T("9.999"); - m_NearsetColorName = _T("Computing..."); - m_NewEntryRed = 9.999; - m_NewEntryBlue = 9.999; - m_NewEntryGreen = 9.999; - //}}AFX_DATA_INIT -} - -BOOL CColorPropertyPage::OnInitDialog() -{ - CPropertyPage::OnInitDialog(); - - for (int i = 0 ;i< 517 ; i++) - { - Standard_CString TheColorName = Quantity_Color::StringName((Quantity_NameOfColor)i); - // update the CComboBox to add the enumeration possibilities. - m_NewEntryColorNameCtrl.AddString( TheColorName ); - } - m_NewEntryColorNameCtrl.SetCurSel(1); - // TODO: Add extra initialization here - UpdateDisplay(1); - - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - -CColorPropertyPage::~CColorPropertyPage() -{ -} - -void CColorPropertyPage::DoDataExchange(CDataExchange* pDX) -{ - CPropertyPage::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CColorPropertyPage) - DDX_Control(pDX, IDC_ColorMap_COMBO_NewEntryColorName , m_NewEntryColorNameCtrl ); - DDX_Control(pDX, IDC_ColorMap_TAB , m_TabCtrl ); - DDX_Text (pDX, IDC_ColorMap_STATIC_Size , m_ColorMapSize ); - DDX_Text (pDX, IDC_ColorMap_STATIC_Type , m_ColorMapType ); - DDX_Text (pDX, IDC_ColorMap_STATIC_EntryColorRed , m_CurrentEntryRed ); - DDX_Text (pDX, IDC_ColorMap_STATIC_EntryColorGreen , m_CurrentEntryGreen ); - DDX_Text (pDX, IDC_ColorMap_STATIC_EntryColorBlue , m_CurrentEntryBlue ); - DDX_Text (pDX, IDC_ColorMap_STATIC_EntryColorName , m_NearsetColorName ); - DDX_Text (pDX, IDC_ColorMap_EDIT_NewEntryColorRed , m_NewEntryRed ); - DDX_Text (pDX, IDC_ColorMap_EDIT_NewEntryColorBlue , m_NewEntryBlue ); - DDX_Text (pDX, IDC_ColorMap_EDIT_NewEntryColorGreen , m_NewEntryGreen ); - //}}AFX_DATA_MAP -} - -BEGIN_MESSAGE_MAP(CColorPropertyPage, CPropertyPage) - //{{AFX_MSG_MAP(CColorPropertyPage) - ON_NOTIFY(TCN_SELCHANGE, IDC_ColorMap_TAB, OnSelchangeColorMapTAB) - ON_CBN_SELCHANGE(IDC_ColorMap_COMBO_NewEntryColorName, OnSelchangeColorMapCOMBONewEntryColorName) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_UpdateCurrentEntry, OnColorMapBUTTONUpdateCurrentEntry) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_NewColorCubeColorMap, OnColorMapBUTTONNewColorCubeColorMap) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_NewGenericColorMap, OnColorMapBUTTONNewGenericColorMap) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_NewColorRampColorMap, OnColorMapBUTTONNewColorRampColorMap) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_NewEntry_EditColor, OnColorMapBUTTONNewEntryEditColor) - ON_BN_CLICKED(IDC_ColorMap_BUTTON_AddNewEntry, OnColorMapBUTTONAddNewEntry) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -void CColorPropertyPage::UpdateDisplay(int CurrentSelectionIndex) -{ - Aspect_TypeOfColorMap aColorMapType = myColorMap->Type(); - switch (aColorMapType) { - case Aspect_TOC_Generic : m_ColorMapType = _T("Generic"); ; break; - case Aspect_TOC_ColorCube : m_ColorMapType = _T("ColorCube"); break; - case Aspect_TOC_ColorRamp : m_ColorMapType = _T("ColorRamp"); break; - default : cout<<" Underknown"; - } - - int ShowOrHide; - if (aColorMapType == Aspect_TOC_Generic) - { - ShowOrHide = SW_SHOW; - GetDlgItem(IDC_ColorMap_STATIC_NewEntryNotavailable)->ShowWindow(SW_HIDE); - } - else - { - ShowOrHide = SW_HIDE; - GetDlgItem(IDC_ColorMap_STATIC_NewEntryNotavailable)->ShowWindow(SW_SHOW); - } - - GetDlgItem(IDC_ColorMap_EDIT_NewEntryColorRed)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_EDIT_NewEntryColorGreen)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_EDIT_NewEntryColorBlue)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_COMBO_NewEntryColorName)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_BUTTON_NewEntry_EditColor)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_BUTTON_UpdateCurrentEntry)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_BUTTON_AddNewEntry)->ShowWindow(ShowOrHide); - GetDlgItem(IDC_ColorMap_STATIC_NewEntryColorNameStatic)->ShowWindow(ShowOrHide); - - TCollection_AsciiString SizeMessage(myColorMap->Size()); - m_ColorMapSize = _T(SizeMessage.ToCString()); - // clear the Tab Ctrl - m_TabCtrl.DeleteAllItems(); - - TC_ITEM TabCtrlItem; - TabCtrlItem.mask = TCIF_TEXT; - - for(int i =0;iSize();i++) // not <=ColorMapSize, I've enter a CSR - { - Aspect_ColorMapEntry aColorMapEntry = myColorMap->FindEntry(i); - TCollection_AsciiString EntryNumerMessage(aColorMapEntry.Index()); - TabCtrlItem.pszText = (LPSTR)EntryNumerMessage.ToCString(); - m_TabCtrl.InsertItem( aColorMapEntry.Index(), &TabCtrlItem ); - } - m_TabCtrl.SetCurSel(CurrentSelectionIndex); - - // update The Current Selected entry - Aspect_ColorMapEntry aColorMapEntry = myColorMap->FindEntry(CurrentSelectionIndex); - if (aColorMapEntry. IsAllocated () ) - { - Quantity_Color TheColor = aColorMapEntry.Color(); - Quantity_Parameter Red,Green,Blue; - TheColor.Values(Red,Green,Blue,Quantity_TOC_RGB); - TCollection_AsciiString Message; - Message = Red; - m_CurrentEntryRed = _T(Message.ToCString()); - m_NewEntryRed = Red; - Message = Green; - m_CurrentEntryGreen = _T(Message.ToCString()); - m_NewEntryGreen = Green; - Message = Blue; - m_CurrentEntryBlue = _T(Message.ToCString()); - m_NewEntryBlue = Blue; - - Standard_CString StringName = Quantity_Color::StringName(TheColor.Name()); - m_NearsetColorName = StringName; - m_NewEntryColorNameCtrl.SetCurSel(TheColor.Name()); - if (aColorMapType == Aspect_TOC_Generic) - if (m_TabCtrl.GetCurSel() == 0) - GetDlgItem(IDC_ColorMap_BUTTON_UpdateCurrentEntry)->ShowWindow(SW_HIDE); - else - GetDlgItem(IDC_ColorMap_BUTTON_UpdateCurrentEntry)->ShowWindow(SW_SHOW); - } - else - { - m_NearsetColorName = _T("Not Allocated"); - m_CurrentEntryRed = _T("9.999"); - m_NewEntryRed = 9.999; - m_CurrentEntryGreen = _T("9.999"); - m_NewEntryGreen = 9.999; - m_CurrentEntryBlue = _T("9.999"); - m_NewEntryBlue = 9.999; - GetDlgItem(IDC_ColorMap_BUTTON_UpdateCurrentEntry)->ShowWindow(SW_HIDE); - } - - UpdateData(false); -} -void CColorPropertyPage::OnColorMapBUTTONNewGenericColorMap() -{ - // TODO: Add your control notification handler code here - myColorMap = V2d_DefaultMap::ColorMap(); - SetModified(true); - UpdateDisplay(1); -} - -void CColorPropertyPage::OnColorMapBUTTONNewColorCubeColorMap() -{ - CColorNewColorCubeColorMapDialog aDlg(NULL); - if (aDlg.DoModal() == IDOK) - { - myColorMap = aDlg.ColorMap(); - SetModified(true); - UpdateDisplay(1); - } -} - -void CColorPropertyPage::OnColorMapBUTTONNewColorRampColorMap() -{ - CColorNewColorRampColorMapDialog aDlg(NULL); - if (aDlg.DoModal() == IDOK) - { - myColorMap = aDlg.ColorMap(); - SetModified(true); - UpdateDisplay(1); - } -} - -///////////////////////////////////////////////////////////////////////////// -// CColorPropertyPage message handlers - -void CColorPropertyPage::OnSelchangeColorMapTAB(NMHDR* pNMHDR, LRESULT* pResult) -{ - UpdateDisplay(m_TabCtrl.GetCurSel()); - *pResult = 0; -} - -void CColorPropertyPage::OnSelchangeColorMapCOMBONewEntryColorName() -{ - UpdateData(true); - int CurSel = m_NewEntryColorNameCtrl.GetCurSel(); - Quantity_NameOfColor SelectedNameOfColor = (Quantity_NameOfColor)CurSel; - Quantity_Color TheSelectedEquivalentColor(SelectedNameOfColor); - - Quantity_Parameter Red,Green,Blue; - TheSelectedEquivalentColor.Values(Red,Green,Blue,Quantity_TOC_RGB); - m_NewEntryRed = Red; - m_NewEntryGreen = Green; - m_NewEntryBlue = Blue; - UpdateData(false); -} - -void CColorPropertyPage::OnColorMapBUTTONNewEntryEditColor() -{ - int CurrentSelectedItem = m_TabCtrl.GetCurSel(); - - COLORREF m_clr ; - m_clr = RGB(m_NewEntryRed*255,m_NewEntryGreen*255,m_NewEntryBlue*255); - CColorDialog dlgColor(m_clr); - if (dlgColor.DoModal() == IDOK) - { - SetModified(TRUE); - m_clr = dlgColor.GetColor(); - m_NewEntryRed = GetRValue(m_clr)/255.; - m_NewEntryGreen = GetGValue(m_clr)/255.; - m_NewEntryBlue = GetBValue(m_clr)/255.; - } - Quantity_Color aColor(m_NewEntryRed,m_NewEntryGreen,m_NewEntryBlue,Quantity_TOC_RGB); - m_NewEntryColorNameCtrl.SetCurSel(aColor.Name()); - UpdateData(false); -} - -void CColorPropertyPage::OnColorMapBUTTONUpdateCurrentEntry() -{ - UpdateData(true); - Handle(Aspect_GenericColorMap) aGenericColorMap = Handle(Aspect_GenericColorMap)::DownCast(myColorMap); - if (aGenericColorMap.IsNull()) - Standard_Failure::Raise(" couldn't update a none Generic Color Map"); - - Aspect_ColorMapEntry aColorMapEntry = myColorMap->FindEntry( m_TabCtrl.GetCurSel()); - Quantity_Color aColor(m_NewEntryRed,m_NewEntryGreen,m_NewEntryBlue,Quantity_TOC_RGB); - aColorMapEntry.SetColor(aColor); - aGenericColorMap->AddEntry(aColorMapEntry); // in fact just update - SetModified(true); - UpdateData(true); - UpdateDisplay(m_TabCtrl.GetCurSel()); - -} - -void CColorPropertyPage::OnColorMapBUTTONAddNewEntry() -{ - UpdateData(true); - Quantity_Color aColor(m_NewEntryRed,m_NewEntryGreen,m_NewEntryBlue,Quantity_TOC_RGB); - Handle(Aspect_GenericColorMap) aGenericColorMap = Handle(Aspect_GenericColorMap)::DownCast(myColorMap); - if (aGenericColorMap.IsNull()) - Standard_Failure::Raise(" couldn't update a none Generic Color Map"); - - int NewEntry = aGenericColorMap->AddEntry(aColor); - SetModified(true); - UpdateDisplay(NewEntry); - UpdateData(false); -} - -BOOL CColorPropertyPage::OnApply() -{ - myViewer->SetColorMap(myColorMap); - myViewer->Update(); - return CPropertyPage::OnApply(); -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.h b/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.h deleted file mode 100755 index a761b6a13e..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/ColorPropertyPage.h +++ /dev/null @@ -1,83 +0,0 @@ -#if !defined(AFX_ColorPropertyPage_H__A815F7A3_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) -#define AFX_ColorPropertyPage_H__A815F7A3_D51B_11D1_8DDE_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// ColorPropertyPage.h : header file -// -#include "Aspect_ColorMap.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CColorPropertyPage dialog - -class CColorPropertyPage : public CPropertyPage -{ - DECLARE_DYNCREATE(CColorPropertyPage) - -private : - Handle(Aspect_ColorMap) myColorMap; -private : - Handle(V2d_Viewer) myViewer; -public: - void SetViewer(Handle(V2d_Viewer) aViewer) { - myViewer = aViewer; - myColorMap = aViewer->ColorMap(); - }; - - -// Construction -public: - CColorPropertyPage(); - ~CColorPropertyPage(); - -// Dialog Data - //{{AFX_DATA(CColorPropertyPage) - enum { IDD = IDD_DIALOG_Color }; - CComboBox m_NewEntryColorNameCtrl; - CTabCtrl m_TabCtrl; - CString m_ColorMapSize ; - CString m_ColorMapType ; - CString m_CurrentEntryRed; - CString m_CurrentEntryGreen; - CString m_CurrentEntryBlue; - CString m_NearsetColorName; - double m_NewEntryRed; - double m_NewEntryBlue; - double m_NewEntryGreen; - //}}AFX_DATA - - -// Overrides - // ClassWizard generate virtual function overrides - //{{AFX_VIRTUAL(CColorPropertyPage) - public: - virtual BOOL OnApply(); - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - // Generated message map functions - //{{AFX_MSG(CColorPropertyPage) - virtual BOOL OnInitDialog(); - afx_msg void OnSelchangeColorMapTAB(NMHDR* pNMHDR, LRESULT* pResult); - afx_msg void OnSelchangeColorMapCOMBONewEntryColorName(); - afx_msg void OnColorMapBUTTONUpdateCurrentEntry(); - afx_msg void OnColorMapBUTTONNewColorCubeColorMap(); - afx_msg void OnColorMapBUTTONNewGenericColorMap(); - afx_msg void OnColorMapBUTTONNewColorRampColorMap(); - afx_msg void OnColorMapBUTTONNewEntryEditColor(); - afx_msg void OnColorMapBUTTONAddNewEntry(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() - -private: - void UpdateDisplay(int CurrentSelectionIndex); -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_ColorPropertyPage_H__A815F7A3_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.cpp deleted file mode 100755 index 25e3ef44ef..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.cpp +++ /dev/null @@ -1,267 +0,0 @@ -// FontPropertyPage.cpp : implementation file -// - -#include "stdafx.h" - -#include "FontPropertyPage.h" -#include "Aspect_FontMapEntry.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CFontPropertyPage property page - -IMPLEMENT_DYNCREATE(CFontPropertyPage, CPropertyPage) - -CFontPropertyPage::CFontPropertyPage() : CPropertyPage(CFontPropertyPage::IDD) -{ - //{{AFX_DATA_INIT(CFontPropertyPage) - m_FontMapSize = _T("Computing..."); - m_CurrentEntryValue = _T("Computing..."); - m_CurrentEntryStyle = _T("Computing..."); - m_CurrentEntrySize = _T("Computing..."); - m_CurrentEntrySlant = _T("Computing..."); - m_NewEntryValue = _T(""); - m_NewEntrySize = 1.0; - m_NewEntrySlant = 0.0; - //}}AFX_DATA_INIT -} - -CFontPropertyPage::~CFontPropertyPage() -{ -} - -BOOL CFontPropertyPage::OnInitDialog() -{ - CPropertyPage::OnInitDialog(); - - m_NewEntry_Type.AddString("DEFAULT"); - m_NewEntry_Type.AddString("COURIER"); - m_NewEntry_Type.AddString("HELVETICA"); - m_NewEntry_Type.AddString("TIMES"); - m_NewEntry_Type.AddString("USERDEFINED"); - m_NewEntry_Type.SetCurSel(1); - - // TODO: Add extra initialization here - UpdateDisplay(1); - - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - - -void CFontPropertyPage::DoDataExchange(CDataExchange* pDX) -{ - CPropertyPage::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CFontPropertyPage) - DDX_Text (pDX, IDC_FontMap_STATIC_Size , m_FontMapSize ); - DDX_Control(pDX, IDC_FontMap_TAB , m_TabCtrl ); - DDX_Text (pDX, IDC_FontMap_STATIC_CurrentEntryValue , m_CurrentEntryValue ); - DDX_Text (pDX, IDC_FontMap_STATIC_CurrentEntryType , m_CurrentEntryStyle ); - DDX_Text (pDX, IDC_FontMap_STATIC_CurrentEntrySize , m_CurrentEntrySize ); - DDX_Text (pDX, IDC_FontMap_STATIC_CurrentEntrySlant , m_CurrentEntrySlant ); - - DDX_Control(pDX, IDC_FontMap_COMBO_NewEntryType , m_NewEntry_Type ); - DDX_Text(pDX, IDC_FontMap_EDIT_NewEntryValue, m_NewEntryValue); - DDX_Text(pDX, IDC_FontMap_EDIT_NewEntrySize, m_NewEntrySize); - DDX_Text(pDX, IDC_FontMap_EDIT_NewEntrySlant, m_NewEntrySlant); - //}}AFX_DATA_MAP -} - - -BEGIN_MESSAGE_MAP(CFontPropertyPage, CPropertyPage) - //{{AFX_MSG_MAP(CFontPropertyPage) - ON_NOTIFY(TCN_SELCHANGE, IDC_FontMap_TAB, OnSelchangeFontMapTAB) - ON_BN_CLICKED(IDC_FontMap_BUTTON_NewEntry_EditFont, OnFontMapBUTTONNewEntryEditFont) - ON_BN_CLICKED(IDC_FontMap_BUTTON_UpdateCurrent, OnFontMapBUTTONUpdateCurrent) - ON_CBN_SELCHANGE(IDC_FontMap_COMBO_NewEntryType, OnSelchangeFontMapCOMBONewEntryType) - ON_BN_CLICKED(IDC_FontMap_BUTTON_NewEntry, OnFontMapBUTTONNewEntry) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CFontPropertyPage message handlers -void CFontPropertyPage::UpdateDisplay(int CurrentSelectionIndex) -{ - // Update the size of the Width map - TCollection_AsciiString SizeMessage(myFontMap->Size()); - m_FontMapSize = _T(SizeMessage.ToCString()); - - // clear the Tab Ctrl - m_TabCtrl.DeleteAllItems(); - TC_ITEM TabCtrlItem; - TabCtrlItem.mask = TCIF_TEXT; - for(int i =1;i<=myFontMap->Size();i++) - { - Aspect_FontMapEntry aFontMapEntry = myFontMap->Entry(i); - TCollection_AsciiString EntryNumerMessage(aFontMapEntry.Index()); - TabCtrlItem.pszText = (LPSTR) EntryNumerMessage.ToCString(); - m_TabCtrl.InsertItem( aFontMapEntry.Index(), &TabCtrlItem ); - } - m_TabCtrl.SetCurSel(CurrentSelectionIndex-1); - // update the current Entry informations - Aspect_FontMapEntry aFontMapEntry = myFontMap->Entry(CurrentSelectionIndex); - - Aspect_FontStyle TheType = aFontMapEntry.Type(); - m_CurrentEntryValue = (TheType.Value() == NULL?" ":TheType.Value()); - - TCollection_AsciiString Message; - switch (TheType.Style()) - { - case Aspect_TOF_DEFAULT : Message = "Aspect_TOF_DEFAULT"; break; - case Aspect_TOF_COURIER : Message = "Aspect_TOF_COURIER"; break; - case Aspect_TOF_HELVETICA : Message = "Aspect_TOF_HELVETICA"; break; - case Aspect_TOF_TIMES : Message = "Aspect_TOF_TIMES"; break; - case Aspect_TOF_USERDEFINED : Message = "Aspect_TOF_USERDEFINED"; break; - default: Message = "Underknown"; - } - m_CurrentEntryStyle = _T(Message.ToCString()); - - Message = TheType.Size (); - m_CurrentEntrySize = _T(Message.ToCString()); - - Message = TheType.Slant (); - m_CurrentEntrySlant = _T(Message.ToCString()); - - // update The New Entry : - switch (TheType.Style()) - { - case Aspect_TOF_DEFAULT : m_NewEntry_Type.SetCurSel(0); break; - case Aspect_TOF_COURIER : m_NewEntry_Type.SetCurSel(1); break; - case Aspect_TOF_HELVETICA : m_NewEntry_Type.SetCurSel(2); break; - case Aspect_TOF_TIMES : m_NewEntry_Type.SetCurSel(3); break; - case Aspect_TOF_USERDEFINED : m_NewEntry_Type.SetCurSel(4); break; - default: ; - } - - m_NewEntryValue = (TheType.Value() == NULL?" ":TheType.Value()); - m_NewEntrySize = TheType.Size (); - m_NewEntrySlant = TheType.Slant (); - if (TheType.Style()==Aspect_TOF_USERDEFINED) - { - GetDlgItem(IDC_FontMap_EDIT_NewEntrySize)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_EDIT_NewEntrySlant)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry_EditFont)->ShowWindow(SW_SHOW); - } - else - { - GetDlgItem(IDC_FontMap_EDIT_NewEntrySize)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_EDIT_NewEntrySlant)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry_EditFont)->ShowWindow(SW_HIDE); - } - UpdateData(false); -} - -void CFontPropertyPage::OnSelchangeFontMapTAB(NMHDR* pNMHDR, LRESULT* pResult) -{ - // TODO: Add your control notification handler code here - UpdateDisplay( m_TabCtrl.GetCurSel()+1); - *pResult = 0; -} - -void CFontPropertyPage::OnSelchangeFontMapCOMBONewEntryType() -{ - UpdateData(true); - // update the New Entry Value message - if (m_NewEntry_Type.GetCurSel() == Aspect_TOF_USERDEFINED) - { - // allow the user to select a font from the common CFontDialog - GetDlgItem(IDC_FontMap_BUTTON_NewEntry_EditFont)->ShowWindow(SW_SHOW); - m_NewEntryValue = "Please Select a Font"; - // remove the posiblility to update while a font was selected - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_EDIT_NewEntrySize)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_EDIT_NewEntrySlant)->ShowWindow(SW_HIDE); - } - else - { - GetDlgItem(IDC_FontMap_EDIT_NewEntrySize)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_EDIT_NewEntrySlant)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry_EditFont)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry)->ShowWindow(SW_SHOW); - Aspect_FontStyle TheType((Aspect_TypeOfFont)m_NewEntry_Type.GetCurSel(),m_NewEntrySize); - m_NewEntryValue = (TheType.Value() == NULL?" ":TheType.Value()); - } - UpdateData(false); - -} - -#include "WNT_FontMapEntry.hxx" -void CFontPropertyPage::OnFontMapBUTTONNewEntryEditFont() -{ - Handle(WNT_FontMapEntry) anEntry = new WNT_FontMapEntry((char* const)(LPCTSTR )m_NewEntryValue); - Standard_Address anAddress = anEntry->LogFont(); - LOGFONT* lf = (LOGFONT*)(anAddress ); - CFontDialog dlg(lf); - if (dlg.DoModal() == IDOK) - { - TCHAR buff[ 255 ]; - wsprintf ( buff, "%d-%d-%d-%d-%d-%d-%d-%d-%d-%d-%d-%d-%d-%s", - lf->lfHeight, lf->lfWidth, lf->lfEscapement, lf->lfOrientation, lf->lfWeight, lf->lfItalic, - lf->lfUnderline, lf->lfStrikeOut, lf->lfCharSet, lf->lfOutPrecision, lf->lfClipPrecision, lf->lfQuality, - lf->lfPitchAndFamily, lf->lfFaceName); - - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry)->ShowWindow(SW_SHOW); - Aspect_FontStyle TheType(buff); - m_NewEntryValue = (TheType.Value() == NULL?" ":TheType.Value()); - } - UpdateData(false); -} - -void CFontPropertyPage::OnFontMapBUTTONUpdateCurrent() -{ - // The Entry to modify : - Aspect_FontMapEntry aFontMapEntry = myFontMap->Entry( m_TabCtrl.GetCurSel()+1); - - UpdateData(true); - Aspect_TypeOfFont aTypeOfFont = (Aspect_TypeOfFont)m_NewEntry_Type.GetCurSel(); - - if (aTypeOfFont == Aspect_TOF_USERDEFINED) - { - Aspect_FontStyle TheType((Standard_CString)(LPCTSTR )m_NewEntryValue); - aFontMapEntry.SetType(TheType); - } - else - { - Aspect_FontStyle TheType((Aspect_TypeOfFont)m_NewEntry_Type.GetCurSel(),m_NewEntrySize,m_NewEntrySlant); - aFontMapEntry.SetType(TheType); - } - myFontMap->AddEntry(aFontMapEntry); // in fact just update - SetModified(true); - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); -} - - -void CFontPropertyPage::OnFontMapBUTTONNewEntry() -{ - // The Entry to modify : - Aspect_FontMapEntry aFontMapEntry; - - UpdateData(true); - Aspect_TypeOfFont aTypeOfFont = (Aspect_TypeOfFont)m_NewEntry_Type.GetCurSel(); - - if (aTypeOfFont == Aspect_TOF_USERDEFINED) - { - Aspect_FontStyle TheType((Standard_CString)(LPCTSTR )m_NewEntryValue); - aFontMapEntry.SetType(TheType); - } - else - { - Aspect_FontStyle TheType((Aspect_TypeOfFont)m_NewEntry_Type.GetCurSel(),m_NewEntrySize,m_NewEntrySlant); - aFontMapEntry.SetType(TheType); - } - myFontMap->AddEntry(aFontMapEntry); // in fact just update - SetModified(true); - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); -} - -BOOL CFontPropertyPage::OnApply() -{ - myViewer->SetFontMap(myFontMap); - myViewer->Update(); - - return CPropertyPage::OnApply(); -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.h b/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.h deleted file mode 100755 index 5cbbe671ed..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/FontPropertyPage.h +++ /dev/null @@ -1,76 +0,0 @@ -#if !defined(AFX_FontPropertyPage_H__A815F7A5_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) -#define AFX_FontPropertyPage_H__A815F7A5_D51B_11D1_8DDE_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// FontPropertyPage.h : header file -// -#include "Aspect_FontMap.hxx" -///////////////////////////////////////////////////////////////////////////// -// CFontPropertyPage dialog - -class CFontPropertyPage : public CPropertyPage -{ - DECLARE_DYNCREATE(CFontPropertyPage) - -private : - Handle(Aspect_FontMap) myFontMap; -private : - Handle(V2d_Viewer) myViewer; -public: - void SetViewer(Handle(V2d_Viewer) aViewer) { - myViewer = aViewer; - myFontMap = aViewer->FontMap(); - }; - -// Construction -public: - CFontPropertyPage(); - ~CFontPropertyPage(); - -// Dialog Data - //{{AFX_DATA(CFontPropertyPage) - enum { IDD = IDD_DIALOG_Font }; - CString m_FontMapSize; - CTabCtrl m_TabCtrl; - CString m_CurrentEntryValue; - CString m_CurrentEntryStyle; - CString m_CurrentEntrySize; - CString m_CurrentEntrySlant; - CComboBox m_NewEntry_Type; - double m_NewEntrySize; - double m_NewEntrySlant; - CString m_NewEntryValue; - //}}AFX_DATA - -// Overrides - // ClassWizard generate virtual function overrides - //{{AFX_VIRTUAL(CFontPropertyPage) - public: - virtual BOOL OnApply(); - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - // Generated message map functions - //{{AFX_MSG(CFontPropertyPage) - virtual BOOL OnInitDialog(); - afx_msg void OnSelchangeFontMapTAB(NMHDR* pNMHDR, LRESULT* pResult); - afx_msg void OnFontMapBUTTONNewEntryEditFont(); - afx_msg void OnFontMapBUTTONUpdateCurrent(); - afx_msg void OnSelchangeFontMapCOMBONewEntryType(); - afx_msg void OnFontMapBUTTONNewEntry(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() -private: - void UpdateDisplay(int CurrentSelectionIndex); - -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_FontPropertyPage_H__A815F7A5_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.cpp deleted file mode 100755 index 1686b0f274..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.cpp +++ /dev/null @@ -1,172 +0,0 @@ -// MarkPropertyPage.cpp : implementation file -// - -#include "stdafx.h" - -#include "MarkPropertyPage.h" - -#include "Aspect_MarkMap.hxx" -#include "Aspect_MarkMapEntry.hxx" -#include "TColQuantity_Array1OfLength.hxx" -#include "TColStd_SequenceOfReal.hxx" -#include "TShort_Array1OfShortReal.hxx" -#include "TColStd_Array1OfBoolean.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CMarkPropertyPage property page - -IMPLEMENT_DYNCREATE(CMarkPropertyPage, CPropertyPage) - -CMarkPropertyPage::CMarkPropertyPage() : CPropertyPage(CMarkPropertyPage::IDD) -{ - //{{AFX_DATA_INIT(CMarkPropertyPage) - m_MarkMapSize = _T("Computing..."); - m_CurrentEntryStyle = _T("Computing..."); - m_CurrentEntryXValue = _T("Computing..."); - m_CurrentEntryYValue = _T("Computing..."); - m_CurrentEntrySValue = _T("Computing..."); - //}}AFX_DATA_INIT - - -} -BOOL CMarkPropertyPage::OnInitDialog() -{ - CPropertyPage::OnInitDialog(); - - UpdateDisplay(1); - - UpdateData(false); - - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - -CMarkPropertyPage::~CMarkPropertyPage() -{ -} - -void CMarkPropertyPage::DoDataExchange(CDataExchange* pDX) -{ - CPropertyPage::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CMarkPropertyPage) - DDX_Control(pDX, IDC_MarkMap_TAB, m_TabCtrl); - DDX_Text(pDX, IDC_MarkMap_STATIC_Size, m_MarkMapSize); - DDX_Text(pDX, IDC_MarkMap_STATIC_CurrentEntryStyle, m_CurrentEntryStyle); - DDX_Text(pDX, IDC_MarkMap_STATIC_CurrentEntryXValue, m_CurrentEntryXValue); - DDX_Text(pDX, IDC_MarkMap_STATIC_CurrentEntryYValue, m_CurrentEntryYValue); - DDX_Text(pDX, IDC_MarkMap_STATIC_CurrentEntrySValue, m_CurrentEntrySValue); - - //}}AFX_DATA_MAP -} - - -BEGIN_MESSAGE_MAP(CMarkPropertyPage, CPropertyPage) - //{{AFX_MSG_MAP(CMarkPropertyPage) - ON_NOTIFY(TCN_SELCHANGE, IDC_MarkMap_TAB, OnSelchangeMarkMapTAB) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CMarkPropertyPage message handlers -void CMarkPropertyPage::UpdateDisplay(int CurrentSelectionIndex) -{ - TCollection_AsciiString SizeMessage(myMarkMap->Size()); - m_MarkMapSize = _T(SizeMessage.ToCString()); - - m_TabCtrl.DeleteAllItems(); - - TC_ITEM TabCtrlItem; - TabCtrlItem.mask = TCIF_TEXT; - - for(int i =1;i<=myMarkMap->Size();i++) - { - Aspect_MarkMapEntry aMarkMapEntry = myMarkMap->Entry(i); - TCollection_AsciiString EntryNumerMessage(aMarkMapEntry.Index()); - TabCtrlItem.pszText = (LPSTR) EntryNumerMessage.ToCString(); - m_TabCtrl.InsertItem( aMarkMapEntry.Index(), &TabCtrlItem ); - } - m_TabCtrl.SetCurSel(CurrentSelectionIndex-1); - - // update The Current Selected entry - Aspect_MarkMapEntry aMarkMapEntry = myMarkMap->Entry(CurrentSelectionIndex); - if (aMarkMapEntry. IsAllocated () ) - { - Aspect_MarkerStyle aMarkerStyle = aMarkMapEntry.Style() ; - switch (aMarkerStyle.Type()) { - case Aspect_TOM_POINT : m_CurrentEntryStyle = _T("Aspect_TOM_POINT"); break; - case Aspect_TOM_PLUS : m_CurrentEntryStyle = _T("Aspect_TOM_PLUS"); break; - case Aspect_TOM_STAR : m_CurrentEntryStyle = _T("Aspect_TOM_STAR"); break; - case Aspect_TOM_O : m_CurrentEntryStyle = _T("Aspect_TOM_O"); break; - case Aspect_TOM_X : m_CurrentEntryStyle = _T("Aspect_TOM_X"); break; - case Aspect_TOM_O_POINT : m_CurrentEntryStyle = _T("Aspect_TOM_O_POINT"); break; - case Aspect_TOM_O_PLUS : m_CurrentEntryStyle = _T("Aspect_TOM_O_PLUS"); break; - case Aspect_TOM_O_STAR : m_CurrentEntryStyle = _T("Aspect_TOM_O_STAR"); break; - case Aspect_TOM_O_X : m_CurrentEntryStyle = _T("Aspect_TOM_O_X"); break; - case Aspect_TOM_BALL : m_CurrentEntryStyle = _T("Aspect_TOM_BALL"); break; - case Aspect_TOM_RING1 : m_CurrentEntryStyle = _T("Aspect_TOM_RING1"); break; - case Aspect_TOM_RING2 : m_CurrentEntryStyle = _T("Aspect_TOM_RING2"); break; - case Aspect_TOM_RING3 : m_CurrentEntryStyle = _T("Aspect_TOM_RING3"); break; - case Aspect_TOM_USERDEFINED : m_CurrentEntryStyle = _T("Aspect_TOM_USERDEFINED"); break; - default : m_CurrentEntryStyle = _T("Underknown"); - } - - cout<<" aMarkerStyle Length: "<ShowWindow(SW_HIDE); - } -} - -void CMarkPropertyPage::OnSelchangeMarkMapTAB(NMHDR* pNMHDR, LRESULT* pResult) -{ - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); - *pResult = 0; -} - -BOOL CMarkPropertyPage::OnApply() -{ -// myViewer->SetMarkMap(myMarkMap); -// myViewer->Update(); - return CPropertyPage::OnApply(); -} - -TCollection_AsciiString CMarkPropertyPage::BuildValuesAscii(const TShort_Array1OfShortReal& anArray) -{ - TCollection_AsciiString Message; - for(int i=1;i<=anArray.Length();i++) - { - Message += anArray.Value(i); - Message += "\t"; - } - return Message; -} - -TCollection_AsciiString CMarkPropertyPage::BuildValuesAscii(const TColStd_Array1OfBoolean& anArray) -{ - TCollection_AsciiString Message; - for(int i=1;i<=anArray.Length();i++) - { - if (anArray(i)) Message += "True"; else Message += "False"; - Message += "\t"; - } - return Message; -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.h b/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.h deleted file mode 100755 index a6ee9bd49f..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/MarkPropertyPage.h +++ /dev/null @@ -1,78 +0,0 @@ -#if !defined(AFX_MarkPropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_) -#define AFX_MarkPropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// MarkPropertyPage.h : header file -// - -#include "V2d_Viewer.hxx" -#include "TColQuantity_Array1OfLength.hxx" -#include "TColQuantity_HArray1OfLength.hxx" -#include "TColStd_Array1OfBoolean.hxx" -///////////////////////////////////////////////////////////////////////////// -// CMarkPropertyPage dialog - -class CMarkPropertyPage : public CPropertyPage -{ -private : - Handle(Aspect_MarkMap) myMarkMap; -private : - Handle(V2d_Viewer) myViewer; -public: - void SetViewer(Handle(V2d_Viewer) aViewer) { - myViewer = aViewer; - myMarkMap = aViewer->MarkMap(); - }; - - DECLARE_DYNCREATE(CMarkPropertyPage) - -// Construction -public: - CMarkPropertyPage(); - ~CMarkPropertyPage(); - -// Dialog Data - //{{AFX_DATA(CMarkPropertyPage) - enum { IDD = IDD_DIALOG_Mark }; - CTabCtrl m_TabCtrl; - CComboBox m_NewEntryControl; - - CString m_MarkMapSize; - CString m_CurrentEntryStyle; - CString m_CurrentEntryXValue; - CString m_CurrentEntryYValue; - CString m_CurrentEntrySValue; - //}}AFX_DATA - - -// Overrides - // ClassWizard generate virtual function overrides - //{{AFX_VIRTUAL(CMarkPropertyPage) - public: - virtual BOOL OnApply(); - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - // Generated message map functions - //{{AFX_MSG(CMarkPropertyPage) - virtual BOOL OnInitDialog(); - afx_msg void OnSelchangeMarkMapTAB(NMHDR* pNMHDR, LRESULT* pResult); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() -private: - void UpdateDisplay(int CurrentSelectionIndex); - - TCollection_AsciiString BuildValuesAscii(const TShort_Array1OfShortReal& anArray); - TCollection_AsciiString BuildValuesAscii(const TColStd_Array1OfBoolean& anArray); - -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_MarkPropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesDialog.rc2 b/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesDialog.rc2 deleted file mode 100755 index 4be558e46e..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesDialog.rc2 +++ /dev/null @@ -1,236 +0,0 @@ -// -// resources Microsoft Visual C++ -// - -///////////////////////////////////////////////////////////////////////////// -// Add manually edited resources here... - -///////////////////////////////////////////////////////////////////////////// - -IDD_DIALOG_Color DIALOG DISCARDABLE 0, 0, 281, 186 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "Color Map " -FONT 8, "MS Sans Serif" -BEGIN - LTEXT "Type Of The Color Map :",IDC_STATIC,20,10,87,10 - LTEXT "To be updated ...",IDC_ColorMap_STATIC_Type,110,10,69, - 10 - LTEXT "Size Of The Color Map :",IDC_STATIC,20,20,79,10 - CONTROL "Tab1",IDC_ColorMap_TAB,"SysTabControl32",TCS_BUTTONS,19, - 53,242,15 - LTEXT "To be updated ...",IDC_ColorMap_STATIC_Size,110,20,69, - 10 - GROUPBOX "Entries :",IDC_STATIC,10,40,264,50 - LTEXT "Color Name :",IDC_STATIC,20,75,50,10 - LTEXT "To be updated ...",IDC_ColorMap_STATIC_EntryColorName, - 204,75,69,10 - PUSHBUTTON "Add",IDC_ColorMap_BUTTON_AddNewEntry,110,145,55,15 - GROUPBOX "New Entry",IDC_STATIC,10,100,267,79 - PUSHBUTTON "Update Current",IDC_ColorMap_BUTTON_UpdateCurrentEntry, - 20,145,55,15 - LTEXT "Color Name :", - IDC_ColorMap_STATIC_NewEntryColorNameStatic,20,120,55,10 - PUSHBUTTON "Edit...",IDC_ColorMap_BUTTON_NewEntry_EditColor,204,145, - 55,15 - LTEXT "999",IDC_ColorMap_STATIC_EntryColorRed,75,75,35,10 - LTEXT "999",IDC_ColorMap_STATIC_EntryColorGreen,120,75,35,10 - LTEXT "999",IDC_ColorMap_STATIC_EntryColorBlue,165,75,35,10 - EDITTEXT IDC_ColorMap_EDIT_NewEntryColorRed,75,120,35,12, - ES_AUTOHSCROLL - EDITTEXT IDC_ColorMap_EDIT_NewEntryColorGreen,120,120,30,12, - ES_AUTOHSCROLL - EDITTEXT IDC_ColorMap_EDIT_NewEntryColorBlue,165,120,35,12, - ES_AUTOHSCROLL - COMBOBOX IDC_ColorMap_COMBO_NewEntryColorName,204,120,70,193, - CBS_DROPDOWN | WS_VSCROLL | WS_TABSTOP - PUSHBUTTON "New Generic Color Map", - IDC_ColorMap_BUTTON_NewGenericColorMap,179,4,95,13 - LTEXT "Not available for this type of Color map", - IDC_ColorMap_STATIC_NewEntryNotavailable,70,130,160,10 - PUSHBUTTON "New Color Cube Color Map ", - IDC_ColorMap_BUTTON_NewColorCubeColorMap,179,18,95,13 - PUSHBUTTON "New Color Ramp Color Map", - IDC_ColorMap_BUTTON_NewColorRampColorMap,179,31,95,13 -END - -IDD_DIALOG_Font DIALOGEX 0, 0, 287, 210 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "Font Map" -FONT 8, "MS Sans Serif" -BEGIN - LTEXT "Size Of The Font Map :",IDC_STATIC,20,10,80,10 - LTEXT "To be updated ...",IDC_FontMap_STATIC_Size,110,10,80,10 - GROUPBOX "Entries :",IDC_STATIC,10,28,270,97,0,WS_EX_TRANSPARENT - CONTROL "Tab1",IDC_FontMap_TAB,"SysTabControl32",TCS_BUTTONS,20, - 40,242,15 - GROUPBOX "New Entry",IDC_STATIC,10,130,270,73 - PUSHBUTTON "Update Current",IDC_FontMap_BUTTON_UpdateCurrent,158, - 181,55,15 - PUSHBUTTON "Add",IDC_FontMap_BUTTON_NewEntry,221,179,55,16 - LTEXT "To be updated...",IDC_FontMap_STATIC_CurrentEntryValue, - 63,75,217,10 - LTEXT "Type :",IDC_STATIC,21,155,23,10 - LTEXT "Type :",IDC_STATIC,21,60,40,10 - LTEXT "To be updated ...",IDC_FontMap_STATIC_CurrentEntryType, - 63,60,80,10 - LTEXT "Size :",IDC_STATIC,21,174,42,10 - LTEXT "Slant :",IDC_STATIC,21,189,28,10 - EDITTEXT IDC_FontMap_EDIT_NewEntrySize,63,172,62,12, - ES_AUTOHSCROLL | ES_WANTRETURN - EDITTEXT IDC_FontMap_EDIT_NewEntrySlant,63,187,62,12, - ES_AUTOHSCROLL | ES_WANTRETURN - LTEXT "Size :",IDC_STATIC,21,90,30,10 - LTEXT "Slant :",IDC_STATIC,21,106,36,10 - LTEXT "Value :",IDC_STATIC,21,75,40,10 - LTEXT "Type :",IDC_STATIC,21,140,42,10 - COMBOBOX IDC_FontMap_COMBO_NewEntryType,63,138,113,77, - CBS_DROPDOWN | WS_VSCROLL | WS_TABSTOP - EDITTEXT IDC_FontMap_EDIT_NewEntryValue,63,153,209,12, - ES_AUTOHSCROLL | ES_READONLY - LTEXT "To be updated...",IDC_FontMap_STATIC_CurrentEntrySize, - 63,90,70,10 - LTEXT "To be updated...",IDC_FontMap_STATIC_CurrentEntrySlant, - 63,106,80,10 - PUSHBUTTON "Edit...",IDC_FontMap_BUTTON_NewEntry_EditFont,191,138, - 55,12 -END - -IDD_DIALOG_Width DIALOG DISCARDABLE 0, 0, 281, 167 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "Width Map " -FONT 8, "MS Sans Serif" -BEGIN - LTEXT "Size Of The Width Map :",IDC_STATIC,15,10,80,10 - CONTROL "Tab1",IDC_WidthMap_TAB,"SysTabControl32",TCS_BUTTONS,21, - 40,242,15 - LTEXT "To be updated ...",IDC_WidthMap_STATIC_Size,107,10,80, - 10 - GROUPBOX "Entries :",IDC_STATIC,10,30,264,57 - LTEXT "Type :",IDC_STATIC,15,60,80,10 - LTEXT "Width :",IDC_STATIC,15,75,80,10 - LTEXT "Type :",IDC_STATIC,15,115,49,10 - LTEXT "Width :",IDC_STATIC,15,130,49,10 - COMBOBOX IDC_WidthMap_COMBO_NewEntryType,70,113,113,77, - CBS_DROPDOWN | WS_VSCROLL | WS_TABSTOP - EDITTEXT IDC_WidthMap_EDIT_NewEntryWidth,70,128,62,12, - ES_AUTOHSCROLL | ES_READONLY | ES_WANTRETURN - LTEXT "To be updated ...",IDC_WidthMap_STATIC_EntryType,107,60, - 80,10 - LTEXT "To be updated ...",IDC_WidthMap_STATIC_EntryWidth,107, - 75,80,10 - PUSHBUTTON "Add",IDC_WidthMap_BUTTON_AddNewEntry,200,130,55,15 - GROUPBOX "New Entry",IDC_STATIC,7,101,267,51 - PUSHBUTTON "Update Current",IDC_WidthMap_BUTTON_UpdateCurrentEntry, - 200,110,55,15 -END - -IDD_DIALOG_NewColorCube DIALOG DISCARDABLE 0, 0, 207, 156 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "New Color Cube" -FONT 8, "MS Sans Serif" -BEGIN - DEFPUSHBUTTON "OK",IDOK,150,10,50,13 - PUSHBUTTON "Cancel",IDCANCEL,150,30,50,14 - LTEXT "base_pixel",IDC_STATIC,20,10,50,10 - LTEXT "greenmax",IDC_STATIC,20,70,50,10 - LTEXT "greenmult",IDC_STATIC,20,90,50,10 - LTEXT "bluemax",IDC_STATIC,20,110,50,10 - LTEXT "bluemult",IDC_STATIC,20,130,50,10 - EDITTEXT IDC_NewColorCube_EDIT_bluemult,80,130,50,12, - ES_AUTOHSCROLL | ES_NUMBER - EDITTEXT IDC_NewColorCube_EDIT_bluemax,80,110,50,12, - ES_AUTOHSCROLL | ES_NUMBER - EDITTEXT IDC_NewColorCube_EDIT_grennmult,80,90,50,12, - ES_AUTOHSCROLL | ES_NUMBER - EDITTEXT IDC_NewColorCube_EDIT_greenmax,80,70,50,12, - ES_AUTOHSCROLL | ES_NUMBER - EDITTEXT IDC_NewColorCube_EDIT_base_pixel,80,10,50,12, - ES_AUTOHSCROLL | ES_NUMBER - LTEXT "redmax",IDC_STATIC,20,30,50,10 - EDITTEXT IDC_NewColorCube_EDIT_redmax,80,30,50,12,ES_AUTOHSCROLL | - ES_NUMBER - LTEXT "redmult",IDC_STATIC,20,50,50,10 - EDITTEXT IDC_NewColorCube_EDIT_redmult,80,50,50,12,ES_AUTOHSCROLL | - ES_NUMBER -END - -IDD_DIALOG_NewColorRamp DIALOG DISCARDABLE 0, 0, 252, 121 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "New Color ramp" -FONT 8, "MS Sans Serif" -BEGIN - DEFPUSHBUTTON "OK",IDOK,150,10,50,13 - PUSHBUTTON "Cancel",IDCANCEL,150,30,50,14 - LTEXT "base_pixel",-1,20,10,49,10 - EDITTEXT IDC_NewColorRamp_EDIT_base_pixel,80,10,40,12, - ES_AUTOHSCROLL | ES_NUMBER - LTEXT "dimension",-1,20,30,49,10 - EDITTEXT IDC_NewColorramp_EDIT_dimension,80,30,40,12, - ES_AUTOHSCROLL | ES_NUMBER - LTEXT "Color Name :", - IDC_ColorMap_STATIC_NewEntryColorNameStatic,20,50,49,10 - PUSHBUTTON "Edit...",IDC_NewColorMapRamp_BUTTON_EditColor,145,70,55,10 - EDITTEXT IDC_NewColorMapRamp_EDIT_ColorRed,28,70,35,12, - ES_AUTOHSCROLL - EDITTEXT IDC_NewColorMapRamp_EDIT_ColorGreen,65,70,35,12, - ES_AUTOHSCROLL - EDITTEXT IDC_NewColorMapRamp_EDIT_ColorBlue,103,70,35,12, - ES_AUTOHSCROLL - COMBOBOX IDC_NewColorMap_COMBO_NewEntryColorName,80,50,70,193, - CBS_DROPDOWN | WS_VSCROLL | WS_TABSTOP -END - -IDD_DIALOG_Type DIALOGEX 0, 0, 287, 170 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "Type Map" -FONT 8, "MS Sans Serif" -BEGIN - LTEXT "Size Of The Typet Map :",-1,20,10,80,10 - LTEXT "To be updated ...",IDC_TypeMap_STATIC_Size,110,10,80,10 - GROUPBOX "Entries :",-1,10,28,270,62,0,WS_EX_TRANSPARENT - CONTROL "Tab1",IDC_TypeMap_TAB,"SysTabControl32",TCS_BUTTONS,20, - 40,242,15 - GROUPBOX "New Entry",-1,10,100,270,60 - PUSHBUTTON "Update Current",IDC_FontMap_BUTTON_UpdateCurrent,160, - 140,55,15 - PUSHBUTTON "Add",IDC_FontMap_BUTTON_NewEntry,220,140,55,15 - LTEXT "To be updated...",IDC_TypeMap_STATIC_CurrentEntryValue, - 63,75,217,10 - LTEXT "Value :",-1,21,126,42,10 - LTEXT "Style :",-1,21,60,40,10 - LTEXT "To be updated ...",IDC_TypeMap_STATIC_CurrentEntryStyle, - 63,60,80,10 - LTEXT "Value :",-1,21,75,40,10 - LTEXT "Style :",-1,21,111,42,10 - COMBOBOX IDC_TypeMap_COMBO_NewEntryStyle,63,108,113,77, - CBS_DROPDOWN | WS_VSCROLL | WS_TABSTOP - EDITTEXT IDC_TypeMap_EDIT_NewEntryValue,63,124,194,12, - ES_AUTOHSCROLL | ES_READONLY -END - -IDD_DIALOG_Mark DIALOGEX 0, 0, 287, 201 -STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU -CAPTION "Mark Map" -FONT 8, "MS Sans Serif" -BEGIN - LTEXT "Size Of The Mark Map :",AFX_ID_PREVIEW_CLOSE,20,10,80, - 10 - LTEXT "To be updated ...",IDC_MarkMap_STATIC_Size,110,10,80,10 - GROUPBOX "Entries :",-1,10,28,270,92,0,WS_EX_TRANSPARENT - CONTROL "Tab1",IDC_MarkMap_TAB,"SysTabControl32",TCS_BUTTONS,20, - 40,242,15 - LTEXT "To be updated...",IDC_MarkMap_STATIC_CurrentEntryXValue, - 63,75,217,9 - LTEXT "Style :",-1,21,60,40,10 - LTEXT "To be updated ...",IDC_MarkMap_STATIC_CurrentEntryStyle, - 63,60,80,10 - LTEXT "XValue :",-1,21,75,40,9 - LTEXT "To be updated...",IDC_MarkMap_STATIC_CurrentEntryYValue, - 63,90,217,10 - LTEXT "YValue :",-1,21,90,40,10 - LTEXT "To be updated...",IDC_MarkMap_STATIC_CurrentEntrySValue, - 63,105,217,10 - LTEXT "SValue :",-1,21,105,40,10 - LTEXT "To be updated...",IDC_MarkMap_STATIC_CurrentEntryValue, - 62,90,217,10 -END diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.cpp deleted file mode 100755 index b40086cecd..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.cpp +++ /dev/null @@ -1,55 +0,0 @@ -// MapProperties.cpp : implementation file -// - -#include "stdafx.h" - -#include "PropertiesSheet.h" - -///////////////////////////////////////////////////////////////////////////// -// CPropertiesSheet - -IMPLEMENT_DYNAMIC(CPropertiesSheet, CPropertySheet) - -CPropertiesSheet::CPropertiesSheet(CWnd* pParentWnd, UINT iSelectPage) - :CPropertySheet("View Map Properties", pParentWnd, iSelectPage) -{ -} - -void CPropertiesSheet::SetViewer (Handle(V2d_Viewer) aViewer) -{ - AddPage(& m_pageWidthProperty); - m_pageWidthProperty.SetViewer(aViewer); - - AddPage(& m_pageColorProperty); - m_pageColorProperty.SetViewer(aViewer); - - AddPage(& m_pageFontProperty); - m_pageFontProperty.SetViewer(aViewer); - - AddPage(& m_pageTypeProperty); - m_pageTypeProperty.SetViewer(aViewer); - - AddPage(& m_pageMarkProperty); - m_pageMarkProperty.SetViewer(aViewer); - -} - -CPropertiesSheet::~CPropertiesSheet() -{ -} - - -BEGIN_MESSAGE_MAP(CPropertiesSheet, CPropertySheet) - //{{AFX_MSG_MAP(CPropertiesSheet) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CPropertiesSheet message handlers - -BOOL CPropertiesSheet::OnInitDialog() -{ - BOOL bResult = CPropertySheet::OnInitDialog(); - return bResult; -} - diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.h b/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.h deleted file mode 100755 index fb5c0da48a..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/PropertiesSheet.h +++ /dev/null @@ -1,68 +0,0 @@ -#if !defined(AFX_PropertiesSheet_H__A815F7A6_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) -#define AFX_PropertiesSheet_H__A815F7A6_D51B_11D1_8DDE_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// PropertiesSheet.h : header file -// - -///////////////////////////////////////////////////////////////////////////// -// CPropertiesSheet -#include "ColorPropertyPage.h" -#include "FontPropertyPage.h" -#include "WidthPropertyPage.h" -#include "TypePropertyPage.h" -#include "MarkPropertyPage.h" - - -class CPropertiesSheet : public CPropertySheet -{ - DECLARE_DYNAMIC(CPropertiesSheet) - - - -private : - CColorPropertyPage m_pageColorProperty; - CFontPropertyPage m_pageFontProperty; - CWidthPropertyPage m_pageWidthProperty; - CTypePropertyPage m_pageTypeProperty; - CMarkPropertyPage m_pageMarkProperty; - -// Construction -public: - CPropertiesSheet(CWnd* pParentWnd = NULL, UINT iSelectPage = 0); - - void SetViewer (Handle(V2d_Viewer) aViewer); - -// Attributes -public: - -// Operations -public: - -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CPropertiesSheet) - public: - virtual BOOL OnInitDialog(); - //}}AFX_VIRTUAL - -// Implementation -public: - virtual ~CPropertiesSheet(); - - // Generated message map functions -protected: - //{{AFX_MSG(CPropertiesSheet) - //}}AFX_MSG - DECLARE_MESSAGE_MAP() - -}; - -///////////////////////////////////////////////////////////////////////////// - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_PropertiesSheet_H__A815F7A6_D51B_11D1_8DDE_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.cpp deleted file mode 100755 index 780a458317..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.cpp +++ /dev/null @@ -1,287 +0,0 @@ -// TypePropertyPage.cpp : implementation file -// - -#include "stdafx.h" - -#include "TypePropertyPage.h" - -#include "Aspect_TypeMap.hxx" -#include "Aspect_TypeMapEntry.hxx" -#include "TColQuantity_Array1OfLength.hxx" -#include "TColStd_SequenceOfReal.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CTypePropertyPage property page - -IMPLEMENT_DYNCREATE(CTypePropertyPage, CPropertyPage) - -CTypePropertyPage::CTypePropertyPage() : CPropertyPage(CTypePropertyPage::IDD) -{ - //{{AFX_DATA_INIT(CTypePropertyPage) - m_TypeMapSize = _T("Computing..."); - m_CurrentEntryStyle = _T("Computing..."); - m_CurrentEntryValue = _T("Computing..."); - m_NewEntryValue = _T(""); - //}}AFX_DATA_INIT - - -} -BOOL CTypePropertyPage::OnInitDialog() -{ - CPropertyPage::OnInitDialog(); - - // TODO: Add extra initialization here - - m_NewEntryControl.AddString("SOLID"); - m_NewEntryControl.AddString("DASH"); - m_NewEntryControl.AddString("DOT"); - m_NewEntryControl.AddString("DOTDASH"); - m_NewEntryControl.AddString("USERDEFINED"); - m_NewEntryControl.SetCurSel(1); - - UpdateDisplay(1); - - UpdateData(false); - - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - -CTypePropertyPage::~CTypePropertyPage() -{ -} - -void CTypePropertyPage::DoDataExchange(CDataExchange* pDX) -{ - CPropertyPage::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CTypePropertyPage) - DDX_Control(pDX, IDC_TypeMap_TAB, m_TabCtrl); - DDX_Control(pDX, IDC_TypeMap_COMBO_NewEntryStyle, m_NewEntryControl); - DDX_Control(pDX, IDC_TypeMap_EDIT_NewEntryValue, m_NewEntryValueControl); - DDX_Text(pDX, IDC_TypeMap_STATIC_Size, m_TypeMapSize); - DDX_Text(pDX, IDC_TypeMap_STATIC_CurrentEntryStyle, m_CurrentEntryStyle); - DDX_Text(pDX, IDC_TypeMap_STATIC_CurrentEntryValue, m_CurrentEntryValue); - DDX_Text(pDX, IDC_TypeMap_EDIT_NewEntryValue, m_NewEntryValue); - - //}}AFX_DATA_MAP -} - - -BEGIN_MESSAGE_MAP(CTypePropertyPage, CPropertyPage) - //{{AFX_MSG_MAP(CTypePropertyPage) - ON_BN_CLICKED(IDC_FontMap_BUTTON_NewEntry, OnFontMapBUTTONNewEntry) - ON_BN_CLICKED(IDC_FontMap_BUTTON_UpdateCurrent, OnFontMapBUTTONUpdateCurrent) - ON_EN_CHANGE(IDC_TypeMap_EDIT_NewEntryValue, OnChangeTypeMapEDITNewEntryValue) - ON_NOTIFY(TCN_SELCHANGE, IDC_TypeMap_TAB, OnSelchangeTypeMapTAB) - ON_CBN_SELCHANGE(IDC_TypeMap_COMBO_NewEntryStyle, OnSelchangeTypeMapCOMBONewEntryStyle) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CTypePropertyPage message handlers -void CTypePropertyPage::UpdateDisplay(int CurrentSelectionIndex) -{ - TCollection_AsciiString SizeMessage(myTypeMap->Size()); - m_TypeMapSize = _T(SizeMessage.ToCString()); - - m_TabCtrl.DeleteAllItems(); - - TC_ITEM TabCtrlItem; - TabCtrlItem.mask = TCIF_TEXT; - - for(int i =1;i<=myTypeMap->Size();i++) - { - Aspect_TypeMapEntry aTypeMapEntry = myTypeMap->Entry(i); - TCollection_AsciiString EntryNumerMessage(aTypeMapEntry.Index()); - TabCtrlItem.pszText = (LPSTR) EntryNumerMessage.ToCString(); - m_TabCtrl.InsertItem( aTypeMapEntry.Index(), &TabCtrlItem ); - } - m_TabCtrl.SetCurSel(CurrentSelectionIndex-1); - - // update The Current Selected entry - Aspect_TypeMapEntry aTypeMapEntry = myTypeMap->Entry(CurrentSelectionIndex); - if (aTypeMapEntry. IsAllocated () ) - { - Aspect_LineStyle TypeMapEntryType = aTypeMapEntry.Type() ; - - switch (TypeMapEntryType.Style()) { - case Aspect_TOL_SOLID : m_CurrentEntryStyle = _T("SOLID"); break; - case Aspect_TOL_DASH : m_CurrentEntryStyle = _T("DASH"); break; - case Aspect_TOL_DOT : m_CurrentEntryStyle = _T("DOT"); break; - case Aspect_TOL_DOTDASH : m_CurrentEntryStyle = _T("DOTDASH"); break; - case Aspect_TOL_USERDEFINED : m_CurrentEntryStyle = _T("USERDEFINED"); break; - default : m_CurrentEntryStyle = _T("Underknown"); - } - int NbValue = TypeMapEntryType.Length(); - TCollection_AsciiString Message = BuildValuesAscii(TypeMapEntryType.Values()); - - m_CurrentEntryValue = _T(Message.ToCString()); - - m_NewEntryControl.SetCurSel(TypeMapEntryType.Style()); - m_NewEntryValue = _T(Message.ToCString()); - if (TypeMapEntryType.Style() == Aspect_TOL_USERDEFINED) - m_NewEntryValueControl.SetReadOnly( false ); - else - m_NewEntryValueControl.SetReadOnly( true ); - } - else - { - m_CurrentEntryStyle = _T("Not Allocated"); - m_CurrentEntryValue = _T(""); - m_NewEntryValue = _T("No value"); - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_HIDE); - } -} - -void CTypePropertyPage::OnSelchangeTypeMapTAB(NMHDR* pNMHDR, LRESULT* pResult) -{ - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); - *pResult = 0; -} -void CTypePropertyPage::OnSelchangeTypeMapCOMBONewEntryStyle() -{ - UpdateData(true); - // the Type Map entry change in the edit part - if (m_NewEntryControl.GetCurSel() == Aspect_TOL_USERDEFINED) - m_NewEntryValueControl.SetReadOnly( false ); - else - { - m_NewEntryValueControl.SetReadOnly( true ); - - // create a dummy map to extract the default values - Aspect_TypeMapEntry aTypeMapEntry(99,(Aspect_TypeOfLine)m_NewEntryControl.GetCurSel()); - Aspect_LineStyle TypeMapEntryType = aTypeMapEntry.Type() ; - TCollection_AsciiString Message = BuildValuesAscii(TypeMapEntryType.Values()); - - m_NewEntryValue = _T(Message.ToCString()); - } - UpdateData(false); -} - -void CTypePropertyPage::OnChangeTypeMapEDITNewEntryValue() -{ - UpdateData(true); - Handle(TColQuantity_HArray1OfLength) anArray; - Standard_Boolean IsDone = ExtractValues(TCollection_AsciiString((char *)(LPCSTR)m_NewEntryValue),anArray); - if (IsDone) - { - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_SHOW); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry)->ShowWindow(SW_SHOW); - } - else - { - GetDlgItem(IDC_FontMap_BUTTON_UpdateCurrent)->ShowWindow(SW_HIDE); - GetDlgItem(IDC_FontMap_BUTTON_NewEntry)->ShowWindow(SW_HIDE); - } -} - -void CTypePropertyPage::OnFontMapBUTTONNewEntry() -{ - UpdateData(true); - int NewEntry; - - if (m_NewEntryControl.GetCurSel() == Aspect_TOL_USERDEFINED) - { - Handle(TColQuantity_HArray1OfLength) anArray; - if (ExtractValues(TCollection_AsciiString((char *)(LPCSTR)m_NewEntryValue),anArray)) - { - Aspect_LineStyle aLineStyle(anArray->Array1()); - NewEntry = myTypeMap->AddEntry( aLineStyle ); - } - else Standard_Failure::Raise(" The String is not Valid "); - } - else - { - Aspect_LineStyle aLineStyle((Aspect_TypeOfLine)m_NewEntryControl.GetCurSel()); - NewEntry = myTypeMap->AddEntry( aLineStyle ); - } - - SetModified(true); - UpdateDisplay(NewEntry); - UpdateData(false); -} - -void CTypePropertyPage::OnFontMapBUTTONUpdateCurrent() -{ - UpdateData(true); - Aspect_TypeMapEntry aTypeMapEntry = myTypeMap->Entry( m_TabCtrl.GetCurSel()+1); - - if (m_NewEntryControl.GetCurSel() == Aspect_TOL_USERDEFINED) - { - Handle(TColQuantity_HArray1OfLength) anArray; - if (ExtractValues(TCollection_AsciiString((char *)(LPCSTR)m_NewEntryValue),anArray)) - { - Aspect_LineStyle aLineStyle(anArray->Array1()); - aTypeMapEntry.SetType( aLineStyle ); - } - else Standard_Failure::Raise(" The String is not Valid "); - } - else - { - Aspect_LineStyle aLineStyle((Aspect_TypeOfLine)m_NewEntryControl.GetCurSel()); - aTypeMapEntry.SetType( aLineStyle ); - } - - myTypeMap->AddEntry(aTypeMapEntry); // in fact just update - - SetModified(true); - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); -} - -BOOL CTypePropertyPage::OnApply() -{ - myViewer->SetTypeMap(myTypeMap); - myViewer->Update(); - return CPropertyPage::OnApply(); -} - -Standard_Boolean CTypePropertyPage::ExtractValues(TCollection_AsciiString aMessage, - Handle(TColQuantity_HArray1OfLength)& anArray) // out -{ - TColStd_SequenceOfReal aSequenceOfReal; - Standard_Integer CurrentStartValue=1; - bool NotFinish = true; - while (NotFinish) - { - CurrentStartValue = aMessage.SearchFromEnd(";"); - if ( CurrentStartValue == aMessage.Length()) return Standard_False; - if (CurrentStartValue != -1) - { - TCollection_AsciiString aNewMessage = aMessage.Split(CurrentStartValue); - aMessage.Remove(aMessage.Length()); - if (aNewMessage.IsRealValue()) - aSequenceOfReal.Append(aNewMessage.RealValue()); - else return Standard_False; - } - else - { - if (aMessage.IsRealValue()) - aSequenceOfReal.Append(aMessage.RealValue()); - else return Standard_False; - NotFinish = false; - } - } - - anArray = new TColQuantity_HArray1OfLength(1,aSequenceOfReal.Length()); - for (int i=1;i<=aSequenceOfReal.Length();i++) - anArray->SetValue(i,aSequenceOfReal(aSequenceOfReal.Length()-i+1)); - - return Standard_True; -} - -TCollection_AsciiString CTypePropertyPage::BuildValuesAscii(const TColQuantity_Array1OfLength& anArray) -{ - TCollection_AsciiString Message; - int NbValue = anArray.Length(); - for (int j=1;j Precision::Confusion()) Message += Length; - else Message += "No value"; - return Message; -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.h b/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.h deleted file mode 100755 index f059870c31..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/TypePropertyPage.h +++ /dev/null @@ -1,81 +0,0 @@ -#if !defined(AFX_TypePropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_) -#define AFX_TypePropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// TypePropertyPage.h : header file -// - -#include "V2d_Viewer.hxx" -#include "TColQuantity_HArray1OfLength.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CTypePropertyPage dialog - -class CTypePropertyPage : public CPropertyPage -{ -private : - Handle(Aspect_TypeMap) myTypeMap; -private : - Handle(V2d_Viewer) myViewer; -public: - void SetViewer(Handle(V2d_Viewer) aViewer) { - myViewer = aViewer; - myTypeMap = aViewer->TypeMap(); - }; - - DECLARE_DYNCREATE(CTypePropertyPage) - -// Construction -public: - CTypePropertyPage(); - ~CTypePropertyPage(); - -// Dialog Data - //{{AFX_DATA(CTypePropertyPage) - enum { IDD = IDD_DIALOG_Type }; - CTabCtrl m_TabCtrl; - CComboBox m_NewEntryControl; - - CString m_TypeMapSize; - CString m_CurrentEntryStyle; - CString m_CurrentEntryValue; - CEdit m_NewEntryValueControl; - CString m_NewEntryValue; - //}}AFX_DATA - - -// Overrides - // ClassWizard generate virtual function overrides - //{{AFX_VIRTUAL(CTypePropertyPage) - public: - virtual BOOL OnApply(); - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - // Generated message map functions - //{{AFX_MSG(CTypePropertyPage) - virtual BOOL OnInitDialog(); - afx_msg void OnFontMapBUTTONNewEntry(); - afx_msg void OnFontMapBUTTONUpdateCurrent(); - afx_msg void OnChangeTypeMapEDITNewEntryValue(); - afx_msg void OnSelchangeTypeMapTAB(NMHDR* pNMHDR, LRESULT* pResult); - afx_msg void OnSelchangeTypeMapCOMBONewEntryStyle(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() -private: - void UpdateDisplay(int CurrentSelectionIndex); - - TCollection_AsciiString BuildValuesAscii(const TColQuantity_Array1OfLength& anArray); - Standard_Boolean ExtractValues(TCollection_AsciiString aMessage,Handle(TColQuantity_HArray1OfLength)& anArray); - -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_TypePropertyPage_H__B6E7AAD3_DB72_11D1_8DE5_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.cpp b/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.cpp deleted file mode 100755 index 2164a4fbd4..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.cpp +++ /dev/null @@ -1,184 +0,0 @@ -// WidthProperty.cpp : implementation file -// - -#include "stdafx.h" - -#include "WidthPropertyPage.h" - -#include "Aspect_WidthMapEntry.hxx" -#include "Aspect_LineStyle.hxx" - -///////////////////////////////////////////////////////////////////////////// -// CWidthPropertyPage property page - -IMPLEMENT_DYNCREATE(CWidthPropertyPage, CPropertyPage) - -CWidthPropertyPage::CWidthPropertyPage() : CPropertyPage(CWidthPropertyPage::IDD) -{ - //{{AFX_DATA_INIT(CWidthPropertyPage) - m_WidthMapSize = _T("Computing..."); - m_EntryType = _T("Computing..."); - m_EntryWidth = _T("Computing..."); - m_NewEntryWidth = 1; - //}}AFX_DATA_INIT -} - -CWidthPropertyPage::~CWidthPropertyPage() -{ -} - -void CWidthPropertyPage::DoDataExchange(CDataExchange* pDX) -{ - CPropertyPage::DoDataExchange(pDX); - //{{AFX_DATA_MAP(CWidthPropertyPage) - DDX_Text (pDX, IDC_WidthMap_STATIC_Size, m_WidthMapSize); - DDX_Control (pDX, IDC_WidthMap_TAB, m_TabCtrl); - DDX_Text (pDX, IDC_WidthMap_STATIC_EntryType, m_EntryType); - DDX_Text (pDX, IDC_WidthMap_STATIC_EntryWidth, m_EntryWidth); - DDX_Control (pDX, IDC_WidthMap_COMBO_NewEntryType, m_NewEntryType); - DDX_Control (pDX, IDC_WidthMap_EDIT_NewEntryWidth, m_NewEntryWidthControl); - DDX_Text (pDX, IDC_WidthMap_EDIT_NewEntryWidth, m_NewEntryWidth); - //}}AFX_DATA_MAP -} - - -BEGIN_MESSAGE_MAP(CWidthPropertyPage, CPropertyPage) - //{{AFX_MSG_MAP(CWidthPropertyPage) - ON_NOTIFY(TCN_SELCHANGE, IDC_WidthMap_TAB, OnSelchangeDialogWidthTAB) - ON_BN_CLICKED(IDC_WidthMap_BUTTON_AddNewEntry, OnWidthMapBUTTONAddNewEntry) - ON_CBN_SELCHANGE(IDC_WidthMap_COMBO_NewEntryType, OnSelchangeWidthMapCOMBONewEntryType) - ON_BN_CLICKED(IDC_WidthMap_BUTTON_UpdateCurrentEntry, OnWidthMapBUTTONUpdateCurrentEntry) - //}}AFX_MSG_MAP -END_MESSAGE_MAP() - -///////////////////////////////////////////////////////////////////////////// -// CWidthPropertyPage message handlers - -BOOL CWidthPropertyPage::OnInitDialog() -{ - CPropertyPage::OnInitDialog(); - - // update the CComboBox to add the enumeration possibilities. - m_NewEntryType.AddString( "THIN" ); - m_NewEntryType.AddString( "MEDIUM" ); - m_NewEntryType.AddString( "THICK" ); - m_NewEntryType.AddString( "VERYTHICK" ); - m_NewEntryType.AddString( "USERDEFINED" ); - m_NewEntryType.SetCurSel(0); - - UpdateDisplay(1); - UpdateData(false); - return TRUE; // return TRUE unless you set the focus to a control - // EXCEPTION: OCX Property Pages should return FALSE -} - - -void CWidthPropertyPage::UpdateDisplay(int CurrentSelectionIndex) -{ - // Update the size of the Width map - TCollection_AsciiString SizeMessage(myWidthMap->Size()); - m_WidthMapSize = _T(SizeMessage.ToCString()); - - // clear the Tab Ctrl - m_TabCtrl.DeleteAllItems(); - TC_ITEM TabCtrlItem; - TabCtrlItem.mask = TCIF_TEXT; - for(int i =1;i<=myWidthMap->Size();i++) - { - Aspect_WidthMapEntry aWidthMapEntry = myWidthMap->Entry(i); - - TCollection_AsciiString EntryNumerMessage(aWidthMapEntry.Index()); - TabCtrlItem.pszText = (LPSTR) EntryNumerMessage.ToCString(); - m_TabCtrl.InsertItem( aWidthMapEntry.Index(), &TabCtrlItem ); - } - m_TabCtrl.SetCurSel(CurrentSelectionIndex-1); - // update the current Entry informations - Aspect_WidthMapEntry aWidthMapEntry = myWidthMap->Entry(CurrentSelectionIndex); - - // update the current entry - switch (aWidthMapEntry.Type()) { - case Aspect_WOL_THIN : m_EntryType = _T("Aspect_WOL_THIN") ; break; - case Aspect_WOL_MEDIUM : m_EntryType = _T("Aspect_WOL_MEDIUM") ; break; - case Aspect_WOL_THICK : m_EntryType = _T("Aspect_WOL_THICK") ; break; - case Aspect_WOL_VERYTHICK : m_EntryType = _T("Aspect_WOL_VERYTHICK") ; break; - case Aspect_WOL_USERDEFINED : m_EntryType = _T("Aspect_WOL_USERDEFINED") ; break; - default : cout<<" Underknown"; - } - - TCollection_AsciiString WidthMessage(aWidthMapEntry.Width()); - m_EntryWidth = _T(WidthMessage.ToCString()); - - // update the edit / new part of the - // also update the edit part - m_NewEntryType.SetCurSel(aWidthMapEntry.Type()); - m_NewEntryWidth = aWidthMapEntry.Width(); - if (aWidthMapEntry.Type() == Aspect_WOL_USERDEFINED) - m_NewEntryWidthControl.SetReadOnly( false); - else - m_NewEntryWidthControl.SetReadOnly( true); - -// if (CurrentSelectionIndex == 1) // the item 1 is not editable ( in the map by default ) -// GetDlgItem(IDC_WidthMap_BUTTON_UpdateCurrentEntry)->ShowWindow(SW_HIDE); -// else - GetDlgItem(IDC_WidthMap_BUTTON_UpdateCurrentEntry)->ShowWindow(SW_SHOW); -} - -void CWidthPropertyPage::OnSelchangeDialogWidthTAB(NMHDR* pNMHDR, LRESULT* pResult) -{ - UpdateDisplay( m_TabCtrl.GetCurSel()+1); - UpdateData(false); - *pResult = 0; -} - -void CWidthPropertyPage::OnSelchangeWidthMapCOMBONewEntryType() -{ - UpdateData(true); - // the Width Map entry change in the edit part - if (m_NewEntryType.GetCurSel() == Aspect_WOL_USERDEFINED) - m_NewEntryWidthControl.SetReadOnly( false); - else - { - m_NewEntryWidthControl.SetReadOnly( true); - Aspect_WidthMapEntry aTmpWidthMapEntry (99,(Aspect_WidthOfLine)m_NewEntryType.GetCurSel()); - m_NewEntryWidth = aTmpWidthMapEntry.Width(); - } - UpdateData(false); -} - -void CWidthPropertyPage::OnWidthMapBUTTONAddNewEntry() -{ - UpdateData(true); - int NewEntry; - if (m_NewEntryType.GetCurSel() == Aspect_WOL_USERDEFINED) - NewEntry =myWidthMap->AddEntry(m_NewEntryWidth); - else - NewEntry =myWidthMap->AddEntry( (Aspect_WidthOfLine)m_NewEntryType.GetCurSel()); - SetModified(true); - UpdateDisplay(NewEntry); - UpdateData(false); -} - -void CWidthPropertyPage::OnWidthMapBUTTONUpdateCurrentEntry() -{ - UpdateData(true); - - Aspect_WidthMapEntry aWidthMapEntry = myWidthMap->Entry( m_TabCtrl.GetCurSel()+1); - - if (m_NewEntryType.GetCurSel() == Aspect_WOL_USERDEFINED) - aWidthMapEntry.SetWidth(m_NewEntryWidth ); - else - aWidthMapEntry.SetType((Aspect_WidthOfLine)m_NewEntryType.GetCurSel()); - - myWidthMap->AddEntry(aWidthMapEntry); // in fact just update - SetModified(true); - UpdateDisplay(m_TabCtrl.GetCurSel()+1); - UpdateData(false); -} - -BOOL CWidthPropertyPage::OnApply() -{ - //AfxGetMainWnd()->SendMessage(WM_USERAPPLY_InMapProperties); - myViewer->SetWidthMap(myWidthMap); - myViewer->Update(); - return CPropertyPage::OnApply(); -} diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.h b/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.h deleted file mode 100755 index 4892533a66..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/WidthPropertyPage.h +++ /dev/null @@ -1,73 +0,0 @@ -#if !defined(AFX_WIDTHPROPERTY_H__0F6C04B3_D5DB_11D1_8DDF_0800369C8A03__INCLUDED_) -#define AFX_WIDTHPROPERTY_H__0F6C04B3_D5DB_11D1_8DDF_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// WidthProperty.h : header file -// -#include "Aspect_WidthMap.hxx" -///////////////////////////////////////////////////////////////////////////// -// CWidthPropertyPage dialog - -class CWidthPropertyPage : public CPropertyPage -{ - DECLARE_DYNCREATE(CWidthPropertyPage) - -private : - Handle(Aspect_WidthMap) myWidthMap; -private : - Handle(V2d_Viewer) myViewer; -public: - void SetViewer(Handle(V2d_Viewer) aViewer) { - myViewer = aViewer; - myWidthMap = aViewer->WidthMap(); - }; - -// Construction -public: - CWidthPropertyPage(); - ~CWidthPropertyPage(); - -// Dialog Data - //{{AFX_DATA(CWidthPropertyPage) - enum { IDD = IDD_DIALOG_Width }; - CString m_WidthMapSize; - CTabCtrl m_TabCtrl; - CString m_EntryType; - CString m_EntryWidth; - CComboBox m_NewEntryType; - CEdit m_NewEntryWidthControl; - double m_NewEntryWidth; - //}}AFX_DATA - - -// Overrides - // ClassWizard generate virtual function overrides - //{{AFX_VIRTUAL(CWidthPropertyPage) - public: - virtual BOOL OnApply(); - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - // Generated message map functions - //{{AFX_MSG(CWidthPropertyPage) - afx_msg void OnSelchangeDialogWidthTAB(NMHDR* pNMHDR, LRESULT* pResult); - virtual BOOL OnInitDialog(); - afx_msg void OnWidthMapBUTTONAddNewEntry(); - afx_msg void OnSelchangeWidthMapCOMBONewEntryType(); - afx_msg void OnWidthMapBUTTONUpdateCurrentEntry(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() - -private: - void UpdateDisplay(int CurrentSelectionIndex); -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_WIDTHPROPERTY_H__0F6C04B3_D5DB_11D1_8DDF_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/Properties/colornewcolorrampcolormapDialog.h b/samples/mfc/standard/03_Viewer2d/src/Properties/colornewcolorrampcolormapDialog.h deleted file mode 100755 index ae228951df..0000000000 --- a/samples/mfc/standard/03_Viewer2d/src/Properties/colornewcolorrampcolormapDialog.h +++ /dev/null @@ -1,61 +0,0 @@ -#if !defined(AFX_ColorNewColorRampColorMapDialog_H__A45F6973_DB41_11D1_8DE5_0800369C8A03__INCLUDED_) -#define AFX_ColorNewColorRampColorMapDialog_H__A45F6973_DB41_11D1_8DE5_0800369C8A03__INCLUDED_ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 -// ColorNewColorRampColorMapDialog.h : header file -// - -///////////////////////////////////////////////////////////////////////////// -// CColorNewColorRampColorMapDialog dialog - -class CColorNewColorRampColorMapDialog : public CDialog -{ -private : - Handle(Aspect_ColorMap) myColorMap; - -// Construction -public: - CColorNewColorRampColorMapDialog(CWnd* pParent = NULL); // standard constructor - Handle(Aspect_ColorMap) ColorMap() {return myColorMap;}; - -// Dialog Data - //{{AFX_DATA(CColorNewColorRampColorMapDialog) - enum { IDD = IDD_DIALOG_NewColorRamp }; - CComboBox m_ColorList; - int m_base_pixel; - int m_dimension; - double m_Red; - double m_Green; - double m_Blue; - //}}AFX_DATA - - -// Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CColorNewColorRampColorMapDialog) - protected: - virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support - //}}AFX_VIRTUAL - -// Implementation -protected: - - // Generated message map functions - //{{AFX_MSG(CColorNewColorRampColorMapDialog) - virtual void OnOK(); - afx_msg void OnColorMapRampBUTTONEditColor(); - virtual BOOL OnInitDialog(); - afx_msg void OnChangeColorMapRampEDITColorRed(); - afx_msg void OnChangeColorMapRampEDITColorGreen(); - afx_msg void OnChangeColorMapRampEDITColorBlue(); - afx_msg void OnSelchangeColorMapCOMBONewEntryColorName(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() -}; - -//{{AFX_INSERT_LOCATION}} -// Microsoft Developer Studio will insert additional declarations immediately before the previous line. - -#endif // !defined(AFX_ColorNewColorRampColorMapDialog_H__A45F6973_DB41_11D1_8DE5_0800369C8A03__INCLUDED_) diff --git a/samples/mfc/standard/03_Viewer2d/src/StdAfx.h b/samples/mfc/standard/03_Viewer2d/src/StdAfx.h index 7f3211b2b2..1d31d7455f 100755 --- a/samples/mfc/standard/03_Viewer2d/src/StdAfx.h +++ b/samples/mfc/standard/03_Viewer2d/src/StdAfx.h @@ -72,170 +72,110 @@ # pragma comment (lib,"TKernel.lib") */ -#include +#include +#include +#include +#include +#include +#include +#include -#include - - -#include - -#include - -#include -#include - -#include "gp_Pnt2d.hxx" -#include "Geom2d_Curve.hxx" -#include "GCE2d_MakeSegment.hxx" -#include "gp_Pnt2d.hxx" - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "SelectMgr_Selection.hxx" - - -#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include #include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "Geom2d_Curve.hxx" - - #include #include -#include -#include -#include -#include - -#include -#include - -#include "SelectMgr_SelectableObject.hxx" - -#include -#include -#include -#include -#include -#include -#include -#include -#include - -class V2d_Viewer; -class PrsMgr_PresentationManager2d; -class SelectMgr_SelectionManager; -#include -class SelectMgr_SelectableObject; -class V2d_View; -#include - -class ISession2D_InteractiveObject; -#include +#include +#include +#include +#include +#include +#include +#include #include -#include -#include -#include -#include -#include +#include + +#include #include -#include - -#include -#include -#include -#include -#include -#include -class SelectBasics_EntityOwner; -class gp_Pnt2d; -#include -#include "TColgp_HArray1OfPnt2d.hxx" #include - -#include -#include -#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include -#include -#include -#include "PrsMgr_PresentationManager2d.hxx" -#include "SelectMgr_Selection.hxx" -#include "Graphic2d_Array1OfVertex.hxx" -#include "Graphic2d_Polyline.hxx" -#include "Graphic2d_Vertex.hxx" -#include "Graphic2d_DisplayList.hxx" +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include #include #include -#include - -#include -#include +#include #include -#include -#include -#include -#include -#include -#include - -class TCollection_AsciiString; -class Graphic2d_GraphicObject; -#include -#include "Aspect_MarkMap.hxx" -#include "V2d_View.hxx" -#include "Aspect_ColorMap.hxx" -#include "Aspect_FontMap.hxx" -#include "Aspect_MarkMap.hxx" -#include "Aspect_TypeMap.hxx" -#include "Aspect_WidthMap.hxx" -#include "Aspect_MarkMap.hxx" -#include "StdSelect_TextProjector2d.hxx" -#include "StdSelect_SensitiveText2d.hxx" -#include "WNT_FontMapEntry.hxx" -#include "WNT_WDriver.hxx" -#include "HLRAlgo_Projector.hxx" - -#include "AIS2D_InteractiveContext.hxx" -#include "AIS2D_InteractiveObject.hxx" - -#include "Graphic2d_TypeOfPolygonFilling.hxx" -#include "Prs2d_AspectLine.hxx" - +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include <..\res\resource.h> +class ISession2D_InteractiveObject; + +class V3d_Viewer; +class SelectMgr_SelectableObject; +class TCollection_AsciiString; +class SelectBasics_EntityOwner; +class gp_Pnt2d; + //{{AFX_INSERT_LOCATION}} // Microsoft Developer Studio will insert additional declarations immediately before the previous line. diff --git a/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.cpp b/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.cpp index cf90a05840..249cdd0f61 100755 --- a/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.cpp +++ b/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.cpp @@ -19,12 +19,11 @@ static char THIS_FILE[] = __FILE__; ///////////////////////////////////////////////////////////////////////////// // CViewer2dApp construction -CViewer2dApp::CViewer2dApp() +CViewer2dApp::CViewer2dApp() : OCC_App() { - SampleName = "Viewer2d"; //for about dialog + SampleName = "Viewer2d"; //for about dialog } - ///////////////////////////////////////////////////////////////////////////// // The one and only CViewer2dApp object diff --git a/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.h b/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.h index e89d701d81..a8d6157de7 100755 --- a/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.h +++ b/samples/mfc/standard/03_Viewer2d/src/Viewer2dApp.h @@ -8,18 +8,20 @@ #pragma once #endif // _MSC_VER > 1000 -#include +#include -class CViewer2dApp : public OCC_2dApp +class CViewer2dApp : public OCC_App { public: - CViewer2dApp(); + + CViewer2dApp(); + // Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CViewer2dApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CViewer2dApp) + public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL }; diff --git a/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.cpp b/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.cpp index d01019c324..d6edf5599c 100755 --- a/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.cpp +++ b/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.cpp @@ -2,33 +2,13 @@ // #include "stdafx.h" - #include "Viewer2dDoc.h" - -#include "OCC_BaseApp.h" - -#include -#include -#include -#include - -#include -#include - -#include - -#include - +#include "OCC_App.h" #include "Primitive\Sample2D_Markers.h" -#include "Primitive\Sample2D_Line.h" #include "Primitive\Sample2D_Text.h" #include "Primitive\Sample2D_Face.h" -#include "Primitive\Sample2D_Curve.h" -#include "Primitive\Sample2D_Rectangle.h" #include "Primitive\Sample2D_Image.h" -#include "PropertiesSheet.h" - ///////////////////////////////////////////////////////////////////////////// // CViewer2dDoc @@ -36,12 +16,11 @@ IMPLEMENT_DYNCREATE(CViewer2dDoc, CDocument) BEGIN_MESSAGE_MAP(CViewer2dDoc, CDocument) //{{AFX_MSG_MAP(CViewer2dDoc) - ON_COMMAND(ID_MENU_CASCADE_PROPERTIES, OnBUTTONTest2DProperties) ON_COMMAND(ID_BUTTON_Test_Text, OnBUTTONTestText) ON_COMMAND(ID_BUTTON_Test_Markers, OnBUTTONTestMarkers) ON_COMMAND(ID_BUTTON_Test_Line, OnBUTTONTestLine) ON_COMMAND(ID_BUTTON_Erase, OnBUTTONErase) - ON_COMMAND(ID_BUTTON_Test_Face, OnBUTTONTestFase) + ON_COMMAND(ID_BUTTON_Test_Face, OnBUTTONTestFace) ON_COMMAND(ID_BUTTON_Test_Rect, OnBUTTONTestRect) ON_COMMAND(ID_BUTTON_Test_Curve, OnBUTTONTestCurve) ON_COMMAND(ID_BUTTON32793, OnBUTTONTestImage) // test image @@ -76,356 +55,188 @@ void CViewer2dDoc::Dump(CDumpContext& dc) const ///////////////////////////////////////////////////////////////////////////// // CViewer2dDoc commands -void CViewer2dDoc::OnBUTTONTest2DProperties() -{ -// TODO: Add your command handler code here - CPropertiesSheet aDial; - aDial.SetViewer(my2DViewer); - aDial.DoModal(); -} - -//================================================================= -//================================================================= -//================================================================= - void CViewer2dDoc::OnBUTTONErase() { - myAISInteractiveContext2D->EraseAll(); - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Erase; - TCollection_AsciiString Message("\ -call : \n\ - myAISInteractiveContext2D->EraseAll();"); - - // Update The Result Dialog - UpdateResultDialog(anID,Message); + if(myAISContext->HasOpenedContext()) + myAISContext->CloseAllContexts(); + myAISContext->EraseAll(); } - - void CViewer2dDoc::OnBUTTONTestText() { - Standard_Integer color=1; + int aColor= 1; Standard_Real j; for (j=15;j<=20;j++) { - TCollection_AsciiString Text("font 0 scale ");Text+=j/20; + TCollection_AsciiString Text("font 0 scale ");Text+=j/20.0; Handle (Sample2D_Text) aText = new Sample2D_Text(Text, - 0,15*(j-15), // anX , anY - Aspect_TOT_SOLID,// aType - 20.0*M_PI/180 , // anAngle - 0.0 , // aSlant - color++, // aColorIndex - 0, // aFontIndex - j/20, // aScale - Standard_False, // aIsUnderline - Standard_False, // aIsZoomable - Graphic2d_TOA_LEFT); // aTypeOfAlignment - myAISInteractiveContext2D->Display(aText, // object - Standard_False); // Redraw - if (color == my2DViewer->ColorMap()->Size()) color =1; + gp_Pnt(0.0,15.0*(j-15.0),0.0), // thePosition + Aspect_TOT_SOLID, // theType + 10.0*M_PI, // theAngle + (Quantity_NameOfColor)(aColor++), // theColor + Font_FA_Regular, // theFontAspect + "Courier", // theFont + j, // theScale + Graphic3d_HTA_LEFT, + Graphic3d_VTA_BOTTOM, + Standard_False); // aIsZoomable + + myAISContext->Display(aText, Standard_False); } - for (int j=5;j<=10;j+=1) + for (j=10;j<=15;j++) { - TCollection_AsciiString Text("font 1 scale ");Text+=j/10; + TCollection_AsciiString Text("font 1 scale ");Text+=j/10.0; Handle (Sample2D_Text) aText = new Sample2D_Text(Text, - 80,15*(j-5), // anX , anY - Aspect_TOT_SOLID,// aType - 0.0 , // anAngle - 0.0 , // aSlant - color++, // aColorIndex - 1, // aFontIndex - j/10, // aScale - Standard_True, // aIsUnderline - Standard_True, // aIsZoomable - Graphic2d_TOA_CENTER); // aTypeOfAlignment + gp_Pnt(80.,15.0*(j-10.0),0.0), // thePosition + Aspect_TOT_SOLID, // theType + 0.0, // theAngle + (Quantity_NameOfColor)(aColor++), // theColor + Font_FA_BoldItalic, // theFontAspect + "Cambria", // theFont + j*2, // theScale + Graphic3d_HTA_LEFT, + Graphic3d_VTA_BOTTOM, + Standard_False); // aIsZoomable - myAISInteractiveContext2D->Display(aText, // object - Standard_False); // Redraw - if (color == my2DViewer->ColorMap()->Size()) color =1; + myAISContext->Display(aText, Standard_False); } - - for (j=5;j<=10;j+=1) + aColor = 1; + for (j=5;j<=10;j++) { - TCollection_AsciiString Text("font 2 scale ");Text+=j/10; + TCollection_AsciiString Text("font 2 scale ");Text+=j/10.0; Handle (Sample2D_Text) aText = new Sample2D_Text(Text, - 140,15*(j-5), // anX , anY - Aspect_TOT_SOLID,// aType - 0.0 , // anAngle - 0.0 , // aSlant - color++, // aColorIndex - 2, // aFontIndex - j/10, // aScale - Standard_False, // aIsUnderline - Standard_True, // aIsZoomable - Graphic2d_TOA_TOPLEFT); // aTypeOfAlignment - myAISInteractiveContext2D->Display(aText, // object - Standard_False); // Redraw - if (color == my2DViewer->ColorMap()->Size()) color =1; + gp_Pnt(140.0,15.0*(j-5.0),0.0), // thePosition + Aspect_TOT_SOLID, // theType + 0.0, // theAngle + (Quantity_NameOfColor)(aColor++), // theColor + Font_FA_Bold, // theFontAspect + "Arial", // theFont + j*2, // theScale + Graphic3d_HTA_LEFT, + Graphic3d_VTA_BOTTOM, + Standard_False); // aIsZoomable + myAISContext->Display(aText,Standard_False); } - - for (j=10;j<=15;j+=1) +for (j=10;j<=15;j++) { - TCollection_AsciiString Text("font 3 scale ");Text+=j/10; - Handle (Sample2D_Text) aText = + TCollection_AsciiString Text("font 3 scale ");Text+=j/10.0; + Handle (Sample2D_Text) aText = new Sample2D_Text(Text, - 260,15*(j-10), // anX , anY - Aspect_TOT_SOLID,// aType - 0 , // anAngle - 0.0 , // aSlant - color++, // aColorIndex - 3, // aFontIndex - j/10, // aScale - Standard_False, // aIsUnderline - Standard_False, // aIsZoomable - Graphic2d_TOA_LEFT); // aTypeOfAlignment - myAISInteractiveContext2D->Display(aText, // object - Standard_False); // Redraw - if (color == my2DViewer->ColorMap()->Size()) color =1; + gp_Pnt(200.0,15.0*(j-10.0),0.0), // thePosition + Aspect_TOT_SOLID, // theType + 0.0, // theAngle + (Quantity_NameOfColor)(aColor++),// theColor + Font_FA_Italic, // theFontAspect + "Georgia", // theFont + j*2, // theScale + Graphic3d_HTA_LEFT, + Graphic3d_VTA_BOTTOM, + Standard_False); // aIsZoomable + myAISContext->Display(aText,Standard_False); } FitAll2DViews(Standard_True); // Update Viewer - // Update Get information to update Result dialog - UINT anID=ID_BUTTON_Test_Text; - TCollection_AsciiString Message(" \ -create a set of Sample2D_Text,display it and declare selectable : \n\ ------------------------------------------------------------------------------- \n\ - Handle (Sample2D_Text) aText; \n\ - // aText = new ... \n\ - myAISInteractiveContext2D->Display(aText, // object \n\ - Standard_False); // Redraw \n\ ------------------------------------------------------------------------------- \n\ - after that the system call the SetContext Method for the display,\n\ ------------------------------------------------------------------------------- \n\ - \n\ -void Sample2D_Text::SetContext(const Handle(AIS2D_InteractiveContext)& theContext) \n\ -{ \n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ -\n\ - Handle(Graphic2d_Text) text; \n\ - text = new Graphic2d_Text(this, myText, myX, myY, myAngle,myTypeOfText,myScale); \n\ - text->SetFontIndex (myFontIndex); \n\ - text->SetColorIndex (myColorIndex); \n\ - text->SetSlant (mySlant); \n\ - text->SetUnderline (myIsUnderline); \n\ - text->SetZoomable (myIsZoomable); \n\ - text->SetAlignment (myTypeOfAlignment); \n\ -}"); - - // Update The Result Dialog - UpdateResultDialog(anID,Message); } void CViewer2dDoc::OnBUTTONTestMarkers() { - { // generic Markers - Standard_Integer MaxIndex = my2DViewer->MarkMap()->Size(); - - for (int i=1;i<=MaxIndex;i++) - { - Standard_Integer EntryNumber = (my2DViewer->MarkMap()->Entry(i)).Index () ; + // generic Markers + Standard_Integer aColor = 20; + for (int i=1;i<=2;i++) + { + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+5,5*i,Aspect_TOM_POINT,Quantity_NOC_YELLOW,2.0); + myAISContext->Display(aMarker, Standard_False); + } + for (int i=1;i<=2;i++) + { + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+10,5*i,Aspect_TOM_O,(Quantity_NameOfColor)(aColor++)); + myAISContext->Display(aMarker, Standard_False); + } + for (int i=1;i<=2;i++) + { + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+15,5*i,Aspect_TOM_O_PLUS,(Quantity_NameOfColor)(aColor++)); + myAISContext->Display(aMarker, Standard_False); + } + for (int i=1;i<=2;i++) + { + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+20,5*i,Aspect_TOM_BALL,(Quantity_NameOfColor)(aColor++)); + myAISContext->Display(aMarker, Standard_False); + } + for (int i=1;i<=2;i++) + { - Handle (Sample2D_Markers) Marker = - new Sample2D_Markers(EntryNumber, // generic marker index - 10*i,0,// display point - 5,5, // size - 0); // angle in radian - myAISInteractiveContext2D->Display(Marker, // object - Standard_False); // Redraw - - } - for (int i=1;i<=MaxIndex;i++) - { - Standard_Integer EntryNumber = (my2DViewer->MarkMap()->Entry(i)).Index () ; - Handle (Sample2D_Markers) Marker = - new Sample2D_Markers(EntryNumber, // generic marker index - 10*i,10,// display point - 5,5, // size - 20*M_PI/180); // angle in radian - myAISInteractiveContext2D->Display(Marker, // object - Standard_False); // Redraw - } - } - - - { // a Circle Marker - Handle (Sample2D_Markers) Marker = - new Sample2D_Markers(10,20,// reference point - 0,0, // display point - 2); // radius - myAISInteractiveContext2D->Display(Marker, // object - Standard_False); // Redraw - - } - - { // an ellips Marker - Handle (Sample2D_Markers) Marker = - new Sample2D_Markers(20,20, // reference point - 0,0, // display point - 3,2, // major, minor radius - 20*M_PI/180); // angle - myAISInteractiveContext2D->Display(Marker, // object - Standard_False); // Redraw - } - - { // a polyline Marker - - Graphic2d_Array1OfVertex myListVertex(1,6); - myListVertex(1)=Graphic2d_Vertex(0.,0.); - myListVertex(2)=Graphic2d_Vertex(0.,5.); - myListVertex(3)=Graphic2d_Vertex(10.,0.); - myListVertex(4)=Graphic2d_Vertex(10.,5.); - myListVertex(5)=Graphic2d_Vertex(20.,0.); - myListVertex(6)=Graphic2d_Vertex(20.,5.); - - Handle (Sample2D_Markers) Marker = - new Sample2D_Markers(30,20, // reference point - myListVertex); - myAISInteractiveContext2D->Display(Marker, // object - Standard_True); // Redraw - - } + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+25,5*i,Aspect_TOM_STAR,(Quantity_NameOfColor)(aColor++)); + myAISContext->Display(aMarker, Standard_False); + } + for (int i=1;i<=2;i++) + { + Handle (Sample2D_Markers) aMarker = + new Sample2D_Markers(10+30,5*i,Aspect_TOM_O_X,(Quantity_NameOfColor)(aColor++)); + myAISContext->Display(aMarker, Standard_False); + } FitAll2DViews(Standard_False); // Update Viewer - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Markers; - TCollection_AsciiString Message(" \ -create a set of Sample2D_Markers and display it :\n\ ----------------------------------------------------\n\ - {\n\ - Standard_Integer MaxIndex = my2DViewer->MarkMap()->Size();\n\ - for (int i=1;i<=MaxIndex;i++) {\n\ - Standard_Integer EntryNumber = (my2DViewer->MarkMap()->Entry(10)).Index () ;\n\ - Handle (Sample2D_Markers) Marker = \n\ - new Sample2D_Markers(EntryNumber, // generic marker index\n\ - 10*i,0,// display point\n\ - 5,5, // size\n\ - 0); // angle in radian\n\ - myAISInteractiveContext2D->Display(Marker, // object\n\ - Standard_False); // Redraw\n\ -\n\ - }\n\ - //...\n\ -\n\ - after that the system call the SetContext Methods : \n\ -\n\ -void Sample2D_Markers::SetContext(const Handle(AIS2D_InteractiveContext)& theContext) \n\ -{ \n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ - if (myCurrentTypeOfMarker == 2D_CTOM_Generic) \n\ - if ( myIndex == 0 ) {\n\ - Handle(Graphic2d_Marker) aMarker= \n\ - new Graphic2d_Marker(this, \n\ - myXPosition ,myYPosition); \n\ - }\n\ - else {\n\ - Handle(Graphic2d_Marker) aMarker= \n\ - new Graphic2d_Marker(this,myIndex, \n\ - myXPosition ,myYPosition, \n\ - myWidth,myHeight,myAngle); \n\ - }\n\ - \n\ - if (myCurrentTypeOfMarker == 2D_CTOM_Polyline) \n\ - Handle(Graphic2d_PolylineMarker) aMarker= \n\ - new Graphic2d_PolylineMarker(this, \n\ - myXPosition,myYPosition, \n\ - myListVertex); \n\ - \n\ - if (myCurrentTypeOfMarker == 2D_CTOM_Circle) \n\ - Handle(Graphic2d_CircleMarker) aMarker= \n\ - new Graphic2d_CircleMarker(this, \n\ - myXPosition,myYPosition, \n\ - myX ,myY,myRadius ); \n\ - \n\ - if (myCurrentTypeOfMarker == 2D_CTOM_Ellips) \n\ - Handle(Graphic2d_EllipsMarker) aMarker= \n\ - new Graphic2d_EllipsMarker(this, \n\ - myXPosition,myYPosition, \n\ - myX,myY, \n\ - myMajorRadius,myMinorRadius, \n\ - myAngle ); \n\ - \n\ -} \n\n"); - // Update The Result Dialog - UpdateResultDialog(anID,Message); } - - void CViewer2dDoc::OnBUTTONTestLine() { - //Handle(ISessionSample2D_Line) aLine = new ISessionSample2D_Line(); - Handle(Sample2D_Line) aLine = new Sample2D_Line(); + for (int i=0;i<=13;++i) + for (int j=0;j<=5;++j) + { + //set of rectangles here + TopoDS_Edge E1 = BRepBuilderAPI_MakeEdge(gp_Pnt(10*i,10*j,0.), gp_Pnt(10*i+7,10*j,0.)); + TopoDS_Edge E2 = BRepBuilderAPI_MakeEdge(gp_Pnt(10*i+7,10*j,0.), gp_Pnt(10*i+7,10*j+5,0.)); + TopoDS_Edge E3 = BRepBuilderAPI_MakeEdge(gp_Pnt(10*i+7,10*j+5,0.), gp_Pnt(10*i,10*j+5,0.)); + TopoDS_Edge E4 = BRepBuilderAPI_MakeEdge(gp_Pnt(10*i,10*j+5,0.), gp_Pnt(10*i,10*j,0.)); + TopoDS_Wire W = BRepBuilderAPI_MakeWire(E1,E2,E3,E4); + TopoDS_Face F = BRepBuilderAPI_MakeFace(W); + Handle_AIS_Shape aRect = new AIS_Shape(F); + //set attributes of boundaries + Handle(AIS_Drawer) aDrawer = new AIS_Drawer(); + Handle(Prs3d_LineAspect) aLineAttrib = + new Prs3d_LineAspect(Quantity_NOC_YELLOW, + (Aspect_TypeOfLine)(Aspect_TOL_SOLID+j),1); + aDrawer->SetFaceBoundaryAspect(aLineAttrib); + aDrawer->SetFaceBoundaryDraw(Standard_True); + aRect->SetAttributes(aDrawer); + + myAISContext->SetDisplayMode(aRect,1); + myAISContext->SetColor(aRect,(Quantity_NameOfColor)(Quantity_NOC_CADETBLUE+2*i),Standard_False); + myAISContext->SetMaterial(aRect,Graphic3d_NOM_PLASTIC,Standard_False); + myAISContext->Display(aRect, Standard_False); -// myInteractiveContext2D->Display(aLine, // object -// Standard_True); // Redraw - - myAISInteractiveContext2D->Display(aLine, // object - Standard_True); // Redraw - - FitAll2DViews(Standard_False); // Update Viewer - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Line; - TCollection_AsciiString Message(" \ -create a Sample2D_Line and display it : \n\ ------------------------------------------------------------------------------- \n\ - Handle(Sample2D_Line) aLine = new Sample2D_Line();\n\ - myAISInteractiveContext2D->Display(aLine, // object\n\ - Standard_True); // Redraw\n\ - FitAll2DViews(Standard_False); // Update Viewer\n\ ------------------------------------------------------------------------------- \n\ - after that the system call the SetContext Methods : \n\ ------------------------------------------------------------------------------- \n\ -void Sample2D_Line::SetContext(const Handle(AIS2D_InteractiveContext)& theContext) \n\ -{\n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ -\n\ - Handle(Prs2d_AspectLine) aLineAspect = new Prs2d_AspectLine; \n\ - aLineAspect->SetTypeOfFill(Graphic2d_TOPF_FILLED); \n\ - aLineAspect->SetWidthIndex(0); \n\ -\n\ - for (int i=0;i<=13;i++)\n\ - for (int j=0;j<=5;j++)\n\ - {\n\ - {\n\ - Graphic2d_Array1OfVertex anArrayVertex(1,5);\n\ - anArrayVertex(1)=Graphic2d_Vertex(20.*i,10.*j+0);\n\ - anArrayVertex(2)=Graphic2d_Vertex(20.*i+10,10.*j+0);\n\ - anArrayVertex(3)=Graphic2d_Vertex(20.*i+10,10.*j+5);\n\ - anArrayVertex(4)=Graphic2d_Vertex(20.*i,10.*j+5);\n\ - anArrayVertex(5)=Graphic2d_Vertex(20.*i,10.*j+0);\n\ - Handle(Graphic2d_Polyline) aPolyline = \n\ - new Graphic2d_Polyline(this,anArrayVertex);\n\ -\n\ - SetAspect(aLineAspect, aPolyline); \n\ -\n\ - aPolyline->SetInteriorColorIndex(i); // to use with Graphic2d_TOPF_FILLED \n\ - aPolyline->SetTypeIndex(j); // type of the polyline \n\ - }\n\ - }\n}"); - - // Update The Result Dialog - UpdateResultDialog(anID,Message); + } + this->FitAll2DViews(Standard_True); } -void CViewer2dDoc::OnBUTTONTestFase() -{ - myAISInteractiveContext2D->EraseAll(); - CFileDialog dlg(TRUE, - NULL, - NULL, - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - "BRep Files (*.brep)|*.brep; ||", - NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); +#include +#include + +void CViewer2dDoc::OnBUTTONTestFace() +{ + //erase all + if(myAISContext->HasOpenedContext()) + myAISContext->CloseAllContexts(); + myAISContext->EraseAll(); + + CFileDialog dlg(TRUE, + NULL, + NULL, + OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, + "BRep Files (*.brep)|*.brep; ||", + NULL ); + + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); initdir += "\\Data"; dlg.m_ofn.lpstrInitialDir = initdir; @@ -436,375 +247,71 @@ void CViewer2dDoc::OnBUTTONTestFase() CString filename = dlg.GetPathName(); Standard_CString aFileName = (Standard_CString)(LPCTSTR)filename; - TopoDS_Shape aFace; - BRep_Builder aBuilder; - Standard_Boolean result = BRepTools::Read(aFace,aFileName,aBuilder); + TopoDS_Shape aFaceShape; + BRep_Builder aBuilder; + Standard_Boolean result = BRepTools::Read(aFaceShape,aFileName,aBuilder); - if(aFace.IsNull() || aFace.ShapeType() != TopAbs_FACE) { - AfxMessageBox("The shape must be not a null Face"); - return; - } + if(aFaceShape.IsNull() || aFaceShape.ShapeType() != TopAbs_FACE) + { + AfxMessageBox("The shape must be not a null Face"); + return; + } -// Handle(ISessionSample2D_Face) aDisplayableFace = new ISessionSample2D_Face( TopoDS::Face(aFace) ); - Handle(Sample2D_Face) aDisplayableFace = new Sample2D_Face( TopoDS::Face(aFace) ); + TopoDS_Face aFace = TopoDS::Face(aFaceShape); + Handle(Sample2D_Face) anAISFace = new Sample2D_Face(aFaceShape); + myAISContext->Display(anAISFace,Standard_True); + //activate selection mode for edges selection + myAISContext->OpenLocalContext(); + myAISContext->Activate(anAISFace,2); - myAISInteractiveContext2D->Display(aDisplayableFace, // object - Standard_True); // Redraw + FitAll2DViews(Standard_False); - Handle(Aspect_ColorMap) aColorMap = my2DViewer->ColorMap(); - Aspect_ColorMapEntry aFORWARDColorMapEntry = aColorMap->FindEntry(aDisplayableFace->FORWARDColorIndex()); - Aspect_ColorMapEntry aREVERSEDColorMapEntry = aColorMap->FindEntry(aDisplayableFace->REVERSEDColorIndex()); - Aspect_ColorMapEntry aINTERNALColorMapEntry = aColorMap->FindEntry(aDisplayableFace->INTERNALColorIndex()); - Aspect_ColorMapEntry aEXTERNALColorMapEntry = aColorMap->FindEntry(aDisplayableFace->EXTERNALColorIndex()); - - Quantity_Color TheFORWARDColor = aFORWARDColorMapEntry.Color(); - Quantity_Color TheREVERSEDColor = aREVERSEDColorMapEntry.Color(); - Quantity_Color TheINTERNALColor = aINTERNALColorMapEntry.Color(); - Quantity_Color TheEXTERNALColor = aEXTERNALColorMapEntry.Color(); - - Standard_CString FORWARDStringName (Quantity_Color::StringName(TheFORWARDColor.Name())); - Standard_CString REVERSEDStringName(Quantity_Color::StringName(TheREVERSEDColor.Name())); - Standard_CString INTERNALStringName(Quantity_Color::StringName(TheINTERNALColor.Name())); - Standard_CString EXTERNALStringName(Quantity_Color::StringName(TheEXTERNALColor.Name())); - FitAll2DViews(Standard_False); // Update Viewer - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Face; - TCollection_AsciiString Message("Forward is \t"); - Message += FORWARDStringName; - Message += "\nReversed is \t"; - Message += REVERSEDStringName; - Message += "\nInternal is \t"; - Message += INTERNALStringName; - Message += "\nExternal is \t"; - Message += EXTERNALStringName; - Message += "\n"; - Message += "\ ------------------------------------------------------------------------------- \n\ -create an Sample2D_Face and display it \n\ ------------------------------------------------------------------------------- \n\ -//...\n\ - TopoDS_Face aFace;\n\ - BRep_Builder aBuilder;\n\ - Standard_Boolean result = BRepTools::Read(aFace,aFileName,aBuilder);\n\ -\n\ - Handle(ISessionSample2D_Face) aDisplayableFace = new ISessionSample2D_Face( aFace );\n\ - myInteractiveContext2D->Display(aDisplayableFace, // object\n\ - Standard_True); // Redraw\n\ -//...\n\ ------------------------------------------------------------------------------- \n\ -void _Face::SetContext() \n\ -{\n\ - Handle(Prs2d_AspectLine) aLineAspect_FORWARD = new Prs2d_AspectLine; \n\ - aLineAspect_FORWARD->SetTypeOfFill(Graphic2d_TOPF_EMPTY);\n\ - aLineAspect_FORWARD->SetTypeIndex(myTypeIndex); \n\ - aLineAspect_FORWARD->SetWidthIndex(myWidthIndex);\n\ - aLineAspect_FORWARD->SetColorIndex(myFORWARDColorIndex);\n\ -\n\ - Handle(Prs2d_AspectLine) aLineAspect_REVERSED = new Prs2d_AspectLine; \n\ - aLineAspect_REVERSED->SetTypeOfFill(Graphic2d_TOPF_EMPTY);\n\ - aLineAspect_REVERSED->SetTypeIndex(myTypeIndex);\n\ - aLineAspect_REVERSED->SetWidthIndex(myWidthIndex);\n\ - aLineAspect_REVERSED->SetColorIndex(myREVERSEDColorIndex);\n\ -\n\ - Handle(Prs2d_AspectLine) aLineAspect_INTERNAL = new Prs2d_AspectLine; \n\ - aLineAspect_INTERNAL->SetTypeOfFill(Graphic2d_TOPF_EMPTY);\n\ - aLineAspect_INTERNAL->SetTypeIndex(myTypeIndex);\n\ - aLineAspect_INTERNAL->SetWidthIndex(myWidthIndex);\n\ - aLineAspect_INTERNAL->SetColorIndex(myINTERNALColorIndex);\n\ -\n\ - Handle(Prs2d_AspectLine) aLineAspect_EXTERNAL = new Prs2d_AspectLine; \n\ - aLineAspect_EXTERNAL->SetTypeOfFill(Graphic2d_TOPF_EMPTY);\n\ - aLineAspect_EXTERNAL->SetTypeIndex(myTypeIndex);\n\ - aLineAspect_EXTERNAL->SetWidthIndex(myWidthIndex);\n\ - aLineAspect_EXTERNAL->SetColorIndex(myEXTERNALColorIndex);"; - -Message +="\ -\n\ -//pcurves of the face \n\ -\n\ - Handle(Graphic2d_SetOfCurves) segment_FORWARD;\n\ - segment_FORWARD = new Graphic2d_SetOfCurves(this); \n\ -\n\ - Handle(Graphic2d_SetOfCurves) segment_REVERSED;\n\ - segment_REVERSED = new Graphic2d_SetOfCurves(this); \n\ -\n\ - Handle(Graphic2d_SetOfCurves) segment_INTERNAL;\n\ - segment_INTERNAL = new Graphic2d_SetOfCurves(this); \n\ -\n\ - Handle(Graphic2d_SetOfCurves) segment_EXTERNAL;\n\ - segment_EXTERNAL = new Graphic2d_SetOfCurves(this); \n\ -\n\ - Standard_Real f,l;\n\ - Standard_Integer i = 1;\n\ - myFace.Orientation(TopAbs_FORWARD);\n\ - TopExp_Explorer ex(myFace,TopAbs_EDGE);\n\ - while (ex.More()) {\n\ - const Handle(Geom2d_Curve) Curve = BRep_Tool::CurveOnSurface\n\ - (TopoDS::Edge(ex.Current()),TopoDS::Face(myFace),f,l);\n\ -\n\ - Handle(Geom2d_TrimmedCurve) c = new Geom2d_TrimmedCurve(Curve,f,l);\n\ -"; -Message += "\ - if (c.IsNull())\n\ - {\n\ - // null curve --> EDGE have a null lenght\n\ - // --> get first and last Vertices\n\ - TopoDS_Edge CurrentEdge= TopoDS::Edge(ex.Current());\n\ -\n\ - TopoDS_Vertex FirstVertex = TopExp::FirstVertex(CurrentEdge);\n\ - TopoDS_Vertex LastVertex = TopExp::LastVertex(CurrentEdge);\n\ -\n\ - if (FirstVertex != LastVertex)\n\ - Standard_Failure::Raise(\"Null Edge pcurve But different vertices\");\n\ -\n\ - gp_Pnt aPnt = BRep_Tool::Pnt(FirstVertex);\n\ -\n\ - Handle(Graphic2d_Marker) aMarker= \n\ - new Graphic2d_Marker(this,myMarkerIndex,\n\ - aPnt.X() ,aPnt.Y(),\n\ - myMarkerWidth,myMarkerHeight,0);\n\ -\n\ -"; -Message += "\ - switch (ex.Current().Orientation())\n\ - {\n\ - case TopAbs_FORWARD: aMarker->SetColorIndex (myFORWARDColorIndex); break;\n\ - case TopAbs_REVERSED: aMarker->SetColorIndex (myREVERSEDColorIndex); break;\n\ - case TopAbs_INTERNAL: aMarker->SetColorIndex (myINTERNALColorIndex); break;\n\ - case TopAbs_EXTERNAL: aMarker->SetColorIndex (myEXTERNALColorIndex); break;\n\ - default : break;\n\ - }\n\ - ex.Next();\n\ - }\n\ - else\n\ - {\n\ - // Display the Curve\n\ - // display the orientation\n\ -\n\ - gp_Pnt2d p1,p2;\n\ - gp_Vec2d v;\n\ - c->D1(l,p1,v);\n\ - Graphic2d_Array1OfVertex aListVertex(1,3);\n\ - if (v.Magnitude() > gp::Resolution()) {\n\ - Standard_Real L = 2;\n\ - Standard_Real H = 1;\n\ - gp_Dir2d d(v);\n\ - p2.SetCoord(- L*d.X() - H*d.Y(),- L*d.Y() + H*d.X());\n\ - aListVertex(1)=Graphic2d_Vertex(p2.X(),p2.Y());\n\ - \n\ - p2.SetCoord(- L*d.X() + H*d.Y(),- L*d.Y() - H*d.X());\n\ - aListVertex(2)=Graphic2d_Vertex(0.,0.);\n\ - aListVertex(3)=Graphic2d_Vertex(p2.X(),p2.Y()); \n\ - }\n\ -"; -Message += "\ -\n\ - Handle(Graphic2d_PolylineMarker) aMarker= \n\ - new Graphic2d_PolylineMarker(this,p1.X(),p1.Y(),aListVertex);\n\ -\n\ - switch (ex.Current().Orientation()) \n\ - {\n\ - case TopAbs_FORWARD: {\n\ - segment_FORWARD->Add(c); \n\ - SetAspect(aLineAspect_FORWARD, aMarker); \n\ - break;\n\ - }\n\ - case TopAbs_REVERSED: {\n\ - segment_REVERSED->Add(c); \n\ - SetAspect(aLineAspect_REVERSED, aMarker); \n\ - break; \n\ - } \n\ - case TopAbs_INTERNAL: { \n\ - segment_INTERNAL->Add(c); \n\ - SetAspect(aLineAspect_INTERNAL, aMarker); \n\ - break; \n\ - } \n\ - case TopAbs_EXTERNAL: { \n\ - segment_EXTERNAL->Add(c); \n\ - SetAspect(aLineAspect_EXTERNAL, aMarker); \n\ - break; \n\ - } \n\ - default : break; \n\ - } \n\ - }\n\ - ex.Next();\n\ - }\n\ -\n\ - SetAspect(aLineAspect_FORWARD, segment_FORWARD);\n\ - SetAspect(aLineAspect_REVERSED, segment_REVERSED);\n\ - SetAspect(aLineAspect_INTERNAL, segment_INTERNAL);\n\ - SetAspect(aLineAspect_EXTERNAL, segment_EXTERNAL);\n\ -\n\ -}\n\ -"; - - // Update The Result Dialog - UpdateResultDialog(anID,Message); } - } + + void CViewer2dDoc::OnBUTTONTestRect() { - Handle (Sample2D_Rectangle) aRectangle = new Sample2D_Rectangle( - 0,0, // display point - 50,80, // size - 20*M_PI/180); // angle in radian - - aRectangle->SetHighlightMode(AIS2D_TOD_OBJECT); - myAISInteractiveContext2D->Display(aRectangle, Standard_False); // Display rectangle + //First rectangle + TopoDS_Edge E11 = BRepBuilderAPI_MakeEdge(gp_Pnt(40.,0.,0.), gp_Pnt(82.5,25.,0.)); + TopoDS_Edge E12 = BRepBuilderAPI_MakeEdge(gp_Pnt(82.5,25.,0.), gp_Pnt(42.5,93.,0.)); + TopoDS_Edge E13 = BRepBuilderAPI_MakeEdge(gp_Pnt(42.5,93.,0.), gp_Pnt(0.,68.,0.)); + TopoDS_Edge E14 = BRepBuilderAPI_MakeEdge(gp_Pnt(0.,68.,0.), gp_Pnt(40.,0.,0.)); + TopoDS_Wire W1 = BRepBuilderAPI_MakeWire(E11,E12,E13,E14); + Handle_AIS_Shape aRect1 = new AIS_Shape(W1); + myAISContext->Display(aRect1); + myAISContext->SetColor(aRect1,Quantity_NOC_YELLOW); + //Second rectangle + TopoDS_Edge E21 = BRepBuilderAPI_MakeEdge(gp_Pnt(110.,0.,0.), gp_Pnt(152.5,25.,0.)); + TopoDS_Edge E22 = BRepBuilderAPI_MakeEdge(gp_Pnt(152.5,25.,0.), gp_Pnt(112.5,93.,0.)); + TopoDS_Edge E23 = BRepBuilderAPI_MakeEdge(gp_Pnt(112.5,93.,0.), gp_Pnt(70.,68.,0.)); + TopoDS_Edge E24 = BRepBuilderAPI_MakeEdge(gp_Pnt(70.,68.,0.), gp_Pnt(110.,0.,0.)); + TopoDS_Wire W2 = BRepBuilderAPI_MakeWire(E21,E22,E23,E24); + Handle_AIS_Shape aRect2 = new AIS_Shape(W2); + myAISContext->Display(aRect2); + myAISContext->SetColor(aRect2,Quantity_NOC_YELLOW); + myAISContext->SetSelectionMode(aRect2,2); - - Handle (Sample2D_Rectangle) aRectangle2 = new Sample2D_Rectangle( - 80,0, // display point - 50,90, // size - 20*M_PI/180); // angle in radian - - aRectangle2->SetHighlightMode(AIS2D_TOD_ELEMENT); - myAISInteractiveContext2D->Display(aRectangle2); // Display rectangle - - - FitAll2DViews(Standard_False); // Update Viewer - - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Rect; - TCollection_AsciiString Message(" \ -create a two of Sample2D_Rectangle and display it : \n\ ------------------------------------------------------------------------------- \n\ - { \n\ - Handle (Sample2D_Rectangle) aRectangle = \n\ - new Sample2D_Rectangle(0,0, // display point \n\ - 50,80, // size \n\ - 20*PI180); // angle in radian \n\ -\n\ - aRectangle->SetHighlightMode(AIS2D_TOD_OBJECT); \n\ - myASIInteractiveContext2D->Display(aRectangle, Standard_False); // Display rectangle \n\ - } \n\ - { \n\ - Handle (Sample2D_Rectangle) aRectangle = \n\ - new Sample2D_Rectangle(80,0, // display point \n\ - 50,90, // size \n\ - 20*PI180); // angle in radian \n\ -\n\ - aRectangle2->SetHighlightMode(AIS2D_TOD_ELEMENT); //Set selection sub elements \n\ - myAISInteractiveContext2D->Display(aRectangle); // Dispaly rectangle \n\ - }\n\ - FitAll2DViews(Standard_False); // Update Viewer\n\ -\n\ ----------------------------------------------------------------- \n\ - after that the system call the SetContext Methods : \n\ ----------------------------------------------------------------- \n\ -void Sample2D_Rectangle::SetContext(const Handle(AIS2D_InteractiveContext)& theContext) \n\ -{\n\ -\n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ -\n\ - // add the polyline in the representation, for all modes\n\ - Handle(Graphic2d_Polyline) ThePolyline;\n\ - ThePolyline = new Graphic2d_Polyline(this,myArray1OfVertex );\n\ - ThePolyline->SetColorIndex ( 1 );\n\ - ThePolyline->SetWidthIndex ( 1 );\n\ - ThePolyline->SetTypeIndex ( 1 );\n\ -\n"); -Message+= "\ ------------------------------------------------------------------------------- \n\ - after on WM_MOUSEMOVE event call a method MoveTo of AIS2D_InteractiveContext \n\ - and on WM_LBUTTONUP enent call a method Select of AIS2D_InteractiveContext\n\ -------------------------------------------------------------------------------"; - - // Update The Result Dialog - UpdateResultDialog(anID,Message); + FitAll2DViews(Standard_True); // Update Viewer } void CViewer2dDoc::OnBUTTONTestCurve() { - Standard_Integer color = 1; - Standard_Integer type = 1; - Standard_Integer width = 1; - - for (Standard_Integer i=0;i<=5;i++) - for (Standard_Integer j=0;j<=5;j++) - { - Handle_Geom2d_Curve aNewCurve = GCE2d_MakeSegment ( gp_Pnt2d(10*i,10*j) , - gp_Pnt2d(10*i+5,10*j+10 )).Value() ; - Handle(Sample2D_Curve) aCurve = new Sample2D_Curve(aNewCurve); - - aCurve->SetTypeOfLineIndex(type++); - aCurve->SetWidthOfLineIndex(width++); - aCurve->SetColorIndex(color++); - - aCurve->SetHighlightMode(AIS2D_TOD_OBJECT); - - myAISInteractiveContext2D->Display(aCurve, // object - Standard_False); // Redraw - - if (type == 5) type = 1; - if (width == 9) width = 1; - if (color == 2) color = 3; // 2 = noir !! - if (color == 13) color = 1; // 13 = nbcolor by default - } - - FitAll2DViews(Standard_True); // Update Viewer - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Curve; - - TCollection_AsciiString Message(" \ -create a set of Sample2D_Curve and display it: \n\ ------------------------------------------------------------------------------- \n\ - Standard_Integer color = 1;\n\ - Standard_Integer type = 1; \n\ - Standard_Integer width = 1; \n\ -\n\ - for (Standard_Integer i=0;i<=5;i++) \n\ - for (Standard_Integer j=0;j<=5;j++)\n\ - {\n\ - Handle_Geom2d_Curve aNewCurve = GCE2d_MakeSegment ( gp_Pnt2d(10*i,10*j) , \n\ - gp_Pnt2d(10*i+5,10*j+10 )).Value() ; \n\ - Handle(Sample2D_Curve) aCurve = new Sample2D_Curve(aNewCurve);\n\ - aCurve->SetColorIndex(color++);\n\ - aCurve->SetTypeOfLineIndex(type++);\n\ - aCurve->SetWidthOfLineIndex(width++);\n\ - aCurve->SetHighlightMode(AIS2D_TOD_OBJECT); \n\ - \n\ - myAISInteractiveContext2D->Display(aCurve, // object\n\ - Standard_False); // Redraw\n\ - if (type == 5) type = 1; //Max number of types + 1\n\ - if (width == 9) width = 1; \n\ - if (color == 2) color =3; // 2 = noir !!\n\ - if (color == 13) color =1; // 13 = nbcolor by default\n\ - }\n\ ------------------------------------------------------------------------------- \n\ - after that the system call the SetContext Methods : \n\ ------------------------------------------------------------------------------- \n"); -Message += "\ -void Sample2D_Curve::Compute(const Handle(AIS2D_InteractiveContext)& theContext) \n\ -{\n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ -\n\ - Handle(Prs2d_AspectLine) aLineAspect = new Prs2d_AspectLine; \n\ - aLineAspect->SetTypeOfFill(Graphic2d_TOPF_FILLED); \n\ -\n\ - \n\ - Handle(Graphic2d_SetOfCurves) segment;\n\ - segment = new Graphic2d_SetOfCurves(this);\n\ -\n\ - segment->Add(myGeom2dCurve);\n\ - \n\ -\n\ - segment->SetColorIndex (myColorIndex);\n\ - segment->SetWidthIndex (myWidthOfLineIndex );\n\ - segment->SetTypeIndex (myTypeOfLineIndex );\n\ - \n\ - SetAspect(aLineAspect); \n\ -}\n\ -\n"; - - // Update The Result Dialog - UpdateResultDialog(anID,Message); + for(int i=0;i<=5;++i) + for(int j=0;j<=5;++j) + { + Handle(Geom_Point) aStart = new Geom_CartesianPoint(gp_Pnt(10*i,10*j,0.)); + Handle(Geom_Point) anEnd = new Geom_CartesianPoint(gp_Pnt(10*i+5,10*j+10,0.)); + Handle(AIS_Line) aLine = new AIS_Line(aStart,anEnd); + Handle(Prs3d_LineAspect) aLineAttrib = + new Prs3d_LineAspect((Quantity_NameOfColor)(Quantity_NOC_CADETBLUE+2*i+2*j), + (Aspect_TypeOfLine)((Aspect_TOL_DASH+i+j)%5),2+i+j); + aLine->Attributes()->SetLineAspect(aLineAttrib); + myAISContext->Display(aLine,Standard_False); + } + FitAll2DViews(Standard_True); } void CViewer2dDoc::OnBUTTONTestImage() @@ -813,78 +320,32 @@ void CViewer2dDoc::OnBUTTONTestImage() NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - "image Files (*.bmp , *.gif , *.xwd)|*.bmp; *.gif; *.xwd; | all files (*.*)|*.*;||", + "image Files (*.bmp , *.gif , *.jpeg, *.bmp, *.ppm, *.exr, *.tga, *.tiff, *.pgf, *.pdf)" + "|*.bmp; *.gif; *.jpeg; *.bmp; *.ppm; *.exr; *.tga; *.tiff; *.pgf; *.pdf;" + "| all files (*.*)|*.*;||", NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); initdir += "\\Data"; dlg.m_ofn.lpstrInitialDir = initdir; - - if (dlg.DoModal() == IDOK) + if(dlg.DoModal() == IDOK) { SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); CString filename = dlg.GetPathName(); - Standard_CString aFileName = (Standard_CString)(LPCTSTR)filename; + TCollection_AsciiString aFileName(filename); + + //erase viewer + if(myAISContext->HasOpenedContext()) + myAISContext->CloseAllContexts(); + myAISContext->EraseAll(); + Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - - anImage->SetCoord(0,0) ; - anImage->SetTypeOfPlacement(Aspect_CP_Center) ; - anImage->SetIsZoomable(Standard_True); - - myAISInteractiveContext2D->Display(anImage, // object - Standard_True); // Redraw - - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_Image; - TCollection_AsciiString Message(" \ -create a Sample2D_Image and display it : \n\ ------------------------------------------------------------------------------- \n\ - CFileDialog dlg(TRUE, \n\ - NULL, \n\ - NULL, \n\ - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,\n\ - \"image Files (*.bmp , *.gif , *.xwd)|*.bmp; *.gif; *.xwd; | all files (*.*)|*.*;||\", \n\ - NULL );\n\ - if (dlg.DoModal() == IDOK) \n\ - {\n\ - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT));\n\ - CString filename = dlg.GetPathName();\n\ - Standard_CString aFileName = (Standard_CString)(LPCTSTR)filename;\n\ - Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName);\n\ -\n\ - anImage->SetCoord(0,0) ;\n\ - anImage->SetTypeOfPlacement(Aspect_CP_Center) ;\n\ - anImage->SetIsZoomable(Standard_True);\n\ -\n\ - myAISInteractiveContext2D->Display(anImage, // Display object\n\ - Standard_True); \n\ - }\n\ ------------------------------------------------------------------------------- \n\ - after that the system call the SetContext method : \n\ ------------------------------------------------------------------------------- \n\ -void Sample2D_Image::SetContext(const Handle(AIS2D_InteractiveContext) theContext)) \n\ -{\n\ - //Set AIS2D_InteractiveContext and default Graphic2d_View \n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ - Graphic2d_GraphicObject::SetView(theContext->CurrentViewer()->View()); \n\ -\n\ - Handle(GraphicSample2D_ImageFile) aGraphic2dImageFile =\n\ - new GraphicSample2D_ImageFile (aGrObj,\n\ - myFile,\n\ - myX, \n\ - myY,\n\ - myDx,\n\ - myDy,\n\ - myTypeOfPlacement,\n\ - myScale); \n\ - if (myIsZoomable)\n\ - aGraphic2dImageFile->SetZoomable(Standard_True);\n\ -}\n\n"); - - // Update The Result Dialog - UpdateResultDialog(filename,Message); + anImage->SetCoord(40,50) ; + anImage->SetScale(1.0); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); + FitAll2DViews(Standard_True); } } @@ -894,148 +355,75 @@ void CViewer2dDoc::OnBUTTONMultipleImage() NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - "image Files (*.bmp , *.gif , *.xwd)|*.bmp; *.gif; *.xwd; | all files (*.*)|*.*;||", + "image Files (*.bmp , *.gif , *.jpeg, *.bmp, *.ppm, *.exr, *.tga, *.tiff, *.pgf, *.pdf)" + "|*.bmp; *.gif; *.jpeg; *.bmp; *.ppm; *.exr; *.tga; *.tiff; *.pgf; *.pdf;" + "| all files (*.*)|*.*;||", NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); initdir += "\\Data"; dlg.m_ofn.lpstrInitialDir = initdir; - + if (dlg.DoModal() == IDOK) { SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); CString filename = dlg.GetPathName(); - Standard_CString aFileName = (Standard_CString)(LPCTSTR)filename; + TCollection_AsciiString aFileName(filename); + //erase viewer + if(myAISContext->HasOpenedContext()) + myAISContext->CloseAllContexts(); + myAISContext->EraseAll(); + //create images { // 1 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(40,50) ; - anImage->SetTypeOfPlacement(Aspect_CP_SouthEast) ; - anImage->SetIsZoomable(Standard_True); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + anImage->SetScale(0.5); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } { // 2 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(50,50) ; - anImage->SetTypeOfPlacement(Aspect_CP_SouthWest) ; - anImage->SetIsZoomable(Standard_True); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + anImage->SetCoord(100,50) ; + anImage->SetScale(0.9); + myAISContext->Display(anImage,Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } { // 3 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(40,40) ; - anImage->SetTypeOfPlacement(Aspect_CP_NorthEast) ; - anImage->SetIsZoomable(Standard_True); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + anImage->SetScale(0.3); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } { // 4 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(50,40) ; - anImage->SetTypeOfPlacement(Aspect_CP_NorthWest) ; - anImage->SetIsZoomable(Standard_True); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } { // 5 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(80,45) ; - anImage->SetTypeOfPlacement(Aspect_CP_West) ; - anImage->SetIsZoomable(Standard_True); - anImage->SetScale(2); - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + anImage->SetScale(2); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } - { // 6 : Non Zoomable + { // 6 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(20,-20) ; - anImage->SetTypeOfPlacement(Aspect_CP_NorthWest) ; - - anImage->SetIsZoomable(Standard_False); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } - { // 7 : Non Zoomable + { // 7 Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); - anImage->SetCoord(0,0) ; - anImage->SetOffset(60,-20) ; // new zoom center - anImage->SetTypeOfPlacement(Aspect_CP_NorthWest) ; - anImage->SetScale(0.5); - anImage->SetIsZoomable(Standard_False); - - myAISInteractiveContext2D->Display(anImage, // Display object - Standard_False); + anImage->SetScale(0.5); + myAISContext->Display(anImage, Standard_False); + myAISContext->SetDisplayMode(anImage,3,Standard_False); } FitAll2DViews(Standard_True); // Update Viewer - // Update Get information to update Result dialog - - UINT anID=ID_BUTTON_Test_MultiImages; - TCollection_AsciiString Message(" \ -create a set of Sample2D_Image and display it : \n\ ------------------------------------------------------------------------------- \n\ - CFileDialog dlg(TRUE, \n\ - NULL, \n\ - NULL, \n\ - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, \n\ - \"image Files (*.bmp , *.gif , *.xwd)|*.bmp; *.gif; *.xwd; | all files (*.*)|*.*;||\", \n\ - NULL ); \n\ - if (dlg.DoModal() == IDOK) \n\ - { \n\ - SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT)); \n\ - CString filename = dlg.GetPathName(); \n\ - Standard_CString aFileName = (Standard_CString)(LPCTSTR)filename; \n\ - { // 1 \n\ - Handle(Sample2D_Image) anImage = new Sample2D_Image(aFileName); \n\ - \n\ - anImage->SetCoord(40,50) ; \n\ - anImage->SetTypeOfPlacement(Aspect_CP_SouthEast) ; \n\ - anImage->SetIsZoomable(Standard_True); \n\ - \n\ - myAISInteractiveContext2D->Display(anImage, // object \n\ - Standard_False); // Redraw \n\ - } \n\ - //... \n\ -} \n\ ------------------------------------------------------------------------------- \n\ - after that the system call the SetContext Methods : \n\ ------------------------------------------------------------------------------- \n\ -void Sample2D_Image::SetContext(const Handle(AIS2D_InteractiveContext) theContext)) \n\ -{\n\ -\n\ - if(theContext.IsNull() || theContext->CurrentViewer().IsNull()) return; \n\ -\n\ - //Set AIS2D_InteractiveContext and default Graphic2d_View \n\ - AIS2D_InteractiveObject::SetContext(theContext); \n\ - Graphic2d_GraphicObject::SetView(theContext->CurrentViewer()->View()); \n\ -\n\ - Handle(GraphicSample2D_ImageFile) aGraphic2dImageFile =\n\ - new GraphicSample2D_ImageFile (aGrObj,\n\ - myFile,\n\ - myX, \n\ - myY,\n\ - myDx,\n\ - myDy,\n\ - myTypeOfPlacement,\n\ - myScale); \n\ - if (myIsZoomable)\n\ - aGraphic2dImageFile->SetZoomable(Standard_True);\n\ -}\n\n"); - // Update The Result Dialog - UpdateResultDialog(filename,Message); } } diff --git a/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.h b/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.h index 6835997893..d582087f42 100755 --- a/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.h +++ b/samples/mfc/standard/03_Viewer2d/src/Viewer2dDoc.h @@ -2,6 +2,9 @@ // ///////////////////////////////////////////////////////////////////////////// +#include +#include +#include #include "OCC_2dDoc.h" @@ -24,12 +27,11 @@ protected: // Generated message map functions protected: //{{AFX_MSG(CViewer2dDoc) - afx_msg void OnBUTTONTest2DProperties(); afx_msg void OnBUTTONTestText(); afx_msg void OnBUTTONTestMarkers(); afx_msg void OnBUTTONTestLine(); afx_msg void OnBUTTONErase(); - afx_msg void OnBUTTONTestFase(); + afx_msg void OnBUTTONTestFace(); afx_msg void OnBUTTONTestRect(); afx_msg void OnBUTTONTestCurve(); afx_msg void OnBUTTONTestImage(); diff --git a/samples/mfc/standard/04_Viewer3d/adm/win/vc10/Viewer3d.vcxproj b/samples/mfc/standard/04_Viewer3d/adm/win/vc10/Viewer3d.vcxproj index 15fde70917..16ae19f6fc 100644 --- a/samples/mfc/standard/04_Viewer3d/adm/win/vc10/Viewer3d.vcxproj +++ b/samples/mfc/standard/04_Viewer3d/adm/win/vc10/Viewer3d.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Viewer3d.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Viewer3d.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -196,7 +196,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Viewer3d.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -239,7 +239,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/Viewer3d.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/04_Viewer3d/adm/win/vc11/Viewer3d.vcxproj b/samples/mfc/standard/04_Viewer3d/adm/win/vc11/Viewer3d.vcxproj index a2681d07a0..8ccfddd1e2 100644 --- a/samples/mfc/standard/04_Viewer3d/adm/win/vc11/Viewer3d.vcxproj +++ b/samples/mfc/standard/04_Viewer3d/adm/win/vc11/Viewer3d.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Viewer3d.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Viewer3d.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -200,7 +200,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Viewer3d.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -243,7 +243,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/Viewer3d.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/04_Viewer3d/adm/win/vc8/Viewer3d.vcproj b/samples/mfc/standard/04_Viewer3d/adm/win/vc8/Viewer3d.vcproj index 1492bdf6ce..ee39dbd47b 100644 --- a/samples/mfc/standard/04_Viewer3d/adm/win/vc8/Viewer3d.vcproj +++ b/samples/mfc/standard/04_Viewer3d/adm/win/vc8/Viewer3d.vcproj @@ -81,7 +81,7 @@ /> GetInitDataDir()); + CString initfile(((OCC_App*) AfxGetApp())->GetInitDataDir()); initfile += "\\Data\\"; if (!aTFileName.IsIntegerValue()) { @@ -174,7 +174,7 @@ Standard_Boolean TexturesExt_Presentation::loadShape(TopoDS_Shape& aShape, TCollection_AsciiString aFileName) { // create a TopoDS_Shape -> read from a brep file - CString initfile(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initfile(((OCC_App*) AfxGetApp())->GetInitDataDir()); initfile += "\\Data\\"; initfile += aFileName.ToCString(); diff --git a/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.cpp b/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.cpp index b2a025fb22..1cdb61ca76 100755 --- a/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.cpp +++ b/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.cpp @@ -26,9 +26,9 @@ END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CViewer3dApp construction -CViewer3dApp::CViewer3dApp() +CViewer3dApp::CViewer3dApp() : OCC_App() { - SampleName = "Viewer3d"; //for about dialog + SampleName = "Viewer3d"; //for about dialog } ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.h b/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.h index 8b0f83995f..31459e5184 100755 --- a/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.h +++ b/samples/mfc/standard/04_Viewer3d/src/Viewer3dApp.h @@ -8,24 +8,24 @@ #pragma once #endif // _MSC_VER >= 1000 -#include +#include -class CViewer3dApp : public OCC_3dApp +class CViewer3dApp : public OCC_App { public: - CViewer3dApp(); + + CViewer3dApp(); // Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CViewer3dApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CViewer3dApp) + public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL - DECLARE_MESSAGE_MAP() + DECLARE_MESSAGE_MAP() }; - ///////////////////////////////////////////////////////////////////////////// //{{AFX_INSERT_LOCATION}} diff --git a/samples/mfc/standard/04_Viewer3d/src/Viewer3dDoc.cpp b/samples/mfc/standard/04_Viewer3d/src/Viewer3dDoc.cpp index 021bd182ac..7ffd698099 100755 --- a/samples/mfc/standard/04_Viewer3d/src/Viewer3dDoc.cpp +++ b/samples/mfc/standard/04_Viewer3d/src/Viewer3dDoc.cpp @@ -460,7 +460,6 @@ void CViewer3dDoc::OnObjectErase() OCC_3dBaseDoc::OnObjectErase(); if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) myOffsetDlg->UpdateValues(); - } void CViewer3dDoc::OnObjectDisplayall() @@ -469,7 +468,6 @@ void CViewer3dDoc::OnObjectDisplayall() OCC_3dBaseDoc::OnObjectDisplayall(); if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) myOffsetDlg->UpdateValues(); - } Handle_User_Cylinder CViewer3dDoc::GetCylinder() @@ -521,77 +519,85 @@ void CViewer3dDoc::InputEvent(const Standard_Integer x , const Standard_Integer y , const Handle(V3d_View)& aView ) { - if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) - myOffsetDlg->UpdateValues(); + if (myOffsetDlg && myOffsetDlg->IsWindowVisible()) + myOffsetDlg->UpdateValues(); - Quantity_Color CSFColor ; - COLORREF MSColor ; - myAISContext->Select(); -// Change the color of a selected face in a user cylinder - if (myState == FACE_COLOR) { - myAISContext->InitSelected(); - if (myAISContext->MoreSelected()) { - //Handle_AIS_InteractiveObject Current = myAISContext->Current() ; - Handle_AIS_InteractiveObject Current = myAISContext->SelectedInteractive() ; - if ( Current->HasColor () ) { - CSFColor = myAISContext->Color(Current); - MSColor = RGB (CSFColor.Red()*255.,CSFColor.Green()*255.,CSFColor.Blue()*255.); - } - else { - MSColor = RGB ( 255,255,255 ) ; - } - - CColorDialog dlgColor(MSColor); - if (dlgColor.DoModal() == IDOK) { - MSColor = dlgColor.GetColor(); - CSFColor = Quantity_Color (GetRValue(MSColor)/255., - GetGValue(MSColor)/255., - GetBValue(MSColor)/255.,Quantity_TOC_RGB); - TopoDS_Shape S = myAISContext->SelectedShape(); - Handle(Geom_Surface) Surface = BRep_Tool::Surface(TopoDS::Face(S)); - if (Surface->IsKind(STANDARD_TYPE(Geom_Plane))) - //Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetPlanarFaceColor(CSFColor.Name()); - Handle(User_Cylinder)::DownCast(myAISContext->SelectedInteractive())->SetPlanarFaceColor(CSFColor.Name()); - else - //Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetCylindricalFaceColor(CSFColor.Name()); - Handle(User_Cylinder)::DownCast(myAISContext->SelectedInteractive())->SetCylindricalFaceColor(CSFColor.Name()); - //myAISContext->Redisplay(myAISContext->Current()); - myAISContext->Redisplay(myAISContext->SelectedInteractive()); - myState = -1; - myAISContext->CloseLocalContext(); - } - } - TCollection_AsciiString Message ("\ - TopoDS_Shape S = myAISContext->SelectedShape(); \n\ - \n\ - Handle(Geom_Surface) Surface = BRep_Tool::Surface(TopoDS::Face(S)); \n\ - \n\ - if (Surface->IsKind(STANDARD_TYPE(Geom_Plane))) \n\ - Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetPlanarFaceColor(CSFColor.Name()); \n\ - else \n\ - Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetCylindricalFaceColor(CSFColor.Name()); \n\ - \n\ - myAISContext->Redisplay(myAISContext->Current()); \n\ - \n\ - myAISContext->CloseLocalContext(); \n\ - \n\ - \n\ - NOTE: a User_Cylinder is an object defined by the user. \n\ - The User_Cylinder class inherit from the AIS_InteractiveObject \n\ - Cascade class, it's use is the same as an AIS_InteractiveObject. \n\ - Methods SetPlanarFaceColor and SetCylindricalFaceColor are also \n\ - defined in the User_Cylinder class. \n\ - \n"); - - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Change face color")); - myCResultDialog.SetText(text); - SetTitle(CString("Change face color")); - - } + Quantity_Color CSFColor; + COLORREF MSColor; + myAISContext->Select(); + + // Change the color of a selected face in a user cylinder + if (myState == FACE_COLOR) + { + myAISContext->InitSelected(); + if (myAISContext->MoreSelected()) + { + Handle_AIS_InteractiveObject Current = myAISContext->SelectedInteractive(); + if (Current->HasColor()) + { + CSFColor = myAISContext->Color (Current); + MSColor = RGB (CSFColor.Red()*255.0, CSFColor.Green()*255.0, CSFColor.Blue()*255.0); + } + else + { + MSColor = RGB (255, 255, 255); + } + + CColorDialog dlgColor(MSColor); + if (dlgColor.DoModal() == IDOK) + { + MSColor = dlgColor.GetColor(); + CSFColor = Quantity_Color (GetRValue (MSColor)/255.0, + GetGValue (MSColor)/255.0, + GetBValue (MSColor)/255.0, + Quantity_TOC_RGB); + + TopoDS_Shape S = myAISContext->SelectedShape(); + Handle(Geom_Surface) Surface = BRep_Tool::Surface (TopoDS::Face(S)); + if (Surface->IsKind (STANDARD_TYPE (Geom_Plane))) + { + Handle(User_Cylinder)::DownCast (myAISContext->SelectedInteractive()) + ->SetPlanarFaceColor (CSFColor.Name()); + } + else + { + Handle(User_Cylinder)::DownCast (myAISContext->SelectedInteractive()) + ->SetCylindricalFaceColor (CSFColor.Name()); + } + + myAISContext->Redisplay (myAISContext->SelectedInteractive()); + myState = -1; + myAISContext->CloseLocalContext(); + } + } + + TCollection_AsciiString aMessage (" TopoDS_Shape S = myAISContext->SelectedShape(); \n" + " \n" + " Handle(Geom_Surface) Surface = BRep_Tool::Surface(TopoDS::Face(S));" + " if (Surface->IsKind(STANDARD_TYPE(Geom_Plane))) \n" + " Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetPlanarFaceColor(CSFColor.Name()); \n" + " else \n" + " Handle(User_Cylinder)::DownCast(myAISContext->Current())->SetCylindricalFaceColor(CSFColor.Name()); \n" + " \n" + " myAISContext->Redisplay(myAISContext->Current()); \n" + " \n" + " myAISContext->CloseLocalContext(); \n" + " \n" + " \n" + " NOTE: a User_Cylinder is an object defined by the user. \n" + " The User_Cylinder class inherit from the AIS_InteractiveObject \n" + " Cascade class, it's use is the same as an AIS_InteractiveObject. \n" + " Methods SetPlanarFaceColor and SetCylindricalFaceColor are also \n" + " defined in the User_Cylinder class. \n" + " \n"); + + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Change face color")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Change face color")); + } } - //----------------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------------- @@ -600,9 +606,9 @@ void CViewer3dDoc::ShiftDragEvent(const Standard_Integer x , const Standard_Integer TheState , const Handle(V3d_View)& aView ) { - OCC_3dBaseDoc::ShiftDragEvent(x,y,TheState,aView); - if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) - myOffsetDlg->UpdateValues(); + OCC_3dBaseDoc::ShiftDragEvent(x,y,TheState,aView); + if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) + myOffsetDlg->UpdateValues(); } @@ -614,33 +620,29 @@ void CViewer3dDoc::ShiftInputEvent(const Standard_Integer x , const Standard_Integer y , const Handle(V3d_View)& aView ) { - OCC_3dBaseDoc::ShiftInputEvent(x,y,aView); - if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) - myOffsetDlg->UpdateValues(); - + OCC_3dBaseDoc::ShiftInputEvent(x,y,aView); + if(myOffsetDlg && myOffsetDlg->IsWindowVisible()) + myOffsetDlg->UpdateValues(); } void CViewer3dDoc::OnObjectColoredMesh() { for(myAISContext->InitCurrent();myAISContext->MoreCurrent();myAISContext->NextCurrent()) - if (myAISContext->Current()->IsKind(STANDARD_TYPE(User_Cylinder))){ - myAISContext->ClearPrs(myAISContext->Current(),6,Standard_False); - myAISContext->RecomputePrsOnly(myAISContext->Current(),Standard_False); - myAISContext->SetDisplayMode(myAISContext->Current(),6); - } - + if (myAISContext->Current()->IsKind(STANDARD_TYPE(User_Cylinder))) + { + myAISContext->ClearPrs(myAISContext->Current(),6,Standard_False); + myAISContext->RecomputePrsOnly(myAISContext->Current(),Standard_False); + myAISContext->SetDisplayMode(myAISContext->Current(),6); + } } void CViewer3dDoc::OnUpdateObjectColoredMesh(CCmdUI* pCmdUI) { bool CylinderIsCurrentAndDisplayed = false; for (myAISContext->InitCurrent();myAISContext->MoreCurrent ();myAISContext->NextCurrent ()) - //if ((myAISContext->IsDisplayed(myAISContext->Current(),1) || myAISContext->IsDisplayed(myAISContext->Current(),0)) - // && myAISContext->Current()->IsKind(STANDARD_TYPE(User_Cylinder))) if(myAISContext->Current()->IsKind(STANDARD_TYPE(User_Cylinder))) CylinderIsCurrentAndDisplayed=true; pCmdUI->Enable (CylinderIsCurrentAndDisplayed); - } void CViewer3dDoc::OnUpdateObjectWireframe(CCmdUI* pCmdUI) @@ -700,19 +702,6 @@ void CViewer3dDoc::OnUpdateOptionsTrihedronStaticTrihedron(CCmdUI* pCmdUI) } -/* -void CViewer3dDoc::OnUpdateObjectColor(CCmdUI* pCmdUI) -{ - bool OneOrMoreInShadingOrWireframe = false; - for (myAISContext->InitCurrent();myAISContext->MoreCurrent ();myAISContext->NextCurrent ()) - if (myAISContext->IsDisplayed(myAISContext->Current(),1) - || myAISContext->IsDisplayed(myAISContext->Current(),0)) - OneOrMoreInShadingOrWireframe = true; - pCmdUI->Enable (OneOrMoreInShadingOrWireframe); - -} -*/ - void CViewer3dDoc::Popup( const Standard_Integer x, const Standard_Integer y , const Handle(V3d_View)& aView ) @@ -747,85 +736,82 @@ void CViewer3dDoc::Popup( const Standard_Integer x, pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON , winCoord.x, winCoord.y , AfxGetMainWnd()); } + //Set faces selection mode void CViewer3dDoc::OnFaces() { - myAISContext->CloseAllContexts(); - myAISContext->OpenLocalContext(); - myAISContext->ActivateStandardMode(TopAbs_FACE); + myAISContext->CloseAllContexts(); + myAISContext->OpenLocalContext(); + myAISContext->ActivateStandardMode (TopAbs_FACE); -TCollection_AsciiString Message ("\ -myAISContext->OpenLocalContext(); \n\ -\n\ -myAISContext->ActivateStandardMode(TopAbs_FACE); \n\ -\n"); + TCollection_AsciiString aMessage (" myAISContext->OpenLocalContext(); \n" + " \n" + " myAISContext->ActivateStandardMode(TopAbs_FACE); \n" + " \n"); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Standard mode: TopAbs_FACE")); - myCResultDialog.SetText(text); - SetTitle(CString("Standard mode: TopAbs_FACE")); + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString("Standard mode: TopAbs_FACE")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Standard mode: TopAbs_FACE")); } //Set edges selection mode void CViewer3dDoc::OnEdges() { - myAISContext->CloseAllContexts(); - myAISContext->OpenLocalContext(); - myAISContext->ActivateStandardMode(TopAbs_EDGE); + myAISContext->CloseAllContexts(); + myAISContext->OpenLocalContext(); + myAISContext->ActivateStandardMode(TopAbs_EDGE); -TCollection_AsciiString Message ("\ -myAISContext->OpenLocalContext(); \n\ -\n\ -myAISContext->ActivateStandardMode(TopAbs_EDGE); \n\ -\n"); + TCollection_AsciiString aMessage (" myAISContext->OpenLocalContext(); \n" + " \n" + " myAISContext->ActivateStandardMode(TopAbs_EDGE); \n" + " \n"); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Standard mode: TopAbs_EDGE")); - myCResultDialog.SetText(text); - SetTitle(CString("Standard mode: TopAbs_EDGE")); + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Standard mode: TopAbs_EDGE")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Standard mode: TopAbs_EDGE")); } // Set vertices selection mode void CViewer3dDoc::OnVertices() { - myAISContext->CloseAllContexts(); - myAISContext->OpenLocalContext(); - myAISContext->ActivateStandardMode(TopAbs_VERTEX); + myAISContext->CloseAllContexts(); + myAISContext->OpenLocalContext(); + myAISContext->ActivateStandardMode (TopAbs_VERTEX); -TCollection_AsciiString Message ("\ -myAISContext->OpenLocalContext(); \n\ -\n\ -myAISContext->ActivateStandardMode(TopAbs_VERTEX); \n\ -\n"); + TCollection_AsciiString aMessage (" myAISContext->OpenLocalContext(); \n" + " \n" + " myAISContext->ActivateStandardMode(TopAbs_VERTEX); \n" + " \n"); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Standard mode: TopAbs_VERTEX")); - myCResultDialog.SetText(text); - SetTitle(CString("Standard mode: TopAbs_VERTEX")); + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Standard mode: TopAbs_VERTEX")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Standard mode: TopAbs_VERTEX")); } //Neutral selection mode void CViewer3dDoc::OnNeutral() { - myAISContext->CloseAllContexts(); + myAISContext->CloseAllContexts(); -TCollection_AsciiString Message ("\ -myAISContext->CloseAllContexts(); \n\ -\n"); + TCollection_AsciiString aMessage (" myAISContext->CloseAllContexts(); \n" + " \n"); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Standard mode: Neutral")); - myCResultDialog.SetText(text); - SetTitle(CString("Standard mode: Neutral")); + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Standard mode: Neutral")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Standard mode: Neutral")); } // Change the color of faces on a user cylinder void CViewer3dDoc::OnUsercylinderChangefacecolor() { - myAISContext->OpenLocalContext(); - myAISContext->Activate(myAISContext->Current(),4); - myState = FACE_COLOR; -// see the following of treatment in inputevent + myAISContext->OpenLocalContext(); + myAISContext->Activate(myAISContext->Current(),4); + myState = FACE_COLOR; + // see the following of treatment in inputevent } // Make 3d fillets on solids @@ -833,167 +819,170 @@ void CViewer3dDoc::OnUsercylinderChangefacecolor() // before running this function void CViewer3dDoc::OnFillet3d() { - if( !myAISContext->HasOpenedContext()) + if (!myAISContext->HasOpenedContext()) + { + AfxMessageBox("It is necessary to activate the edges selection mode\n" + "and select edges on an object before \nrunning this function"); + return; + } + + myAISContext->InitSelected(); + if (myAISContext->MoreSelected()) + { + Handle(AIS_Shape) S = Handle(AIS_Shape)::DownCast (myAISContext->SelectedInteractive()); + + if (S.IsNull()) { - AfxMessageBox("It is necessary to activate the edges selection mode\n\ -and select edges on an object before \nrunning this function"); - return; + AfxMessageBox("It is necessary to activate the edges selection mode\n" + "and select edges on an object before \nrunning this function"); + return; } - - myAISContext->InitSelected(); - if (myAISContext->MoreSelected()) { - Handle(AIS_Shape) S = Handle(AIS_Shape)::DownCast(myAISContext->SelectedInteractive()); - - if (S.IsNull()){ - AfxMessageBox("It is necessary to activate the edges selection mode\n\ -and select edges on an object before \nrunning this function"); - return; - } - - TopoDS_Shape Sh=S->Shape(); - - BRepFilletAPI_MakeFillet aFillet(Sh); - - for (myAISContext->InitSelected(); myAISContext->MoreSelected(); myAISContext->NextSelected()) - { - TopoDS_Edge anEdge; - try { - anEdge=TopoDS::Edge(myAISContext->SelectedShape()); - } - catch(Standard_Failure) - { - } - - if (anEdge.IsNull()) - { - AfxMessageBox("It is necessary to activate the edges selection mode\n\ -and select edges on an object before \nrunning this function"); - return; - } - } - BoxRadius dlg(NULL,10.); - if (dlg.DoModal() == IDOK){ - for (myAISContext->InitSelected(); myAISContext->MoreSelected(); myAISContext->NextSelected()){ - TopoDS_Edge anEdge = TopoDS::Edge(myAISContext->SelectedShape()); - aFillet.Add(dlg.m_radius,anEdge); - } - } - else return; + TopoDS_Shape Sh=S->Shape(); - TopoDS_Shape aNewShape; -// if(!aFillet.IsDone()) - try{ - aNewShape = aFillet.Shape(); - } - catch(Standard_Failure) - { - AfxMessageBox("Error During Fillet computation"); - return; - } - S ->Set(aNewShape); - myAISContext->Redisplay(S); - - } -TCollection_AsciiString Message ("\ -Handle(AIS_Shape) S = Handle(AIS_Shape)::DownCast(myAISContext->Interactive()); \n\ -\n\ -BRepAPI_MakeFillet aFillet(S->Shape()); \n\ -\n\ -TopoDS_Edge anEdge=TopoDS::Edge(myAISContext->SelectedShape()); \n\ -\n\ -aFillet.Add(dlg.m_radius,anEdge); \n\ -\n\ -TopoDS_Shape aNewShape = aFillet.Shape(); \n\ -\n\ -S ->Set(aNewShape); \n\ -\n\ -myAISContext->Redisplay(S); \n\ -\n"); + BRepFilletAPI_MakeFillet aFillet(Sh); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Make a fillet")); - myCResultDialog.SetText(text); - SetTitle(CString("Make a fillet")); + for (myAISContext->InitSelected(); myAISContext->MoreSelected(); myAISContext->NextSelected()) + { + TopoDS_Shape aSelShape = myAISContext->SelectedShape(); + if (aSelShape.ShapeType() != TopAbs_EDGE) + { + AfxMessageBox("It is necessary to activate the edges selection mode\n\ + and select edges on an object before \nrunning this function"); + return; + } + } + + BoxRadius dlg(NULL,10.); + if (dlg.DoModal() == IDOK) + { + for (myAISContext->InitSelected(); myAISContext->MoreSelected(); myAISContext->NextSelected()) + { + TopoDS_Edge anEdge = TopoDS::Edge(myAISContext->SelectedShape()); + aFillet.Add(dlg.m_radius,anEdge); + } + } + else + { + return; + } + + TopoDS_Shape aNewShape; + try + { + aNewShape = aFillet.Shape(); + } + catch (Standard_Failure) + { + AfxMessageBox("Error During Fillet computation"); + return; + } + + S ->Set (aNewShape); + myAISContext->Redisplay (S); + } + + TCollection_AsciiString aMessage (" Handle(AIS_Shape) S = Handle(AIS_Shape)::DownCast(myAISContext->Interactive()); \n" + " \n" + " BRepAPI_MakeFillet aFillet(S->Shape()); \n" + " \n" + " TopoDS_Edge anEdge=TopoDS::Edge(myAISContext->SelectedShape()); \n" + " \n" + " aFillet.Add(dlg.m_radius,anEdge); \n" + " \n" + " TopoDS_Shape aNewShape = aFillet.Shape(); \n" + " \n" + " S->Set(aNewShape); \n" + " \n" + " myAISContext->Redisplay(S); \n" + " \n"); + + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Make a fillet")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Make a fillet")); } + // Create and display a circle with standard tools void CViewer3dDoc::OnCircle() { - gp_Ax2 ax2(gp_Pnt(0., 0., 0.), gp_Dir(0., 0., -1.)); - Handle(Geom_Circle) C = new Geom_Circle(ax2, 300); -// GC_MakeCircle C(gp_Pnt(-100.,-300.,0.),gp_Pnt(-50.,-200.,0.),gp_Pnt(-10.,-250.,0.)); -// Handle(AIS_Circle) anAISCirc = new AIS_Circle(C.Value()); - Handle(AIS_Circle) anAISCirc = new AIS_Circle(C); - myAISContext->Display(anAISCirc); + gp_Ax2 anAx2 (gp_Pnt (0., 0., 0.), gp_Dir(0., 0., -1.)); + Handle(Geom_Circle) aGeomCircle = new Geom_Circle (anAx2, 300); -TCollection_AsciiString Message ("\ -GC_MakeCircle C(gp_Pnt(-100.,-300.,0.),gp_Pnt(-50.,-200.,0.),gp_Pnt(-10.,-250.,0.)); \n\ -\n\ -Handle(AIS_Circle) anAISCirc = new AIS_Circle(C.Value()); \n\ -\n\ -myAISContext->Display(anAISCirc); \n\ -\n"); + // the lines above substitute + // GC_MakeCircle C(gp_Pnt(-100.,-300.,0.),gp_Pnt(-50.,-200.,0.),gp_Pnt(-10.,-250.,0.)); + // Handle(AIS_Circle) anAISCirc = new AIS_Circle(C.Value()); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Create a circle")); - myCResultDialog.SetText(text); - SetTitle(CString("Create a circle")); + Handle(AIS_Circle) anAISCirc = new AIS_Circle(aGeomCircle); + myAISContext->Display (anAISCirc); + + TCollection_AsciiString aMessage (" GC_MakeCircle C(gp_Pnt(-100.,-300.,0.),gp_Pnt(-50.,-200.,0.),gp_Pnt(-10.,-250.,0.)); \n" + " \n" + " Handle(AIS_Circle) anAISCirc = new AIS_Circle(C.Value()); \n" + " \n" + " myAISContext->Display(anAISCirc); \n" + " \n"); + + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString ("Create a circle")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Create a circle")); } void CViewer3dDoc::OnLine() { - // TODO: Add your command handler code here - gp_Lin L(gp_Pnt(0.,0.,0.),gp_Dir(1.,0.,0.)); - Handle(Geom_Line) aLine = new Geom_Line(L); - Handle(AIS_Line) anAISLine = new AIS_Line(aLine); - myAISContext->Display(anAISLine); + // TODO: Add your command handler code here + gp_Lin aGpLin (gp_Pnt (0., 0., 0.), gp_Dir(1., 0., 0.)); + Handle(Geom_Line) aGeomLin = new Geom_Line (aGpLin); + Handle(AIS_Line) anAISLine = new AIS_Line (aGeomLin); + myAISContext->Display (anAISLine); -TCollection_AsciiString Message ("\ -gp_Lin L(gp_Pnt(0.,0.,0.),gp_Dir(1.,0.,0.)); \n\ -\n\ -Handle(Geom_Line) aLine = new Geom_Line(L); \n\ -\n\ -Handle(AIS_Line) anAISLine = new AIS_Line(aLine); \n\ -\n\ -myAISContext->Display(anAISLine); \n\ -\n"); + TCollection_AsciiString aMessage (" gp_Lin L(gp_Pnt(0.,0.,0.),gp_Dir(1.,0.,0.)); \n" + " \n" + " Handle(Geom_Line) aLine = new Geom_Line(L); \n" + " \n" + " Handle(AIS_Line) anAISLine = new AIS_Line(aLine); \n" + " \n" + " myAISContext->Display(anAISLine); \n" + " \n"); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Create a line")); - myCResultDialog.SetText(text); - SetTitle(CString("Create a line")); + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString("Create a line")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Create a line")); } void CViewer3dDoc::OnNbisos() { - int nu = myAISContext->DefaultDrawer()->UIsoAspect()->Number(); - int nv = myAISContext->DefaultDrawer()->VIsoAspect()->Number(); - DlgIsos dlg(NULL,nu,nv); - if (dlg.DoModal() == IDOK) { - myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber(dlg.m_isou); - myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(dlg.m_isov); + int aNumU = myAISContext->DefaultDrawer()->UIsoAspect()->Number(); + int aNumV = myAISContext->DefaultDrawer()->VIsoAspect()->Number(); -TCollection_AsciiString Message ("\ -myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber(dlg.m_isou); \n\ -\n\ -myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(dlg.m_isov); \n\ -\n"); + DlgIsos aDlg (NULL, aNumU, aNumV); - CString text(Message.ToCString()); - myCResultDialog.SetTitle(CString("Iso Aspect")); - myCResultDialog.SetText(text); - SetTitle(CString("Iso Aspect")); + if (aDlg.DoModal() == IDOK) + { + myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber (aDlg.m_isou); + myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber (aDlg.m_isov); - } + TCollection_AsciiString aMessage (" myAISContext->DefaultDrawer()->UIsoAspect()->SetNumber(dlg.m_isou); \n" + " \n" + " myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(dlg.m_isov); \n" + " \n"); + + CString aMsgStr (aMessage.ToCString()); + myCResultDialog.SetTitle (CString("Iso Aspect")); + myCResultDialog.SetText (aMsgStr); + SetTitle (CString ("Iso Aspect")); + } } BOOL CViewer3dDoc::OnNewDocument() { - if (!CDocument::OnNewDocument()) - return FALSE; + if (!CDocument::OnNewDocument()) + return FALSE; - // TODO: add reinitialization code here - // (SDI documents will reuse this document) + // TODO: add reinitialization code here + // (SDI documents will reuse this document) SetTitle(myPresentation->GetName()); myAISContext->EraseAll(Standard_False); @@ -1006,7 +995,7 @@ BOOL CViewer3dDoc::OnNewDocument() pView->Reset(); } - return TRUE; + return TRUE; } void CViewer3dDoc::OnFileNew() @@ -1048,7 +1037,7 @@ void CViewer3dDoc::DoSample() Standard_SStream aSStream; aSStream << "An exception was caught: " << Standard_Failure::Caught() << ends; Standard_CString aMsg = aSStream.str().c_str(); -// aSStream.rdbuf()->freeze(0); // allow deletion of dynamic array + // aSStream.rdbuf()->freeze(0); // allow deletion of dynamic array AfxMessageBox (aMsg); } } @@ -1125,39 +1114,28 @@ void CViewer3dDoc::OnUpdateBUTTONEnd(CCmdUI* pCmdUI) void CViewer3dDoc::OnDumpView() { - // save current directory and restore it on exit - char aCurPath[MAX_PATH]; - ::GetCurrentDirectory(MAX_PATH, aCurPath); - - ::SetCurrentDirectory(myLastPath); - - CFileDialog *aDlg = new CFileDialog(false, "gif", "OCCView.gif", - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, "GIF Files (*.gif)|*.gif||", NULL); - - int result = aDlg->DoModal(); - if ( result == IDOK) + CFileDialog aDlg (false, "gif", "OCCView.gif", OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, + "GIF Files (*.GIF)|*.gif|" + "BMP Files (*.BMP)|*.bmp|" + "PNG Files (*.PNG)|*.png|" + "JPEG Files (*.JPG)|*.jpg|" + "PPM Files (*.PPM)|*.ppm|" + "TIFF Files (*.TIFF)|*.tiff|" + "TGA Files (*.TGA)|*.tga|" + "EXR Files (*.EXR)|*.exr||", NULL); + if (aDlg.DoModal() != IDOK) { - CString aFileName = aDlg->GetFileName(); - delete aDlg; - - POSITION pos = GetFirstViewPosition(); - while (pos != NULL) - { - CViewer3dView* pView = (CViewer3dView*) GetNextView(pos); - pView->UpdateWindow(); - } - - myViewer->InitActiveViews(); - Handle(V3d_View) aView = myViewer->ActiveView(); - char aStrFileName[MAX_PATH]; - strcpy_s(aStrFileName, aFileName); - aView->Dump(aStrFileName); + return; } - else - delete aDlg; - - ::GetCurrentDirectory(MAX_PATH, myLastPath); - ::SetCurrentDirectory(aCurPath); + + for (POSITION aPos = GetFirstViewPosition(); aPos != NULL;) + { + CViewer3dView* pView = (CViewer3dView* )GetNextView (aPos); + pView->UpdateWindow(); + } + myViewer->InitActiveViews(); + Handle(V3d_View) aView = myViewer->ActiveView(); + aView->Dump (aDlg.GetPathName()); } void CViewer3dDoc::Start() diff --git a/samples/mfc/standard/05_ImportExport/adm/win/vc10/ImportExport.vcxproj b/samples/mfc/standard/05_ImportExport/adm/win/vc10/ImportExport.vcxproj index ec4c425174..e13f527a00 100644 --- a/samples/mfc/standard/05_ImportExport/adm/win/vc10/ImportExport.vcxproj +++ b/samples/mfc/standard/05_ImportExport/adm/win/vc10/ImportExport.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/ImportExport.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/ImportExport.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -195,7 +195,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/ImportExport.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -237,7 +237,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/ImportExport.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/05_ImportExport/adm/win/vc11/ImportExport.vcxproj b/samples/mfc/standard/05_ImportExport/adm/win/vc11/ImportExport.vcxproj index b18b466224..f9e8ca9b75 100644 --- a/samples/mfc/standard/05_ImportExport/adm/win/vc11/ImportExport.vcxproj +++ b/samples/mfc/standard/05_ImportExport/adm/win/vc11/ImportExport.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/ImportExport.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/ImportExport.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -199,7 +199,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/ImportExport.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -241,7 +241,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/ImportExport.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/05_ImportExport/adm/win/vc8/ImportExport.vcproj b/samples/mfc/standard/05_ImportExport/adm/win/vc8/ImportExport.vcproj index d9fb3a9fe1..45b3bae757 100644 --- a/samples/mfc/standard/05_ImportExport/adm/win/vc8/ImportExport.vcproj +++ b/samples/mfc/standard/05_ImportExport/adm/win/vc8/ImportExport.vcproj @@ -81,7 +81,7 @@ /> #include -BEGIN_MESSAGE_MAP(CImportExportApp, OCC_3dApp) +BEGIN_MESSAGE_MAP(CImportExportApp, OCC_App) //{{AFX_MSG_MAP(CSerializeApp) ON_COMMAND(ID_FILE_OPEN, OnFileOpen) //}}AFX_MSG_MAP @@ -20,16 +20,19 @@ END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CImportExportApp construction -CImportExportApp::CImportExportApp() +CImportExportApp::CImportExportApp() : OCC_App() { - // Set the local system units - try - { UnitsAPI::SetLocalSystem(UnitsAPI_MDTV); } - catch (Standard_Failure) - { - AfxMessageBox("Fatal Error in units initialisation"); - } - SampleName = "ImportExport"; //for about dialog + // Set the local system units + try + { + UnitsAPI::SetLocalSystem (UnitsAPI_MDTV); + } + catch (Standard_Failure) + { + AfxMessageBox ("Fatal Error in units initialisation"); + } + + SampleName = "ImportExport"; //for about dialog } ///////////////////////////////////////////////////////////////////////////// @@ -111,7 +114,7 @@ void CImportExportApp::OnFileOpen() NULL ); - CString initdir(((OCC_BaseApp*) AfxGetApp())->GetInitDataDir()); + CString initdir(((OCC_App*) AfxGetApp())->GetInitDataDir()); initdir += "\\Data"; dlg.m_ofn.lpstrInitialDir = initdir; diff --git a/samples/mfc/standard/05_ImportExport/src/ImportExportApp.h b/samples/mfc/standard/05_ImportExport/src/ImportExportApp.h index 9ffb99d178..e0233677fa 100755 --- a/samples/mfc/standard/05_ImportExport/src/ImportExportApp.h +++ b/samples/mfc/standard/05_ImportExport/src/ImportExportApp.h @@ -8,25 +8,29 @@ #pragma once #endif // _MSC_VER >= 1000 -#include +#include -class CImportExportApp : public OCC_3dApp +class CImportExportApp : public OCC_App { public: - CImportExportApp(); + + CImportExportApp(); // Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CImportExportApp) - public: - virtual BOOL InitInstance(); - virtual CDocument* OpenDocumentFile(LPCTSTR lpszFileName); - //}}AFX_VIRTUAL + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CImportExportApp) + public: + virtual BOOL InitInstance(); + virtual CDocument* OpenDocumentFile(LPCTSTR lpszFileName); + //}}AFX_VIRTUAL + protected: - //{{AFX_MSG(CSerializeApp) - afx_msg void OnFileOpen(); - //}}AFX_MSG - DECLARE_MESSAGE_MAP() + + //{{AFX_MSG(CSerializeApp) + afx_msg void OnFileOpen(); + //}}AFX_MSG + + DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/06_Ocaf/adm/win/vc10/Ocaf.vcxproj b/samples/mfc/standard/06_Ocaf/adm/win/vc10/Ocaf.vcxproj index 51207d946d..3176a8ffb5 100644 --- a/samples/mfc/standard/06_Ocaf/adm/win/vc10/Ocaf.vcxproj +++ b/samples/mfc/standard/06_Ocaf/adm/win/vc10/Ocaf.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Ocaf.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Ocaf.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -195,7 +195,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Ocaf.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -237,7 +237,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/Ocaf.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/06_Ocaf/adm/win/vc11/Ocaf.vcxproj b/samples/mfc/standard/06_Ocaf/adm/win/vc11/Ocaf.vcxproj index a46b98a0b0..5a86f0d3ff 100644 --- a/samples/mfc/standard/06_Ocaf/adm/win/vc11/Ocaf.vcxproj +++ b/samples/mfc/standard/06_Ocaf/adm/win/vc11/Ocaf.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Ocaf.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Ocaf.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -199,7 +199,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Ocaf.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -241,7 +241,7 @@ 0x0409 - TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKLCAF.lib;TKBrep.lib;TKIGES.lib;TKShHealing.lib;TKStep.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/Ocaf.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/06_Ocaf/adm/win/vc8/Ocaf.vcproj b/samples/mfc/standard/06_Ocaf/adm/win/vc8/Ocaf.vcproj index cdcefa0a8d..69a09fa581 100644 --- a/samples/mfc/standard/06_Ocaf/adm/win/vc8/Ocaf.vcproj +++ b/samples/mfc/standard/06_Ocaf/adm/win/vc8/Ocaf.vcproj @@ -81,7 +81,7 @@ /> = 1000 -#include +#include #include "OcafDoc.h" #include "TOCAF_Application.hxx" -class COcafApp : public OCC_3dApp +class COcafApp : public OCC_App { - public: - COcafApp(); - ~COcafApp(); + + COcafApp(); // Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(COcafApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL - void OnFileOpen(); -// CasCade : + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(COcafApp) + public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL + void OnFileOpen(); public: - // ========================================= - // ========================================= - Handle_TOcaf_Application GetApp() {return myApp;} + Handle_TOcaf_Application GetApp() {return myApp;} private : - Handle_TOcaf_Application myApp; - BOOL IsViewExisting(CDocument* pDoc,CRuntimeClass* pViewClass,CView*& pView); - CMultiDocTemplate* pDocTemplateForView3d; + BOOL IsViewExisting(CDocument* pDoc,CRuntimeClass* pViewClass,CView*& pView); -// End CasCade - DECLARE_MESSAGE_MAP() +private: + Handle_TOcaf_Application myApp; + CMultiDocTemplate* pDocTemplateForView3d; + + DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/07_Triangulation/adm/win/vc10/Triangulation.vcxproj b/samples/mfc/standard/07_Triangulation/adm/win/vc10/Triangulation.vcxproj index 5423ad4e52..586a366154 100644 --- a/samples/mfc/standard/07_Triangulation/adm/win/vc10/Triangulation.vcxproj +++ b/samples/mfc/standard/07_Triangulation/adm/win/vc10/Triangulation.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/Triangulation.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/Triangulation.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -195,7 +195,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/Triangulation.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -237,7 +237,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/Triangulation.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/07_Triangulation/adm/win/vc11/Triangulation.vcxproj b/samples/mfc/standard/07_Triangulation/adm/win/vc11/Triangulation.vcxproj index 894a80ce67..4abf37fbca 100644 --- a/samples/mfc/standard/07_Triangulation/adm/win/vc11/Triangulation.vcxproj +++ b/samples/mfc/standard/07_Triangulation/adm/win/vc11/Triangulation.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/Triangulation.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/Triangulation.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -199,7 +199,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/Triangulation.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -241,7 +241,7 @@ 0x0409 - TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKVrml.lib;TKStl.lib;TKBRep.lib;TKIGES.lib;TKShHealing.lib;TKSTEP.lib;TKSTEP209.lib;TKSTEPAttr.lib;TKSTEPBase.lib;TKXSBase.lib;TKShapeSchema.lib;TKBO.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKMesh.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/Triangulation.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) diff --git a/samples/mfc/standard/07_Triangulation/adm/win/vc8/Triangulation.vcproj b/samples/mfc/standard/07_Triangulation/adm/win/vc8/Triangulation.vcproj index 66980d8928..5818374e40 100644 --- a/samples/mfc/standard/07_Triangulation/adm/win/vc8/Triangulation.vcproj +++ b/samples/mfc/standard/07_Triangulation/adm/win/vc8/Triangulation.vcproj @@ -81,7 +81,7 @@ /> GetInitDataDir()); + CString initfile(((OCC_App*) AfxGetApp())->GetInitDataDir()); initfile += "\\..\\..\\Data\\"; initfile += aFileName; diff --git a/samples/mfc/standard/07_Triangulation/src/TriangulationApp.cpp b/samples/mfc/standard/07_Triangulation/src/TriangulationApp.cpp index d7926da8e5..40af313f50 100755 --- a/samples/mfc/standard/07_Triangulation/src/TriangulationApp.cpp +++ b/samples/mfc/standard/07_Triangulation/src/TriangulationApp.cpp @@ -13,9 +13,9 @@ ///////////////////////////////////////////////////////////////////////////// // CTriangulationApp construction -CTriangulationApp::CTriangulationApp() +CTriangulationApp::CTriangulationApp() : OCC_App() { - SampleName = "TopologyTriangulation"; //for about dialog + SampleName = "TopologyTriangulation"; //for about dialog } ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/07_Triangulation/src/TriangulationApp.h b/samples/mfc/standard/07_Triangulation/src/TriangulationApp.h index 9e1fd361a5..2630b7da34 100755 --- a/samples/mfc/standard/07_Triangulation/src/TriangulationApp.h +++ b/samples/mfc/standard/07_Triangulation/src/TriangulationApp.h @@ -8,18 +8,20 @@ #pragma once #endif // _MSC_VER >= 1000 -#include +#include -class CTriangulationApp : public OCC_3dApp +class CTriangulationApp : public OCC_App { public: - CTriangulationApp(); + + CTriangulationApp(); + // Overrides - // ClassWizard generated virtual function overrides - //{{AFX_VIRTUAL(CTriangulationApp) - public: - virtual BOOL InitInstance(); - //}}AFX_VIRTUAL + // ClassWizard generated virtual function overrides + //{{AFX_VIRTUAL(CTriangulationApp) + public: + virtual BOOL InitInstance(); + //}}AFX_VIRTUAL }; ///////////////////////////////////////////////////////////////////////////// diff --git a/samples/mfc/standard/07_Triangulation/src/TriangulationDoc.cpp b/samples/mfc/standard/07_Triangulation/src/TriangulationDoc.cpp index 7f6df42f77..88b8697ad1 100755 --- a/samples/mfc/standard/07_Triangulation/src/TriangulationDoc.cpp +++ b/samples/mfc/standard/07_Triangulation/src/TriangulationDoc.cpp @@ -407,39 +407,28 @@ void CTriangulationDoc::OnUpdateBUTTONPrev(CCmdUI* pCmdUI) void CTriangulationDoc::OnDumpView() { - // save current directory and restore it on exit - char aCurPath[MAX_PATH]; - ::GetCurrentDirectory(MAX_PATH, aCurPath); - - ::SetCurrentDirectory(myLastPath); - - CFileDialog *aDlg = new CFileDialog(false, "gif", "OCCView.gif", - OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, "GIF Files (*.gif)|*.gif||", NULL); - - int result = aDlg->DoModal(); - if ( result == IDOK) + CFileDialog aDlg (false, "gif", "OCCView.gif", OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, + "GIF Files (*.GIF)|*.gif|" + "BMP Files (*.BMP)|*.bmp|" + "PNG Files (*.PNG)|*.png|" + "JPEG Files (*.JPEG)|*.jpeg|" + "PPM Files (*.PPM)|*.ppm|" + "TIFF Files (*.TIFF)|*.tiff|" + "TGA Files (*.TGA)|*.tga|" + "EXR Files (*.EXR)|*.exr||", NULL); + if (aDlg.DoModal() != IDOK) { - CString aFileName = aDlg->GetFileName(); - delete aDlg; - - POSITION pos = GetFirstViewPosition(); - while (pos != NULL) - { - OCC_3dView* pView = (OCC_3dView*) GetNextView(pos); - pView->UpdateWindow(); - } - - myViewer->InitActiveViews(); - Handle(V3d_View) aView = myViewer->ActiveView(); - char aStrFileName[MAX_PATH]; - strcpy_s(aStrFileName, aFileName); - aView->Dump(aStrFileName); + return; } - else - delete aDlg; - - ::GetCurrentDirectory(MAX_PATH, myLastPath); - ::SetCurrentDirectory(aCurPath); + + for (POSITION aPos = GetFirstViewPosition(); aPos != NULL;) + { + OCC_3dView* pView = (OCC_3dView* )GetNextView (aPos); + pView->UpdateWindow(); + } + myViewer->InitActiveViews(); + Handle(V3d_View) aView = myViewer->ActiveView(); + aView->Dump (aDlg.GetPathName()); } void CTriangulationDoc::Fit() diff --git a/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj b/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj index d257c1bfe4..cc4812c1b0 100644 --- a/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj +++ b/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj @@ -112,7 +112,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bin/HLR.exe true ..\..\..\..\win32\vc10\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -154,7 +154,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bin/HLR.exe true ..\..\..\..\win64\vc10\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -195,7 +195,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc10\bind/HLR.exe true ..\..\..\..\win32\vc10\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -237,7 +237,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc10\bind/HLR.exe true ..\..\..\..\win64\vc10\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -360,151 +360,15 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - - - - - - - diff --git a/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj.filters b/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj.filters index 139976d56b..d8f08c9e32 100644 --- a/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj.filters +++ b/samples/mfc/standard/08_HLR/adm/win/vc10/HLR.vcxproj.filters @@ -5,9 +5,6 @@ {71b03503-46e1-4a70-bf46-9d403d37b35a} cpp;c;cxx;rc;def;r;odl;idl;hpj;bat - - {21baab48-bf6d-4fc2-9378-bf7ce6dbfaca} - {22270cbf-7f10-4c26-8fc6-7f68842b776d} h;hpp;hxx;hm;inl @@ -41,47 +38,11 @@ Source Files - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - Header Files - - Header Files - - - Header Files - - - Header Files - - - Header Files - Header Files @@ -91,12 +52,6 @@ Header Files - - Header Files - - - Header Files - Header Files @@ -106,12 +61,6 @@ Header Files - - Header Files - - - Header Files - diff --git a/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj b/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj index 0bf93f9d3d..fd5057c449 100644 --- a/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj +++ b/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj @@ -116,7 +116,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bin/HLR.exe true ..\..\..\..\win32\vc11\lib;$(CSF_OPT_LIB32);%(AdditionalLibraryDirectories) @@ -158,7 +158,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bin/HLR.exe true ..\..\..\..\win64\vc11\lib;$(CSF_OPT_LIB64);%(AdditionalLibraryDirectories) @@ -199,7 +199,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win32\vc11\bind/HLR.exe true ..\..\..\..\win32\vc11\libd;$(CSF_OPT_LIB32D);%(AdditionalLibraryDirectories) @@ -241,7 +241,7 @@ 0x0409 - TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV2d.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) + TKBRep.lib;FWOSPlugin.lib;PTKernel.lib;TKBool.lib;TKCAF.lib;TKCDF.lib;TKernel.lib;TKFeat.lib;TKFillet.lib;TKG2d.lib;TKG3d.lib;TKGeomAlgo.lib;TKGeomBase.lib;TKHLR.lib;TKMath.lib;TKOffset.lib;TKPCAF.lib;TKPrim.lib;TKPShape.lib;TKService.lib;TKTopAlgo.lib;TKV3d.lib;mfcsample.lib;%(AdditionalDependencies) ../../../../win64\vc11\bind/HLR.exe true ..\..\..\..\win64\vc11\libd;$(CSF_OPT_LIB64D);%(AdditionalLibraryDirectories) @@ -364,151 +364,15 @@ %(AdditionalIncludeDirectories) %(PreprocessorDefinitions) - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - Disabled - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - EnableFastChecks - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - MaxSpeed - %(AdditionalIncludeDirectories) - %(PreprocessorDefinitions) - - - - - - - - - diff --git a/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj.filters b/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj.filters index 139976d56b..d8f08c9e32 100644 --- a/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj.filters +++ b/samples/mfc/standard/08_HLR/adm/win/vc11/HLR.vcxproj.filters @@ -5,9 +5,6 @@ {71b03503-46e1-4a70-bf46-9d403d37b35a} cpp;c;cxx;rc;def;r;odl;idl;hpj;bat - - {21baab48-bf6d-4fc2-9378-bf7ce6dbfaca} - {22270cbf-7f10-4c26-8fc6-7f68842b776d} h;hpp;hxx;hm;inl @@ -41,47 +38,11 @@ Source Files - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - - - Source Files\Properties - Header Files - - Header Files - - - Header Files - - - Header Files - - - Header Files - Header Files @@ -91,12 +52,6 @@ Header Files - - Header Files - - - Header Files - Header Files @@ -106,12 +61,6 @@ Header Files - - Header Files - - - Header Files - diff --git a/samples/mfc/standard/08_HLR/adm/win/vc8/HLR.vcproj b/samples/mfc/standard/08_HLR/adm/win/vc8/HLR.vcproj index 26d4654069..1dad57dca6 100644 --- a/samples/mfc/standard/08_HLR/adm/win/vc8/HLR.vcproj +++ b/samples/mfc/standard/08_HLR/adm/win/vc8/HLR.vcproj @@ -81,7 +81,7 @@ /> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -1143,14 +755,6 @@ RelativePath="..\..\..\src\HLRView2D.h" > - - - - @@ -1163,14 +767,6 @@ RelativePath="..\..\..\src\StdAfx.h" > - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -1140,14 +752,6 @@ RelativePath="..\..\..\src\HLRView2D.h" > - - - - @@ -1160,14 +764,6 @@ RelativePath="..\..\..\src\StdAfx.h" > - - - -