All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.swt.layout.RowData Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2000, 2018 IBM Corporation and others.
 *
 * This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License 2.0
 * which accompanies this distribution, and is available at
 * https://www.eclipse.org/legal/epl-2.0/
 *
 * SPDX-License-Identifier: EPL-2.0
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
package org.eclipse.swt.layout;

import org.eclipse.swt.*;
import org.eclipse.swt.graphics.*;

/**
 * Each control controlled by a RowLayout can have its initial
 * width and height specified by setting a RowData object
 * into the control.
 * 

* The following code uses a RowData object to change the initial * size of a Button in a Shell: *

*
 * 		Display display = new Display();
 * 		Shell shell = new Shell(display);
 * 		shell.setLayout(new RowLayout());
 * 		Button button1 = new Button(shell, SWT.PUSH);
 * 		button1.setText("Button 1");
 * 		button1.setLayoutData(new RowData(50, 40));
 * 
* * @see RowLayout * @see Sample code and further information */ public final class RowData { /** * width specifies the desired width in points. This value * is the wHint passed into Control.computeSize(int, int, boolean) * to determine the preferred size of the control. * * The default value is SWT.DEFAULT. * * @see org.eclipse.swt.widgets.Control#computeSize(int, int, boolean) */ public int width = SWT.DEFAULT; /** * height specifies the preferred height in points. This value * is the hHint passed into Control.computeSize(int, int, boolean) * to determine the preferred size of the control. * * The default value is SWT.DEFAULT. * * @see org.eclipse.swt.widgets.Control#computeSize(int, int, boolean) */ public int height = SWT.DEFAULT; /** * exclude informs the layout to ignore this control when sizing * and positioning controls. If this value is true, * the size and position of the control will not be managed by the * layout. If this value is false, the size and * position of the control will be computed and assigned. * * The default value is false. * * @since 3.1 */ public boolean exclude = false; /** * Constructs a new instance of RowData using * default values. */ public RowData () { } /** * Constructs a new instance of RowData according to the parameters. * A value of SWT.DEFAULT indicates that no minimum width or * no minimum height is specified. * * @param width a minimum width for the control * @param height a minimum height for the control */ public RowData (int width, int height) { this.width = width; this.height = height; } /** * Constructs a new instance of RowData according to the parameter. * A value of SWT.DEFAULT indicates that no minimum width or * no minimum height is specified. * * @param point a point whose x coordinate specifies a minimum width for the control * and y coordinate specifies a minimum height for the control */ public RowData (Point point) { this (point.x, point.y); } String getName () { String string = getClass ().getName (); int index = string.lastIndexOf ('.'); if (index == -1) return string; return string.substring (index + 1, string.length ()); } /** * Returns a string containing a concise, human-readable * description of the receiver. * * @return a string representation of the RowData object */ @Override public String toString () { String string = getName ()+" {"; if (width != SWT.DEFAULT) string += "width="+width+" "; if (height != SWT.DEFAULT) string += "height="+height+" "; if (exclude) string += "exclude="+exclude+" "; string = string.trim(); string += "}"; return string; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy