Mercurial > projects > dwt-samples
view jface/snippets/Snippet047VirtualLazyTreeViewer.d @ 140:2b4e94cafb85
tabs vs. spaces
author | Frank Benoit <benoit@tionex.de> |
---|---|
date | Thu, 07 Aug 2008 17:16:24 +0200 |
parents | 96a2d0b35360 |
children | 42c3056512ba |
line wrap: on
line source
/******************************************************************************* * Copyright (c) 2006 Tom Schindl and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Tom Schindl - initial API and implementation * Port to the D programming language: * yidabu at gmail dot com ( D China http://www.d-programming-language-china.org/ ) *******************************************************************************/ module jface.snippets.Snippet047VirtualLazyTreeViewer; import dwtx.jface.viewers.ILazyTreeContentProvider; import dwtx.jface.viewers.LabelProvider; import dwtx.jface.viewers.TreeViewer; import dwtx.jface.viewers.Viewer; import dwt.DWT; import dwt.layout.FillLayout; import dwt.widgets.Display; import dwt.widgets.Shell; import dwt.dwthelper.utils; import tango.util.Convert; import tango.util.container.LinkedList; /** * @param args */ void main(String[] args) { Display display = new Display(); Shell shell = new Shell(display); shell.setLayout(new FillLayout()); new Snippet047VirtualLazyTreeViewer(shell); shell.open(); while (!shell.isDisposed()) { if (!display.readAndDispatch()) display.sleep(); } display.dispose(); } /** * A simple TreeViewer to demonstrate usage of an ILazyContentProvider. * */ public class Snippet047VirtualLazyTreeViewer { alias ArrayWrapperT!(IntermediateNode) ArrayWrapperIntermediateNode; alias ArrayWrapperT!(LeafNode) ArrayWrapperLeafNode; private class MyContentProvider : ILazyTreeContentProvider { private TreeViewer viewer; private IntermediateNode[] elements; public this(TreeViewer viewer) { this.viewer = viewer; } public void dispose() { } public void inputChanged(Viewer viewer, Object oldInput, Object newInput) { if(cast(ArrayWrapperIntermediateNode) newInput) this.elements = (cast(ArrayWrapperIntermediateNode) newInput).array; } /* * (non-Javadoc) * * @see dwtx.jface.viewers.ILazyTreeContentProvider#getParent(java.lang.Object) */ public Object getParent(Object element) { if (cast(LeafNode)element) return (cast(LeafNode) element).parent; return new ArrayWrapperIntermediateNode(elements); } /* * (non-Javadoc) * * @see dwtx.jface.viewers.ILazyTreeContentProvider#updateChildCount(java.lang.Object, * int) */ public void updateChildCount(Object element, int currentChildCount) { int length = 0; if (cast(IntermediateNode)element) { IntermediateNode node = cast(IntermediateNode) element; length = node.children.length; } /// TODO: fix me access violation here if(element !is null && elements !is null && (cast(ArrayWrapperIntermediateNode)element) && (cast(ArrayWrapperIntermediateNode)element).array is elements) length = elements.length; viewer.setChildCount(element, length); } /* * (non-Javadoc) * * @see dwtx.jface.viewers.ILazyTreeContentProvider#updateElement(java.lang.Object, * int) */ public void updateElement(Object parent, int index) { Object element; if (cast(IntermediateNode)parent) element = (cast(IntermediateNode) parent).children[index]; else element = elements[index]; viewer.replace(parent, index, element); updateChildCount(element, -1); } } public class LeafNode { public int counter; public IntermediateNode parent; public this(int counter, IntermediateNode parent) { this.counter = counter; this.parent = parent; } public String toString() { return "Leaf " ~ to!(String)(this.counter); } } public class IntermediateNode { public int counter; public LeafNode[] children; public this(int counter) { this.counter = counter; children = new LeafNode[0]; } public String toString() { return "Node " ~ to!(String)(this.counter); } public void generateChildren(int i) { children = new LeafNode[i]; for (int j = 0; j < i; j++) { children[j] = new LeafNode(j, this); } } } public this(Shell shell) { final TreeViewer v = new TreeViewer(shell, DWT.VIRTUAL | DWT.BORDER); v.setLabelProvider(new LabelProvider()); v.setContentProvider(new MyContentProvider(v)); v.setUseHashlookup(true); IntermediateNode[] model = createModel(); v.setInput(new ArrayWrapperIntermediateNode(model)); v.getTree().setItemCount(model.length); } private IntermediateNode[] createModel() { IntermediateNode[] elements = new IntermediateNode[10]; for (int i = 0; i < 10; i++) { elements[i] = new IntermediateNode(i); elements[i].generateChildren(1000); } return elements; } }