1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1995, Vrije Universiteit Amsterdam.
5
// Author: Frank Dehne (frank@cs.vu.nl).
7
// TCM is free software; you can redistribute it and/or modify
8
// it under the terms of the GNU General Public License as published by
9
// the Free Software Foundation; either version 2 of the License, or
10
// (at your option) any later version.
12
// TCM is distributed in the hope that it will be useful,
13
// but WITHOUT ANY WARRANTY; without even the implied warranty of
14
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
// GNU General Public License for more details.
17
// You should have received a copy of the GNU General Public License
18
// along with TCM; if not, write to the Free Software
19
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21
////////////////////////////////////////////////////////////////////////////////
22
#include "miniellipse.h"
24
MiniEllipse::MiniEllipse(ShapeView *v, Grafport *g, double x, double y)
30
MiniEllipse::MiniEllipse(const MiniEllipse &c): Ellipse(c) {
31
namePosition = c.namePosition;
35
MiniEllipse::MiniEllipse(const NodeShape &c): Ellipse(c) {
39
void MiniEllipse::Init() {
40
SetSize(MIN_WIDTH, MIN_HEIGHT);
41
namePosition = CENTER;
42
NodeShape::SetResizable(False);
43
SetHandles(MIN_HANDLES);
45
SetFixedIndexLabel(True);
46
Point pt(*GetPosition());
47
Ellipse::SetPosition(&pt);
50
void MiniEllipse::CalcPositionName() {
52
int th = GetName()->GetHeight();
53
int tw = GetName()->GetWidth();
54
if (namePosition == TOP) {
55
pt.x = GetPosition()->x;
56
pt.y = GetTopLeft()->y - th/2;
58
else if (namePosition == BOTTOM) {
59
pt.x = GetPosition()->x;
60
pt.y = GetTopLeft()->y + GetHeight() + th/2;
62
else if (namePosition == LEFT) {
63
pt.x = GetTopLeft()->x - tw/2 - 2;
64
pt.y = GetPosition()->y;
66
else if (namePosition == RIGHT) {
67
pt.x = GetTopLeft()->x + GetWidth() + tw/2 + 2;
68
pt.y = GetPosition()->y;
71
pt.x = GetPosition()->x;
72
pt.y = GetPosition()->y;
74
GetName()->SetPosition(&pt);
77
void MiniEllipse::SetPosition(const Point *p, bool snap) {
78
Ellipse::SetPosition(p, snap);
82
void MiniEllipse::SetFont(XFont *ft) {
87
void MiniEllipse::SetAlignment(TextAlign::Type al) {
88
Ellipse::SetAlignment(al);
92
void MiniEllipse::SetName(const string *s) {
93
GetName()->SetString(s);
97
void MiniEllipse::SetTextShape() {
98
Ellipse::SetTextShape();
102
void MiniEllipse::SetSize(int w, int h) {
103
Ellipse::SetSize(w, h);