|
ACF $AcfVersion:0$
|
Basic implementation of a multiple model observer. More...
#include <CMultiModelObserverBase.h>
Public Member Functions | |
| CMultiModelObserverBase () | |
| virtual | ~CMultiModelObserverBase () |
| int | GetModelCount () const |
| Gets the number of connected models. | |
| IModel * | GetObservedModel (int modelIndex) const |
Get access to connected model with the index index. | |
| IModel * | GetModelPtr (int modelIndex) const |
Get access to connected model with the index index. | |
| void | EnsureModelsDetached () |
| Ensure all attached models are detached. | |
| void | SetObservedIds (const istd::IChangeable::ChangeSet &changeMask) |
| Set list of ID's beeing observed. | |
| virtual bool | IsModelAttached (const IModel *modelPtr) const override |
| Checks if the specified model is currently attached to this observer. | |
| virtual bool | OnModelAttached (IModel *modelPtr, istd::IChangeable::ChangeSet &changeMask) override |
| Callback invoked when an observable model is about to be attached to this observer. | |
| virtual bool | OnModelDetached (IModel *modelPtr) override |
| Callback invoked when an observable model is about to be detached from this observer. | |
| virtual void | BeforeUpdate (IModel *modelPtr) override |
| Callback invoked before an update of the observer's content occurs. | |
| virtual void | AfterUpdate (IModel *modelPtr, const istd::IChangeable::ChangeSet &changeSet) override |
| Callback invoked after an update of the observer's content occurs. | |
Public Member Functions inherited from istd::IPolymorphic | |
| virtual | ~IPolymorphic () |
Protected Member Functions | |
| virtual void | OnUpdate (IModel *modelPtr, const istd::IChangeable::ChangeSet &changeSet) |
| Called on update of observed model. | |
Basic implementation of a multiple model observer.
Definition at line 23 of file CMultiModelObserverBase.h.
| imod::CMultiModelObserverBase::CMultiModelObserverBase | ( | ) |
|
virtual |
|
overridevirtual |
Callback invoked after an update of the observer's content occurs.
This is the primary notification method where observers react to model changes. It's called after the model has finished updating its state. The implementation should examine the changeSet to determine what changed and update accordingly.
| modelPtr | Pointer to the model that has changed |
| changeSet | Contains information about what changed in the model. Use changeSet.Contains(changeId) to check for specific changes. The changeSet respects the mask specified in OnModelAttached(). |
Implements imod::IObserver.
|
overridevirtual |
Callback invoked before an update of the observer's content occurs.
This method is called at the start of a model update cycle, before any data actually changes. It allows the observer to prepare for the update, such as saving current state for comparison or disabling UI updates temporarily.
| modelPtr | Pointer to the model that is about to change |
Implements imod::IObserver.
| void imod::CMultiModelObserverBase::EnsureModelsDetached | ( | ) |
Ensure all attached models are detached.
If there are some attached models they will be detached and removed from observed list.
| int imod::CMultiModelObserverBase::GetModelCount | ( | ) | const |
Gets the number of connected models.
| IModel * imod::CMultiModelObserverBase::GetModelPtr | ( | int | modelIndex | ) | const |
Get access to connected model with the index index.
GetObservedModel instead. | IModel * imod::CMultiModelObserverBase::GetObservedModel | ( | int | modelIndex | ) | const |
Get access to connected model with the index index.
| modelIndex | index of model. |
|
overridevirtual |
Checks if the specified model is currently attached to this observer.
This method allows querying whether a specific model is being observed, or whether any model at all is attached.
| modelPtr | Pointer to the model object to check. If nullptr, checks whether any model is attached to this observer. |
Implements imod::IObserver.
|
overridevirtual |
Callback invoked when an observable model is about to be attached to this observer.
This method is called by the model when attempting to establish an observer relationship. The implementation should:
| modelPtr | Pointer to the model object being attached. Never nullptr. |
| changeMask | Output parameter where the observer specifies which change types it wants to be notified about. Set the appropriate change flags using changeMask.Set(changeId). An empty mask means the observer wants all changes. |
Implements imod::IObserver.
Reimplemented in imod::TMultiModelObserverBase< ModelInterface >.
|
overridevirtual |
Callback invoked when an observable model is about to be detached from this observer.
This method is called when the observer-model relationship is being terminated, either explicitly or because the model is being destroyed. The implementation should clean up any state or resources related to this model.
| modelPtr | Pointer to the model object being detached |
Implements imod::IObserver.
|
protectedvirtual |
Called on update of observed model.
This method is designed to be overload by derrived classes.
| void imod::CMultiModelObserverBase::SetObservedIds | ( | const istd::IChangeable::ChangeSet & | changeMask | ) |
Set list of ID's beeing observed.