com.alee.utils.SizeUtils Maven / Gradle / Ivy
/*
* This file is part of WebLookAndFeel library.
*
* WebLookAndFeel library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* WebLookAndFeel library 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 WebLookAndFeel library. If not, see .
*/
package com.alee.utils;
import java.awt.*;
import java.util.Map;
import java.util.WeakHashMap;
/**
* This class provides a set of utilities to modify component sizes.
*
* @author Mikle Garin
*/
public final class SizeUtils
{
/**
* todo 1. Add maximum size options
*/
/**
* Weak hash map for keeping components preferred sizes.
*/
private static final Map preferredSizeCache = new WeakHashMap ();
private static final Map minimumSizeCache = new WeakHashMap ();
/**
* Returns component preferred width.
*
* @param component component to process
* @param component type
* @return component preferred width
*/
public static int getPreferredWidth ( final C component )
{
final Dimension ps = preferredSizeCache.get ( component );
return ps != null ? ps.width : -1;
}
/**
* Sets component preferred width.
* Pass -1 to let component choose preferred width on its own.
*
* @param component component to process
* @param preferredWidth new component preferred width
* @param component type
* @return modified component
*/
public static C setPreferredWidth ( final C component, final int preferredWidth )
{
Dimension ps = preferredSizeCache.get ( component );
if ( ps == null )
{
ps = new Dimension ( preferredWidth, -1 );
preferredSizeCache.put ( component, ps );
}
else
{
ps.width = preferredWidth;
}
return component;
}
/**
* Returns component preferred height.
*
* @param component component to process
* @param component type
* @return component preferred height
*/
public static int getPreferredHeight ( final C component )
{
final Dimension ps = preferredSizeCache.get ( component );
return ps != null ? ps.height : -1;
}
/**
* Sets component preferred height.
* Pass -1 to let component choose preferred height on its own.
*
* @param component component to process
* @param preferredHeight new component preferred height
* @param component type
* @return modified component
*/
public static C setPreferredHeight ( final C component, final int preferredHeight )
{
Dimension ps = preferredSizeCache.get ( component );
if ( ps == null )
{
ps = new Dimension ( -1, preferredHeight );
preferredSizeCache.put ( component, ps );
}
else
{
ps.height = preferredHeight;
}
return component;
}
/**
* Returns component minimum width.
*
* @param component component to process
* @param component type
* @return component minimum width
*/
public static int getMinimumWidth ( final C component )
{
final Dimension ms = minimumSizeCache.get ( component );
return ms != null ? ms.width : -1;
}
/**
* Sets component minimum width.
* Pass -1 to let component choose minimum width on its own.
*
* @param component component to process
* @param minimumWidth new component minimum width
* @param component type
* @return modified component
*/
public static C setMinimumWidth ( final C component, final int minimumWidth )
{
Dimension ms = minimumSizeCache.get ( component );
if ( ms == null )
{
ms = new Dimension ( minimumWidth, -1 );
minimumSizeCache.put ( component, ms );
}
else
{
ms.width = minimumWidth;
}
return component;
}
/**
* Returns component minimum height.
*
* @param component component to process
* @param component type
* @return component minimum height
*/
public static int getMinimumHeight ( final C component )
{
final Dimension ms = minimumSizeCache.get ( component );
return ms != null ? ms.height : -1;
}
/**
* Sets component minimum height.
* Pass -1 to let component choose minimum height on its own.
*
* @param component component to process
* @param minimumHeight new component minimum height
* @param component type
* @return modified component
*/
public static C setMinimumHeight ( final C component, final int minimumHeight )
{
Dimension ms = minimumSizeCache.get ( component );
if ( ms == null )
{
ms = new Dimension ( -1, minimumHeight );
minimumSizeCache.put ( component, ms );
}
else
{
ms.height = minimumHeight;
}
return component;
}
/**
* Returns component preferred size.
*
* @param component component to process
* @param actualPreferredSize actual component preferred size
* @param component type
* @return component preferred size
*/
public static Dimension getPreferredSize ( final C component, final Dimension actualPreferredSize )
{
final Dimension ps = preferredSizeCache.get ( component );
final Dimension ms = minimumSizeCache.get ( component );
final Dimension preferredSize = new Dimension ( actualPreferredSize );
if ( ps != null && ps.width != -1 )
{
preferredSize.width = ps.width;
}
else if ( ms != null && ms.width != -1 )
{
preferredSize.width = Math.max ( ms.width, preferredSize.width );
}
if ( ps != null && ps.height != -1 )
{
preferredSize.height = ps.height;
}
else if ( ms != null && ms.height != -1 )
{
preferredSize.height = Math.max ( ms.height, preferredSize.height );
}
return preferredSize;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy