mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0029940: The method TPrsStd_AISPresentation::SetSelectionMode() seems useless for transactions
A boolean parameter is added with a default value to the method TPrsStd_AISPresentation::SetSelectionMode(). By default, behavior of the method is not changed. But if the parameter's value is changed to FALSE, change of selection mode for the object will not influence the transaction. In other words, the attribute will not set modified and will not put into transaction delta. This behavior suits the usual notion of the object in an application: the object has color, material, transparency, but selection mode is not a property of the object. It is a property of an operation involving the object. Therefore, it has sense to remove the method SetSelectionMode() from TPrsStd_AISPresentation. For a while, it is marked as obsolete.
This commit is contained in:
parent
6487fb1c9c
commit
31e8d3c185
@ -285,11 +285,12 @@ void TDataXtd_Presentation::SetMode(const Standard_Integer theMode)
|
||||
//function : SetSelectionMode
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void TDataXtd_Presentation::SetSelectionMode(const Standard_Integer theSelectionMode)
|
||||
void TDataXtd_Presentation::SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction)
|
||||
{
|
||||
if (! myHasOwnSelectionMode || mySelectionMode != theSelectionMode)
|
||||
{
|
||||
Backup();
|
||||
if (theTransaction)
|
||||
Backup();
|
||||
mySelectionMode = theSelectionMode;
|
||||
myHasOwnSelectionMode = Standard_True;
|
||||
}
|
||||
|
@ -114,7 +114,13 @@ public:
|
||||
|
||||
Standard_EXPORT void SetMode(const Standard_Integer theMode);
|
||||
|
||||
Standard_EXPORT void SetSelectionMode(const Standard_Integer theSelectionMode);
|
||||
//! Sets selection mode.
|
||||
//! If "theTransaction" flag is OFF, modification of the attribute doesn't influence the transaction mechanism
|
||||
//! (the attribute doesn't participate in undo/redo).
|
||||
//! Certainly, if any other data of the attribute is modified (display mode, color, ...),
|
||||
//! the attribute will be included into transaction.
|
||||
//! Obsolete method (may be removed later).
|
||||
Standard_EXPORT void SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction = Standard_True);
|
||||
|
||||
Standard_EXPORT Standard_Integer MaterialIndex() const;
|
||||
|
||||
|
@ -591,10 +591,11 @@ Standard_Boolean TPrsStd_AISPresentation::HasOwnSelectionMode() const
|
||||
//function : SetSelectionMode
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void TPrsStd_AISPresentation::SetSelectionMode(const Standard_Integer theSelectionMode)
|
||||
void TPrsStd_AISPresentation::SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction)
|
||||
{
|
||||
Backup();
|
||||
getData()->SetSelectionMode (theSelectionMode);
|
||||
if (theTransaction)
|
||||
Backup();
|
||||
getData()->SetSelectionMode (theSelectionMode, theTransaction);
|
||||
|
||||
if ( myAIS.IsNull() )
|
||||
AISUpdate();
|
||||
|
@ -157,8 +157,14 @@ public:
|
||||
Standard_EXPORT void UnsetMode();
|
||||
|
||||
Standard_EXPORT Standard_Integer SelectionMode() const;
|
||||
|
||||
Standard_EXPORT void SetSelectionMode (const Standard_Integer theSelectionMode);
|
||||
|
||||
//! Sets selection mode.
|
||||
//! If "theTransaction" flag is OFF, modification of the attribute doesn't influence the transaction mechanism
|
||||
//! (the attribute doesn't participate in undo/redo).
|
||||
//! Certainly, if any other data of the attribute is modified (display mode, color, ...),
|
||||
//! the attribute will be included into transaction.
|
||||
//! Obsolete method (may be removed later).
|
||||
Standard_EXPORT void SetSelectionMode (const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction = Standard_True);
|
||||
|
||||
Standard_EXPORT Standard_Boolean HasOwnSelectionMode() const;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user