/*******************************************************************************
* Copyright (c) 2000, 2010 IBM Corporation 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.swt.snippets;
/*
* GridLayout snippet: show a wrappable Label that fills available width
* without expanding it
*
* For a list of all SWT example snippets see
* http://www.eclipse.org/swt/snippets/
*/
import org.eclipse.swt.*;
import org.eclipse.swt.layout.*;
import org.eclipse.swt.widgets.*;
public class Snippet335 {
public static void main(String[] args) {
Display display = new Display();
Shell shell = new Shell(display);
shell.setLayout(new GridLayout());
Label label = new Label(shell, SWT.WRAP | SWT.BORDER);
GridData labelData = new GridData();
labelData.widthHint = 10; /* default width */
labelData.horizontalAlignment = SWT.FILL; /* grow to fill available width */
label.setLayoutData(labelData);
label.setText("Snippets are minimal stand-alone programs that demonstrate specific techniques or functionality.");
new Button(shell, SWT.PUSH).setText("This button determines the Shell's width");
/* do an initial pack() so that the Shell determines its required width */
shell.pack();
/* update the Label's width hint to match what the layout allocated for it */
labelData.widthHint = label.getBounds().width;
/*
* do a second pack() so that the Label will compute its required height
* based on its correct width instead of its previously-set default width
*/
shell.pack();
shell.open();
while (!shell.isDisposed()) {
if (!display.readAndDispatch()) display.sleep();
}
display.dispose();
}
}