1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 2001, Universiteit Twente.
5
// Author: Frank Dehne (frank@cs.vu.nl), David N. Jansen (dnjansen@cs.utwente.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 "ellipsedbox.h"
25
const PolyPoint EllipsedBox::p1(0,-0.5, 0.5, 0, 0, 0, 0.5, 0, true);
26
const PolyPoint EllipsedBox::p2(0, 0.5,-0.5, 0, 0, 0, 0.5, 0, true, true);
27
const PolyPoint EllipsedBox::p4(0, 0.5,-0.5, 0, 0, 0,-0.5, 0, true);
28
const PolyPoint EllipsedBox::p5(0,-0.5, 0.5, 0, 0, 0,-0.5, 0, true, true);
30
const PolyPoint EllipsedBox::c0(0,-0.5, 0.5, 0, -1, 0, 0.5, 0);
31
const PolyPoint EllipsedBox::c1(0, 0.5,-0.5, 0, -1, 0, 0.5, 0, false, true);
32
const PolyPoint EllipsedBox::c2(0, 0.5,-0.5, 0, 1, 0,-0.5, 0);
33
const PolyPoint EllipsedBox::c3(0,-0.5, 0.5, 0, 1, 0,-0.5, 0, false, true);
35
const Polygon EllipsedBox::exterior((new List<const PolyPoint *>)
36
->add(&p5)->add(&PolyPoint::LeftArc)->add(&p1)
37
->add(&p2)->add(&PolyPoint::RightArc)->add(&p4),
40
const Polygon EllipsedBox::childarea((new List<const PolyPoint *>)
41
->add(&c3)->add(&PolyPoint::LeftArc1)->add(&c0)
42
->add(&c1)->add(&PolyPoint::RightArc1)->add(&c2));
44
const ShapeType EllipsedBox::ebType(Code::ELLIPSED_BOX, 80.0, 40.0, 1.0, 0.0,
45
&exterior, &childarea, &PolyPoint::Index, &PolyPoint::Dupli,
46
&PolyPoint::Multi, &exterior);
48
EllipsedBox::EllipsedBox(ShapeView *v, Grafport *g, double x, double y)
49
:NodeShape(v, g, x, y, &ebType)
53
EllipsedBox::EllipsedBox(const NodeShape &c)
54
:NodeShape(c, &ebType)