1
0
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:
aba 2013-03-29 17:39:13 +04:00 committed by bugmaster
parent 2c896b8f8a
commit 973191093d
3 changed files with 191 additions and 190 deletions

21
samples/mfc/standard/08_HLR/src/SelectionDialog.cpp Executable file → Normal file
View 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));
} }

View File

@ -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);
} }
} }
} }

View File

@ -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) ;