30class OutputConnectorField;
82 Field(
const std::string& name = std::string());
103 const std::string&
getName()
const {
return _name; }
106 void setName(
const std::string& name) { _name = name; }
309 Field& operator=(
const Field&) {
return *
this; }
Field to encapsulate a pointer to an ML base object.
Defines the class FieldContainer to encapsulate a vector of fields for (see class Field).
Class to define and to manage field sensors.
Strength
Enumeration type describing the strength of notifications.
Base class for all fields used in the ML.
void setName(const std::string &name)
Sets the name of field. Should be called only once after or while construction.
virtual std::string getStringValue() const =0
Returns the value of the field as string value.
size_t getNumDestinationFields()
Returns the number of destination fields which could receive notifications or value sets.
Field(const std::string &name=std::string())
Constructor: Creates a field with name.
static bool areNotificationsEnabledGlobally()
Returns whether the notification mechanism for all fields (e.g., when field values are set) is enable...
void attachField(Field *targetField, bool propagateValueOnConnect)
Connects this class instance with the target field targetField.
void detachFieldSensor(FieldSensor *sensor)
Detaches the field sensor sensor of this class instance in both directions.
FieldContainer * _fieldContainer
The owning field container.
MLint getCStringValueSize()
Returns the length of the character string of the string value of the field.
void setOutputOnly(bool outputOnly=true)
Mark field as a pure output field that is never read by its module.
Field * getDestinationField(size_t index)
Returns destination field at index. Returns NULL if index is out of range.
void attachField(OutputConnectorField *targetField)
This calls attachField(targetField, false).
std::vector< Field * > _destinationFields
List of (target) fields which shall be set to the value of this field or which shall be notified only...
void copyCStringValue(char *valueBuffer, MLint bufferSize)
Copies the value of the field (as character string) into the specified buffer valueBuffer.
std::vector< Field * > _sourceFields
List of (source) fields, which will notify this field or which will copy their value to this field.
void attachField(BaseField *targetField)
size_t getNumSourceFields()
Returns the number of source fields which could send notifications or value sets.
std::string _name
The name of this field.
virtual ~Field()
Destructor: Destroy field and remove all connection to fields an sensors.
void detachAllFields()
Disconnects all source and target fields of this instance in both directions.
static void enableNotificationsGlobally(bool flag)
Enables or disables globally the notification mechanism for all fields and field sensors when field v...
void detachDestinationFields()
Disconnects all target fields of this instance in both directions.
static MLint & enableNotificationsCounterState()
Provides read/write access to the current counter state (see enableNotificationsGlobally(bool) ).
virtual MLint isValidValue()
Returns true (=1) if the field's value is valid; otherwise false (=0) is returned.
virtual void setStringValue(const std::string &value)=0
Set field value as string value.
void detachField(Field *targetField)
Disconnects connections between target field targetField and this instance.
bool isOutputOnly() const
Returns if this field is marked as pure output field.
void detachFieldSensors()
Detaches all field sensors of this class instance in both directions.
void detachSourceField(Field *field)
Removes a source field from this instance. If not found then this call does nothing.
virtual void touch(FieldSensor::Strength strength=FieldSensor::CHANGED)
Notifies all connected fields and field sensors.
void detachSourceFields()
Disconnects all source fields of this instance in both directions.
FieldContainer * getFieldContainer() const
Get the field container of the field (which may be NULL).
Field * getSourceField(size_t index)
Returns the source field at index. Returns NULL if index is out of range.
std::string getFullName() const
Returns "fieldContainerType(instanceName).fieldName" (if field container is available,...
std::vector< FieldSensor * > _sensors
List of field sensors.
void attachSourceField(Field *field)
Inserts a field as source field in this instance, i.e., from now on *this might receive values and/or...
void detachFieldInternal(Field *field)
Only remove the given field from the destination list.
const std::string & getName() const
Returns name of field.
virtual void setValueFromField(const Field &field)
Sets the value of this field from the given field.
void attachFieldSensor(FieldSensor *sensor)
Attaches a field sensor sensor of this class instance in both directions.
void attachField(NotifyField *targetField)
bool areNotificationsEnabled()
Returns whether the notification mechanism for this field (e.g., when field values are set) is enable...
void attachField(SoNodeField *targetField)
void enableNotifications(bool flag)
Enables or disables notification of attached fields and field sensors when the field value is set or ...
static MLint _enableNotifications
Flag which disables the notification process of field (sensors) globally.
Field without value for notifications.
Field to encapsulate a pointer to an output connector which represents a module output.
Field to encapsulate a pointer to an SoNode instance of OpenInventor.
#define MLEXPORT
To export symbols from a dll/shared object, we need to mark them with the MLEXPORT symbol.
Target mlrange_cast(Source arg)
Generic version of checked ML casts.
#define ML_ABSTRACT_ROOT_CLASS_HEADER(className)
MLint64 MLint
A signed ML integer type with at least 64 bits used for index calculations on very large images even ...
MLEXPORT std::ostream & operator<<(std::ostream &s, const ml::Field &v)
Overloads the operator "<<" for stream output of Field objects.
Flags for internal usage.
unsigned int insideTouch
< Flag to suppress multiple notifications of fields, which could lead to endless loops.
unsigned int observersWereRemovedInsideTouch
< Flag that indicates that the sensor/destination fields lists contain NULL entries
unsigned int notifyAttachmentsFlag
< Flag to suppress the notification of connected fields and field sensors when field values are set.
unsigned int outputOnly
< Flag to mark this field as pure output field (this is used by the MeVisLab IDE).