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 * This class is a special tree node which holds the EdgeReferenceMutableTreeNode
|
fiore@3
|
23 * in the tree layout, where It is normally placed as a {@code DiagramNode}'s child.
|
fiore@0
|
24 */
|
fiore@0
|
25 @SuppressWarnings("serial")
|
fiore@3
|
26 public class EdgeReferenceHolderMutableTreeNode extends DiagramTreeNode {
|
fiore@0
|
27
|
fiore@3
|
28 EdgeReferenceHolderMutableTreeNode(Object userObj){
|
fiore@0
|
29 super(userObj);
|
fiore@0
|
30 }
|
fiore@0
|
31
|
fiore@0
|
32 @Override
|
fiore@0
|
33 public String toString(){
|
fiore@0
|
34 StringBuilder builder = new StringBuilder(super.toString());
|
fiore@0
|
35 builder.append(" (").append(getChildCount()).append(")");
|
fiore@0
|
36 return builder.toString();
|
fiore@0
|
37 }
|
fiore@0
|
38
|
fiore@0
|
39 /**
|
fiore@3
|
40 * Returns a String representing this object for this tree node in a way more suitable
|
fiore@3
|
41 * for a text to speech synthesizer to read, than {@code toString()}.
|
fiore@3
|
42 *
|
fiore@0
|
43 * @return a String suitable for text to speech synthesis
|
fiore@0
|
44 */
|
fiore@0
|
45 @Override
|
fiore@0
|
46 public String spokenText(){
|
fiore@0
|
47 StringBuilder builder = new StringBuilder(getName());
|
fiore@0
|
48 builder.append(", ");
|
fiore@0
|
49 builder.append(getChildCount() == 0 ? "empty" : getChildCount());
|
fiore@0
|
50 if(!"".equals(notes)){
|
fiore@0
|
51 builder.append(NOTES_SPEAK);
|
fiore@0
|
52 }
|
fiore@0
|
53 if(!bookmarkKeys.isEmpty())
|
fiore@0
|
54 builder.append(BOOKMARK_SPEAK);
|
fiore@0
|
55 return builder.toString();
|
fiore@0
|
56 }
|
fiore@0
|
57 }
|