OMSimulatorLib
The OMSimulator project is a FMI-based co-simulation environment.
Loading...
Searching...
No Matches
ElementGeometry.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenModelica.
3 *
4 * Copyright (c) 1998-CurrentYear, Open Source Modelica Consortium (OSMC),
5 * c/o Linköpings universitet, Department of Computer and Information Science,
6 * SE-58183 Linköping, Sweden.
7 *
8 * All rights reserved.
9 *
10 * THIS PROGRAM IS PROVIDED UNDER THE TERMS OF GPL VERSION 3 LICENSE OR
11 * THIS OSMC PUBLIC LICENSE (OSMC-PL) VERSION 1.2.
12 * ANY USE, REPRODUCTION OR DISTRIBUTION OF THIS PROGRAM CONSTITUTES
13 * RECIPIENT'S ACCEPTANCE OF THE OSMC PUBLIC LICENSE OR THE GPL VERSION 3,
14 * ACCORDING TO RECIPIENTS CHOICE.
15 *
16 * The OpenModelica software and the Open Source Modelica
17 * Consortium (OSMC) Public License (OSMC-PL) are obtained
18 * from OSMC, either from the above address,
19 * from the URLs: http://www.ida.liu.se/projects/OpenModelica or
20 * http://www.openmodelica.org, and in the OpenModelica distribution.
21 * GNU version 3 is obtained from: http://www.gnu.org/copyleft/gpl.html.
22 *
23 * This program is distributed WITHOUT ANY WARRANTY; without
24 * even the implied warranty of MERCHANTABILITY or FITNESS
25 * FOR A PARTICULAR PURPOSE, EXCEPT AS EXPRESSLY SET FORTH
26 * IN THE BY RECIPIENT SELECTED SUBSIDIARY LICENSE CONDITIONS OF OSMC-PL.
27 *
28 * See the full OSMC Public License conditions for more details.
29 *
30 */
31
32#ifndef _SSD_ELEMENT_GEOMETRY_H_
33#define _SSD_ELEMENT_GEOMETRY_H_
34
35#include "OMSimulator/Types.h"
36
37#include <pugixml.hpp>
38
39#include <string>
40
41namespace oms
42{
43 namespace ssd
44 {
45 class ElementGeometry : protected ssd_element_geometry_t
46 {
47 public:
51
53
54 void setX1(double x1) {this->x1 = x1;}
55 void setY1(double y1) {this->y1 = y1;}
56 void setX2(double x2) {this->x2 = x2;}
57 void setY2(double y2) {this->y2 = y2;}
58 void setSizePosition(double x1, double y1, double x2, double y2) {this->x1 = x1; this->y1 = y1; this->x2 = x2; this->y2 = y2;}
59 void setRotation(double rotation) {this->rotation = rotation;}
60 void setIconSource(std::string iconSource);
61 void setIconRotation(double iconRotation) {this->iconRotation = iconRotation;}
62 void setIconFlip(bool iconFlip) {this->iconFlip = iconFlip;}
63 void setIconFixedAspectRatio(bool iconFixedAspectRatio) {this->iconFixedAspectRatio = iconFixedAspectRatio;}
64
65 double getX1() const {return x1;}
66 double getY1() const {return y1;}
67 double getX2() const {return x2;}
68 double getY2() const {return y2;}
69 double getRotation() const {return rotation;}
70 std::string getIconSource() const {return std::string(iconSource);}
71 bool hasIconSource() const {return (NULL != iconSource);}
72 double getIconRotation() const {return iconRotation;}
73 bool getIconFlip() const {return iconFlip;}
74 bool getIconFixedAspectRatio() const {return iconFixedAspectRatio;}
75
76 oms_status_enu_t exportToSSD(pugi::xml_node& root) const;
77 oms_status_enu_t importFromSSD(const pugi::xml_node& node);
78 };
79 }
80}
81
82#endif
Definition ElementGeometry.h:46
double getY1() const
Definition ElementGeometry.h:66
~ElementGeometry()
Definition ElementGeometry.cpp:78
bool hasIconSource() const
Definition ElementGeometry.h:71
bool getIconFlip() const
Definition ElementGeometry.h:73
double getX2() const
Definition ElementGeometry.h:67
double getIconRotation() const
Definition ElementGeometry.h:72
bool getIconFixedAspectRatio() const
Definition ElementGeometry.h:74
void setIconRotation(double iconRotation)
Definition ElementGeometry.h:61
void setY1(double y1)
Definition ElementGeometry.h:55
void setSizePosition(double x1, double y1, double x2, double y2)
Definition ElementGeometry.h:58
std::string getIconSource() const
Definition ElementGeometry.h:70
void setRotation(double rotation)
Definition ElementGeometry.h:59
oms_status_enu_t exportToSSD(pugi::xml_node &root) const
Definition ElementGeometry.cpp:134
void setIconFlip(bool iconFlip)
Definition ElementGeometry.h:62
double getX1() const
Definition ElementGeometry.h:65
oms_status_enu_t importFromSSD(const pugi::xml_node &node)
Definition ElementGeometry.cpp:166
void setX2(double x2)
Definition ElementGeometry.h:56
void setX1(double x1)
Definition ElementGeometry.h:54
double getRotation() const
Definition ElementGeometry.h:69
double getY2() const
Definition ElementGeometry.h:68
void setY2(double y2)
Definition ElementGeometry.h:57
void setIconSource(std::string iconSource)
Definition ElementGeometry.cpp:119
void setIconFixedAspectRatio(bool iconFixedAspectRatio)
Definition ElementGeometry.h:63
ElementGeometry()
Definition ElementGeometry.cpp:39
ElementGeometry & operator=(ElementGeometry const &rhs)
Definition ElementGeometry.cpp:86
Definition AlgLoop.h:45