annotate java/src/uk/ac/qmul/eecs/ccmi/diagrammodel/EdgeReferenceHolderMutableTreeNode.java @ 8:ea7885bd9bff tip

fixed bug : render solid line as dotted/dashed when moving the stylus from dotted/dashed to solid
author ccmi-guest
date Thu, 03 Jul 2014 16:12:20 +0100
parents 9e67171477bc
children
rev   line source
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 }