1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 2002, Universiteit Twente, Enschede.
5
// Author: 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
////////////////////////////////////////////////////////////////////////////////
24
#include "sizeshapebordercmd.h"
25
#include "scdcreateandlinecmd.h"
27
#include "nodeshape.h"
30
SCViewer::SCViewer(Config *c, SCWindow *d): DiagramViewer(c, d) { }
32
/* virtual */ Command *SCViewer::Connect(int x, int y) {
34
x = int(0.5 + ScaleCorrect(x));
35
y = int(0.5 + ScaleCorrect(y));
38
if (Toolkit::EditorWithInterEdgeConnections(
39
GetMainWindow()->GetTool())) {
40
if ((shape = GetCurView()->HitShape(x, y))) {
41
if ( shape->IsNodeShape() && shape->IsSelected() &&
42
(w = shape->HitHandles(x, y)) >= 0)
43
return new SizeShapeBorderCmd(shape, w);
44
else if ( shape->IsNodeShape() || (shape->IsLine() &&
45
!((Line*)shape)->IsCurved()) ) {
46
if ( Code::SCD_AND_EDGE == GetDefaultEdgeType() )
47
return new SCDCreateAndLineCmd(shape);
48
return new CreateEdgeCmd(shape);
51
} else if ((shape = GetCurView()->HitNodeShape(x, y))) {
52
if (shape->IsSelected() && (w = shape->HitHandles(x, y)) >= 0)
53
return new SizeShapeBorderCmd(shape, w);
54
else if ( Code::SCD_AND_EDGE == GetDefaultEdgeType() )
55
return new SCDCreateAndLineCmd(shape);
56
return new CreateEdgeCmd(shape);