📄 lwrasterlayout.java
字号:
/**
* Caption: Zaval Light-Weight Visual Components Library
* $Revision: 2.79 $
* $Date: 2003/08/22 11:24:16 $
*
* @author: Andrei Vishnevsky
* @version: 3.50
*
* Zaval Light-Weight Visual Components Library (LwVCL) is a pure Java
* alternative to humble AWT-based and SWING-based GUI interfaces for
* wide ranges of platforms, including J2SE, PersonalJava and J2ME.
*
* Designed as light-weight but, alternatively to Swing, built separately
* from AWT (not on top of the java.awt library like Swing), the LwVCL is
* the good alternative to highly performant, memory-efficient, flexible
* GUI solution for embedded, stand-alone and applet applications.
*
* For more info on this product read Zaval Light-Weight Visual Components Library Tutorial
* (It comes within this package).
* The latest product version is always available from the product's homepage:
* http://www.zaval.org/products/lwvcl/
* and from the SourceForge:
* http://sourceforge.net/projects/zaval0003/
*
* Contacts:
* Support : support@zaval.org
* Change Requests : change-request@zaval.org
* Feedback : feedback@zaval.org
* Other : info@zaval.org
*
* Copyright (C) 2001-2003 Zaval Creative Engineering Group (http://www.zaval.org)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* (version 2) as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
*/
package org.zaval.lw;import java.awt.*;/** * This class implements layout manager interface. The layout manager uses original * locations (that have been set with <code>setLocation</code> method) and original * sizes (that have been set with <code>setSize</code> method) or preferred sizes to layout * child components. It is possible to align child components sizes according to the * parent component, in this case the child component will be sized to have right bottom * corner in the right bottom corner of the parent container. * <p> * The layout manager is the same <code>null</code> layout manager in Java AWT * library terms if the original sizes are used (layout flag is <code>0</code>). */public class LwRasterLayoutimplements LwLayout{ /** * Defines child widths alignment by the parent component. */ public static final int W_BY_PARENT = 1; /** * Defines child heights alignment by the parent component. */ public static final int H_BY_PARENT = 2; /** * Defines childs prefered sizes usage as the child sizes. */ public static final int USE_PS_SIZE = 4; private int flag; /** * Constructs the layout manager that uses child components locations and sizes to layout its. * This layout is analog of <code>null</code> layout for Java AWT Library. */ public LwRasterLayout() { this(0); } /** * Constructs the layout manager with the specified layout flag. The flag defines * what how the child components should be sized. The following constants (or its * combination) can be used as the flag value: * <ul> * <li> * W_BY_PARENT - to align child components widths by parent size. * </li> * <li> * H_BY_PARENT - to align child components heights by parent size. * </li> * <li> * USE_PS_SIZE - to use preferred sizes as the child components sizes. * </li> * </ul> * @param <code>f</code> the specified layout flag. */ public LwRasterLayout(int f) { flag = f; } /** * Invoked when the specified layoutable component is added to the layout container * (that uses the layout manager). The specified constraints, layoutable component * and child index are passed as arguments into the method. * @param <code>id</code> the layoutable component constraints. * @param <code>lw</code> the layoutable component. * @param <code>index</code> the child index. */ public void componentAdded(Object id, Layoutable lw, int index) {} /** * Invoked when the specified layoutable component is removed from the layout * container, that uses the layout manager. * @param <code>lw</code> the layoutable component to be removed * @param <code>index</code> the child index. */ public void componentRemoved(Layoutable lw, int index) {} /** * Calculates the preferred size dimensions for the layout container. * The method calculates "pure" preferred size, it means that an insets * of the container is not considered as a part of the size. The layout * manager calculates the preferred size as maximal location of the right * bound for a visible child component. * @param <code>c</code> the layout container. */ public Dimension calcPreferredSize(LayoutContainer c) { Dimension m = new Dimension(); boolean b = (flag & USE_PS_SIZE) > 0; for (int i=0; i<c.count(); i++) { Layoutable el = c.get(i); if (el.isVisible()) { Point p = el.getLocation(); Dimension ps = b?el.getPreferredSize():el.getSize(); p.x += ps.width; p.y += ps.height; if (p.x > m.width ) m.width = p.x; if (p.y > m.height) m.height = p.y; } } return m; } /** * Lays out the child layoutable components inside the layout container. * The layout algorithm just sizes child components if the layout flag indicates * to use preferred sizes or align child sizes and moves location of children using an offset that * is provided by <code>getLayoutOffset</code> method of the container. * @param <code>c</code> the layout container that needs to be laid out. */ public void layout(LayoutContainer c) { Point offs = c.getLayoutOffset(); Insets ins = c.getInsets(); int r = c.getWidth() - ins.right, b = c.getHeight() - ins.bottom; boolean usePsSize = (flag & USE_PS_SIZE) > 0; for (int i=0; i<c.count(); i++) { Layoutable el = c.get(i); if (el.isVisible()) { Point p = el.getLocation(); p.x += offs.x; p.y += offs.y; el.setLocation(p.x, p.y); Dimension ps = usePsSize?el.getPreferredSize():el.getSize(); if ((flag & W_BY_PARENT)>0) ps.width = r - p.x; if ((flag & H_BY_PARENT)>0) ps.height = b - p.y; el.setSize(ps.width, ps.height); } } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -