Skip to content

Commit

Permalink
(#10) Added support for gradient paints
Browse files Browse the repository at this point in the history
New Additions:
- PsdfUtil:
    - Derivation from DrawUtil for working with `.psdf` files.
    - Added support for saving `RadialGradient` and `LinearGradient` to a psdf file
- Polygon2D -- Changed `color` variable to `paint` to support all types of `Paint` objects.
- DrawUtil
    - Moved psdf content to PsdfUtil
    - `paintEquals` method for comparing equality between two `Paint` objects.
    - Changed `randomFont` method to draw font names from the original font set.
    - Added methods to generate random linear/radial gradients:
        - `randomLinearGradient`
        - `randomLinearGradientWithAlpha`
        - `randomRadialGradient`
        - `randomRadialGradientWithAlpha`

Files Moved:
- `tech.fastj.graphics.DisplayUtil.java` → `tech.fastj.graphics.util.DisplayUtil.java`
- `tech.fastj.graphics.DrawUtil.java` → `tech.fastj.graphics.util.DrawUtil.java`
- `tech.fastj.graphics.util.GradientBuilder.java` → `tech.fastj.graphics.util.gradients.GradientBuilder.java`
- `tech.fastj.graphics.util.Gradients.java` → `tech.fastj.graphics.util.gradients.Gradients.java`
- `tech.fastj.graphics.util.LinearGradientBuilder.java` → `tech.fastj.graphics.util.gradients.LinearGradientBuilder.java`
- `tech.fastj.graphics.util.RadialGradientBuilder.java` → `tech.fastj.graphics.util.gradients.RadialGradientBuilder.java`
  • Loading branch information
lucasstarsz committed May 29, 2021
1 parent 3e44d61 commit ad883ba
Show file tree
Hide file tree
Showing 26 changed files with 662 additions and 321 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,12 @@
import tech.fastj.math.Maths;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.Display;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.game.Model2D;
import tech.fastj.graphics.game.Polygon2D;
import tech.fastj.graphics.game.Text2D;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.util.PsdfUtil;

import tech.fastj.systems.control.Scene;

Expand Down Expand Up @@ -125,7 +126,7 @@ private Polygon2D createPlayerHealthBar() {
}

private Model2D createPlayer() {
return new Model2D(DrawUtil.load2DModel(FilePaths.PathToResources + "player.psdf"));
return new Model2D(PsdfUtil.loadPsdf(FilePaths.PathToResources + "player.psdf"));
}

private void newWave() {
Expand All @@ -150,7 +151,7 @@ private Model2D createEnemy() {
Maths.randomAtEdge(-500f, 1220f)
);

return (Model2D) new Model2D(DrawUtil.load2DModel(FilePaths.PathToResources + "enemy.psdf"))
return (Model2D) new Model2D(PsdfUtil.loadPsdf(FilePaths.PathToResources + "enemy.psdf"))
.setTranslation(randomPosition)
.addBehavior(new EnemyMovement(this), this)
.addAsGameObject(this);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import tech.fastj.engine.FastJEngine;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.Drawable;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.game.Polygon2D;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import tech.fastj.engine.FastJEngine;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.game.Polygon2D;
import tech.fastj.graphics.game.Text2D;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import tech.fastj.engine.FastJEngine;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.Display;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.game.Polygon2D;
import tech.fastj.graphics.ui.UIElement;
Expand Down Expand Up @@ -63,7 +63,7 @@ public void load(Display display) {

/* With all that out of the way, we can create our player! */
player = new Polygon2D(boxPoints) // the Polygon2D class is for game objects that are polygons, so it makes sense to use for our square player.
.setColor(Color.RED) // Just to show it off, we'll set the player's color to red.
.setPaint(Color.red) // Just to show it off, we'll set the player's color to red.
.addBehavior(playerScript, this) // Then, we'll add our two behaviors -- the player script...
.addBehavior(rotationScript, this) // ...and the rotation script. The second param is the scene itself -- read the docs for more info.
.addAsGameObject(this); // and lastly, we need to add the game object to the scene.
Expand Down
1 change: 1 addition & 0 deletions src/main/java/module-info.java
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,5 @@
exports tech.fastj.systems.behaviors;
exports tech.fastj.systems.control;
exports tech.fastj.systems.tags;
exports tech.fastj.graphics.util.gradients;
}
2 changes: 1 addition & 1 deletion src/main/java/tech/fastj/engine/FastJEngine.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import tech.fastj.engine.internals.Timer;
import tech.fastj.math.Point;
import tech.fastj.graphics.Display;
import tech.fastj.graphics.DisplayUtil;
import tech.fastj.graphics.util.DisplayUtil;

import tech.fastj.systems.behaviors.BehaviorManager;
import tech.fastj.systems.control.LogicManager;
Expand Down
2 changes: 2 additions & 0 deletions src/main/java/tech/fastj/graphics/Display.java
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
import tech.fastj.math.Pointf;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.ui.UIElement;
import tech.fastj.graphics.util.DisplayUtil;
import tech.fastj.graphics.util.DrawUtil;

import tech.fastj.systems.input.keyboard.Keyboard;
import tech.fastj.systems.input.mouse.Mouse;
Expand Down
1 change: 1 addition & 0 deletions src/main/java/tech/fastj/graphics/Drawable.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import tech.fastj.math.Pointf;
import tech.fastj.graphics.game.GameObject;
import tech.fastj.graphics.ui.UIElement;
import tech.fastj.graphics.util.DrawUtil;

import tech.fastj.systems.control.Scene;
import tech.fastj.systems.tags.TaggableEntity;
Expand Down
5 changes: 3 additions & 2 deletions src/main/java/tech/fastj/graphics/game/Model2D.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@
import tech.fastj.math.Maths;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.Boundary;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.util.PsdfUtil;

import tech.fastj.systems.control.Scene;

Expand All @@ -14,7 +15,7 @@
/**
* {@code Drawable} subclass for grouping an array of {@code Polygon2D}s under a single object.
* <p>
* This class is compatible with loading from a .PSDF file, using the {@code DrawUtil.load2DModel()} method.
* This class is compatible with loading from a .PSDF file, using the {@link PsdfUtil#loadPsdf(String)} method.
*
* @author Andrew Dey
* @version 1.0.0
Expand Down
75 changes: 26 additions & 49 deletions src/main/java/tech/fastj/graphics/game/Polygon2D.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import tech.fastj.math.Maths;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.Boundary;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;

import tech.fastj.systems.control.Scene;

Expand All @@ -24,8 +24,8 @@
*/
public class Polygon2D extends GameObject {

/** {@link Color} representing the default color value of {@code (0, 0, 0)}. */
public static final Color DefaultColor = Color.black;
/** {@link Paint} representing the default paint value as the color black: {@code (0, 0, 0)}. */
public static final Paint DefaultPaint = Color.black;
/** {@code boolean} representing the default "should fill" value of {@code true}. */
public static final boolean DefaultFill = true;
/** {@code boolean} representing the default "should render" value of {@code true}. */
Expand All @@ -34,9 +34,8 @@ public class Polygon2D extends GameObject {
private Path2D.Float renderPath;
private Pointf[] points;

private Color color;
private Paint paint;
private boolean paintFilled;
private boolean shouldFill;

private float rotation;
private Pointf scale;
Expand All @@ -46,24 +45,24 @@ public class Polygon2D extends GameObject {
/**
* {@code Polygon2D} constructor that takes in a set of points.
* <p>
* This constructor defaults the color to {@link #DefaultColor}, the fill to {@link #DefaultFill}, and sets the
* This constructor defaults the paint to {@link #DefaultPaint}, the fill to {@link #DefaultFill}, and sets the
* {@code show} boolean to {@link #DefaultShow}.
*
* @param pts {@code Pointf} array that defines the points for the polygon.
*/
public Polygon2D(Pointf[] pts) {
this(pts, DefaultColor, DefaultFill, DefaultShow);
this(pts, DefaultPaint, DefaultFill, DefaultShow);
}

/**
* {@code Polygon2D} constructor that takes in a set of points, a color, a fill variable, and a show variable.
* {@code Polygon2D} constructor that takes in a set of points, a paint, a fill variable, and a show variable.
*
* @param pts {@code Pointf} array that defines the points for the polygon.
* @param color {@code Color} variable that sets the color of the polygon.
* @param paint {@code Paint} variable that sets the paint of the polygon.
* @param fill Boolean that determines whether the polygon should be filled, or only outlined.
* @param show Boolean that determines whether the polygon should be shown on screen.
*/
public Polygon2D(Pointf[] pts, Color color, boolean fill, boolean show) {
public Polygon2D(Pointf[] pts, Paint paint, boolean fill, boolean show) {
super();
points = pts;

Expand All @@ -74,26 +73,26 @@ public Polygon2D(Pointf[] pts, Color color, boolean fill, boolean show) {
scale = GameObject.DefaultScale.copy();
translation = new Pointf(getBound(Boundary.TopLeft));

setColor(color);
setPaint(paint);
setFilled(fill);

setCollisionPath(renderPath);
setShouldRender(show);
}

/**
* {@code Polygon2D} constructor that takes in a set of points, a color, fill variable, a show variable, and the
* {@code Polygon2D} constructor that takes in a set of points, a paint variable, fill variable, a show variable, and the
* translation, rotation, and scale of the polygon.
*
* @param pts {@code Pointf} array that defines the points for the polygon.
* @param setLocation {@code Pointf} to set the initial location of the polygon.
* @param setRotation {@code Pointf} to set the initial rotation of the polygon.
* @param setScale {@code Pointf} to set the initial scale of the polygon.
* @param color {@code Color} variable that sets the color of the polygon.
* @param paint {@code Paint} variable that sets the paint of the polygon.
* @param fill Boolean that determines whether the polygon should be filled, or only outlined.
* @param show Boolean that determines whether the polygon should be shown on screen.
*/
public Polygon2D(Pointf[] pts, Pointf setLocation, float setRotation, Pointf setScale, Color color, boolean fill, boolean show) {
public Polygon2D(Pointf[] pts, Pointf setLocation, float setRotation, Pointf setScale, Paint paint, boolean fill, boolean show) {
super();
points = pts;

Expand All @@ -108,7 +107,7 @@ public Polygon2D(Pointf[] pts, Pointf setLocation, float setRotation, Pointf set
setRotation(setRotation);
setScale(setScale);

setColor(color);
setPaint(paint);
setFilled(fill);

setCollisionPath(renderPath);
Expand All @@ -133,26 +132,17 @@ public Pointf[] getOriginalPoints() {
return points;
}

/**
* Gets the color set for this polygon.
*
* @return The {@code Color} set for this polygon.
*/
public Color getColor() {
return color;
}

/**
* Gets the paint for this polygon.
*
* @return The {@code Color} set for this polygon.
* @return The {@code Paint} set for this polygon.
*/
public Paint getPaint() {
return paint;
}

/**
* Sets the pain for this polygon.
* Sets the paint for this polygon.
*
* @param newPaint The {@code Paint} to be used for the polygon.
* @return This instance of the {@code Polygon2D}, for method chaining.
Expand All @@ -162,25 +152,14 @@ public Polygon2D setPaint(Paint newPaint) {
return this;
}

/**
* Sets the color for the polygon.
*
* @param newColor The {@code Color} to be used for the polygon.
* @return This instance of the {@code Polygon2D}, for method chaining.
*/
public Polygon2D setColor(Color newColor) {
color = newColor;
return this;
}

/**
* Gets the fill boolean for this polygon.
*
* @return The boolean variable for this polygon, which determines if the polygon should be filled, or only
* outlined.
*/
public boolean isFilled() {
return paintFilled;
return shouldFill;
}

/**
Expand All @@ -190,7 +169,7 @@ public boolean isFilled() {
* @return This instance of the {@code Polygon2D}, for method chaining.
*/
public Polygon2D setFilled(boolean fill) {
paintFilled = fill;
shouldFill = fill;
return this;
}

Expand Down Expand Up @@ -293,13 +272,11 @@ public void scale(Pointf scaleMod, Pointf centerpoint) {
public void render(Graphics2D g) {
if (!shouldRender()) return;

// g.setColor(color);

Paint oldPaint = g.getPaint();

g.setPaint(paint);

if (paintFilled) {
if (shouldFill) {
g.fill(renderPath);
} else {
g.draw(renderPath);
Expand All @@ -313,8 +290,8 @@ public void destroy(Scene originScene) {
points = null;
renderPath = null;

color = null;
paintFilled = false;
paint = null;
shouldFill = false;

scale = null;
translation = null;
Expand Down Expand Up @@ -349,8 +326,8 @@ public boolean equals(Object other) {
}
Polygon2D polygon2D = (Polygon2D) other;

return paintFilled == polygon2D.paintFilled
&& Objects.equals(color, polygon2D.color)
return shouldFill == polygon2D.shouldFill
&& DrawUtil.paintEquals(paint, polygon2D.paint)
&& Objects.equals(translation, polygon2D.translation)
&& Objects.equals(scale, polygon2D.scale)
&& Maths.floatEquals(polygon2D.rotation, rotation)
Expand All @@ -360,7 +337,7 @@ public boolean equals(Object other) {

@Override
public int hashCode() {
int result = Objects.hash(renderPath, color, paintFilled, rotation, scale, translation);
int result = Objects.hash(renderPath, paint, shouldFill, rotation, scale, translation);
result = 31 * result + Arrays.hashCode(points);
return result;
}
Expand All @@ -370,8 +347,8 @@ public String toString() {
return "Polygon2D{" +
"renderPath=" + renderPath +
", points=" + Arrays.toString(points) +
", color=" + color +
", paintFilled=" + paintFilled +
", paint=" + paint +
", paintFilled=" + shouldFill +
", rotation=" + rotation +
", scale=" + scale +
", translation=" + translation +
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/tech/fastj/graphics/game/Text2D.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import tech.fastj.engine.CrashMessages;
import tech.fastj.engine.FastJEngine;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;

import tech.fastj.systems.control.Scene;

Expand Down
2 changes: 1 addition & 1 deletion src/main/java/tech/fastj/graphics/ui/elements/Button.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import tech.fastj.engine.FastJEngine;
import tech.fastj.math.Pointf;
import tech.fastj.graphics.Camera;
import tech.fastj.graphics.DrawUtil;
import tech.fastj.graphics.util.DrawUtil;
import tech.fastj.graphics.game.Text2D;
import tech.fastj.graphics.ui.UIElement;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package tech.fastj.graphics;
package tech.fastj.graphics.util;

import tech.fastj.math.Point;
import tech.fastj.graphics.Display;

import java.awt.DisplayMode;
import java.awt.GraphicsDevice;
Expand Down
Loading

0 comments on commit ad883ba

Please sign in to comment.