mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0023831: Ghosts appears in 2D viewer of HLR MFC sample
2d view updating was corrected. ISession2D_Shape drawing was corrected. Style changes
This commit is contained in:
parent
2c896b8f8a
commit
973191093d
21
samples/mfc/standard/08_HLR/src/SelectionDialog.cpp
Executable file → Normal file
21
samples/mfc/standard/08_HLR/src/SelectionDialog.cpp
Executable file → Normal file
@ -32,7 +32,7 @@ CSelectionDialog::CSelectionDialog(CHLRDoc* aDoc,CWnd* pParent /*=NULL*/)
|
|||||||
m_DisplayMode = 0;
|
m_DisplayMode = 0;
|
||||||
m_NbIsos = 2;
|
m_NbIsos = 2;
|
||||||
m_DrawHiddenLine = TRUE;
|
m_DrawHiddenLine = TRUE;
|
||||||
m_HlrModeIsOn = FALSE;
|
m_DegeneratedModeOn = TRUE;
|
||||||
//}}AFX_DATA_INIT
|
//}}AFX_DATA_INIT
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -44,7 +44,7 @@ void CSelectionDialog::DoDataExchange(CDataExchange* pDX)
|
|||||||
DDX_Radio(pDX, IDC_DisplayDefault, m_DisplayMode);
|
DDX_Radio(pDX, IDC_DisplayDefault, m_DisplayMode);
|
||||||
DDX_Text(pDX, IDC_EDIT_NBIsos, m_NbIsos);
|
DDX_Text(pDX, IDC_EDIT_NBIsos, m_NbIsos);
|
||||||
DDX_Check(pDX, IDC_DrawHiddenLine, m_DrawHiddenLine);
|
DDX_Check(pDX, IDC_DrawHiddenLine, m_DrawHiddenLine);
|
||||||
DDX_Check(pDX, IDC_HlrModeIsOn, m_HlrModeIsOn);
|
DDX_Check(pDX, IDC_DegeneratedMode, m_DegeneratedModeOn);
|
||||||
//}}AFX_DATA_MAP
|
//}}AFX_DATA_MAP
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ BEGIN_MESSAGE_MAP(CSelectionDialog, CDialog)
|
|||||||
ON_WM_RBUTTONUP()
|
ON_WM_RBUTTONUP()
|
||||||
ON_WM_MOUSEMOVE()
|
ON_WM_MOUSEMOVE()
|
||||||
ON_BN_CLICKED(IDC_DrawHiddenLine, OnDrawHiddenLine)
|
ON_BN_CLICKED(IDC_DrawHiddenLine, OnDrawHiddenLine)
|
||||||
ON_BN_CLICKED(IDC_HlrModeIsOn, OnHlrMode)
|
ON_BN_CLICKED(IDC_DegeneratedMode, OnDegeneratedMode)
|
||||||
ON_WM_DRAWITEM()
|
ON_WM_DRAWITEM()
|
||||||
ON_WM_PAINT()
|
ON_WM_PAINT()
|
||||||
//}}AFX_MSG_MAP
|
//}}AFX_MSG_MAP
|
||||||
@ -121,9 +121,9 @@ BOOL CSelectionDialog::OnInitDialog()
|
|||||||
void CSelectionDialog::OnDisplay(bool isFit)
|
void CSelectionDialog::OnDisplay(bool isFit)
|
||||||
{
|
{
|
||||||
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(true);
|
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(true);
|
||||||
if (!myDisplay)
|
if(!myDisplay) {
|
||||||
{
|
Handle(Graphic3d_GraphicDriver) aGraphicDriver =
|
||||||
Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((CHLRApp*)AfxGetApp())->GetGraphicDriver();
|
((CHLRApp*)AfxGetApp())->GetGraphicDriver();
|
||||||
|
|
||||||
myActiveViewer = new V3d_Viewer(aGraphicDriver,(short *) "Visu3D");
|
myActiveViewer = new V3d_Viewer(aGraphicDriver,(short *) "Visu3D");
|
||||||
myActiveViewer->SetDefaultLights();
|
myActiveViewer->SetDefaultLights();
|
||||||
@ -143,8 +143,7 @@ void CSelectionDialog::OnDisplay(bool isFit)
|
|||||||
|
|
||||||
myInteractiveContext->Display(myTrihedron);
|
myInteractiveContext->Display(myTrihedron);
|
||||||
}
|
}
|
||||||
if (isFit)
|
if(isFit) {
|
||||||
{
|
|
||||||
myActiveView->ZFitAll();
|
myActiveView->ZFitAll();
|
||||||
myActiveView->FitAll();
|
myActiveView->FitAll();
|
||||||
}
|
}
|
||||||
@ -162,7 +161,7 @@ void CSelectionDialog::SetTitle(CString & aTitle)
|
|||||||
void CSelectionDialog::OnGetShape()
|
void CSelectionDialog::OnGetShape()
|
||||||
{
|
{
|
||||||
UpdateData(true);
|
UpdateData(true);
|
||||||
myDoc->GetInteractiveContext2D()->EraseAll();
|
myDoc->GetInteractiveContext2D()->RemoveAll();
|
||||||
myDisplayableShape = new ISession2D_Shape( );
|
myDisplayableShape = new ISession2D_Shape( );
|
||||||
UpdateProjector();
|
UpdateProjector();
|
||||||
myDisplayableShape->SetNbIsos(m_NbIsos);
|
myDisplayableShape->SetNbIsos(m_NbIsos);
|
||||||
@ -197,7 +196,6 @@ void CSelectionDialog::OnGetShape()
|
|||||||
|
|
||||||
myDoc->FitAll2DViews(Standard_False); // Update Viewer
|
myDoc->FitAll2DViews(Standard_False); // Update Viewer
|
||||||
|
|
||||||
|
|
||||||
// check the selection :
|
// check the selection :
|
||||||
// if no object : disable all possiblity!!
|
// if no object : disable all possiblity!!
|
||||||
ShowHideButton(OneOrMoreFound);
|
ShowHideButton(OneOrMoreFound);
|
||||||
@ -207,7 +205,7 @@ void CSelectionDialog::OnGetShape()
|
|||||||
void CSelectionDialog::Apply()
|
void CSelectionDialog::Apply()
|
||||||
{
|
{
|
||||||
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT));
|
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT));
|
||||||
myDoc->GetInteractiveContext2D()->EraseAll(/*Standard_False*/);
|
myDoc->GetInteractiveContext2D()->RemoveAll();
|
||||||
UpdateData(true);
|
UpdateData(true);
|
||||||
|
|
||||||
Standard_Integer DisplayMode = m_DisplayMode;
|
Standard_Integer DisplayMode = m_DisplayMode;
|
||||||
@ -344,6 +342,7 @@ void CSelectionDialog::OnUpdate2D()
|
|||||||
myDoc->ActivateFrame(RUNTIME_CLASS(OCC_2dView),SW_NORMAL);
|
myDoc->ActivateFrame(RUNTIME_CLASS(OCC_2dView),SW_NORMAL);
|
||||||
UpdateProjector();
|
UpdateProjector();
|
||||||
Apply();
|
Apply();
|
||||||
|
myDoc->FitAll2DViews(Standard_False);
|
||||||
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW));
|
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,23 +64,25 @@ void ISession2D_Shape::BuildPolyAlgo()
|
|||||||
myPolyAlgo->Update();
|
myPolyAlgo->Update();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,
|
void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& thePresentationManager,
|
||||||
const Handle(Prs3d_Presentation)& aPresentation,
|
const Handle(Prs3d_Presentation)& thePresentation,
|
||||||
const Standard_Integer aMode)
|
const Standard_Integer theMode)
|
||||||
{
|
{
|
||||||
Standard_Integer TheMode = aMode;
|
|
||||||
|
Standard_Integer aMode = theMode;
|
||||||
Standard_Boolean DrawHiddenLine= Standard_True;
|
Standard_Boolean DrawHiddenLine= Standard_True;
|
||||||
if (TheMode >= 1000)
|
thePresentation->Clear();
|
||||||
|
if (aMode >= 1000)
|
||||||
{
|
{
|
||||||
DrawHiddenLine = Standard_False;
|
DrawHiddenLine = Standard_False;
|
||||||
TheMode -= 1000;
|
aMode -= 1000;
|
||||||
}
|
}
|
||||||
|
|
||||||
Standard_Boolean UsePolyAlgo= Standard_True;
|
Standard_Boolean UsePolyAlgo= Standard_True;
|
||||||
if (TheMode >= 100)
|
if (aMode >= 100)
|
||||||
{
|
{
|
||||||
UsePolyAlgo = Standard_False;
|
UsePolyAlgo = Standard_False;
|
||||||
TheMode -= 100;
|
aMode -= 100;
|
||||||
}
|
}
|
||||||
TopoDS_Shape VCompound;
|
TopoDS_Shape VCompound;
|
||||||
TopoDS_Shape Rg1LineVCompound;
|
TopoDS_Shape Rg1LineVCompound;
|
||||||
@ -133,34 +135,34 @@ void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPres
|
|||||||
Aspect_TOL_SOLID,1);
|
Aspect_TOL_SOLID,1);
|
||||||
|
|
||||||
|
|
||||||
switch(TheMode)
|
switch(aMode)
|
||||||
{
|
{
|
||||||
case (1):
|
case (1):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, VCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, VCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (2):
|
case (2):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (3):
|
case (3):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, RgNLineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, RgNLineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (4):
|
case (4):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, OutLineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, OutLineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation,VCompound, aLineAspect);
|
DrawCompound(thePresentation,VCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation,Rg1LineVCompound, aLineAspect);
|
DrawCompound(thePresentation,Rg1LineVCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation,RgNLineVCompound, aLineAspect);
|
DrawCompound(thePresentation,RgNLineVCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation,OutLineVCompound, aLineAspect);
|
DrawCompound(thePresentation,OutLineVCompound, aLineAspect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,34 +173,34 @@ void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPres
|
|||||||
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_BLUE1,
|
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_BLUE1,
|
||||||
Aspect_TOL_DOTDASH,1);
|
Aspect_TOL_DOTDASH,1);
|
||||||
|
|
||||||
switch(TheMode)
|
switch(aMode)
|
||||||
{
|
{
|
||||||
case (6):
|
case (6):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, HCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, HCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (7):
|
case (7):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (8):
|
case (8):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, RgNLineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, RgNLineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (9):
|
case (9):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, OutLineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, OutLineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, HCompound, aLineAspect);
|
DrawCompound(thePresentation, HCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspect);
|
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, RgNLineHCompound, aLineAspect);
|
DrawCompound(thePresentation, RgNLineHCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, OutLineHCompound, aLineAspect);
|
DrawCompound(thePresentation, OutLineHCompound, aLineAspect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -210,40 +212,40 @@ void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPres
|
|||||||
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_WHITE,
|
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_WHITE,
|
||||||
Aspect_TOL_SOLID,1);
|
Aspect_TOL_SOLID,1);
|
||||||
|
|
||||||
switch (TheMode)
|
switch (aMode)
|
||||||
{
|
{
|
||||||
case (1):
|
case (1):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, VCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, VCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (2):
|
case (2):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (3):
|
case (3):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, RgNLineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, RgNLineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (4):
|
case (4):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, OutLineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, OutLineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (5):
|
case (5):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, IsoLineVCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, IsoLineVCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, VCompound, aLineAspect);
|
DrawCompound(thePresentation, VCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspect);
|
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, RgNLineVCompound, aLineAspect);
|
DrawCompound(thePresentation, RgNLineVCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, OutLineVCompound, aLineAspect);
|
DrawCompound(thePresentation, OutLineVCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, IsoLineVCompound , aLineAspect);
|
DrawCompound(thePresentation, IsoLineVCompound , aLineAspect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -254,40 +256,40 @@ void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPres
|
|||||||
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_ALICEBLUE,
|
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_ALICEBLUE,
|
||||||
Aspect_TOL_DOT,1);
|
Aspect_TOL_DOT,1);
|
||||||
|
|
||||||
switch(TheMode)
|
switch(aMode)
|
||||||
{
|
{
|
||||||
case (6):
|
case (6):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, HCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, HCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (7):
|
case (7):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (8):
|
case (8):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, RgNLineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, RgNLineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (9):
|
case (9):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, OutLineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, OutLineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case (10):
|
case (10):
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, IsoLineHCompound, aLineAspectHighlighted);
|
DrawCompound(thePresentation, IsoLineHCompound, aLineAspectHighlighted);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
DrawCompound(aPresentation, HCompound, aLineAspect);
|
DrawCompound(thePresentation, HCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspect);
|
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, RgNLineHCompound, aLineAspect);
|
DrawCompound(thePresentation, RgNLineHCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, OutLineHCompound, aLineAspect);
|
DrawCompound(thePresentation, OutLineHCompound, aLineAspect);
|
||||||
DrawCompound(aPresentation, IsoLineHCompound, aLineAspect);
|
DrawCompound(thePresentation, IsoLineHCompound, aLineAspect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ void BuildPolyAlgo();
|
|||||||
void DrawCompound(const Handle(Prs3d_Presentation)& thePresentation,const TopoDS_Shape& theCompound, const Handle(Prs3d_LineAspect) theAspect);
|
void DrawCompound(const Handle(Prs3d_Presentation)& thePresentation,const TopoDS_Shape& theCompound, const Handle(Prs3d_LineAspect) theAspect);
|
||||||
|
|
||||||
|
|
||||||
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(PrsMgr_PresentationManager3d)& thePresentationManager,const Handle(Prs3d_Presentation)& thePresentation,const Standard_Integer theMode = 0) ;
|
||||||
|
|
||||||
virtual void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ;
|
virtual void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection,const Standard_Integer aMode) ;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user