All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines
Public Member Functions | Static Public Attributes | Protected Member Functions
DinverDCCore::RefractionTarget Class Reference

Brief description of class still missing. More...

#include <RefractionTarget.h>

Inheritance diagram for DinverDCCore::RefractionTarget:
DinverDCCore::Target QGpCoreTools::XMLClass

List of all members.

Public Member Functions

const QList< RefractionCurve > & curves () const
QList< RefractionCurve > & curves ()
 RefractionTarget ()
 RefractionTarget (const RefractionTarget &o)
void setCurves (const QList< RefractionCurve > &c)
virtual const QString & xml_tagName () const

Static Public Attributes

static const QString xmlRefractionTargetTag = "RefractionTarget"

Protected Member Functions

virtual XMLMember xml_member (XML_MEMBER_ARGS)
virtual void xml_writeChildren (XML_WRITECHILDREN_ARGS) const

Detailed Description

Brief description of class still missing.

Full description of class still missing


Constructor & Destructor Documentation

Description of constructor still missing

References TRACE.

    : Target()
{
  TRACE;
}

Description of destructor still missing

References TRACE.

    : Target(o)
{
  TRACE;
  _curves=o._curves;
}

Member Function Documentation

const QList<RefractionCurve>& DinverDCCore::RefractionTarget::curves ( ) const [inline]
{return _curves;}

References TRACE.

Referenced by TargetListWidget::targetList().

{
  TRACE;
  _curves=c;
  for(QList<RefractionCurve>::iterator it=_curves.begin(); it!=_curves.end(); it++) {
    it->sort();
  }
}

Re-implement this function to offer XML restore (children and properties) support to your class.

From tag and map (with contains the attibute value) return a unique identifier under the format of a XMLMember. XMLMember is initialized with 3 types of contructors:

  • An integer: id number of a property
  • A XMLClass * : a child of this object identified by tag
  • Default constructor: error, unknow child or property

Map of attributes can be inspected in this way (can be achived also in xml_setProperty()):

    static const QString tmp("childrenName");
    XMLRestoreAttributeIterator it=map.find(tmp);
    if(it!=map.end()) {
      // found attribute "childrenName"
    }

If the map of attributes is not used:

    Q_UNUSED(attributes);
    if(tag=="x1") return XMLMember(0);
    else if(tag=="y1") return XMLMember(1);
    else if(tag=="x2") return XMLMember(2);
    else if(tag=="y2") return XMLMember(3);
    else return XMLMember(XMLMember::Unknown);

Arithmetic operations + and - apply to XMLMember to avoid confusion of property id numbers between inherited objects. Offset 3 corresponds to the number of properties defined in this object.

    if(tag=="anInteger") return XMLMember(0);
    else if(tag=="aString") return XMLMember(1);
    else if(tag=="aDouble") return XMLMember(2);
    return AbstractLine::xml_member(tag, attributes, context)+3;

For the arguments of this function use Macro XML_MEMBER_ARGS.

Reimplemented from DinverDCCore::Target.

References TRACE.

{
  TRACE;
  Q_UNUSED(context);
  if(tag=="RefractionCurve") {
    _curves.append(RefractionCurve());
    return XMLMember(&_curves.last());
  } else return Target::xml_member(tag, attributes, context);
}
virtual const QString& DinverDCCore::RefractionTarget::xml_tagName ( ) const [inline, virtual]

Reimplemented from QGpCoreTools::XMLClass.

References TRACE.

{
  TRACE;
  for(QList<RefractionCurve>::const_iterator it=_curves.begin(); it!=_curves.end(); ++it) {
    it->xml_save(s, context);
  }
}

Member Data Documentation

const QString DinverDCCore::RefractionTarget::xmlRefractionTargetTag = "RefractionTarget" [static]

The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines