diff java/src/uk/ac/qmul/eecs/ccmi/gui/PropertyTableModel.java @ 0:78b7fc5391a2

first import, outcome of NIME 2014 hackaton
author Fiore Martin <f.martin@qmul.ac.uk>
date Tue, 08 Jul 2014 16:28:59 +0100
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/java/src/uk/ac/qmul/eecs/ccmi/gui/PropertyTableModel.java	Tue Jul 08 16:28:59 2014 +0100
@@ -0,0 +1,169 @@
+/*  
+ CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool
+  
+ Copyright (C) 2011  Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/)
+
+ This program 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 3 of the License, or
+ (at your option) any later version.
+
+ This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
+*/
+package uk.ac.qmul.eecs.ccmi.gui;
+
+import java.util.HashSet;
+import java.util.List;
+import java.util.ArrayList;
+import java.util.Set;
+
+import javax.swing.table.AbstractTableModel;
+
+import uk.ac.qmul.eecs.ccmi.diagrammodel.NodeProperties.Modifiers;
+
+
+/**
+ * A table model containing the property values currently edited in a table of a {@code PropertyEditorDialog} 
+ * and the modifiers assigned to them
+ * in the form of an array of indexes pointing to the modifiers types  
+ */
+@SuppressWarnings("serial")
+public class PropertyTableModel extends AbstractTableModel {
+	
+	/**
+	 * Construct a new {@code PropertyTableModel}.
+	 * 
+	 * @param propertyType the type of the node property related to this table model 
+	 * @param values the list of values for this node property
+	 * @param modifiers the modifiers for this node property 
+	 */
+	public PropertyTableModel(String propertyType, List<String> values, Modifiers modifiers ){
+		data = new ArrayList<ModifierString>();
+		for(int i = 0; i< values.size();i++){
+			String value = values.get(i);
+			data.add(new ModifierString(value, (modifiers == null) ? null : modifiers.getIndexes(i)));
+		}
+		data.add(new ModifierString(null));
+		columnName = propertyType;
+	}
+	
+	@Override
+	public int getColumnCount() {
+		return 1;
+	}
+
+	@Override
+	public int getRowCount() {
+		return data.size();
+	}
+
+	@Override
+	public Object getValueAt(int rowIndex, int columnIndex) {
+		return data.get(rowIndex);
+	}
+	
+	@Override
+	public String getColumnName(int column){
+		 return columnName;
+	}
+	
+	@Override
+	public void setValueAt(Object value, int rowIndex, int columnIndex){
+		/* we filled up the last row, create another  one */
+		if((rowIndex == data.size()-1)&&(!value.toString().equals(""))){
+			data.add(new ModifierString(null));
+			data.get(rowIndex).value = value.toString();
+			fireTableRowsInserted(data.size()-1, data.size()-1);
+			fireTableCellUpdated(rowIndex,columnIndex);
+		}else if((rowIndex != data.size()-1)&&(value.toString().equals(""))){
+			data.remove(rowIndex);
+			fireTableRowsDeleted(rowIndex,rowIndex);
+		}else {
+			data.get(rowIndex).value = value.toString();
+			fireTableCellUpdated(rowIndex,columnIndex);
+		}
+	}
+	
+	@Override
+	public boolean isCellEditable(int rowIndex, int columnIndex){
+		return true;
+	}
+	
+	/**
+	 * Returns the indexes (pointing to the modifiers types) of the property value at the specified row in the table
+	 * with this model.
+	 * 
+	 * @param row the row of the property value 
+	 * @return the modifiers type indexes for the specified property value 
+	 */
+	public Set<Integer> getIndexesAt(int row){
+		return data.get(row).modifierIndexes;
+	}
+	
+	/**
+	 * Set the the indexes (pointing to the modifiers types) of the property value at the specified row in the table
+	 * with this model.
+	 * 
+	 * @param row he row of the property value 
+	 * @param indexes  the modifiers type indexes for the specified property value 
+	 */
+	public void setIndexesAt(int row, Set<Integer> indexes){
+		data.get(row).modifierIndexes = new HashSet<Integer>();
+		data.get(row).modifierIndexes.addAll(indexes);
+	}
+	
+	/**
+	 * Set the the indexes (pointing to the modifiers types) of the property value at the specified row in the table
+	 * with this model.
+	 * 
+	 * @param row he row of the property value 
+	 * @param indexes  the modifiers type indexes for the specified property value 
+	 */
+	public void setIndexesAt(int row, Integer[] indexes){
+		data.get(row).modifierIndexes = new HashSet<Integer>();
+		for(int i=0; i<indexes.length; i++)
+			data.get(row).modifierIndexes.add(indexes[i]);
+	}
+	
+	private List<ModifierString> data;
+	private String columnName;
+	
+	private class ModifierString  {
+		ModifierString(String value, Set<Integer> s){
+			this.value = value;
+			modifierIndexes = new HashSet<Integer>();
+			if(s != null){
+					modifierIndexes.addAll(s);
+			}
+		}
+		
+		ModifierString(Set<Integer> s){
+			this("",s);
+		}
+		
+		@Override
+		public boolean equals(Object o){
+			return value.equals(o);
+		}
+		
+		@Override
+		public int hashCode(){
+			return value.hashCode();
+		}
+		
+		@Override
+		public String toString(){
+			return value;
+		}
+		
+		private String value;
+		private Set<Integer> modifierIndexes;
+	}
+
+}