⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tabletree.java

📁 源码为Eclipse开源开发平台桌面开发工具SWT的源代码,
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/******************************************************************************* * Copyright (c) 2000, 2004 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Common Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/cpl-v10.html *  * Contributors: *     IBM Corporation - initial API and implementation *******************************************************************************/package org.eclipse.swt.custom;import org.eclipse.swt.*;import org.eclipse.swt.events.*;import org.eclipse.swt.graphics.*;import org.eclipse.swt.widgets.*;/**  * A TableTree is a selectable user interface object * that displays a hierarchy of items, and issues * notification when an item is selected. * A TableTree may be single or multi select. * <p> * The item children that may be added to instances of this class * must be of type <code>TableTreeItem</code>. * </p><p> * Note that although this class is a subclass of <code>Composite</code>, * it does not make sense to add <code>Control</code> children to it, * or set a layout on it. * </p><p> * <dl> *	<dt><b>Styles:</b> <dd> SINGLE, MULTI, CHECK, FULL_SELECTION *	<dt><b>Events:</b> <dd> Selection, DefaultSelection, Collapse, Expand * </dl> * <p> * Note: Only one of the styles SINGLE, and MULTI may be specified. * </p> */public class TableTree extends Composite {	Table table;	TableTreeItem[] items = EMPTY_ITEMS;	Image plusImage, minusImage, sizeImage;	/*	* TableTreeItems are not treated as children but rather as items.	* When the TableTree is disposed, all children are disposed because 	* TableTree inherits this behaviour from Composite.  The items	* must be disposed separately.  Because TableTree is not part of	* the org.eclipse.swt.widgets package, the method releaseWidget can 	* not be overriden (this is how items are disposed of in Table and Tree).	* Instead, the items are disposed of in response to the dispose event on the	* TableTree.  The "inDispose" flag is used to distinguish between disposing	* one TableTreeItem (e.g. when removing an entry from the TableTree) and 	* disposing the entire TableTree.	*/	boolean inDispose = false;		static final TableTreeItem[] EMPTY_ITEMS = new TableTreeItem [0];		static final String[] EMPTY_TEXTS = new String [0];		static final Image[] EMPTY_IMAGES = new Image [0];	static final String ITEMID = "TableTreeItemID"; //$NON-NLS-1$/** * Constructs a new instance of this class given its parent * and a style value describing its behavior and appearance. * <p> * The style value is either one of the style constants defined in * class <code>SWT</code> which is applicable to instances of this * class, or must be built by <em>bitwise OR</em>'ing together  * (that is, using the <code>int</code> "|" operator) two or more * of those <code>SWT</code> style constants. The class description * lists the style constants that are applicable to the class. * Style bits are also inherited from superclasses. * </p> * * @param parent a widget which will be the parent of the new instance (cannot be null) * @param style the style of widget to construct * * @exception IllegalArgumentException <ul> *    <li>ERROR_NULL_ARGUMENT - if the parent is null</li> * </ul> * @exception SWTException <ul> *    <li>ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the parent</li> * </ul> * * @see SWT#SINGLE * @see SWT#MULTI * @see SWT#CHECK * @see SWT#FULL_SELECTION * @see #getStyle */public TableTree(Composite parent, int style) {	super(parent, checkStyle (style));	table = new Table(this, style);	Listener tableListener = new Listener() {		public void handleEvent(Event e) {			switch (e.type) {			case SWT.MouseDown: onMouseDown(e); break;			case SWT.Selection: onSelection(e); break;			case SWT.DefaultSelection: onSelection(e); break;			case SWT.KeyDown: onKeyDown(e); break;			}		}	};	int[] tableEvents = new int[]{SWT.MouseDown, 		                           SWT.Selection, 		                           SWT.DefaultSelection, 		                           SWT.KeyDown};	for (int i = 0; i < tableEvents.length; i++) {		table.addListener(tableEvents[i], tableListener);	}		Listener listener = new Listener() {		public void handleEvent(Event e) {			switch (e.type) {			case SWT.Dispose: onDispose(e); break;			case SWT.Resize:  onResize(e); break;			case SWT.FocusIn: onFocusIn(e); break;			}		}	};	int[] events = new int[]{SWT.Dispose, 		                      SWT.Resize, 		                      SWT.FocusIn};	for (int i = 0; i < events.length; i++) {		addListener(events[i], listener);	}	                      }int addItem(TableTreeItem item, int index) {	if (index < 0 || index > items.length) SWT.error(SWT.ERROR_INVALID_ARGUMENT);	TableTreeItem[] newItems = new TableTreeItem[items.length + 1];	System.arraycopy(items, 0, newItems, 0, index);	newItems[index] = item;	System.arraycopy(items, index, newItems, index + 1, items.length - index); 	items = newItems;	/* Return the index in the table where this table should be inserted */	if (index == items.length - 1 ) 		return table.getItemCount();	else 		return table.indexOf(items[index+1].tableItem);}/** * Adds the listener to the collection of listeners who will * be notified when the receiver's selection changes, by sending * it one of the messages defined in the <code>SelectionListener</code> * interface. * <p> * When <code>widgetSelected</code> is called, the item field of the event object is valid. * If the reciever has <code>SWT.CHECK</code> style set and the check selection changes, * the event object detail field contains the value <code>SWT.CHECK</code>. * <code>widgetDefaultSelected</code> is typically called when an item is double-clicked. * The item field of the event object is valid for default selection, but the detail field is not used. * </p> * * @param listener the listener which should be notified * * @exception IllegalArgumentException <ul> *    <li>ERROR_NULL_ARGUMENT - if the listener is null</li> * </ul> * @exception SWTException <ul> *    <li>ERROR_WIDGET_DISPOSED - if the receiver has been disposed</li> *    <li>ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver</li> * </ul> * * @see SelectionListener * @see #removeSelectionListener * @see SelectionEvent */public void addSelectionListener(SelectionListener listener) {	checkWidget();	if (listener == null) SWT.error (SWT.ERROR_NULL_ARGUMENT);	TypedListener typedListener = new TypedListener (listener);	addListener (SWT.Selection,typedListener);	addListener (SWT.DefaultSelection,typedListener);}/** * Adds the listener to the collection of listeners who will * be notified when an item in the receiver is expanded or collapsed * by sending it one of the messages defined in the <code>TreeListener</code> * interface. * * @param listener the listener which should be notified * * @exception IllegalArgumentException <ul> *    <li>ERROR_NULL_ARGUMENT - if the listener is null</li> * </ul> * @exception SWTException <ul> *    <li>ERROR_WIDGET_DISPOSED - if the receiver has been disposed</li> *    <li>ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver</li> * </ul> * * @see TreeListener * @see #removeTreeListener */public void addTreeListener(TreeListener listener) {	checkWidget();	if (listener == null) SWT.error (SWT.ERROR_NULL_ARGUMENT);	TypedListener typedListener = new TypedListener (listener);	addListener (SWT.Expand, typedListener);	addListener (SWT.Collapse, typedListener);}private static int checkStyle (int style) {	int mask = SWT.LEFT_TO_RIGHT | SWT.RIGHT_TO_LEFT; 	style = style & mask;	return style;} public Point computeSize (int wHint, int hHint, boolean changed) {	checkWidget();	return table.computeSize (wHint, hHint, changed);}public Rectangle computeTrim (int x, int y, int width, int height) {	checkWidget();	return table.computeTrim(x, y, width, height);}/** * Deselects all items. * <p> * If an item is selected, it is deselected. * If an item is not selected, it remains unselected. * * @exception SWTError <ul> *	<li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread *	<li>ERROR_WIDGET_DISPOSED when the widget has been disposed * </ul> */public void deselectAll () {	checkWidget();	table.deselectAll();}/* Expand upward from the specified leaf item. */void expandItem (TableTreeItem item) {	if (item == null) return;	expandItem(item.parentItem);	if (!item.getVisible()) item.setVisible(true);	if ( !item.expanded && item.items.length > 0) {		item.setExpanded(true);		Event event = new Event();		event.item = item;		notifyListeners(SWT.Expand, event);	}}public Color getBackground () {	// This method must be overriden otherwise, in a TableTree in which the first	// item has no sub items, a grey (Widget background colour) square will appear in	// the first column of the first item.	// It is not possible in the constructor to set the background of the TableTree	// to be the same as the background of the Table because this interferes with 	// the TableTree adapting to changes in the System color settings.	return table.getBackground();}public Rectangle getClientArea () {	return table.getClientArea();}public Color getForeground () {	return table.getForeground();}public Font getFont () {	return table.getFont();}/** * Gets the number of items. * <p> * @return the number of items in the widget */public int getItemCount () {	//checkWidget();	return items.length;}/** * Gets the height of one item. * <p> * This operation will fail if the height of * one item could not be queried from the OS. * * @return the height of one item in the widget * * @exception SWTError <ul> *	<li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread *	<li>ERROR_WIDGET_DISPOSED when the widget has been disposed *	<li>ERROR_CANNOT_GET_ITEM_HEIGHT when the operation fails * </ul> */public int getItemHeight () {	checkWidget();	return table.getItemHeight();}/** * Gets the items. * <p> * @return the items in the widget */public TableTreeItem [] getItems () {	//checkWidget();	TableTreeItem[] newItems = new TableTreeItem[items.length];	System.arraycopy(items, 0, newItems, 0, items.length);	return newItems;}/** * Gets the selected items. * <p> * This operation will fail if the selected * items cannot be queried from the OS. * * @return the selected items in the widget * * @exception SWTError <ul> *		<li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread</li> *		<li>ERROR_WIDGET_DISPOSED when the widget has been disposed</li> * 		<li>ERROR_CANNOT_GET_SELECTION when the operation fails</li> *	</ul> */public TableTreeItem [] getSelection () {	checkWidget();	TableItem[] selection = table.getSelection();	TableTreeItem [] result = new TableTreeItem[selection.length];	for (int i = 0; i < selection.length; i++){		result[i] = (TableTreeItem) selection[i].getData(ITEMID);	}	return result;}/** * Gets the number of selected items. * <p> * This operation will fail if the number of selected * items cannot be queried from the OS. * * @return the number of selected items in the widget * * @exception SWTError <ul> *		<li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread</li> *		<li>ERROR_WIDGET_DISPOSED when the widget has been disposed</li> * 		<li>ERROR_CANNOT_GET_COUNT when the operation fails</li> *	</ul> */public int getSelectionCount () {	checkWidget();	return table.getSelectionCount();}public int getStyle () {	checkWidget();	return table.getStyle();}/** * Returns the underlying Table control. * * @return the underlying Table control */public Table getTable () {	//checkWidget();	return table;}void createImages () {		int itemHeight = sizeImage.getBounds().height;	// Calculate border around image. 	// At least 9 pixels are needed to draw the image	// Leave at least a 6 pixel border.	int indent = Math.min(6, (itemHeight - 9) / 2);	indent = Math.max(0, indent);	int size = Math.max (10, itemHeight - 2 * indent); 	size = ((size + 1) / 2) * 2; // size must be an even number	int midpoint = indent + size / 2;		Color foreground = getForeground();	Color plusMinus = getDisplay().getSystemColor(SWT.COLOR_WIDGET_NORMAL_SHADOW);	Color background = getBackground();		/* Plus image */	PaletteData palette = new PaletteData(new RGB[]{foreground.getRGB(), background.getRGB(), plusMinus.getRGB()});	ImageData imageData = new ImageData(itemHeight, itemHeight, 4, palette);	imageData.transparentPixel = 1;	plusImage = new Image(getDisplay(), imageData);	GC gc = new GC(plusImage);	gc.setBackground(background);	gc.fillRectangle(0, 0, itemHeight, itemHeight);	gc.setForeground(plusMinus);	gc.drawRectangle(indent, indent, size, size);	gc.setForeground(foreground);	gc.drawLine(midpoint, indent + 2, midpoint, indent + size - 2);	gc.drawLine(indent + 2, midpoint, indent + size - 2, midpoint);	gc.dispose();		/* Minus image */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -