45#define ML_CSOLIST_REFCOUNTED 1
217 inline unsigned int numSelectedCSOs()
const {
return static_cast<unsigned int>(_selectedCSOs.size()); }
219 inline unsigned int numSelectedGroups()
const {
return static_cast<unsigned int>(_selectedGroups.size()); }
224 if (_selectedCSOs.size() > 0) {
225 return _selectedCSOs[index];
233 if (_selectedGroups.size() > 0) {
234 return _selectedGroups[index];
262 CSO_DEBUG(
"Using the deprecated method 'CSOList::getCenterOfSelectedCSOs()'; use 'CSOList::getCenterOfSelectedCSOs(bool& resultIsValid)' instead!");
270 CSO_DEBUG(
"Using the deprecated method 'CSOList::getCenterOfSelectedGroups()'; use 'CSOList::getCenterOfSelectedGroups(bool& resultIsValid)' instead!");
283 CSO*
addCSO(
const std::vector<Vector3>& seedPositions,
bool closed,
bool useUndoRedo);
286 CSO*
addCSO(
unsigned int numSeedPoints,
bool closed,
bool useUndoRedo);
301 CSO*
addCircle(
const Vector3& midPoint,
const Vector3& normal,
double radius,
double pointDistanceInMM = 1.,
const std::string& subtype=
"circle");
303 CSO*
addArrow(
const Vector3& pointAt,
const Vector3& direction,
double length,
double pointDistanceInMM = 1.,
const std::string& subtype=
"arrow");
305 CSO*
addPolygon(
const std::vector<Vector3>& points,
double pointDistanceInMM = 1.,
const std::string& subtype=
"polygon");
307 CSO*
addPolyline(
const std::vector<Vector3>& points,
double pointDistanceInMM = 1.,
const std::string& subtype=
"polyline");
310 CSO*
addClosedSpline(
const std::vector<Vector3>& points,
bool useInterpolation=
true,
double pointDistanceInMM = 1.,
const std::string& subtype=
"spline");
313 CSO*
addOpenSpline(
const std::vector<Vector3>& points,
bool useInterpolation=
true,
double pointDistanceInMM = 1.,
const std::string& subtype=
"spline");
320 double angleInRadian = .0,
double pointDistanceInMM = 1.,
const std::string& subtype =
"rectangle");
328 double angleInRadian = .0,
double pointDistanceInMM = 1.,
const std::string& subtype =
"ellipse");
349 bool removeGroups(
const std::vector<CSOGroup *> &groupsToRemove,
bool useUndoRedo=
true);
640 index0 = index1 = -1;
652 std::vector<CSO*>_csoList;
654 std::vector<CSOGroup*>_groupList;
657 std::vector<CSO*>_selectedCSOs;
659 std::vector<CSOGroup*>_selectedGroups;
662 CSO* _currentlyUnderMouseCSO;
665 bool _csoUndoRedoManagerEnabled;
667 CSOUndoRedoManager* _csoUndoRedoManager;
669 CSOManager* _csoManager;
674 unsigned int _currentLastCSOId;
677 unsigned int _currentLastGroupId;
681 static std::vector<CSOList*> _registeredCSOLists;
684 std::vector<CSONotificationCBData>_notificationObservers;
687 std::map<std::string, int>_csoLabelUniqueIdMap;
690 std::map<std::string, int>_groupLabelUniqueIdMap;
694 static MLuint64 _uniqueListChangeId;
697 bool _enableRepaintObserver;
699 bool _enableFinishedObserver;
701 bool _enableInteractionObserver;
703 bool _enableSelectionObserver;
705 bool _enableStartNewCSOObserver;
707 bool _enableCSOMovedObserver;
709 bool _enableCSOCurrentlyUnderMouseObserver;
712 int _numberOfEventMuteRequests;
718 inline bool _canUseUndoRedo(
bool shouldUseUndoRedo)
const {
return shouldUseUndoRedo && _csoUndoRedoManagerEnabled && _csoUndoRedoManager; }
720 void _setDefaultValues(CSO* cso);
722 void _setDefaultValues(CSOGroup* group);
724 void _setDefaultRules(CSOGroup* group);
727 void _emptyInternalListOfCSOs();
729 void _emptyInternalListOfGroups();
732 CSOIdVector _filterContainedGroups(
const std::vector<CSOGroup*> &groups,
const std::vector<CSOGroup*>& container);
733 CSOIdVector _filterContainedCSOs(
const std::vector<CSO*> &csos,
const std::vector<CSO*>& container);
736 bool pathPointListIndexIsInRange(CSO* cso,
int index)
const;
738 bool seedPointIndexIsRange(CSO* cso,
int index)
const;
745 bool _fromStreamV1(std::istream& inStream, std::string& message);
748 bool _fromStreamV3(std::istream& inStream, std::string& message);
751 bool _fromStreamV4(std::istream& inStream, std::string& message);
754 bool _fromStreamV5(std::istream& inStream,
bool asBinary, std::string& message);
756 bool loadFromVersionBefore5(std::istream& inStream,
bool binary,
short version,
bool swapBytes, std::string& message);
759 bool _fromStreamV6(std::istream& inStream,
bool asBinary, std::string& message, ModuleBackgroundTask* task=
nullptr);
762 void reconstructPathPointListToSeedPointLinks( CSO* cso, std::vector<IndexPair>& pathIndexPairs, std::vector<IndexPair>& seedIndexPairs,
const std::string& version, std::string& message);
766 bool _checkLine(
const std::string& line,
const std::string& name, std::string& errorMessage);
769 inline std::string spaces(
unsigned int numSpaces)
const
771 std::stringstream result;
772 for (
unsigned int i = 0; i < numSpaces; ++i)
780 std::string buildLabel(std::string label, std::string format,
int id)
783 size_t p = format.find(
"%i");
784 if (p == std::string::npos)
787 p = format.find(
"%i");
789 std::stringstream ss;
791 std::string tmp = format.replace(p, 2, ss.str());
792 return label.append(tmp);
796 static void registerCSOList(CSOList* csoList);
798 static void deregisterCSOList(CSOList* csoList);
#define CSO_DEBUG(msg)
Output macro for debug output.
std::map< unsigned int, unsigned int > CSOIdToCSOIdMap
Defines a map type to map old CSOIds to new CSOIds when merging CSOLists.
const unsigned int INVALID_CSO_ID
Defines a CSO/CSOGroup ID that is invalid.
std::vector< unsigned int > CSOIdVector
Defines a vector to hold CSO and CSOGroup IDs.
#define MLCSO_EXPORT
Defines export symbols for classes, so they can be used in other DLLs.
CSOEventType
Enumeration for specifying the exact type of event.
void updateCurrentGroupId(const unsigned int newId)
Updates the current CSOGroup ID if the new ID is larger than the current ID.
CSO * addCSO(const std::vector< Vector3 > &seedPositions, bool closed, bool useUndoRedo)
void sendModuleEventGroup(CSOEvent *event)
Sends a module CSOGroup event.
void enableFinishedObserver()
Enables the finished observer mechanism.
Vector3 getCenterOfSelectedCSOs(bool &resultIsValid) const
MLuint64 getListChangeId() const
Returns the list change ID that changes whenever a CSO is added or removed (unique accross all CSOLis...
unsigned int getCSOIndex(CSO *cso) const
Returns the index of the specified CSO in its list.
CSO * addCSO(unsigned int numSeedPoints, bool closed, bool useUndoRedo)
CSOGroup * addGroup(const std::string &label, bool useUndoRedo=true)
Adds a new CSOGroup with specified label to the list and returns a pointer to it.
bool isStartNewCSONotificationEnabled() const
Returns whether the 'start new CSO' notification is enabled.
void breakCSOfromAllGroups(CSO *cso, bool useUndoRedo=true)
Breaks all combinations of the specified CSO and any CSOGroup.
CSOIdVector getSelectedCSOIds()
Returns a vector with IDs of the selected CSOs.
unsigned int getGroupIndex(unsigned int id) const
Returns the index of the CSOGroup with the specified ID in its list.
void disableCSOMovedObserver()
Disables the 'CSO moved' observer mechanism.
bool saveTo(std::string &filename, bool binary, std::string &message, ModuleBackgroundTask *task=nullptr) const
CSO * addArrow(const Vector3 &pointAt, const Vector3 &direction, double length, double pointDistanceInMM=1., const std::string &subtype="arrow")
Adds an arrow pointing to pointAt from direction with a length.
CSO * addCSOCopy(CSO *cso, bool useUndoRedo=true, unsigned int csoId=INVALID_CSO_ID)
Adds a copy of the specified CSO to the list and returns a pointer to it.
bool setSelected(CSO *cso)
CSOList(const CSOList &csoList)
Copy constructor.
CSOList * deepCopy() const override
Creates a deep copy of the CSOList.
void sendPreEvent(CSOEvent::CSOEventType eventType, unsigned int csoId, unsigned int groupId)
void enableInteractionObserver()
Enables the interaction observer mechanism.
CSO * addPolyline(const std::vector< Vector3 > &points, double pointDistanceInMM=1., const std::string &subtype="polyline")
Adds a linearly interpolated open polyline with the specified points as seed points.
bool isSelected(const CSOGroup *group) const
Returns whether the specified CSOGroup is currently selected.
void resetUniqueGroupLabelIdMap()
CSOGroup * getGroupById(unsigned int id) const
Returns a pointer to a CSOGroup with the specified ID.
CSOUndoRedoManager * getUndoRedoManager()
Returns a pointer to the undo/redo manager of this CSOList.
CSOList(bool shouldRegisterCSOList)
void sendPreEvent(CSOEvent::CSOEventType eventType, const CSOIdVector &csoIds)
Sends a pre-event with the specified event type and the CSO IDs.
bool hasCSO(CSO *cso) const
Returns whether there is the specified CSO in the list.
bool removeGroups(const std::vector< CSOGroup * > &groupsToRemove, bool useUndoRedo=true)
bool removeCSO(unsigned int id, bool useUndoRedo=true)
std::string getUniqueCSOLabel(std::string label, std::string format, bool addIdAlways)
unsigned int getCurrentGroupId()
CSOGroup * addGroup(bool useUndoRedo=true)
Adds a new CSOGroup to the list and returns a pointer to it.
unsigned int numCSOs() const
Returns the number of CSOs in the list.
void disableFinishedObserver()
Disables the finished observer mechanism.
void listChanged()
Called whenever the list has changed to generate a new ID. This also changes the geometry ID.
CSOIdVector getAllCSOIds() const
Returns a vector with the IDs of the CSOs contained in the list.
void removeFromSelection(CSO *cso)
Removes the specified CSO from the list of selected CSOs.
void addSelected(CSOGroup *group)
Adds the specified CSOGroup to the list of selected CSOGroups (no double entry).
void addSelected(CSO *cso)
Adds the specified CSO to the list of selected CSOs (no double entry).
CSOGroup * getGroupAt(unsigned int index) const
Returns the CSOGroup at the specified index position.
void breakAllCSOsFromGroup(CSOGroup *group, bool useUndoRedo=true)
Breaks all combinations of the specified CSOGroup and any CSO.
void sendPostEvent(CSOEvent::CSOEventType eventType, unsigned int csoId, const CSOIdVector &groupIds)
void sendPostEvent(CSOEvent::CSOEventType eventType, const CSOIdVector &csoIds, const CSOIdVector &groupIds)
Sends a post-event with the specified type, CSO IDs, and CSOGroup IDs.
void registerCSOListForNotificationObservers()
Registers this CSOList in the static list of CSOLists for handling observers.
void sendPostEvent(CSOEvent::CSOEventType eventType, const CSOIdVector &csoIds)
Sends a post-event with the specified type and CSO IDs.
CSO * addCSO(bool useUndoRedo=true)
Adds a new CSO to the list and returns its pointer.
void setManager(CSOManager *manager)
Sets the pointer to the internal manager and sets the CSOGroup default rules.
void undo()
Performs an undo of the last modification.
void setCurrentCSOId(unsigned int id)
Sets the current last ID for CSOs. Do not tamper with it.
void removeNotificationObserver(csoNotificationCB *callback, void *userData)
Removes a notification observer from this CSOList.
bool isNotMutingEvents()
Returns whether CSOEvents are currently emitted.
CSO * getCSOById(unsigned int id) const
CSOGroup * getGroupByLabel(const std::string &label) const
Returns a pointer to a CSOGroup with the specified label.
void sendCloseEventGroup()
Sends a CSOLIST_EVENT_GROUP_CLOSE event to let listeners combine preceding events....
void clearSelectedCSOs()
Clears all selected CSOs.
void enableSelectionObserver()
Enables the selection observer mechanism.
CSOList()
Standard constructor.
bool removeGroup(CSOGroup *group, bool useUndoRedo=true)
CSOIdVector getAllGroupIds() const
Returns a vector with the IDs of the CSOGroups contained in the list.
void enableStartNewCSOObserver()
Enables the 'start new CSO' observer mechanism.
void enableUndoRedoManager()
Enables the undo/redo mechanism.
bool removeAll(bool useUndoRedo=true)
void clone(const CSOList &csoList, bool useUndoRedo=false)
Clones the internal CSOs and CSOGroups of the specified CSOList to this one.
void notifyObservers(int notificationFlag)
Notifies all observers.
bool isInteractionInitNotificationEnabled() const
Returns whether the interaction init notification is enabled.
unsigned int numSelectedCSOs() const
Returns the number of selected CSOs.
CSO * addCircle(const Vector3 &midPoint, const Vector3 &normal, double radius, double pointDistanceInMM=1., const std::string &subtype="circle")
void merge(const CSOList &csoList, const CSOGroupMergeHandling mergeMode, CSOIdToCSOIdMap &origToThisGroupIdMap, CSOIdToCSOIdMap &origToThisCSOIdMap, bool useUndoRedo=false)
Merges the internal CSOs and CSOGroups of the specified CSOList to this one with the specified merge ...
void updateCurrentCSOId(unsigned int newId)
Updates the current ID if the new ID is larger than the current ID.
bool isFinishedNotificationEnabled() const
Returns whether the finished notification is enabled.
void merge(const CSOList &csoList, bool mergeGroupWithSameLabel, CSOIdToCSOIdMap &origToThisGroupIdMap, CSOIdToCSOIdMap &origToThisCSOIdMap, bool useUndoRedo=false)
Merges the internal CSOs and CSOGroups of the specified CSOList to this one.
bool removeCSO(CSO *cso, bool useUndoRedo=true)
bool isSelectionNotificationEnabled() const
Returns whether the selection notification is enabled.
void sendPreEvent(CSOEvent::CSOEventType eventType, const CSOIdVector &csoIds, const CSOIdVector &groupIds)
Sends a pre-event with the specified event type, CSO IDs, and CSOGroup IDs.
MLuint64 getGeometryChangeId() const
Returns the geometry change ID that changes on any CSO geometry change or list change (unique accross...
CSOGroup * addGroupCopy(CSOGroup *group, bool useUndoRedo=true, unsigned int groupId=INVALID_CSO_ID)
bool saveTo(std::ostream &outStream, bool binary, ModuleBackgroundTask *task=nullptr) const
static EnumValues< CSOPathPointsStyle > getLineStyleModes()
void sendOpenEventGroup()
Sends a CSOLIST_EVENT_GROUP_OPEN event to let listeners combine following events.
unsigned int numSelectedGroups() const
Returns the number of selected CSOGroups.
void removeFromSelection(const std::vector< CSO * > &csos)
Removes the specified CSOs from the list of selected CSOs.
CSO * getSelectedCSOAt(unsigned int index) const
Returns a pointer to the selected CSO at the specified index; no checking!
unsigned int getCSOIndex(unsigned int id) const
Returns the index of the CSO with the specified ID in its list.
bool isUndoRedoManagerEnabled() const
Returns 'true' if the undo/redo mechanism is enabled, 'false' otherwise.
void sendPreEvent(CSOEvent::CSOEventType eventType, unsigned int csoId)
Sends a pre-event with the specified event type and the CSO ID.
CSO * addEllipse(const Vector3 &midPoint, const Vector3 &uVector, const Vector3 &vVector, double angleInRadian=.0, double pointDistanceInMM=1., const std::string &subtype="ellipse")
CSO * getCSOByLabel(const std::string &label) const
ML_SET_ADDSTATE_VERSION(1)
void addStateToTree(TreeNode *) const override
Attaches the object state as children of the specified parent node.
bool isCSOMovedNotificationEnabled() const
Returns whether the 'CSO moved' notification is enabled.
bool removeAllCSO(bool useUndoRedo=true)
void resetUniqueCSOLabelIdMap()
CSO * getCSOCurrentlyUnderMouse() const
Returns the pointer to the CSO currently under the mouse cursor.
void disableSelectionObserver()
Disables the selection observer mechanism.
void removeFromSelection(const std::vector< CSOGroup * > &groups)
Removes the specified CSOGroups from the list of selected CSOGroups.
void sendPostEvent(CSOEvent::CSOEventType eventType, unsigned int csoId, unsigned int groupId)
CSO * addPoint(const Vector3 &position, const std::string &subtype="point")
Adds a point CSO at the specified position.
void setCurrentGroupId(unsigned int id)
Sets the current last ID for CSOGroups. Do not tamper with it.
CSO * addPolygon(const std::vector< Vector3 > &points, double pointDistanceInMM=1., const std::string &subtype="polygon")
Adds a linearly interpolated closed polygon with the specified points as seed points.
void muteEvents()
Prevents the CSOList from sending any CSOEvents until unmuteEvents is called.
unsigned int getCurrentCSOId()
CSO * addClosedSpline(const std::vector< Vector3 > &points, bool useInterpolation=true, double pointDistanceInMM=1., const std::string &subtype="spline")
CSO * addCSONoEvent(bool useUndoRedo=true)
Adds a new CSO to the list and returns its pointer. (Without sending any events).
void sendPostEvent(CSOEvent::CSOEventType eventType, unsigned int csoId)
Sends a post-event with the specified type and CSO ID.
void _addGroupRelationCommand(CSO *cso, CSOGroup *group)
Helper method to be used only inside MLCSO.
bool isRepaintNotificationEnabled() const
Returns whether the repaint notification is enabled.
void setUndoRedoManager(CSOUndoRedoManager *undoRedoManager)
Sets the internal undo/redo manager.
void addNotificationObserver(csoNotificationCB *callback, void *userData)
Adds a notification observer to this CSOList.
void closeUndoRedoGroup()
Closes a undo/redo group. All undoable commands before this are grouped together.
void disableUndoRedoManager()
Enables the undo/redo mechanism.
bool isCSOCurrentlyUnderMouseNotificationEnabled() const
Returns whether the 'CSO currently under mouse' notification is enabled.
static EnumValues< CSOVoxelWriteModes > getVoxelWriteModes()
Vector3 getCenterOfSelectedGroups(bool &resultIsValid) const
void enableCSOCurrentlyUnderMouseObserver()
Enables the 'CSO currently under mouse' observer mechanism.
void clearSelectedGroups()
Clears all selected CSOGroups.
Vector3 getCenterOfSelectedCSOs() const
void sendPreEvent(CSOEvent::CSOEventType eventType, unsigned int csoId, const CSOIdVector &groupIds)
bool isSelected(const CSO *cso) const
void disableCSOCurrentlyUnderMouseObserver()
Disables the 'CSO currently under mouse' observer mechanism.
void disableRepaintObserver()
Disables the repaint observer mechanism.
bool setSelected(CSOGroup *group)
bool loadFrom(std::string &filename, std::string &message, ModuleBackgroundTask *task=nullptr)
void disableStartNewCSOObserver()
Disables the 'start new CSO' observer mechanism.
static void removeNotificationObserverFromAllCSOLists(csoNotificationCB *callback, void *userData)
Removes a certain notification observer from all CSOLists.
void removeFromSelection(CSOGroup *group)
Removes the specified CSOGroup from the list of selected CSOGroups.
CSOGroup * getSelectedGroupAt(unsigned int index) const
Returns a pointer to the selected CSOGroup at the specified index; no checking!
void enableRepaintObserver()
Enables the repaint observer mechanism.
bool removeGroup(unsigned int id, bool useUndoRedo=true)
void setCSOCurrentlyUnderMouse(CSO *csoUnderMouse)
void updateDisplays()
Updates all connected information/managing modules (not the renderers!).
void openUndoRedoGroup(const std::string &description="Contour Operation")
Opens a undo/redo group. All undoable commands after this are grouped together.
void geometryChanged()
Called whenever the geometry of a CSO has changed.
CSOManager * getManager()
Returns a pointer to the manager of this CSOList.
void readStateFromTree(TreeNode *) override
Reads the object state from the children of the specified parent node.
@ NOTIFICATION_INTERACTION_INIT
Flag for the observer mechanism, should be set if the interaction must be initialized.
@ NOTIFICATION_CSO_MOVED
Flag for the observer mechanism, should be set if a CSO was moved.
@ NOTIFICATION_NONE
Flag for the observer mechanism, signalizing no notification at all.
@ NOTIFICATION_GROUP_FINISHED
Flag for the observer mechanism, should be set if a CSOGroup action is finished.
@ NOTIFICATION_UNDO_REDO_STATE_CHANGED
Flag for the observer mechanism, should be set if the availability of undo/redo steps changes.
@ NOTIFICATION_REPAINT
Flag for the observer mechanism, should be set if a repaint should occur.
@ NOTIFICATION_START_NEW_CSO
Flag for the observer mechanism, signalizing that the generation of a new CSO has been started.
@ NOTIFICATION_GROUP_SELECTION
Flag for the observer mechanism, should be set if a CSOGroup selection changes.
@ NOTIFICATION_CSO_UNDER_MOUSE_CHANGED
Flag for the observer mechanism, should be set if the CSO under the mouse cursor changes.
@ NOTIFICATION_CSO_FINISHED
Flag for the observer mechanism, should be set if a CSO action is finished.
@ NOTIFICATION_CSO_SELECTION
Flag for the observer mechanism, should be set if a CSO selection changes.
CSO * addRectangle(const Vector3 &midPoint, const Vector3 &uVector, const Vector3 &vVector, double angleInRadian=.0, double pointDistanceInMM=1., const std::string &subtype="rectangle")
CSOIdVector getSelectedGroupIds()
Returns a vector with IDs of the selected CSOGroups.
void disableInteractionObserver()
Disables the interaction observer mechanism.
Vector3 getCenterOfSelectedGroups() const
unsigned int getGroupIndex(CSOGroup *group) const
Returns the index of the specified CSOGroup in its list.
static EnumValues< CSOSeedPointStyle > getSeedPointStyles()
bool loadFrom(std::istream &inStream, bool binary, std::string &message, ModuleBackgroundTask *task=nullptr)
bool hasGroup(CSOGroup *group) const
Returns whether there is the specified CSOGroup in the list.
static void alignSeedPathLinks(CSO *cso)
Aligns seed point positions with path point lists of a specified CSO by a squared distance-sum criter...
CSO * addOpenSpline(const std::vector< Vector3 > &points, bool useInterpolation=true, double pointDistanceInMM=1., const std::string &subtype="spline")
void redo()
Performs a redo of the last undo modification.
void enableCSOMovedObserver()
Enables the 'CSO moved' observer mechanism.
bool combineCSOandGroup(CSO *cso, CSOGroup *group, bool useUndoRedo=true)
Combines the specified CSO with the specified CSOGroup.
std::string getUniqueGroupLabel(std::string label, std::string format, bool addIdAlways)
void sendPreEvent(CSOEvent::CSOEventType eventType)
Sends a pre-event with the specified event type.
bool removeAllGroups(bool useUndoRedo)
void breakCSOandGroup(CSO *cso, CSOGroup *group, bool useUndoRedo=true)
Breaks the combination of the specified CSO and the specified CSOGroup.
CSO * getCSOAt(unsigned int index) const
Returns a pointer to the CSO at the specified position in the internal list.
void sendPostEvent(CSOEvent::CSOEventType eventType)
Sends a post-event with the specified event type.
void clearSelectedSeedPoints()
Clears all selected seed points in all CSOs.
unsigned int numGroups() const
Returns the number of CSOGroups.
CSOListRules & getRules()
Returns the rules for this CSOList.
RefCountedBase()
Constructor.
#define ML_REFCOUNTED_PTR(CLASSNAME)
Macro that defines convenience Ptr/ConstPtr typedefs to be used instead of intrusive_ptr templates.
#define ML_CLASS_HEADER(className)
UINT64 MLuint64
Introduce platform-independent 64-bit unsigned integer type.
void csoNotificationCB(void *data, int notificationFlag)
Defines the function signature for the callback methods that is to be touched by a CSOList notificati...
Tvec3< MLdouble > Vector3
A vector with three components of type double.
int notificationFlag
The notification flag encodes which notifications are sent.
csoNotificationCB * notificationCB
The callback function that is triggered by the notification.
void * notificationCBData
The callback data that is a pointer to the observer object.