// Created on: 1998-03-27 // Created by: Robert COUBLANC // Copyright (c) 1998-1999 Matra Datavision // Copyright (c) 1999-2014 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and / or modify it // under the terms of the GNU Lesser General Public version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #include #include #include #include #include #include #include #include #include StdSelect_Shape::StdSelect_Shape(const TopoDS_Shape& sh): mysh(sh) {} void StdSelect_Shape::Compute(const Handle(PrsMgr_PresentationManager3d)& /*PM*/, const Handle(Prs3d_Presentation)& P, const Standard_Integer aMode) { if(mysh.IsNull()) return; static Handle(Prs3d_Drawer) DRWR; if(DRWR.IsNull()){ DRWR = new Prs3d_Drawer(); DRWR->WireAspect()->SetWidth(2); DRWR->LineAspect()->SetWidth(2.); DRWR->PlaneAspect()->EdgesAspect()->SetWidth(2.); DRWR->FreeBoundaryAspect()->SetWidth(2.); DRWR->UnFreeBoundaryAspect()->SetWidth(2.); Standard_Integer I = 5;//pour tests... DRWR->PointAspect()->SetTypeOfMarker((Aspect_TypeOfMarker)I); DRWR->PointAspect()->SetScale(2.); } Standard_Boolean CanShade = (mysh.ShapeType()<5 || mysh.ShapeType()==8); if(aMode==1){ if(CanShade) StdPrs_ShadedShape::Add(P,mysh,DRWR); else StdPrs_WFShape::Add(P,mysh,DRWR); } else if (aMode==0) StdPrs_WFShape::Add(P,mysh,DRWR); } void StdSelect_Shape::Compute(const Handle_Prs3d_Projector& aProjector , const Handle_Geom_Transformation& aGeomTrans, const Handle_Prs3d_Presentation& aPresentation ) { PrsMgr_PresentableObject::Compute(aProjector,aGeomTrans,aPresentation); } void StdSelect_Shape::Compute(const Handle_Prs3d_Projector& aProjector, const Handle_Prs3d_Presentation& aPresentation) { PrsMgr_PresentableObject::Compute(aProjector,aPresentation); }