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

📄 lwrasterlayout.java

📁 Zaval Light-Weight Visual Components Library (LwVCL) is a pure Java alternative to humble AWT-based
💻 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 + -