Archers Vs Zombies - Dev Log - 01
I am working on a new game for Android and PC (Windows, Mac and Linux) platforms. The name of the game is not clear yet, for now is Archer Vs Zombies. It is being developed using Libgdx (using its box2d port for the physics), Artemis Entity System Framework and Animation4j. I want to be blogging about the game development progress, maybe some game design decisions and how I am using the libraries, stuff like that.
Quick Description
An archer has to defend something (could be a castle, a house, people) from enemies (zombies, vampires, etc) which are coming to steal/destroy/kill/eat brains (yeah, they are bad) by throwing arrows to them. There will be waves of enemies and different levels with different landscapes.
Here is a video of the current status of the game, so you can visualize the concept:
note: something happened with the video, it should be finished after second 20.
Here are the features I will concentrate for now:
- There are enemies which comes to kill/steal/destroy.
- Add a movable target as the first enemy prototype.
- The player can control the bow power.
- Add feedback of the current bow power (probably add an arrow in the bow when charging which moves depending on the charge).
- Restrict bow power.
I already have some ideas to add more depth to the game but I want to explain them in further posts.
The game is open source (for now?) with the codename of archervsworld. Also I have a link here if you want to test the latest PC stable version, and here to test the latest Android stable version.
Hope you like it.
Face Hunt - Android Market
Face Hunt is now on Android market, categorized as Casual Game, so if you want to download it on your Android device, you can search for it on the Android market. We also provide a QR code for easy access:
As we are testing Android development and Android market, please play the game and make comments and/or rate it so we can improve our games for you. Thanks.
There is also a new Gameplay’s Video:
Face Hunt - Introduction
We are developing an Android game using Libgdx named Face Hunt. It is only a test to learn a bit about Libgdx and Android’s world. Right now, the game will work best on 480x800 devices.
The game is about killing smilies by touching them :D, here is a video:
And here is the qr code for the link of the game if you want to download the game in your android and test it:
Btw, if you want to download the apk, you can touch the image. Don’t rely on that link, it could be down in any time, the idea is to put our games on android market directly.
Animation4j - Interpolation Functions
Interpolation Functions are a key concept in animation4j project, they define how to a variable should change from one value to another. To define interpolation functions in animation4j, InterpolatorFunction interface should be implemented, the API looks like this:
public interface InterpolatorFunction { /** * @param t * A real number in the interval [0,1] * @return The interpolated value. */ float interpolate(float t); }
So basically, functions works for values of t
between interval [0,1]. An example implementation of this function is a linear Bézier:
/** * Linear Bézier curve implementation of an InterpolatorFunction. * */ public class LinearBezierInterpolatorFunction implements InterpolatorFunction { private final float p0, p1; public LinearBezierInterpolatorFunction(float p0, float p1) { this.p0 = p0; this.p1 = p1; } @Override public float interpolate(float t) { if (t < 0) return p0; if (t > 1) return p1; return (1 - t) * p0 + t * p1; } }
The library already provides some implementations, you could instantiate them using InterpolatorFunctionFactory factory class. The API of the factory looks like this:
// returns a cubic Bézier interpolation function based on the four specified points. InterpolatorFunction cubicBezier(float p0, float p1, float p2, float p3); // returns a quadratic Bézier interpolation function based on the four specified points. InterpolatorFunction quadratic(float p0, float p1, float p2); // returns a cubic Bézier interpolation function with presetted values. InterpolatorFunction ease(); // returns a linear Bézier interpolation function. InterpolatorFunction linear(); // returns a cubic Bézier interpolation function with presetted values. InterpolatorFunction easeIn(); // returns a cubic Bézier interpolation function with presetted values. InterpolatorFunction easeOut(); // returns a cubic Bézier interpolation function with presetted values. InterpolatorFunction easeInOut();
In the previous post we talked about transitions of variables from one value to another using Transition interface. When building a transition using the Transitions factory, you could specify the interpolation functions you want to use, if you don’t, then linear Bézier functions are used by default. One example of how to create a Transition specifying the interpolation functions looks like this:
Transition<Vector2f> transition = Transitions.transition( new Vector2f(0f, 0f), // the starting value vector2fConverter, // the type converter (using two variables) InterpolatorFunctionFactory.easeOut(), // the interpolation function for the first variable InterpolatorFunctionFactory.easeIn()); // the interpolation function for the second variable
One thing to mention is that Transitions factory methods use a varargs to specify interpolation functions parameters because we don’t know beforehand how many variables you need. In case you specify less functions than variables, then linear Bézier functions will be used for the variables without functions specified.
As we said on the previous post, animation4j API could change since this blog post was written. API used for this post is the one of the current released version 0.0.8 (already uploaded to maven central).
Animation4j - Transitions
As we said on a previous post, we are going to talk a bit more about the current released version (0.0.8) of animation4j, remember that the API could change since we wrote this post.
In this case, we are going to talk about making a transition from one value to another in some time. Animation4j provides you one interface to make transitions, the Transition interface, the API by now looks like this:
public interface Transition<T> { /** * Returns the current value of the transition. * */ T get(); /** * Start an interpolation from a to b in the specified default time. * * @param t * The wanted new value. */ void set(T t); /** * Start an interpolation from a to b in the specified time. * * @param t * The wanted new value. * @param time * The time to set the new value. If time is zero, then value is applied directly. */ void set(T t, int time); }
The library uses generics so you can create transitions of any type. To do this, you can use the Transitions factory class, where you can create transitions for your types. The API of the factory class looks like this:
<T> Transition<T> transition(T startValue, TypeConverter<T> typeConverter);
The current Transition generic implementation internally work with a float[] in order to optimize memory and to simplify internal work. To use it, you will have to create a converter from your type to float[] and vice versa by implementing the [TypeConverter
/** * Provides a way to convert an object in a float[] array and vice versa, for interpolation purposes. * * @param <T> * The type to convert. * @author acoppes */ public interface TypeConverter<T> { /** * Returns the quantity of variables are used to convert the object to the float[] and vice versa. * * @return the quantity of variables used. */ int variables(); /** * Copy the values of the object to the specified float array, if null it will create a new float array. * * @param object * The object from where to get the values to fulfill the float array. * @param x * The float array to copy the values of the object. If null it will create a new float array. * @return The float array with the values of the object. */ float[] copyFromObject(T object, float[] x); /** * Copy the values of the float array to the specified object. * * @param object * The object which the float array values will be copied to. If null or object immutable, it will create a new object. * @param x * The float array to get the values to fulfill the object. * @return An object with the values of the float array. */ T copyToObject(T object, float[] x); }
Type converters should be stateless, so you can reuse a single type converter for all your transitions of the same type. For the next Vector2f class example:
public class Vector2f { public float x,y; public Vector2f(float x, float y) { set(x,y); } public void set(float x, float y) { this.x = x; this.y = y; } }
We could create the next type converter:
public class Vector2fConverter implements TypeConverter<Vector2f> { @Override public float[] copyFromObject(Vector2f v, float[] x) { if (x == null) x = new float[variables()]; // don't worry about garbage generation, the transition implementation will cache these values. x[0] = v.x; x[1] = v.y; return x; } @Override public Vector2f copyToObject(Vector2f v, float[] x) { if (v == null) v = new Vector2f(0, 0); // don't worry about garbage generation, the transition implementation will cache these values. v.x = x[0]; v.y = x[1]; return v; } @Override public int variables() { // we are only using two variables. return 2; } }
So, to create a transition, your code would look like:
TypeConverter<Vector2f> converter = new Vector2fConverter(); // could be reused Transition<Vector2f> transition = Transitions.transition(new Vector2f(100, 100), converter); // now, set a transition to (500,500) in five seconds. transition.set(new Vector2f(500, 500), 5000); // wait some time, and get the value interpolated Vector2f v = transition.get();
For more information, there is an transitions example in the examples module.
The idea is to provide different TypeConverter implementations for different libraries as project modules so you don’t have to implement a TypeConverter for a Slick2D vector2f, or libgdx Vector2. However it is really easy to implement a type converter and you only have to do it once. Also, you will probably use transitions only for some types.
In one of the next posts, we want to talk about interpolation functions (and how are they used for transitions) as they are key concepts in animation4j project.