diff --git a/src/AIS/AIS_ConnectedInteractive.cxx b/src/AIS/AIS_ConnectedInteractive.cxx index 4f74b25e80..d2d5010762 100644 --- a/src/AIS/AIS_ConnectedInteractive.cxx +++ b/src/AIS/AIS_ConnectedInteractive.cxx @@ -56,21 +56,6 @@ AIS_InteractiveObject(aTypeOfPresentation3d) SetHilightMode(0); } -//======================================================================= -//function : Type -//purpose : -//======================================================================= -AIS_KindOfInteractive AIS_ConnectedInteractive::Type() const -{ - return AIS_KOI_Object; -} - -Standard_Integer AIS_ConnectedInteractive::Signature() const -{ - return 0; -} - - //======================================================================= //function : Connect //purpose : diff --git a/src/AIS/AIS_ConnectedInteractive.hxx b/src/AIS/AIS_ConnectedInteractive.hxx index f7ac4c39ea..31255f1fe2 100644 --- a/src/AIS/AIS_ConnectedInteractive.hxx +++ b/src/AIS/AIS_ConnectedInteractive.hxx @@ -57,8 +57,6 @@ class AIS_ConnectedInteractive : public AIS_InteractiveObject public: - - //! Disconnects the previous view and sets highlight //! mode to 0. This highlights the wireframe presentation //! aTypeOfPresentation3d. @@ -66,52 +64,50 @@ public: Standard_EXPORT AIS_ConnectedInteractive(const PrsMgr_TypeOfPresentation3d aTypeOfPresentation3d = PrsMgr_TOP_AllView); //! Returns KOI_Object - Standard_EXPORT virtual AIS_KindOfInteractive Type() const Standard_OVERRIDE; - - //! Returns 1 - Standard_EXPORT virtual Standard_Integer Signature() const Standard_OVERRIDE; + virtual AIS_KindOfInteractive Type() const Standard_OVERRIDE { return AIS_KOI_Object; } + + //! Returns 0 + virtual Standard_Integer Signature() const Standard_OVERRIDE { return 0; } //! Establishes the connection between the Connected //! Interactive Object, anotherIobj, and its reference. Standard_EXPORT virtual void Connect (const Handle(AIS_InteractiveObject)& anotherIObj); - + //! Establishes the connection between the Connected //! Interactive Object, anotherIobj, and its reference. //! Locates instance in aLocation. Standard_EXPORT virtual void Connect (const Handle(AIS_InteractiveObject)& anotherIobj, const gp_Trsf& aLocation); - //! Returns true if there is a connection established //! between the presentation and its source reference. - Standard_Boolean HasConnection() const; - + Standard_Boolean HasConnection() const { return !myReference.IsNull(); } //! Returns the connection with the reference Interactive Object. - const Handle(AIS_InteractiveObject)& ConnectedTo() const; - + const Handle(AIS_InteractiveObject)& ConnectedTo() const { return myReference; } + //! Clears the connection with a source reference. The //! presentation will no longer be displayed. //! Warning Must be done before deleting the presentation. Standard_EXPORT void Disconnect(); - + //! Informs the graphic context that the interactive Object //! may be decomposed into sub-shapes for dynamic selection. - virtual Standard_Boolean AcceptShapeDecomposition() const Standard_OVERRIDE; - - + virtual Standard_Boolean AcceptShapeDecomposition() const Standard_OVERRIDE + { + return !myReference.IsNull() && myReference->AcceptShapeDecomposition(); + } + //! Return true if reference presentation accepts specified display mode. + virtual Standard_Boolean AcceptDisplayMode (const Standard_Integer theMode) const Standard_OVERRIDE + { + return myReference.IsNull() + || myReference->AcceptDisplayMode (theMode); + } DEFINE_STANDARD_RTTIEXT(AIS_ConnectedInteractive,AIS_InteractiveObject) protected: - - Handle(AIS_InteractiveObject) myReference; - - -private: - - //! Calculates the view aPresentation and its updates. //! The latter are managed by aPresentationManager. //! The display mode aMode is 0 by default. @@ -121,8 +117,8 @@ private: //! compute anything, but just uses the //! presentation of this last object, with //! a transformation if there's one stored. - Standard_EXPORT virtual void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, const Handle(Prs3d_Presentation)& aPresentation, const Standard_Integer aMode = 0) Standard_OVERRIDE; - + Standard_EXPORT virtual void Compute (const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, const Handle(Prs3d_Presentation)& aPresentation, const Standard_Integer aMode) Standard_OVERRIDE; + //! Computes the presentation according to a point of view //! given by . //! To be Used when the associated degenerated Presentations @@ -131,37 +127,32 @@ private: //! WARNING : must be applied //! to the object to display before computation !!! Standard_EXPORT virtual void Compute (const Handle(Prs3d_Projector)& aProjector, const Handle(Geom_Transformation)& aTrsf, const Handle(Prs3d_Presentation)& aPresentation) Standard_OVERRIDE; - + //! Computes the presentation according to a point of view //! given by . Standard_EXPORT virtual void Compute (const Handle(Prs3d_Projector)& aProjector, const Handle(Prs3d_Presentation)& aPresentation) Standard_OVERRIDE; - + //! Generates sensitive entities by copying //! them from myReference selection, creates and sets an entity //! owner for this entities and adds them to theSelection Standard_EXPORT virtual void ComputeSelection (const Handle(SelectMgr_Selection)& theSelection, const Standard_Integer theMode) Standard_OVERRIDE; - + //! Generates sensitive entities by copying //! them from myReference sub shapes selection, creates and sets an entity //! owner for this entities and adds them to theSelection Standard_EXPORT void computeSubShapeSelection (const Handle(SelectMgr_Selection)& theSelection, const Standard_Integer theMode); - + Standard_EXPORT void updateShape (const Standard_Boolean WithLocation = Standard_True); - + //! Computes the presentation according to a point of view //! given by . Standard_EXPORT void Compute (const Handle(Prs3d_Projector)& aProjector, const Handle(Prs3d_Presentation)& aPresentation, const TopoDS_Shape& aShape); - TopoDS_Shape myShape; +protected: + Handle(AIS_InteractiveObject) myReference; + TopoDS_Shape myShape; }; - -#include - - - - - #endif // _AIS_ConnectedInteractive_HeaderFile diff --git a/src/AIS/AIS_ConnectedInteractive.lxx b/src/AIS/AIS_ConnectedInteractive.lxx deleted file mode 100644 index 7f12b4c91d..0000000000 --- a/src/AIS/AIS_ConnectedInteractive.lxx +++ /dev/null @@ -1,25 +0,0 @@ -// Created on: 1997-01-08 -// Created by: Robert COUBLANC -// Copyright (c) 1997-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 License 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. - -inline const Handle(AIS_InteractiveObject)& AIS_ConnectedInteractive::ConnectedTo() const -{return myReference;} - - -inline Standard_Boolean AIS_ConnectedInteractive::HasConnection() const -{return !myReference.IsNull();} - -inline Standard_Boolean AIS_ConnectedInteractive::AcceptShapeDecomposition() const -{return myReference.IsNull()? Standard_False : myReference->AcceptShapeDecomposition();} diff --git a/src/AIS/FILES b/src/AIS/FILES index c4ea1469a3..70d284bf6a 100644 --- a/src/AIS/FILES +++ b/src/AIS/FILES @@ -30,7 +30,6 @@ AIS_ConcentricRelation.cxx AIS_ConcentricRelation.hxx AIS_ConnectedInteractive.cxx AIS_ConnectedInteractive.hxx -AIS_ConnectedInteractive.lxx AIS_ConnectStatus.hxx AIS_DataMapIteratorOfDataMapOfILC.hxx AIS_DataMapIteratorOfDataMapofIntegerListOfinteractive.hxx