fiore@0
|
1 /*
|
fiore@0
|
2 CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool
|
fiore@0
|
3
|
fiore@0
|
4 Copyright (C) 2011 Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/)
|
fiore@0
|
5
|
fiore@0
|
6 This program is free software: you can redistribute it and/or modify
|
fiore@0
|
7 it under the terms of the GNU General Public License as published by
|
fiore@0
|
8 the Free Software Foundation, either version 3 of the License, or
|
fiore@0
|
9 (at your option) any later version.
|
fiore@0
|
10
|
fiore@0
|
11 This program is distributed in the hope that it will be useful,
|
fiore@0
|
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
|
fiore@0
|
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
fiore@0
|
14 GNU General Public License for more details.
|
fiore@0
|
15
|
fiore@0
|
16 You should have received a copy of the GNU General Public License
|
fiore@0
|
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
|
fiore@0
|
18 */
|
fiore@0
|
19 package uk.ac.qmul.eecs.ccmi.diagrammodel;
|
fiore@0
|
20
|
fiore@0
|
21 /**
|
fiore@0
|
22 *
|
fiore@0
|
23 * The diagramModeltreeNode placed in a node subtree representing an edge connecting
|
fiore@0
|
24 * that node with another node.
|
fiore@0
|
25 *
|
fiore@0
|
26 */
|
fiore@0
|
27 @SuppressWarnings("serial")
|
fiore@0
|
28 public class EdgeReferenceMutableTreeNode extends DiagramModelTreeNode {
|
fiore@0
|
29 public EdgeReferenceMutableTreeNode(DiagramEdge edge, DiagramNode node){
|
fiore@0
|
30 super();
|
fiore@0
|
31 this.edge = edge;
|
fiore@0
|
32 this.node = node;
|
fiore@0
|
33 }
|
fiore@0
|
34
|
fiore@0
|
35 @Override
|
fiore@0
|
36 public String toString(){
|
fiore@0
|
37 final String and = " and ";
|
fiore@0
|
38 StringBuilder b = new StringBuilder();
|
fiore@0
|
39 b.append("to ");
|
fiore@0
|
40 for(int i=0;i<edge.getNodesNum();i++){
|
fiore@0
|
41 DiagramNode n = edge.getNodeAt(i);
|
fiore@0
|
42 if(!n.equals(node))
|
fiore@0
|
43 b.append(n.getName()).append(and);
|
fiore@0
|
44 }
|
fiore@0
|
45 // remove the last " and "
|
fiore@0
|
46 b.delete(b.length()-and.length(), b.length());
|
fiore@0
|
47 b.append(", via ");
|
fiore@0
|
48 b.append(edge.getName());
|
fiore@0
|
49 super.setUserObject(b.toString());
|
fiore@0
|
50 return super.toString();
|
fiore@0
|
51 }
|
fiore@0
|
52
|
fiore@0
|
53 @Override
|
fiore@0
|
54 public String getName(){
|
fiore@0
|
55 return toString();
|
fiore@0
|
56 }
|
fiore@0
|
57
|
fiore@0
|
58 /**
|
fiore@0
|
59 * Return a String representing this object for this tree node in a way more suitable
|
fiore@0
|
60 * for a text to speech synthesizer to read, than toString().
|
fiore@0
|
61 * @return a String suitable for text to speech synthesis
|
fiore@0
|
62 */
|
fiore@0
|
63 @Override
|
fiore@0
|
64 public String spokenText(){
|
fiore@0
|
65 toString();
|
fiore@0
|
66 return super.spokenText();
|
fiore@0
|
67 }
|
fiore@0
|
68
|
fiore@0
|
69 /**
|
fiore@0
|
70 * Returns the diagram edge that this tree node represents inside the node subtree
|
fiore@0
|
71 * @return a reference to the actual edge
|
fiore@0
|
72 */
|
fiore@0
|
73 public DiagramEdge getEdge(){
|
fiore@0
|
74 return edge;
|
fiore@0
|
75 }
|
fiore@0
|
76
|
fiore@0
|
77 /**
|
fiore@0
|
78 * Returns the node containing this tree node in its subtree. Notice that
|
fiore@0
|
79 * diagram nodes are DiagrammodelTreeNode as well.
|
fiore@0
|
80 * @return a reference to the diagram node
|
fiore@0
|
81 */
|
fiore@0
|
82 public DiagramNode getNode(){
|
fiore@0
|
83 return node;
|
fiore@0
|
84 }
|
fiore@0
|
85
|
fiore@0
|
86 private DiagramEdge edge;
|
fiore@0
|
87 private DiagramNode node;
|
fiore@0
|
88 }
|