📄 ssddiagram.c
字号:
//------------------------------------------------------------------------------//// This file is part of Toolkit for Conceptual Modeling (TCM).// (c) copyright 1999, Vrije Universiteit Amsterdam and University of Twente.// Author: Frank Dehne (frank@cs.vu.nl).// Author: Henk van de Zandschulp (henkz@cs.utwente.nl).//// TCM is free software; you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation; either version 2 of the License, or// (at your option) any later version.//// TCM is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with TCM; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.//-----------------------------------------------------------------------------#include "ssdgraph.h"#include "ssdwindow.h"#include "ssdviewer.h"#include "ssdchecks.h"#include "messagedialog.h"#include "ssdtripleclassbox.h"#include "ssddoubleclassbox.h"#include "ssdsingleclassbox.h"#include "ssdsingleobjectbox.h"#include "ssddoubleobjectbox.h"#include "c2r2line.h"#include "ssdr2line.h"#include "ssdrcline.h"#include "ssdbinaryassociationedge.h"#include "ssdobjectlinkedge.h"#include "ssdparticipantlinkedge.h"#include "ssdgeneralizationedge.h"#include "ssdassociationlinkedge.h"#include "ssdaggregationedge.h"#include "ssdcompositionedge.h"#include "commentlink.h"#include "ssdclassnode.h"#include "ssdobjectnode.h"#include "ssdgeneralizationnode.h"#include "ssdaggregationnode.h"#include "ssdassociationnode.h"#include "diamond.h"#include "emptyedge.h"#include "miniellipse.h"#include "blackdot.h"#include "textbox.h"#include "comment.h"#include "notebox.h"#include "hexagon.h"#include "note.h"#include "ssddiagram.h"#include <stdio.h>#include <limits.h>const int SSDDiagram::MINI_ELLIPSE_WIDTH = 8;const int SSDDiagram::MINI_ELLIPSE_HEIGHT = 8;SSDDiagram::SSDDiagram(Config *c, SSDWindow *d, SSDViewer *v, SSDGraph *g): ERDiagram(c, d, v, g) { UpdateNodeType(1); UpdateEdgeType(1); ssdChecks = new SSDChecks(this, g);}SSDDiagram::~SSDDiagram() { delete ssdChecks;}Thing *SSDDiagram::CreateThing(int classNr) { Grafport *g = GetDiagramViewer()->GetGrafport(); ShapeView *v = GetDiagramViewer()->GetCurView(); SSDGraph *cg = (SSDGraph *)GetGraph(); Thing *thing = 0; if (classNr == Code::VIEW) thing = new ShapeView(GetDiagramViewer()); // node shapes (the simple triplebox, doublebox and box are used // in older file formats. else if (classNr==Code::SSD_TRIPLE_CLASS_BOX||classNr==Code::TRIPLE_BOX) thing = new SSDTripleClassBox(v, g, 0, 0); else if (classNr==Code::SSD_DOUBLE_CLASS_BOX||classNr==Code::DOUBLE_BOX) thing = new SSDDoubleClassBox(v, g, 0, 0); else if (classNr==Code::SSD_SINGLE_CLASS_BOX||classNr==Code::BOX) thing = new SSDSingleClassBox(v, g, 0, 0); else if (classNr==Code::SSD_DOUBLE_OBJECT_BOX) thing = new SSDDoubleObjectBox(v, g, 0, 0); else if (classNr==Code::SSD_SINGLE_OBJECT_BOX) thing = new SSDSingleObjectBox(v, g, 0, 0); else if (classNr == Code::MINI_ELLIPSE) { MiniEllipse *el = new MiniEllipse(v, g, 0, 0); el->SetResizable(True); thing = el; } else if (classNr == Code::BLACK_DOT) thing = new BlackDot(v, g, 0, 0); else if (classNr==Code::TEXT_BOX) thing = new TextBox(v, g, 0, 0); else if (classNr==Code::NOTE_BOX) thing = new NoteBox(v, g, 0, 0); else if (classNr==Code::DIAMOND) thing = new Diamond(v, g, 0, 0); // lines else if (classNr==Code::T4_LINE || classNr==Code::C2R2_LINE) thing = new C2R2Line(v, g, 0, 0, 0); else if (classNr==Code::LINE) thing = new Line(v, g, 0, 0, 0); else if (classNr==Code::SSD_RCLINE) thing = new SSDRCLine(v, g, 0, 0, 0); else if (classNr==Code::SSD_R2LINE || classNr==Code::T2_LINE) thing = new SSDR2Line(v, g, 0, 0, 0); // nodes else if (classNr==Code::CLASS_NODE || classNr==Code::SSD_CLASS_NODE) thing = new SSDClassNode(cg); else if (classNr==Code::SSD_OBJECT_NODE) thing = new SSDObjectNode(cg); else if (classNr==Code::TAXONOMY_JUNCTION || classNr==Code::SSD_GENERALIZATION_NODE) thing = new SSDGeneralizationNode(cg); else if (classNr==Code::SSD_AGGREGATION_NODE) thing = new SSDAggregationNode(cg); else if (classNr == Code::RELATIONSHIP_NODE || classNr==Code::SSD_ASSOCIATION_NODE) thing = new SSDAssociationNode(cg); else if (classNr==Code::NOTE) thing = new Note(cg); else if (classNr==Code::COMMENT) thing = new Comment(cg); // edges else if (classNr==Code::BINARY_RELATIONSHIP || classNr==Code::SSD_BINARY_ASSOCIATION_EDGE) thing = new SSDBinaryAssociationEdge(cg, 0, 0); else if (classNr==Code::SSD_ASSOCIATION_LINK_EDGE) thing = new SSDAssociationLinkEdge(cg, 0, 0); else if (classNr==Code::COMMENT_LINK) thing = new CommentLink(cg, 0, 0); else if (classNr==Code::ISA_RELATIONSHIP || classNr==Code::SSD_GENERALIZATION_EDGE) thing = new SSDGeneralizationEdge(cg, 0, 0); else if (classNr==Code::SSD_OBJECT_LINK_EDGE) thing = new SSDObjectLinkEdge(cg, 0, 0); else if (classNr==Code::SSD_PARTICIPANT_LINK_EDGE) thing = new SSDParticipantLinkEdge(cg, 0, 0); else if (classNr==Code::EMPTY_EDGE) //Compatibility thing = new EmptyEdge(cg, 0, 0); else if (classNr==Code::SSD_AGGREGATION_EDGE) thing = new SSDAggregationEdge(cg, 0, 0); else if (classNr==Code::SSD_COMPOSITION_EDGE) thing = new SSDCompositionEdge(cg, 0, 0); else error("%s, line %d: impl error: wrong class number %d\n", __FILE__, __LINE__, classNr); return thing;} Node *SSDDiagram::CreateNode(){ Node *node = 0; SSDGraph *g = (SSDGraph *)GetGraph(); if (GetNodeType()==Code::NOTE) node = new Note(g); else if (GetNodeType()==Code::SSD_GENERALIZATION_NODE) node = new SSDGeneralizationNode(g); else if (GetNodeType()==Code::SSD_AGGREGATION_NODE) node = new SSDAggregationNode(g); else if (GetNodeType()==Code::SSD_CLASS_NODE) node = new SSDClassNode(g); else if (GetNodeType()==Code::SSD_OBJECT_NODE) node = new SSDObjectNode(g); else if (GetNodeType()==Code::SSD_ASSOCIATION_NODE) node = new SSDAssociationNode(g); else if (GetNodeType()==Code::COMMENT) node = new Comment(g); else error( "%s, line %d: impl error: unknown node type\n", __FILE__, __LINE__); return node;}Edge *SSDDiagram::CreateEdge(Subject *subj1, Subject* subj2){ if (!CheckEdgeConstraints(subj1, subj2)) return 0; Edge* edge = 0; SSDGraph *g = (SSDGraph *)GetGraph(); if (GetEdgeType()==Code::COMMENT_LINK) edge = new CommentLink(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_ASSOCIATION_LINK_EDGE) edge = new SSDAssociationLinkEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_BINARY_ASSOCIATION_EDGE) edge = new SSDBinaryAssociationEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_GENERALIZATION_EDGE) edge = new SSDGeneralizationEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_OBJECT_LINK_EDGE) edge = new SSDObjectLinkEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_PARTICIPANT_LINK_EDGE) edge = new SSDParticipantLinkEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_AGGREGATION_EDGE) edge = new SSDAggregationEdge(g, subj1, subj2); else if (GetEdgeType() == Code::SSD_COMPOSITION_EDGE) edge = new SSDCompositionEdge(g, subj1, subj2); else error( "%s, line %d: impl error: unknown edge type\n", __FILE__, __LINE__); if (GetEdgeType() == Code::SSD_GENERALIZATION_EDGE) { if (!CheckIsaLoop(edge)) { delete edge; return 0; } } return edge;}NodeShape *SSDDiagram::CreateNodeShape(Node* node, int x, int y) { NodeShape* shape = 0; Grafport *g = GetDiagramViewer()->GetGrafport(); ShapeView *v = GetDiagramViewer()->GetCurView(); if (GetNodeShapeType() == Code::SSD_SINGLE_CLASS_BOX) shape = new SSDSingleClassBox(v, g, x, y); else if (GetNodeShapeType() == Code::SSD_DOUBLE_CLASS_BOX) shape = new SSDDoubleClassBox(v, g, x, y); else if (GetNodeShapeType() == Code::SSD_TRIPLE_CLASS_BOX) shape = new SSDTripleClassBox(v, g, x, y); else if (GetNodeShapeType() == Code::SSD_SINGLE_OBJECT_BOX) shape = new SSDSingleObjectBox(v, g, x, y); else if (GetNodeShapeType() == Code::SSD_DOUBLE_OBJECT_BOX) shape = new SSDDoubleObjectBox(v, g, x, y); else if (GetNodeShapeType() == Code::MINI_ELLIPSE) { shape = new MiniEllipse(v, g, x, y); shape->SetResizable(True); } else if (GetNodeShapeType() == Code::BLACK_DOT) shape = new BlackDot(v, g, x, y); else if (GetNodeShapeType() == Code::NOTE_BOX) shape = new NoteBox(v, g, x, y); else if (GetNodeShapeType() == Code::TEXT_BOX) shape = new TextBox(v, g, x, y); else if (GetNodeShapeType() == Code::DIAMOND) shape = new Diamond(v, g, x, y); else error( "%s, line %d: impl error: " "node shape type doesn't exist\n", __FILE__, __LINE__); if (check(shape)) { shape->SetSubject(node); shape->SetTextShape(); if (GetNodeShapeType() == Code::MINI_ELLIPSE) shape->SetFixedName(False); } return shape;}Line *SSDDiagram::CreateLine(Edge* edge, GShape *from, GShape *to, List<Point*> *l) { Grafport *g = GetDiagramViewer()->GetGrafport(); ShapeView *v = GetDiagramViewer()->GetCurView(); Line* line = 0; if (GetLineType()== Code::C2R2_LINE) line = new C2R2Line(v, g, from, to, l, IsCurve()); else if (GetLineType()== Code::SSD_R2LINE) line = new SSDR2Line(v, g, from, to, l, IsCurve()); else if (GetLineType()== Code::SSD_RCLINE) line = new SSDRCLine(v, g, from, to, l, IsCurve()); else if (GetLineType()== Code::LINE) line = new Line(v, g, from, to, l, IsCurve()); else error( "%s, line %d: impl error: " "edge shape type does not exist\n", __FILE__, __LINE__); if (check(line)) { line->SetSubject(edge); line->SetTextShape(); line->SetEnd1(GetLineEnd1()); line->SetEnd2(GetLineEnd2()); if (GetEdgeType()==Code::SSD_GENERALIZATION_EDGE) { if (to->GetClassType()==Code::MINI_ELLIPSE) line->SetEnd2(LineEnd::EMPTY); } if (GetEdgeType()==Code::SSD_COMPOSITION_EDGE || GetEdgeType()==Code::SSD_AGGREGATION_EDGE) { if (to->GetClassType()==Code::BLACK_DOT) line->SetEnd2(LineEnd::EMPTY); } if (GetEdgeType()==Code::COMMENT_LINK || GetEdgeType()==Code::SSD_AGGREGATION_EDGE || GetEdgeType()==Code::SSD_COMPOSITION_EDGE || GetEdgeType()==Code::SSD_PARTICIPANT_LINK_EDGE) line->SetFixedName(True); } return line;}void SSDDiagram::UpdateNodeType(int num) { ((DiagramWindow *)GetMainWindow())->SetNodeName(num); switch (num) { case 1: SetNodeType(Code::SSD_CLASS_NODE); SetNodeShapeType(Code::SSD_SINGLE_CLASS_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 2: SetNodeType(Code::SSD_CLASS_NODE); SetNodeShapeType(Code::SSD_DOUBLE_CLASS_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 3: SetNodeType(Code::SSD_CLASS_NODE); SetNodeShapeType(Code::SSD_TRIPLE_CLASS_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 4: SetNodeType(Code::SSD_ASSOCIATION_NODE); SetNodeShapeType(Code::DIAMOND); SetNodeLineStyle(LineStyle::SOLID); break; case 5: SetNodeType(Code::COMMENT); SetNodeShapeType(Code::TEXT_BOX); SetNodeLineStyle(LineStyle::INVISIBLE); break; case 6: SetNodeType(Code::SSD_OBJECT_NODE); SetNodeShapeType(Code::SSD_SINGLE_OBJECT_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 7: SetNodeType(Code::SSD_OBJECT_NODE); SetNodeShapeType(Code::SSD_DOUBLE_OBJECT_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 8: SetNodeType(Code::NOTE); SetNodeShapeType(Code::NOTE_BOX); SetNodeLineStyle(LineStyle::SOLID); break; case 9: SetNodeType(Code::SSD_GENERALIZATION_NODE);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -