proguard.gui.splash.RectangleSprite Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of proguard-gui Show documentation
Show all versions of proguard-gui Show documentation
ProGuardGUI is an interface for ProGuard, the free shrinker, optimizer, obfuscator, and preverifier for Java bytecode
/*
* ProGuard -- shrinking, optimization, obfuscation, and preverification
* of Java bytecode.
*
* Copyright (c) 2002-2020 Guardsquare NV
*
* This program 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 2 of the License, or (at your option)
* any later version.
*
* 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 proguard.gui.splash;
import java.awt.*;
/**
* This Sprite represents an animated rounded rectangle. It can optionally be filled.
*
* @author Eric Lafortune
*/
public class RectangleSprite implements Sprite
{
private final boolean filled;
private final VariableColor color;
private final VariableInt x;
private final VariableInt y;
private final VariableInt width;
private final VariableInt height;
private final VariableInt arcWidth;
private final VariableInt arcHeight;
/**
* Creates a new rectangular RectangleSprite.
* @param filled specifies whether the rectangle should be filled.
* @param color the variable color of the rectangle.
* @param x the variable x-ordinate of the upper-left corner of the rectangle.
* @param y the variable y-ordinate of the upper-left corner of the rectangle.
* @param width the variable width of the rectangle.
* @param height the variable height of the rectangle.
*/
public RectangleSprite(boolean filled,
VariableColor color,
VariableInt x,
VariableInt y,
VariableInt width,
VariableInt height)
{
this(filled, color, x, y, width, height, new ConstantInt(0), new ConstantInt(0));
}
/**
* Creates a new RectangleSprite with rounded corners.
* @param filled specifies whether the rectangle should be filled.
* @param color the variable color of the rectangle.
* @param x the variable x-ordinate of the upper-left corner of the rectangle.
* @param y the variable y-ordinate of the upper-left corner of the rectangle.
* @param width the variable width of the rectangle.
* @param height the variable height of the rectangle.
* @param arcWidth the variable width of the corner arcs.
* @param arcHeight the variable height of the corner arcs.
*/
public RectangleSprite(boolean filled,
VariableColor color,
VariableInt x,
VariableInt y,
VariableInt width,
VariableInt height,
VariableInt arcWidth,
VariableInt arcHeight)
{
this.filled = filled;
this.color = color;
this.x = x;
this.y = y;
this.width = width;
this.height = height;
this.arcWidth = arcWidth;
this.arcHeight = arcHeight;
}
// Implementation for Sprite.
public void paint(Graphics graphics, long time)
{
graphics.setColor(color.getColor(time));
int xt = x.getInt(time);
int yt = y.getInt(time);
int w = width.getInt(time);
int h = height.getInt(time);
int aw = arcWidth.getInt(time);
int ah = arcHeight.getInt(time);
if (filled)
{
graphics.fillRoundRect(xt, yt, w, h, aw, ah);
}
else
{
graphics.drawRoundRect(xt, yt, w, h, aw, ah);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy