Sunday, January 29, 2012

GameStates, Contexts, and Entities.... OH MY!!

Ok, so as indicated by my last post, I am now working on the basic design of my new component engine. I have made good progress so far. I have been able to set up the basic structure, and recreate my previous GraphViewer application. So far my component engine has these elements:

GameState - This is pretty much the main game class for now. It holds everything that the main part of the game needs. Later on I will build a state manager that will manage different states of the application (Intro, game menu, credits, game, etc...)

Contexts - Every context manages a different part of the game (Graphics, physics, input, sound, etc...) These contexts allow the different sub-system code to be drawn out of the different Components

Entity - A basic game object that ties together various components.

Components - This is an individual part of an entity that is responsible for a specific task. For Example there is a graphics component that handles what mesh to draw, or what color to draw it. You can mix and match components in an entity depending on what you want to do with the game object.

Ok, thats about it for now. I will expect a demo of what I am doing sometime this week...

Wednesday, January 25, 2012

The Next Step

I have the opportunity now that GraphViewer is nearing completion, to start planning out my next step. My next objective is to create more of a simple prototype of my game. This involves creating a basic game class to base the game off of. I have seen many ways of setting up a base game class, but the one that I find is most effective is the component model. Here is pretty simple explanation by Robert Nystrom. Pretty much it splits up the roles of a single object in a game. There is a separate graphics component, that draws everything to the screen, a physics component, that handles everything physical, etc. You can plug and play different components depending on how you want the object to act. I have sketched up simple plan for my game:

As you can see, the GameState object has several contexts (which handle the graphics/input/audio API), and and "Object pool" of entities. An entity is simply a "thing" in the game. It could be anything, a star ship, a laser, or even a timer. It is merely made up of components. Every context also has a pointer to each separate component. This is where it differs from Robert Nystom's model, allowing each context know about each entity's components. This allows for optimization within each context. 

Tuesday, January 24, 2012

The GraphViewer Application

I have mostly finished up my Graph Viewer Application. It now reads a file with an extension ".graph" and dynamically displays it. Here is an example of such a file:

Graph.graph:
v(100,0)
v(-100,0)
v(0,100)
v(0,-100)
v(200,200)
v(200,-200)
v(0,0)
v(-100,-200)
e(6,0)
e(6,1)
e(6,2)
e(6,3)
e(6,4)
e(4,5)
e(1,2)
e(6,5)
e(1,7)
e(3,7)

As you can see, Vertices in the graph are denoted by v(x,y), and an edge connecting two vertices is denoted by e(v1,v2). The GraphViewer application then reads this file and displays it:


Now that I have this prototype up and running, I can start thinking about the mechanics of my RTS game. Imagine that each of these circles is a planet or star system, and that each line is a trade route. Every circle only has resources available that it generates on its own, or is "traded" from a neighboring planet. Thus (5) has resources generated from its own planet, and some from the planets (4), and (6). This is no "global" resource pool.

This will introduce a new level of strategy. An Enemy could "cut off" another world's resource by attacking a neighboring planet. The "capital" planet (which usually has the most resource usage) must be in center with the most neighboring planets just to sustain the capital planet. 

Sunday, January 22, 2012

The First Steps

So after a few hours looking at various 2D graphics libraries, and trying to get them all set up, I found SFML. SFML is a very good and simple 2D media library, and so much more. Think of SDL, but modern. After a quick 10 minutes I was up and running.


As shown here, SFML is drawing a custom Graph class that I created (which is pretty much a list of points, and a list of the lines connection each point). This is a very good start for my GraphVeiwer application, which will help with future development of the RTS that I am planning. 

Saturday, January 21, 2012

Bring on the Vectors...

Hey everybody. Today I finished up building a simple 2d Vector class. I will be using this class not only in this project, but also many other projects in the future. I ran it through several tests, making sure it didn't break. This is the class that I came up with:



/* 
 * File:   Vector2.h
 * Author: Eric
 *
 * Created on January 20, 2012, 8:33 AM
 */

#ifndef VECTOR2_H
#define VECTOR2_H

#include 
#include "math.h"

class Vector2 {
private:
    float x, y;
    
public:
    Vector2():x(0.0f), y(0.0f){};
    Vector2(float x, float y):x(x),y(y){};
        
    float getX(){return x;};
    float getY(){return y;};
    void setX(float a){x=a;};
    void setY(float a){y=a;};
    
    float length(){return sqrt(x*x + y*y);};
    float mag2(){return x*x + y*y;};
    void normalize(){
        float Length = length(); 
        if(Length != 0){
                x = x/Length;
                y = y/Length;
        }  
    };
    
    Vector2 normalized(){
        float length = this->length();
        if(length != 0){
            return Vector2(x/length, y/length);
        } 
        return Vector2();
    };
    
    bool operator==(const Vector2 a){return (x == a.x) && (y == a.y);};
    
    Vector2 operator+(const Vector2 a){return Vector2(x + a.x, y + a.y);};
    Vector2 operator-(const Vector2 a){return Vector2(x - a.x, y - a.y);};
    Vector2 operator-(){return Vector2(-x,-y);};
    
    template Vector2 operator+(const T a){return Vector2(a + x, a + y);};
    template Vector2 operator-(const T a){return Vector2(a - x, a - y);};
    template Vector2 operator*(const T a){return Vector2(a * x, a * y);};
    template Vector2 operator/(const T a){return Vector2(x/a, y/a);};
    
    friend std::ostream& operator<< (std::ostream &out, const Vector2 &c){ return out << "(" << c.x << "," << c.y << ")"; };
    
    float dot(const Vector2 a){return x * a.x + y * a.y;};
    
    static const Vector2 zero;
    static const Vector2 unit_x;
    static const Vector2 unit_y;
};

 const Vector2 Vector2::zero = Vector2();
 const Vector2 Vector2::unit_x = Vector2(1.0f, 0.0f); 
 const Vector2 Vector2::unit_y = Vector2(0.0f, 1.0f);

#endif /* VECTOR2_H */



I am quite content with this vector class. I should do everything I need and more. Here are some useful features:

Mathematical Operators We should be able to do the most common operations on this vectors (add, subtract, negate, multiply by any constant, dot product). Also, there are functions to normalize the current vector, or return a normalized copy of the vector.


Static Unit Vectors included are some pre-defined vectors; the Zero Vector, unit X vector, and unit Y vector. 


Simplicity This vector class is simple and fits into one header file. So including it in a project is as simple as coping the Vector2.h file into your header file directory.

Display included is an override for the stream operator (<<), making printing a vector a snap. This will be very useful in debugging.

Friday, January 20, 2012

Welcome!

Hello World! My name is Eric Hurst. Programming has always been a hobby of mine. I have explored deeply into the worlds of C++, Java, and PHP. Ever since my days of BASIC, I knew that Programming was for me. This development journal will be a record of my trials, journeys, and hopefully success of my newest programming ventures. Development journals from others have always been an inspiration to me, and I have always dreamed of having my own. I hope others will also be able to benefit from my contributions as well.

 Many times have I attempted to create the next-gen game engine, but lost interest or locked myself down in a system that was going nowhere. Every time it would get better, but I never completed a viable game engine. This time around I hope for much better, with more reasonable goals and specific plans. I plan on making a 2D RTS game (name pending) with a different resource/combat system. Instead of a global resource pool, resources will be location specific. Also, game play will be more Macro-management, rather than micromanaging, allowing the player to focus on strategy, rather than administration.

More is on the way. Comments are always welcome, whether they be mistakes in code, or general tips.