User Tag List

Page 2 of 3 FirstFirst 1 2 3 LastLast
Results 11 to 20 of 23

Thread: Scripting API/Reference/Design thread

  1. #11
    The Time-Loop Continues ZC Developer
    Gleeok's Avatar
    Join Date
    Apr 2007
    Posts
    4,827
    Mentioned
    259 Post(s)
    Tagged
    10 Thread(s)
    vBActivity - Stats
    Points
    12,978
    Level
    33
    vBActivity - Bars
    Lv. Percent
    28.3%
    I'm working on the battle engine right now so let's see if we can add a bit of the combat and battle related API to this. (Though there's too much to type everything out right now, here's a brief description.)

    *Data*
    -character_data
    -character_class
    -monster_data

    (Each of the previous holds base data for attributes, sprite id's, names, script name, description, etc..)

    *Game Instances*
    -character (initialized from character_data. all characters are )
    -party (contains arrays of active/inactive characters, shared inventory, etc.)
    -monster (initialized from monster_data. normally temporary objects for battles)

    *Combat Instances*
    -combatant
    -player_combatant (holds a reference to a character)
    -enemy_combatant(holds a reference to a monster)


    Attributes are pretty much done and I'm in the process of "finalizing" other things as well. All attributes of any object above can be references by scripts by:
    Code:
    attributes.max_param[]
    attributes.stat[]
    attributes.status_atk[]
    attributes.status_def
    attributes.element_atk[]
    attributes.element_def[]
    attributes.misc[]
    These can be kind of tricky at first though. For example
    Code:
    character.attributes.stat[STR] != character.base_attributes.stat[STR];
    It's easy to type the wrong one.
    The difference is character.attributes is read-only since it includes all the modified values from equipment, buffs, modifiers as well, and, accidentally setting base_attributes could be bad.


    *Interesting Side-Effects from the design (Due mostly to c++ code-reuse patterns..and/or it was a few extra LOC. I wasn't even planning any of this, I swear!)*
    -All monsters can equip items, and hold an inventory! Imagine a group of Goblins each equipped with long swords and leather gear!
    -Easily possible to have "capsule monsters" or whatever. There you go.

    And that's it for now. It's a WIP.

    Quote Originally Posted by Imzogelmo View Post
    I was just reading through to see if I can get an idea of how much would be pre-built vs. needing to be made with a script. Naturally, my mind first considers the menuing system-- any kind of Final Fantasy game has a main menu and various sub-menus accessible from it-- but the exact layout and contents of the menu would vary based on the specific details of the game. For instance, Final Fantasy IV needs 5 characters to be visible; FF V needs a job menu; FF VI needs a skills menu, etc. My point being that while they are all very similar and can probably be built from the same basic parts, the specific form that you end up with would differ based on the need of the game.

    Parallel to that, I think the map would be a fairly universal module across games as well. Maps need a width, height, tileset, and of course the data (including probably at least a couple of layers). Several general things populate the map perhaps as additional layers: NPCs, treasure chests, event triggers, warps, animated tiles, layer-priority shifts, diagonal stairways, etc. It seems me that if you get the map powerful and flexible, and then a menu-subsystem.. that's 2/3 of the work right there (the battle engine being the other 1/3, of course).
    Right you are. My idea for menus is this:

    A specialized, stripped down UI library designed only for console-styled jrpgs. (Obviously anything that can handle this can also handle any other kind of game, that doesn't involve a mouse that is, without too much trouble.) ...And that's it. O_o ...well things like auto-layout and auto-managed lists of various types is a huge win. I think this is the best option overall in terms of useability without tons of stupid windowing layout scripts, anyway.

    If you have something better though then let me know, though I think component-based is by far the easiest and most flexible.
    This post contains the official Gleeok seal of approval. Look for these and other posts in an area near you.

  2. #12
    Floormaster Imzogelmo's Avatar
    Join Date
    Sep 2005
    Location
    Earth, currently
    Age
    46
    Posts
    387
    Mentioned
    7 Post(s)
    Tagged
    3 Thread(s)
    vBActivity - Stats
    Points
    1,480
    Level
    13
    vBActivity - Bars
    Lv. Percent
    1.77%
    At the risk of a pun, I think we're on the same page as far as menus. It has to be flexible enough to handle dynamic and static text, intuitive as far as a tree of selections goes, and quick to produce from an end-user.

  3. #13
    The Time-Loop Continues ZC Developer
    Gleeok's Avatar
    Join Date
    Apr 2007
    Posts
    4,827
    Mentioned
    259 Post(s)
    Tagged
    10 Thread(s)
    vBActivity - Stats
    Points
    12,978
    Level
    33
    vBActivity - Bars
    Lv. Percent
    28.3%
    Quote Originally Posted by Imzogelmo View Post
    At the risk of a pun, I think we're on the same page as far as menus. It has to be flexible enough to handle dynamic and static text, intuitive as far as a tree of selections goes, and quick to produce from an end-user.
    I think you mean U and I are on the same page. ...I mean, ..yeah. Not looking forward to it, but I think I have some good concepts that are easy enough to add. I'd like to get a battle loop first, but definately been thinking about it.

    Forgot to mention but RPGLib is set up as a weird moduled unity build thing. That way no matter how many more files I add to it, it won't break and there's no need for makefile bs. It just compiles 3 .cpp files that include all the other files. I *could* set up the other project that way if it becomes an issue.
    This post contains the official Gleeok seal of approval. Look for these and other posts in an area near you.

  4. #14
    The Time-Loop Continues ZC Developer
    Gleeok's Avatar
    Join Date
    Apr 2007
    Posts
    4,827
    Mentioned
    259 Post(s)
    Tagged
    10 Thread(s)
    vBActivity - Stats
    Points
    12,978
    Level
    33
    vBActivity - Bars
    Lv. Percent
    28.3%
    Apparently the first post is too big to contain any more.. I'll see what I can do about that.

    Anyway here we go. More Core Data Types:
    (this process was 1/3 automated so some things were not output. but it should give an idea of how it works.) :)
    Code:
    /**
     * class that manages attribute values.
     */
    class attributes;
    {
    	attributes();
    	attributes(const attributes &);
    	attributes& operator +=(const attributes &);
    	attributes& operator -=(const attributes &);
    	attributes operator +(const attributes &) const;
    	attributes operator -(const attributes &) const;
    
    	int get_max_param(int) const;
    	int get_stat(int) const;
    	int get_element(int);
    	int get_status_atk(int);
    	int get_status_def(int);
    
    	void set_max_param(int, int) const;
    	void set_stat(int, int) const;
    	void set_element(int, int);
    	void set_status_atk(int, int);
    	void set_status_def(int, int);
    
    };
    
    
    /**
     * class that manages items and amount.
     */
    class inventory
    {
    	inventory();
    	inventory(const inventory &);
    
    };
    
    
    
    /**
     * class that manages equipped items.
     */
    class equipment
    {
    	equipment();
    	equipment(const equipment &);
    
    };
    
    
    
    /**
     * class that describes an enchantment
     * or temporary effect on an actor or entity.
     */
    class buff
    {
    	buff();
    	buff(const buff &);
    
    };
    
    
    
    /**
     * class that holds all basic information of a character
     */
    class character_data
    {
    	string name;
    	string script;
    	string description;
    	int id;
    	int race_id;
    	int class_id;
    	int portrait_id;
    	int map_spriteset_id;
    	int battle_spriteset_id;
    	int lv;
    	int exp;
    	int gold;
    	attributes attributes;
    
    };
    
    
    
    /**
     * class that holds all basic information of a monster
     */
    class monster_data
    {
    	string name;
    	string script;
    	string description;
    	int id;
    	int portrait_id;
    	int map_spriteset_id;
    	int battle_spriteset_id;
    	int lv;
    	int exp;
    	int gold;
    	attributes attributes;
    	item_dropset item_dropset;
    
    };
    
    
    /**
     * class that is an instance of a character or monster class;
     */
    class actor
    {
    	actor();
    	actor(const actor &);
    
    	string name;
    	string script;
    	int id;
    	int portrait_id;
    	int map_spriteset_id;
    	int battle_spriteset_id;
    
    	int get_lv() const;
    	int get_exp() const;
    	int get_gold() const;
    
    	void set_lv(int) const;
    	void set_exp(int) const;
    	void set_gold(int) const;
    
    	int get_param(int) const;
    	int get_max_param(int) const;
    	int get_base_max_param(int) const;
    	int get_stat(int) const;
    	int get_base_stat(int) const;
    	int get_status_atk(int) const;
    	int get_status_def(int) const;
    	int get_base_status_atk(int) const;
    	int get_base_status_def(int) const;
    
    	void set_param(int, int) const;
    	void set_base_max_param(int, int) const;
    	void set_base_stat(int, int) const;
    	void set_base_status_atk(int, int) const;
    	void set_base_status_def(int, int) const;
    
    	const attributes& get_attributes() const;
    	const equipment& get_equipment() const;
    
    };
    
    
    
    /**
     * class entity that is a battle instance of, and 
     * holds a reference to, an actor.
     */
    class combatant
    {
    	actor();
    	actor(const actor &);
    
    	actor@ get_actor() const;
    
    	int get_param(int) const;
    	int get_max_param(int) const;
    	int get_base_max_param(int) const;
    	int get_stat(int) const;
    	int get_base_stat(int) const;
    	int get_status_atk(int) const;
    	int get_status_def(int) const;
    	int get_base_status_atk(int) const;
    	int get_base_status_def(int) const;
    
    	void set_param(int, int) const;
    	void set_base_max_param(int, int) const;
    	void set_base_stat(int, int) const;
    	void set_base_status_atk(int, int) const;
    	void set_base_status_def(int, int) const;
    
    	const attributes& get_attributes() const;
    	const equipment& get_equipment() const;
    
    };
    
    
    /**
     * class that manages a list of current active and reserve
     * party members, as well as other information.
     */
    class party
    {
    	party();
    	party(const party &);
    
    	int get_gold() const;
    	int get_size() const;
    	int get_active_size() const;
    	int get_reserve_size() const;
    	int get_max_size() const;
    	int get_max_active_size() const;
    	int get_active_member_id(int index) const;
    	int get_reserve_member_id(int index) const;
    
    	actor@ get_active_member(int index) const;
    	actor@ get_reserve_member(int index) const;
    
    	inventory& get_inventory();
    	const inventory& get_inventory() const;
    
    	void set_gold(int);
    	void set_max_size(int);
    	void set_max_active_size(int);
    
    	void add_gold(int);
    	void remove_gold(int);
    
    	void add_member(int);
    	void remove_member(int);
    
    	bool has_member(int) const;
    	bool is_member_active(int) const;
    	bool is_member_in_reserve(int) const;
    	bool is_full() const;
    
    };
    Basic Sprite classes reference:
    Code:
    //----------------------------------
    // * Sprite
    //----------------------------------
    class sprite
    {
    public:
    	vec2 size;
    	vec2 scale;
    	color color;
    	blendmode blendmode;
    	float angle;
    	rectf uv;
    
    	sprite();
    	sprite(const sprite&);
    	sprite &operator =(const sprite&);
    
    };
    
    
    
    //----------------------------------
    // * SpriteAnimation
    //----------------------------------
    class sprite_animation 
    {
    public:
    	int animation_speed;
    	int frame;
    	int num_frames;
    	rect source_rect;
    	rectf uv;
    
    
    	bool is_animated() const;
    	//void flip(int flags);
    
    };
    
    
    //----------------------------------
    // * AnimatedSprite
    //----------------------------------
    class animated_sprite : public sprite_animation
    {
    public:
    	vec2 size;
    	vec2 scale;
    	color color;
    	blendmode blendmode;
    	float angle;
    
    	animated_sprite();
    	animated_sprite(const animated_sprite&);
    	animated_sprite &operator =(const sprite&);
    	animated_sprite &operator =(const animated_sprite&);
    
    };
    
    
    //----------------------------------
    // * AnimatedSpriteSet
    //----------------------------------
    class animated_spriteset
    {
    public:
    	sprite_animation animation[];
    	vec2 size;
    	vec2 scale;
    	color color;
    	blendmode blendmode;
    	float angle;
    	int num_animations; //get
    	int state;
    
    	animated_spriteset();
    	animated_spriteset(const animated_spriteset&);
    	animated_spriteset &operator =(const animated_spriteset&);
    
    	//void add_animation(const rect& sourceRect, float speed, int numFrames, int frameOffsetX, int frameOffsetY);
    	//void remove_animation(int index);
    
    };
    Whewee... we're getting serious now!

    Anyway it's not perfect but it's the best documentation I can do right now.
    Ideas for better design, names, functions, etc.. are most welcome.
    This post contains the official Gleeok seal of approval. Look for these and other posts in an area near you.

  5. #15
    The Time-Loop Continues ZC Developer
    Gleeok's Avatar
    Join Date
    Apr 2007
    Posts
    4,827
    Mentioned
    259 Post(s)
    Tagged
    10 Thread(s)
    vBActivity - Stats
    Points
    12,978
    Level
    33
    vBActivity - Bars
    Lv. Percent
    28.3%
    I.. umm... sorta shit-canned the entire scripting engine... yeah. >_>

    The reason was because it wasn't productive enough, period. Things like LUA and angelscript are great so long as the scripts are only responsible for doing specialized tasks and logic. That, and binding and creating the script API, both c++ side and script side, was taking up too much time. Angelscript worked great for my last side-project, but for a large project with this kind of scope you really need a more serious solution--well, that or some serious man power. Since I have zero additional man-power in this scenario it was actually a pretty easy call to scrap the whole thing for something better.

    So what's better? -Embedded C# is better. There's also a lot of potential support for other languages: http://en.wikipedia.org/wiki/List_of_CLI_languages
    This is in fact pretty much exactly what Unity3D does, and the .NET framework already has a shit ton of utility classes and containers ready to go without any fuss, so once the initial cost of set-up is out of the way it's smooth sailing.

    The benefits as I see them are:
    -Scripts can compile directly into machine code and would be almost as fast as c++. Can also be AOT compiled.
    -Maintain portability; Works for x86, X64, and ARM.
    -Large framework, with the ability to simply drop-in code off the web. eg., XNA, or use 3rd party libraries.
    -Easy to write with an entire interwebs worth of reference material.
    -Existing tools for integrated development environment such as Visual Studio, MonoDevelop; also some lightweight ones as well.
    -Debugging support through Mono, or perhaps directly debugging through an additional assembly layer (have to think about this).
    -I might actually work on it more.

    Cons:
    -Initial setup time.
    -???

    Thoughts?

    I'll probably just throw together either a Tetris or Galaga clone for fun in order to test everything out.
    This post contains the official Gleeok seal of approval. Look for these and other posts in an area near you.

  6. #16
    Cor Blimey! CJC's Avatar
    Join Date
    Dec 2002
    Location
    Fading into the darkness
    Age
    36
    Posts
    1,398
    Mentioned
    150 Post(s)
    Tagged
    6 Thread(s)
    vBActivity - Stats
    Points
    6,640
    Level
    25
    vBActivity - Bars
    Lv. Percent
    4.39%
    I dare you to build a battle engine where the multiplier for damage is determined by how many lines you complete with a single piece of Tetris, thrown by the enemy's defense rating (so an enemy with a defense of say 12 might through a huge and unwieldly piece). Also, when you 'bust' on the tetris board your party gets hit with a huge attack, like a megaflare or something!

    ...What does that have to do with scripting? Nothing, you just said Tetris and I have a short attention span.

  7. #17
    Here lies mero. Died by his own dumbassitude.
    Join Date
    May 2011
    Posts
    929
    Mentioned
    102 Post(s)
    Tagged
    2 Thread(s)
    vBActivity - Stats
    Points
    5,527
    Level
    23
    vBActivity - Bars
    Lv. Percent
    13.96%
    You got any plans for 3D Capabilities?

  8. #18
    The Time-Loop Continues ZC Developer
    Gleeok's Avatar
    Join Date
    Apr 2007
    Posts
    4,827
    Mentioned
    259 Post(s)
    Tagged
    10 Thread(s)
    vBActivity - Stats
    Points
    12,978
    Level
    33
    vBActivity - Bars
    Lv. Percent
    28.3%
    Yes, you can do 3D (mostly) the same as XNA. Of course getting it to work with 2D is another matter.

    http://tech.pro/tutorial/750/creatin...red-box-in-xna


    There's also a VertexArray which is something like this:

    Code:
    VertexColorTexture3D faces[8];
    
    //fill the faces of the cube
    faces[0].position = new Vector3(0,1,0);
    faces[0].uv = animatedSprite.GetUVRect().TopLeft();
    faces[0].color = Color.Blue;
    
    //etc.
    VertexArray<VertexColorTexture3D> vertexArray = new VertexArray();
    vertexArray.Add(faces);
    
    Graphics.GraphicsDevice.DrawVertices(vertexArray);
    It's just openGl so you can write it in c/c++ and call that from a script also.

    I'm sure there are other ways; I haven't really given it much thought. The engine itself doesn't much, if any, 3D, so you have to do it yourself, or use 3rd party libraries.
    This post contains the official Gleeok seal of approval. Look for these and other posts in an area near you.

  9. #19
    Here lies mero. Died by his own dumbassitude.
    Join Date
    May 2011
    Posts
    929
    Mentioned
    102 Post(s)
    Tagged
    2 Thread(s)
    vBActivity - Stats
    Points
    5,527
    Level
    23
    vBActivity - Bars
    Lv. Percent
    13.96%
    As long as I can recreate FF5 in 3D I'll be happy.

  10. #20
    Here lies mero. Died by his own dumbassitude.
    Join Date
    May 2011
    Posts
    929
    Mentioned
    102 Post(s)
    Tagged
    2 Thread(s)
    vBActivity - Stats
    Points
    5,527
    Level
    23
    vBActivity - Bars
    Lv. Percent
    13.96%
    C# is a lot of fun, you know that Gleeok.

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •  
About us
Armageddon Games is a game development group founded in 1997. We are extremely passionate about our work and our inspirations are mostly drawn from games of the 8-bit and 16-bit era.
Social