Docjar: A Java Source and Docuemnt Enginecom.*    java.*    javax.*    org.*    all    new    plug-in

Quick Search    Search Deep

org.eclipse.swt.custom
Class TableTreeEditor  view TableTreeEditor download TableTreeEditor.java

java.lang.Object
  extended byorg.eclipse.swt.custom.ControlEditor
      extended byorg.eclipse.swt.custom.TableTreeEditor

public class TableTreeEditor
extends ControlEditor

A TableTreeEditor is a manager for a Control that appears above a cell in a TableTree and tracks with the moving and resizing of that cell. It can be used to display a text widget above a cell in a TableTree so that the user can edit the contents of that cell. It can also be used to display a button that can launch a dialog for modifying the contents of the associated cell.

Here is an example of using a TableTreeEditor:

	final TableTree tableTree = new TableTree(shell, SWT.FULL_SELECTION | SWT.HIDE_SELECTION);
	final Table table = tableTree.getTable();
	TableColumn column1 = new TableColumn(table, SWT.NONE);
	TableColumn column2 = new TableColumn(table, SWT.NONE);
	for (int i = 0; i < 10; i++) {
		TableTreeItem item = new TableTreeItem(tableTree, SWT.NONE);
		item.setText(0, "item " + i);
		item.setText(1, "edit this value");
		for (int j = 0; j < 3; j++) {
			TableTreeItem subitem = new TableTreeItem(item, SWT.NONE);
			subitem.setText(0, "subitem " + i + " " + j);
			subitem.setText(1, "edit this value");
		}
	}
	column1.setWidth(100);
	column2.pack();
	
	final TableTreeEditor editor = new TableTreeEditor(tableTree);
	//The editor must have the same size as the cell and must
	//not be any smaller than 50 pixels.
	editor.horizontalAlignment = SWT.LEFT;
	editor.grabHorizontal = true;
	editor.minimumWidth = 50;
	// editing the second column
	final int EDITABLECOLUMN = 1;
	
	tableTree.addSelectionListener(new SelectionAdapter() {
		public void widgetSelected(SelectionEvent e) {
			// Clean up any previous editor control
			Control oldEditor = editor.getEditor();
			if (oldEditor != null) oldEditor.dispose();
	
			// Identify the selected row
			TableTreeItem item = (TableTreeItem)e.item;
			if (item == null) return;
	
			// The control that will be the editor must be a child of the Table
			Text newEditor = new Text(table, SWT.NONE);
			newEditor.setText(item.getText(EDITABLECOLUMN));
			newEditor.addModifyListener(new ModifyListener() {
				public void modifyText(ModifyEvent e) {
					Text text = (Text)editor.getEditor();
					editor.getItem().setText(EDITABLECOLUMN, text.getText());
				}
			});
			newEditor.selectAll();
			newEditor.setFocus();
			editor.setEditor(newEditor, item, EDITABLECOLUMN);
		}
	});
 


Field Summary
(package private)  int column
           
(package private)  org.eclipse.swt.events.ControlListener columnListener
           
(package private)  TableTreeItem item
           
(package private)  TableTree tableTree
           
(package private)  org.eclipse.swt.events.TreeListener treeListener
           
 
Fields inherited from class org.eclipse.swt.custom.ControlEditor
editor, grabHorizontal, grabVertical, horizontalAlignment, minimumHeight, minimumWidth, parent, verticalAlignment
 
Constructor Summary
TableTreeEditor(TableTree tableTree)
          Creates a TableTreeEditor for the specified TableTree.
 
Method Summary
(package private)  org.eclipse.swt.graphics.Rectangle computeBounds()
           
 void dispose()
          Removes all associations between the TableTreeEditor and the cell in the table tree.
 int getColumn()
          Returns the zero based index of the column of the cell being tracked by this editor.
 TableTreeItem getItem()
          Returns the TableTreeItem for the row of the cell being tracked by this editor.
(package private)  void resize()
           
 void setColumn(int column)
           
 void setEditor(org.eclipse.swt.widgets.Control editor, TableTreeItem item, int column)
          Specify the Control that is to be displayed and the cell in the table that it is to be positioned above.
 void setItem(TableTreeItem item)
           
 
Methods inherited from class org.eclipse.swt.custom.ControlEditor
getEditor, layout, scroll, setEditor
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

tableTree

TableTree tableTree

item

TableTreeItem item

column

int column

columnListener

org.eclipse.swt.events.ControlListener columnListener

treeListener

org.eclipse.swt.events.TreeListener treeListener
Constructor Detail

TableTreeEditor

public TableTreeEditor(TableTree tableTree)
Creates a TableTreeEditor for the specified TableTree.

Method Detail

computeBounds

org.eclipse.swt.graphics.Rectangle computeBounds()
Overrides:
computeBounds in class ControlEditor

dispose

public void dispose()
Removes all associations between the TableTreeEditor and the cell in the table tree. The TableTree and the editor Control are not disposed.

Overrides:
dispose in class ControlEditor

getColumn

public int getColumn()
Returns the zero based index of the column of the cell being tracked by this editor.


getItem

public TableTreeItem getItem()
Returns the TableTreeItem for the row of the cell being tracked by this editor.


setColumn

public void setColumn(int column)

setItem

public void setItem(TableTreeItem item)

setEditor

public void setEditor(org.eclipse.swt.widgets.Control editor,
                      TableTreeItem item,
                      int column)
Specify the Control that is to be displayed and the cell in the table that it is to be positioned above.

Note: The Control provided as the editor must be created with its parent being the Table control specified in the TableEditor constructor.


resize

void resize()
Overrides:
resize in class ControlEditor