1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +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

279
samples/mfc/standard/08_HLR/src/SelectionDialog.cpp Executable file → Normal file
View File

@ -23,67 +23,67 @@ static char THIS_FILE[] = __FILE__;
// CSelectionDialog dialog
CSelectionDialog::CSelectionDialog(CHLRDoc* aDoc,CWnd* pParent /*=NULL*/)
: CDialog(CSelectionDialog::IDD, pParent)
: CDialog(CSelectionDialog::IDD, pParent)
{
myDoc = aDoc;
myDisplay = false;
//{{AFX_DATA_INIT(CSelectionDialog)
m_Algo = 0;
m_DisplayMode = 0;
m_NbIsos = 2;
m_DrawHiddenLine = TRUE;
m_HlrModeIsOn = FALSE;
//}}AFX_DATA_INIT
myDoc = aDoc;
myDisplay = false;
//{{AFX_DATA_INIT(CSelectionDialog)
m_Algo = 0;
m_DisplayMode = 0;
m_NbIsos = 2;
m_DrawHiddenLine = TRUE;
m_DegeneratedModeOn = TRUE;
//}}AFX_DATA_INIT
}
void CSelectionDialog::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CSelectionDialog)
DDX_Radio(pDX, IDC_PolyAlgo, m_Algo);
DDX_Radio(pDX, IDC_DisplayDefault, m_DisplayMode);
DDX_Text(pDX, IDC_EDIT_NBIsos, m_NbIsos);
DDX_Check(pDX, IDC_DrawHiddenLine, m_DrawHiddenLine);
DDX_Check(pDX, IDC_HlrModeIsOn, m_HlrModeIsOn);
//}}AFX_DATA_MAP
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CSelectionDialog)
DDX_Radio(pDX, IDC_PolyAlgo, m_Algo);
DDX_Radio(pDX, IDC_DisplayDefault, m_DisplayMode);
DDX_Text(pDX, IDC_EDIT_NBIsos, m_NbIsos);
DDX_Check(pDX, IDC_DrawHiddenLine, m_DrawHiddenLine);
DDX_Check(pDX, IDC_DegeneratedMode, m_DegeneratedModeOn);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CSelectionDialog, CDialog)
//{{AFX_MSG_MAP(CSelectionDialog)
ON_BN_CLICKED(ID_GetShape, OnGetShape)
ON_BN_CLICKED(IDC_DisplayDefault, OnDisplayDefault)
ON_BN_CLICKED(IDC_VIsoParametrics, OnVIsoParametrics)
ON_BN_CLICKED(IDC_VApparentContour, OnVApparentContour)
ON_BN_CLICKED(IDC_VSewingEdges, OnVSewingEdges)
ON_BN_CLICKED(IDC_VsharpEdges, OnVsharpEdges)
ON_BN_CLICKED(IDC_VsmoothEdges, OnVsmoothEdges)
ON_BN_CLICKED(IDC_HsharpEdges, OnHsharpEdges)
ON_BN_CLICKED(IDC_HsmoothEdges, OnHsmoothEdges)
ON_BN_CLICKED(IDC_HSewingEdges, OnHSewingEdges)
ON_BN_CLICKED(IDC_HIsoParametrics, OnHIsoParametrics)
ON_BN_CLICKED(IDC_HApparentContour, OnHApparentContour)
ON_EN_CHANGE(IDC_EDIT_NBIsos, OnChangeEDITNBIsos)
ON_BN_CLICKED(IDC_Algo, OnAlgo)
ON_BN_CLICKED(IDC_PolyAlgo, OnPolyAlgo)
ON_BN_CLICKED(ID_Update2D, OnUpdate2D)
ON_BN_CLICKED(IDC_TopView, OnTopView)
ON_BN_CLICKED(IDC_BottomView, OnBottomView)
ON_BN_CLICKED(IDC_LeftView, OnLeftView)
ON_BN_CLICKED(IDC_RightView, OnRightView)
ON_BN_CLICKED(IDC_FrontView, OnFrontView)
ON_BN_CLICKED(IDC_BackView, OnBackView)
ON_BN_CLICKED(IDC_AxoView, OnAxoView)
ON_WM_LBUTTONDOWN()
ON_WM_LBUTTONUP()
ON_WM_RBUTTONDOWN()
ON_WM_RBUTTONUP()
ON_WM_MOUSEMOVE()
ON_BN_CLICKED(IDC_DrawHiddenLine, OnDrawHiddenLine)
ON_BN_CLICKED(IDC_HlrModeIsOn, OnHlrMode)
ON_WM_DRAWITEM()
ON_WM_PAINT()
//}}AFX_MSG_MAP
//{{AFX_MSG_MAP(CSelectionDialog)
ON_BN_CLICKED(ID_GetShape, OnGetShape)
ON_BN_CLICKED(IDC_DisplayDefault, OnDisplayDefault)
ON_BN_CLICKED(IDC_VIsoParametrics, OnVIsoParametrics)
ON_BN_CLICKED(IDC_VApparentContour, OnVApparentContour)
ON_BN_CLICKED(IDC_VSewingEdges, OnVSewingEdges)
ON_BN_CLICKED(IDC_VsharpEdges, OnVsharpEdges)
ON_BN_CLICKED(IDC_VsmoothEdges, OnVsmoothEdges)
ON_BN_CLICKED(IDC_HsharpEdges, OnHsharpEdges)
ON_BN_CLICKED(IDC_HsmoothEdges, OnHsmoothEdges)
ON_BN_CLICKED(IDC_HSewingEdges, OnHSewingEdges)
ON_BN_CLICKED(IDC_HIsoParametrics, OnHIsoParametrics)
ON_BN_CLICKED(IDC_HApparentContour, OnHApparentContour)
ON_EN_CHANGE(IDC_EDIT_NBIsos, OnChangeEDITNBIsos)
ON_BN_CLICKED(IDC_Algo, OnAlgo)
ON_BN_CLICKED(IDC_PolyAlgo, OnPolyAlgo)
ON_BN_CLICKED(ID_Update2D, OnUpdate2D)
ON_BN_CLICKED(IDC_TopView, OnTopView)
ON_BN_CLICKED(IDC_BottomView, OnBottomView)
ON_BN_CLICKED(IDC_LeftView, OnLeftView)
ON_BN_CLICKED(IDC_RightView, OnRightView)
ON_BN_CLICKED(IDC_FrontView, OnFrontView)
ON_BN_CLICKED(IDC_BackView, OnBackView)
ON_BN_CLICKED(IDC_AxoView, OnAxoView)
ON_WM_LBUTTONDOWN()
ON_WM_LBUTTONUP()
ON_WM_RBUTTONDOWN()
ON_WM_RBUTTONUP()
ON_WM_MOUSEMOVE()
ON_BN_CLICKED(IDC_DrawHiddenLine, OnDrawHiddenLine)
ON_BN_CLICKED(IDC_DegeneratedMode, OnDegeneratedMode)
ON_WM_DRAWITEM()
ON_WM_PAINT()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
@ -91,39 +91,39 @@ END_MESSAGE_MAP()
BOOL CSelectionDialog::OnInitDialog()
{
CDialog::OnInitDialog();
CDialog::OnInitDialog();
VERIFY(TopView.AutoLoad(IDC_TopView, this));
VERIFY(BottomView.AutoLoad(IDC_BottomView, this)) ;
VERIFY(LeftView .AutoLoad(IDC_LeftView , this)) ;
VERIFY(RightView .AutoLoad(IDC_RightView , this)) ;
VERIFY(FrontView .AutoLoad(IDC_FrontView , this)) ;
VERIFY(BackView .AutoLoad(IDC_BackView , this)) ;
VERIFY(AxoView .AutoLoad(IDC_AxoView , this)) ;
VERIFY(TopView.AutoLoad(IDC_TopView, this));
VERIFY(BottomView.AutoLoad(IDC_BottomView, this)) ;
VERIFY(LeftView .AutoLoad(IDC_LeftView , this)) ;
VERIFY(RightView .AutoLoad(IDC_RightView , this)) ;
VERIFY(FrontView .AutoLoad(IDC_FrontView , this)) ;
VERIFY(BackView .AutoLoad(IDC_BackView , this)) ;
VERIFY(AxoView .AutoLoad(IDC_AxoView , this)) ;
// get the View Window position to managed mouse move
CRect BoxRect,ViewRect;
GetWindowRect(BoxRect);
CWnd * TheViewerWindow = GetDlgItem(IDC_DUMMYBUTTON);
TheViewerWindow->GetWindowRect(ViewRect);
myPosMinX = ViewRect.TopLeft().x - BoxRect.TopLeft().x;
myPosMaxX = ViewRect.Width()+myPosMinX;
myPosMinY = ViewRect.TopLeft().y - BoxRect.TopLeft().y;
myPosMaxY = myPosMinY + ViewRect.Height();
// get the View Window position to managed mouse move
CRect BoxRect,ViewRect;
GetWindowRect(BoxRect);
CWnd * TheViewerWindow = GetDlgItem(IDC_DUMMYBUTTON);
TheViewerWindow->GetWindowRect(ViewRect);
myPosMinX = ViewRect.TopLeft().x - BoxRect.TopLeft().x;
myPosMaxX = ViewRect.Width()+myPosMinX;
myPosMinY = ViewRect.TopLeft().y - BoxRect.TopLeft().y;
myPosMaxY = myPosMinY + ViewRect.Height();
ShowHideButton(Standard_False);
OnDisplay(true);
ShowHideButton(Standard_False);
OnDisplay(true);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CSelectionDialog::OnDisplay(bool isFit)
{
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(true);
if (!myDisplay)
{
Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((CHLRApp*)AfxGetApp())->GetGraphicDriver();
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(true);
if(!myDisplay) {
Handle(Graphic3d_GraphicDriver) aGraphicDriver =
((CHLRApp*)AfxGetApp())->GetGraphicDriver();
myActiveViewer = new V3d_Viewer(aGraphicDriver,(short *) "Visu3D");
myActiveViewer->SetDefaultLights();
@ -142,15 +142,14 @@ void CSelectionDialog::OnDisplay(bool isFit)
myTrihedron=new AIS_Trihedron(aTrihedronAxis);
myInteractiveContext->Display(myTrihedron);
}
if (isFit)
{
myActiveView->ZFitAll();
myActiveView->FitAll();
}
myActiveView->Redraw();
myDisplay = Standard_True;
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(false);
}
if(isFit) {
myActiveView->ZFitAll();
myActiveView->FitAll();
}
myActiveView->Redraw();
myDisplay = Standard_True;
GetDlgItem(IDC_DUMMYBUTTON)->SetRedraw(false);
}
@ -162,7 +161,7 @@ void CSelectionDialog::SetTitle(CString & aTitle)
void CSelectionDialog::OnGetShape()
{
UpdateData(true);
myDoc->GetInteractiveContext2D()->EraseAll();
myDoc->GetInteractiveContext2D()->RemoveAll();
myDisplayableShape = new ISession2D_Shape( );
UpdateProjector();
myDisplayableShape->SetNbIsos(m_NbIsos);
@ -182,9 +181,9 @@ void CSelectionDialog::OnGetShape()
OneOrMoreFound = Standard_True;
TopoDS_Shape aShape = anAISShape->Shape();
myDisplayableShape->Add( aShape );
myInteractiveContext->Display(anAISShape);
myInteractiveContext->Display(anAISShape);
}
}
}
Standard_Integer DisplayMode = m_DisplayMode;
if (m_Algo == 1) DisplayMode+=100;
@ -193,11 +192,10 @@ void CSelectionDialog::OnGetShape()
myDoc->GetInteractiveContext2D()->Display(myDisplayableShape, // object
DisplayMode, // display mode
DisplayMode, // selection mode
Standard_True); // Redraw
Standard_True); // Redraw
myDoc->FitAll2DViews(Standard_False); // Update Viewer
// check the selection :
// if no object : disable all possiblity!!
ShowHideButton(OneOrMoreFound);
@ -207,7 +205,7 @@ void CSelectionDialog::OnGetShape()
void CSelectionDialog::Apply()
{
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT));
myDoc->GetInteractiveContext2D()->EraseAll(/*Standard_False*/);
myDoc->GetInteractiveContext2D()->RemoveAll();
UpdateData(true);
Standard_Integer DisplayMode = m_DisplayMode;
@ -225,64 +223,64 @@ void CSelectionDialog::Apply()
void CSelectionDialog::UpdateProjector()
{
V3d_Coordinate DX,DY,DZ,XAt,YAt,ZAt, Vx,Vy,Vz ;
myActiveView->Proj(DX,DY,DZ);
myActiveView->At(XAt,YAt,ZAt);
myActiveView->Up( Vx,Vy,Vz );
OnDisplay(false);
Standard_Boolean IsPerspective = (myActiveView->Type() == V3d_PERSPECTIVE);
Quantity_Length aFocus = 1;
Prs3d_Projector aPrs3dProjector(IsPerspective,aFocus,DX,DY,DZ,XAt,YAt,ZAt,Vx,Vy,Vz);
HLRAlgo_Projector aProjector = aPrs3dProjector.Projector();
if (myDisplayableShape.IsNull()) return;
myDisplayableShape->SetProjector(aProjector);
V3d_Coordinate DX,DY,DZ,XAt,YAt,ZAt, Vx,Vy,Vz ;
myActiveView->Proj(DX,DY,DZ);
myActiveView->At(XAt,YAt,ZAt);
myActiveView->Up( Vx,Vy,Vz );
OnDisplay(false);
Standard_Boolean IsPerspective = (myActiveView->Type() == V3d_PERSPECTIVE);
Quantity_Length aFocus = 1;
Prs3d_Projector aPrs3dProjector(IsPerspective,aFocus,DX,DY,DZ,XAt,YAt,ZAt,Vx,Vy,Vz);
HLRAlgo_Projector aProjector = aPrs3dProjector.Projector();
if (myDisplayableShape.IsNull()) return;
myDisplayableShape->SetProjector(aProjector);
}
void CSelectionDialog::ShowHideButton(Standard_Boolean EnableButton)
{
UpdateData(true);
UpdateData(true);
GetDlgItem(ID_Update2D )->EnableWindow(EnableButton);
GetDlgItem(IDC_DisplayDefault )->EnableWindow(EnableButton);
GetDlgItem(IDC_PolyAlgo )->EnableWindow(EnableButton);
GetDlgItem(IDC_Algo )->EnableWindow(EnableButton);
GetDlgItem(ID_Update2D )->EnableWindow(EnableButton);
GetDlgItem(IDC_DisplayDefault )->EnableWindow(EnableButton);
GetDlgItem(IDC_PolyAlgo )->EnableWindow(EnableButton);
GetDlgItem(IDC_Algo )->EnableWindow(EnableButton);
GetDlgItem(IDC_VsharpEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VsmoothEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VSewingEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VApparentContour )->EnableWindow(EnableButton);
GetDlgItem(IDC_VIsoParametrics )->EnableWindow(EnableButton);
GetDlgItem(IDC_VsharpEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VsmoothEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VSewingEdges )->EnableWindow(EnableButton);
GetDlgItem(IDC_VApparentContour )->EnableWindow(EnableButton);
GetDlgItem(IDC_VIsoParametrics )->EnableWindow(EnableButton);
GetDlgItem(IDC_DrawHiddenLine )->EnableWindow(EnableButton);
GetDlgItem(IDC_DrawHiddenLine )->EnableWindow(EnableButton);
GetDlgItem(IDC_HsmoothEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HSewingEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HApparentContour )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HsharpEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HIsoParametrics )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HsmoothEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HSewingEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HApparentContour )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HsharpEdges )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_HIsoParametrics )->EnableWindow(EnableButton && m_DrawHiddenLine);
GetDlgItem(IDC_EDIT_NBIsos )->EnableWindow(EnableButton);
GetDlgItem(IDC_STATIC_NbIsos )->EnableWindow(EnableButton);
GetDlgItem(IDC_EDIT_NBIsos )->EnableWindow(EnableButton);
GetDlgItem(IDC_STATIC_NbIsos )->EnableWindow(EnableButton);
if(m_Algo == 0)
{
if (m_DisplayMode == 5) m_DisplayMode=0;
if (m_DisplayMode == 10) m_DisplayMode=0;
if(m_Algo == 0)
{
if (m_DisplayMode == 5) m_DisplayMode=0;
if (m_DisplayMode == 10) m_DisplayMode=0;
GetDlgItem(IDC_VIsoParametrics)->EnableWindow(false);
GetDlgItem(IDC_HIsoParametrics)->EnableWindow(false);
GetDlgItem(IDC_STATIC_NbIsos) ->EnableWindow(false);
GetDlgItem(IDC_EDIT_NBIsos) ->EnableWindow(false);
}
else
{
GetDlgItem(IDC_VIsoParametrics)->EnableWindow(true);
GetDlgItem(IDC_HIsoParametrics)->EnableWindow(m_DrawHiddenLine);
GetDlgItem(IDC_STATIC_NbIsos) ->EnableWindow(true);
GetDlgItem(IDC_EDIT_NBIsos) ->EnableWindow(true);
}
UpdateData(false);
GetDlgItem(IDC_VIsoParametrics)->EnableWindow(false);
GetDlgItem(IDC_HIsoParametrics)->EnableWindow(false);
GetDlgItem(IDC_STATIC_NbIsos) ->EnableWindow(false);
GetDlgItem(IDC_EDIT_NBIsos) ->EnableWindow(false);
}
else
{
GetDlgItem(IDC_VIsoParametrics)->EnableWindow(true);
GetDlgItem(IDC_HIsoParametrics)->EnableWindow(m_DrawHiddenLine);
GetDlgItem(IDC_STATIC_NbIsos) ->EnableWindow(true);
GetDlgItem(IDC_EDIT_NBIsos) ->EnableWindow(true);
}
UpdateData(false);
}
void CSelectionDialog::OnDisplayDefault()
@ -343,7 +341,8 @@ void CSelectionDialog::OnUpdate2D()
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_WAIT));
myDoc->ActivateFrame(RUNTIME_CLASS(OCC_2dView),SW_NORMAL);
UpdateProjector();
Apply();
Apply();
myDoc->FitAll2DViews(Standard_False);
SetCursor(AfxGetApp()->LoadStandardCursor(IDC_ARROW));
}

View File

@ -64,23 +64,25 @@ void ISession2D_Shape::BuildPolyAlgo()
myPolyAlgo->Update();
}
void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,
const Handle(Prs3d_Presentation)& aPresentation,
const Standard_Integer aMode)
void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& thePresentationManager,
const Handle(Prs3d_Presentation)& thePresentation,
const Standard_Integer theMode)
{
Standard_Integer TheMode = aMode;
Standard_Integer aMode = theMode;
Standard_Boolean DrawHiddenLine= Standard_True;
if (TheMode >= 1000)
thePresentation->Clear();
if (aMode >= 1000)
{
DrawHiddenLine = Standard_False;
TheMode -= 1000;
aMode -= 1000;
}
Standard_Boolean UsePolyAlgo= Standard_True;
if (TheMode >= 100)
if (aMode >= 100)
{
UsePolyAlgo = Standard_False;
TheMode -= 100;
aMode -= 100;
}
TopoDS_Shape VCompound;
TopoDS_Shape Rg1LineVCompound;
@ -132,35 +134,35 @@ void ISession2D_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPres
Handle(Prs3d_LineAspect) aLineAspect = new Prs3d_LineAspect(Quantity_NOC_WHITE,
Aspect_TOL_SOLID,1);
switch(TheMode)
switch(aMode)
{
case (1):
{
DrawCompound(aPresentation, VCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, VCompound, aLineAspectHighlighted);
break;
}
case (2):
{
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspectHighlighted);
break;
}
case (3):
{
DrawCompound(aPresentation, RgNLineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, RgNLineVCompound, aLineAspectHighlighted);
break;
}
case (4):
{
DrawCompound(aPresentation, OutLineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, OutLineVCompound, aLineAspectHighlighted);
break;
}
default:
{
DrawCompound(aPresentation,VCompound, aLineAspect);
DrawCompound(aPresentation,Rg1LineVCompound, aLineAspect);
DrawCompound(aPresentation,RgNLineVCompound, aLineAspect);
DrawCompound(aPresentation,OutLineVCompound, aLineAspect);
DrawCompound(thePresentation,VCompound, aLineAspect);
DrawCompound(thePresentation,Rg1LineVCompound, aLineAspect);
DrawCompound(thePresentation,RgNLineVCompound, 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,
Aspect_TOL_DOTDASH,1);
switch(TheMode)
switch(aMode)
{
case (6):
{
DrawCompound(aPresentation, HCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, HCompound, aLineAspectHighlighted);
break;
}
case (7):
{
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspectHighlighted);
break;
}
case (8):
{
DrawCompound(aPresentation, RgNLineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, RgNLineHCompound, aLineAspectHighlighted);
break;
}
case (9):
{
DrawCompound(aPresentation, OutLineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, OutLineHCompound, aLineAspectHighlighted);
break;
}
default:
{
DrawCompound(aPresentation, HCompound, aLineAspect);
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspect);
DrawCompound(aPresentation, RgNLineHCompound, aLineAspect);
DrawCompound(aPresentation, OutLineHCompound, aLineAspect);
DrawCompound(thePresentation, HCompound, aLineAspect);
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspect);
DrawCompound(thePresentation, RgNLineHCompound, 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,
Aspect_TOL_SOLID,1);
switch (TheMode)
switch (aMode)
{
case (1):
{
DrawCompound(aPresentation, VCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, VCompound, aLineAspectHighlighted);
break;
}
case (2):
{
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspectHighlighted);
break;
}
case (3):
{
DrawCompound(aPresentation, RgNLineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, RgNLineVCompound, aLineAspectHighlighted);
break;
}
case (4):
{
DrawCompound(aPresentation, OutLineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, OutLineVCompound, aLineAspectHighlighted);
break;
}
case (5):
{
DrawCompound(aPresentation, IsoLineVCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, IsoLineVCompound, aLineAspectHighlighted);
break;
}
default:
{
DrawCompound(aPresentation, VCompound, aLineAspect);
DrawCompound(aPresentation, Rg1LineVCompound, aLineAspect);
DrawCompound(aPresentation, RgNLineVCompound, aLineAspect);
DrawCompound(aPresentation, OutLineVCompound, aLineAspect);
DrawCompound(aPresentation, IsoLineVCompound , aLineAspect);
DrawCompound(thePresentation, VCompound, aLineAspect);
DrawCompound(thePresentation, Rg1LineVCompound, aLineAspect);
DrawCompound(thePresentation, RgNLineVCompound, aLineAspect);
DrawCompound(thePresentation, OutLineVCompound, 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,
Aspect_TOL_DOT,1);
switch(TheMode)
switch(aMode)
{
case (6):
{
DrawCompound(aPresentation, HCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, HCompound, aLineAspectHighlighted);
break;
}
case (7):
{
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspectHighlighted);
break;
}
case (8):
{
DrawCompound(aPresentation, RgNLineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, RgNLineHCompound, aLineAspectHighlighted);
break;
}
case (9):
{
DrawCompound(aPresentation, OutLineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, OutLineHCompound, aLineAspectHighlighted);
break;
}
case (10):
{
DrawCompound(aPresentation, IsoLineHCompound, aLineAspectHighlighted);
DrawCompound(thePresentation, IsoLineHCompound, aLineAspectHighlighted);
break;
}
default:
{
DrawCompound(aPresentation, HCompound, aLineAspect);
DrawCompound(aPresentation, Rg1LineHCompound, aLineAspect);
DrawCompound(aPresentation, RgNLineHCompound, aLineAspect);
DrawCompound(aPresentation, OutLineHCompound, aLineAspect);
DrawCompound(aPresentation, IsoLineHCompound, aLineAspect);
DrawCompound(thePresentation, HCompound, aLineAspect);
DrawCompound(thePresentation, Rg1LineHCompound, aLineAspect);
DrawCompound(thePresentation, RgNLineHCompound, aLineAspect);
DrawCompound(thePresentation, OutLineHCompound, 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);
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) ;