90 Days Ago — A Reflection

If you have been following along, you’ll know that we’ve made tremendous progress over the last 90 days of Violet.  I am thankful for Root for giving me the opportunity to invest my time into this project.  This project that initially started out as a way to recoup from my divorce has now become a work of art that I truly believe in.

The past week has been pretty tame with the amount of new features added.  I’ve mostly been working 80 hour weeks on this project since the start of the leave of absence and simply needed to “catch my breath”.  We’ve also needed to do another round of refactoring.  Since I won’t be in the code as much, I wanted to get much of it tidied up.  That way when I come back to coding, I don’t spend hours scratching my head wondering why something was left with a TODO mark.

Tomorrow is going to be hard for me.  If you haven’t guessed by now, today is the last day of my leave of absence from Root.  I feel very much like a kid going back to school after a long summer vacation.  I am not ready to go back.

What I Have Discovered

What I’ve discovered with my time off is that game development is what I want to be doing full time.  Like every job, not every minute of it is glamorous.  However, the overall common goal of making a game with a small team is something I’ve always wanted to do.  And this was fully realized during these last few months.

I’ve also discovered that I like working for myself.  I don’t think I could do game development if I was told to “build to this spec”.  I love experimenting with ideas and building out systems in such a way where ideas and game play can become integrated in a meaningful and fun way.

I love Root for its flexibility and its culture, but I’ve learned that web development is not what I want to do for the rest of my life.

What’s Next?

Though we have made a lot of progress, the game is hardly near complete.  In the next couple months we’ll probably not add major features, but rather take our existing systems and start plugging art and content into it.  Just in the last couple of weeks we’ve seen a 180 that the game has taken with world building and updated art.  We still have A TON to plug in, and much of that I can mindlessly add after a day of web development.

Also during these next couple months, we will be researching how to market the game so that we can reach everyone who could be interested in this project.  This is because I feel the next logical steps are to get funded using a crowdfunding platform, such as Kickstarter.  In order for this project to truly be successful, and for our ideas to fully blossom, we need to be dedicated on it.  The only way to be dedicated on this is to have a way for the bills to be paid.

We Need YOUR Help

This project will only be successful if YOU help share it with others.  In the next week or so, I am going to be hitting the social media platforms and getting pages/channels/etc. added.  When these are added, please like/follow/share with those you think will be interested in this project.  The more eyes on this, the better chances we have of being successful!

For those who have followed along and have helped contribute, whether with game assets, testing, or simply being supportive, THANK YOU!  We couldn’t do this without your support!

Violet
Violet

 

 

 

Putting It All Togther

Much of this past week and a half has been devoted to world building and polishing.  We’ve made a lot of progress in the last few months.  However, this update really “puts it all together”.  Below are some screenshots of the current status of the game:

North Castle Path
North Castle Path
Hidden Treasure
Hidden Treasure
Sneaky Sneaky
Sneaky Sneaky
Northern Grasslands Trail
Northern Grasslands Trail
Carrot Field
Carrot Field
Barn
Barn
Ambushed
Ambushed
Rainy FIght
Rainy Fight
Gazing Across Eve River
Gazing Across Eve River
Fight With Knight Ghost
Fight With Knight Ghost
Rainy Night
Rainy Night
Skeletons Emerge
Skeletons Emerge
Enter Southern Mountains
Enter Southern Mountains
Southern Mountains
Southern Mountains
Eve River Trail
Eve River Trail
Updated Pause Screen
Updated Pause Screen
Updated Quick Menu Screen
Updated Quick Menu Screen
Skeletons Emerge 2
Skeletons Emerge 2
Frozen Against Knight Ghost
Frozen Against Knight Ghost
Attacking Two Minotaurs
Attacking Two Minotaurs
Eve River Dock
Eve River Dock
Attacking Reptile With Shovel
Attacking Reptile With Shovel
Treasure Amongst Minotaurs
Treasure Amongst Minotaurs
Lake Eve Trail
Lake Eve Trail
Treasure Under Evergreen
Treasure Under Evergreen
Fight Against Reptiles
Fight Against Reptiles
An Evening At Lake Eve
Northern Mountains
Northern Mountains
Northern Mountains 2
Northern Mountains 2
Dodging Centaur Fire Attack
Dodging Centaur Fire Attack
Centaur Dual
Centaur Dual
Dodging Centaur Attack
Dodging Centaur Attack
Northern Mountains Night Time
Northern Mountains Night Time
Top of Northern Mountains
Top of Northern Mountains

 

World Building Beginnings

I’m going to keep this post short and sweet.  We’ve been world building the last few days.  Here are some screenshots quickly stitched together:

The Mountains
The Mountains

Legends say that when the world was created, Lake Eve, as it’s known by humans, was the starting point of creation.

Making Mountains Out of Mole Hills

It’s been quite a few days since the last post.  We’ve done lots of tedious behind-the-scenes work, mostly involving graphic updates.  Here’s a little of what we’ve done:

Updated Weapons

If there was any new real “feature” from this update, it would be changing the weapon mechanic slightly.  One thing I noticed as people were playing the game is most would use the Sword and Shield combo (myself included).  Perhaps this is because the Shield comes naturally with the Sword, but I wanted to find a way to make the Sword less “OP” so that more would be drawn to the Mace and Spear.  When the player was facing up or down, the Sword‘s hit box would span from -90° to 90°.  This would cover quite a bit of area.  We decided to shrink the range to be -45° to 45° — still covering quite a bit of area, and still feeling natural, but losing a little bit of its “edge” in range.  The Mace on the other hand would keep its -90° to 90° hitbox range.  With the Mace‘s power and range, it might make players more willing to use the weapon now.

Updated Sword Angle
Updated Sword Angle

By doing this, we obviously had to update all the animations for the weapons currently in the game.  When I was getting the initial ideas of the weapon mechanic, I used a “git-er-done” approach, and sort of faked the animations.  Though the animations currently in the game are not final, everything is now connected to the player.  If we would have in the past looked really closely, we would have noticed that most of the animations from the player and the weapon were not actually aligned.  This was most noticeable with the Mace weapon.  Now all of the weapons are properly aligned with the player.

To implement the mechanic, and fixing the “git-er-done” approach, we had to go tediously frame by frame to match them to the player’s animation.  You may have noticed I left out the player facing left or right when describing the Sword earlier.  This is because these range’s hit boxes were really off — mainly due to the drawing perspective.  Thus, we had to add these animations manually as well, which took a bit of time and patience.

Alas, we have a base for all of our weapon animations.  What does this mean?  We can now produce more weapons of the Sword, Spear or Mace type by following a few simple rules.  Of course, this is all still manual, but positioning is now less painful.

So far we’ve added a variety of different weapons.  There is plenty more to come, but I was distracted by other polishing items.  Take a look below:

Axe
Axe
Long Stick
Long Stick
Trident
Trident
Shield Variation 1
Shield Variation 1
Shield Variation 2
Shield Variation 2
Shield Variation 3
Shield Variation 3
Fire Rod
Fire Rod
Ice Rod
Ice Rod
Water Rod
Water Rod

New Trees

Hannah has been hard at work the last couple weeks adding new graphics.  Here area a few new trees:

Willow Trees
Willow Trees
Evergreens
Evergreens
Palm Trees
Palm Trees

WIP Cave

I forgot when I said that the updated weapon mechanic was the only “real” new feature.  We started a cave concept right on the end of the last update and the beginning of this update.

Outside Cave
Outside Cave
Inside Cave
Inside Cave

The reason why this is still WIP is because it’s using a mixture of two mechanics — the building mechanic and the layerDepth mechanic of bridges.  Originally, buildings were decided not to have “roofs”.  If one went inside a building, the walls and roofs would simply fade out — there was no collision on them.  However, with a cave, we could technically be able to walk on the tops of them (at least, that’s how I envision them working).  To make this possible, I ported over some of the layerDepth mechanics.  The idea works, but there is quite a bit of polishing to do.  I wanted to wait on polishing because I knew we would be adding…

Infinite Tileable Cliffs

Hannah’s has been a beast with these cliffs!  We added cliffs originally for concept, but we really needed a way for them to be able to stack as tall as we wanted to them to be — so we could not only build hills, but mountainscapes.  These almost finished, but we wanted to share the progress of what we had so far:

Outer Cliffs Smaller
Outer Cliffs Smaller
Outer Cliffs
Outer Cliffs
Inner Cliffs
Inner Cliffs
Inner Cliffs Smaller
Inner Cliffs Smaller
Cliff Ends
Cliff Ends

Conclusion

With most of the basic landscape assets in place, we are beginning to create a more realistic game world.  It’s really awesome to see all of this art starting to come together!  Stay tuned!

Shield Bash, Water Rod, Camera Updates and More!

When 10 days go by without a post, you know something is cooking!  Hold on tight — I’m about to drop a ton of new features:

Polishing

Okay, I guess this isn’t really a feature.  But the last 10 days have seen quite a bit of improvements and polishing.  The main reason for this is we’ve had quite a few people play test the game in the past week, and we wanted the experience to be as good as possible.  There are many, many more improvements not listed here — an exhaustive list would be many pages long, and probably quite boring.  Here are a list of notable, exciting (from my perspective) improvements:

Fatal Error Fixes

There have been several game breaking errors that have been occurring.  Most of them I originally thought were because of objects going inside / outside of the loading zones.  However, this wasn’t the case.  They were mostly due to a pointer to instances being destroyed not getting nulled (or in Game Maker, set to noone).  We have one nagging fatal bug left that I cannot for the life of me figure out where it’s coming from.  We’ll eventually squash it though. 🙂

Masking on Weapons

Many objects use invisible masks to represent collisions.  One of these objects were weapons.  Game Maker has a limit in that an animation cannot turn on and off masks for a given sprite animation.  We can specify per frame collisions based on the sprite image itself.  But if pixels exists for a certain frame, the collision will be on those pixels.  Why this matters is, for example, the sword animation should not have collisions on the first two images of the animation, because they are “wind up” frames.

Behind the scenes, we wrote a script that every frame of the animation would check which frame the animation was on and swap the mask for a certain specific separate masking image for each frame.  The code became quite a case statement mess.  Though Game Maker’s turning on / off masks limitation still exists, I found that swapping for a specific separate masking image was redundant as we could simply swap for the actual image in the animation at a given frame.  Though there are still a few case statements, we were able to condense them by saying:

switch (image_index)
{
  case 0:
  case 1:
    mask_index = spr_MaskNone;
    break;

  case 2:
  case 3:
  case 4:
    mask_index = -1; //which means the actual sprite image
    break;
  
  default:
    mask_index = spr_MaskNone;
    break;
}

vs.

switch (image_index)
{
  case 0:
  case 1:
    mask_index = spr_MaskNone;
    break;

  case 2:
    mask_index = spr_SwordMask1;
    break;

  case 3:
    mask_index = spr_SwordMask2;
    break;

  case 4:
    mask_index = spr_SwordMask3;
    break;

  default:
    mask_index = spr_MaskNone;
    break;
}

As we can see, we no longer have to maintain specific images for specific frames.  This will scale much better as well.

Shooting Fixes

When shooting arrows, fire or ice, sometimes where the arrow spawned was a little inaccurate.  This was most noticeable with enemies.  This issue has now been fixed.

The other shooting fix was objects like bushes or rocks were preventing these objects from continuing flight.  This is no longer the case, and seems more natural as these objects are drawn to be “smaller”.

Bottom Buttons Multiple Buttons

One of the new features added is the ability to shield bash (continue reading for more information).  To do a shield bash, the user must press L Trigger plus Xbox B on a classic layout.  Before now, the bottom button tutorial only supported one button.  Now we can supply infinite amount of button combinations (not practical, of course) for the player to learn how to do certain moves / tasks.

Updated Buttons
Updated Buttons

Enemies Attacking Outside View

I am not entirely sure when this bug came into the system, but the code to determine whether an enemy can “see” the player was broken.  This code is made up of three overarching checks:

  1. Is there a solid wall between the enemy and the hero?
  2. Is the hero in the enemy’s field of vision?
  3. Is the enemy in the viewport?

The last check was broken.  Somehow the location we were checking for the viewport was always the hero’s location instead of the enemy’s location.  Thus, the hero is always in the viewport and this check would return true.

The side effects of this were that enemies would attack the hero even when the player couldn’t see the enemy.  This was “unfair”.  The other was that hoards of enemies would come attacking the hero — to the point of overwhelming.  An enemy’s vision might be able to see the player, but the player couldn’t “see” the enemy due to the viewport not showing the enemy.  Again, this was “unfair”.  However, this is now resolved! 😀

Alright, onto new features!

Shield Bash

One of my friends since conception of the game has wanted the ability to attack with the shield.  I’ve liked the idea, but wasn’t sure the best way to go about it.  Finally, a year or so later, the ability to shield bash has been implemented.

Shield Bash
Shield Bash

Shield bashing is meant to be more of a defense of tactic.  If the player can time the attack right, the hero will parry the attack and cause the enemy to stop their attack and be stunned.  However, the player can deal damage with their shield if the shield collides with the enemy.  However, attacking with the shield is slower and will degrade the shield very quickly.

Coming up with this tactic was a very interesting problem to solve for.  Originally we were checking to see if the shield bash object was colliding with the weapon object.  However, as we were play testing this, it didn’t feel right.  I whipped out The Legend of Zelda:  Breath of the Wild to see how they implemented countering.  What I ended up discovering was that to perform a successful parry, the player had to anticipate the attack coming — almost performing the inputs of the parry before the enemy’s attack had happened.

To implement such a tactic, we could no longer perform collision events on the attacking weapon and the shield bash object, since the attack and input was not in “anticipation”, but rather as it was happening, or had happened.  Thus, we had to check if the attack was going to happen to see if a parry was happening.

How do we predict the future?  Magic.

No, just kidding.  In the polishing section of this post where we summarized the masking updates (you didn’t skip that, right? 😉 ), there are a couple frames were collisions are purposely turned off.  What we check for is:

  1. An enemy is within the vicinity and is currently holding a weapon.
  2. If the above is true, we check to see if the above weapon is in the initial part of the animation.
  3. If the above is true, and we are shield bashing, a parry can be performed.

There’s enough frames before the attack happens, that this feels “right”.  There currently is a “/” above the enemy’s head, so the player knows they are about to attack.  With this knowledge, a player can shield bash at the right time to perform a parry.

Updates to the Soldier AI

Since the hero has the ability to perform a parry, it was decided that the enemies who carry shields should be able to do the same.  This was implemented much like how the dodge counter works in the Updated Enemies and AI section.  If an enemy carries a shield, the more often the player uses their weapon, the more chances the enemy will perform a shield bash themselves.

The other update to the Soldier AI was after a Soldier gets stunned, they have the ability to either perform a dodge or a shield bash.  There is a science to this, but we don’t want to spill all the beans on how it works.  You’ll have to figure it out yourself!

Resolution and Camera

In the post “Audio Controller and More“, it was mentioned that there was an ability to pan the camera.  The more I played with the feature in the game, the more I disliked it.  This was mainly due to trying to play the game with a camera that snapped back — it just didn’t feel right.  However, I thought it was still important to be stealthy in this regard.

The other big problem we were trying to solve for in the last couple weeks was defining the screen resolution of the game.  This is an important thing to nail down as it decides game play, as well as device support.

Pixel art does not scale very well when using multiples other than integers.  For example, we can scale pixel art up by 2x, 3x, etc., but distortion will happen when using non integer values (1.5 for example).  When coming up with the original game play, we were using 1440 x 810 as the resolution.  We knew this was not going to be the final resolution, but kept with this as it was easy to see code with the the game window up (made for easier debugging).

When figuring out resolutions, we started with 960 x 540.  This felt like a good resolution because it could be scaled to 1920 x 1080 since multiplying by 2 is a whole number.  However, since the viewport was shrunk down, the combat felt “claustrophobic” to me.  However, when people were play testing, it didn’t seem to bother them.  I am sure the bug fix with the enemies and the view certainly did help, but something was still missing.

Instead of panning the camera, I thought “what if we could zoom out the camera instead”?  Originally I tied moving the R-Stick up and down to zooming in and out.  However, this seem to conflict when trying to target enemies in lock on mode.  We decided to make pressing in the R-Stick to be a zoom toggle:

Zoom 1280 x 720
Zoom 1280 x 720
Zoom 1920 x 1080
Zoom 1920 x 1080

As we can see, zooming the camera out “scratches that itch” to be able to see more around the player, giving the stealthy player more area to view.  You may have noticed that we’re using 1280 x 720 instead of 960 x 540.  I felt 1280 x 720 gave the player more view area by default, which made combat feel less daunting.  However, 1280 x 720 is possibly the worse number to chose for our resolution, since a graphics card has to decide what a 1.5 pixel is supposed to be.

One thing we noticed though when scaling our art is that the art Hannah has drawn scales pretty well, even at non integer numbers.  I am not sure what magic is happening there, but I will be doing some pixel art research to figure out why that is.  The hero and enemies do distort, but it is hardly noticeable, especially when viewing from longer distances, such as playing on a TV.  Because of this, I think the game play outweighs the slight distortion one would see when zooming in / out.  Plus, we are using 64 x 64 graphic tileset in most cases, which I believe gives us more leeway in how art scales.

The only other issue we were having was since 1080 is the maximum “zoomed out” resolution, all of our surfaces must be drawn to that scale, since we never know when the player will “zoom out”.  Because of this, I noticed some slow down in the drawing events.  This is something I will keep my eye on, but the issue seems to be better with the 2.2.2.308 Beta Runtime version of Game Maker Studio.

Map Screen

The next WIP feature that we added was a map screen.  There is still a lot to do with this feature as the map that has been present is just the “playground” map.  Pressing Xbox Back or Select will pop up the map screen:

Map Screen
Map Screen

For one, it does not fill the entire screen.  We figured since the real map will be much larger, this will not be a problem.  However, the map WILL BE MUCH LARGER, which means the texture will probably need to be split into several surfaces to be drawn on screen.  This will be an interesting problem to solve for.  The other is we’ll most likely want to be able to zoom in and out of the map, pan, and set “interesting stamps” or waypoints the player can follow.  Right now they yellow dots simply represent where the violets or at, but they can really be anything.  Really, the only thing the map feature does right now is display, and lets the player be able to go to the main “pause” screen and back again without any issues.  Hence, WIP. 🙂

Water Rod

The water rod is the newest item to be added to the game.  It’s the missing link to our “rock, paper, scissors” concept, where fire beats ice, ice beats water, and water beats fire.  The water rod will blast a gush of water into enemies and pushes them back.

Water Rod
Water Rod

The water that comes out of the water rod automatically stuns enemies, as well as pierces shields.  It’s damage dealt is generally not much, but works great as a defensive powerhouse.  It will also put out fires and grow / restore plants that were being burnt from fire.  Finally, in the future, we may even add the ability for the water rod to push blocks or other objects (to potentially solve puzzles).

Bridges / Layers

The final feature that we want to share is the concept of bridges.  In a 2D perspective, we are only given x and y variables for positioning.  Thus, anything above or below the character is faked.  For example, if the hero’s position occupies a position on a bridge, is the character on the bridge, or under the bridge?  It’s a tricky problem to solve for sure!

I spent quite a bit of time thinking and looking at games like The Legend of Zelda, A Link to the Past (LoZ aLttP) to figure out how they “faked it”.  I kept looking at this image to figure out how this was solved.  In the image, there are several spots where there are overpasses Link can travel on.  When examining the image, I noticed the only way to get to the above section of the overpasses was by climbing stairs.  My guess then was in LoZ aLttP, the stairs was used as a flag internally because when moving up or down the stairs, the player loses control as Link goes up or down these stairs.  This flag, we’ll call layerDepth would be set to 1 when going up the stairs, and 0 when going down the stairs.  If Link’s layerDepth is equal to 1, he would be considered on the overpass, thus drawn on top of it, and collisions on the overpass would occur (probably checking if collision and layerDepth == 1).  If Link’s layerDepth is 0, collisions on the overpass would be ignored so that the player could “pass under” the overpass, and thus be drawn underneath.

The layerDepth concept was implemented in a similar way, except we didn’t want to be bound to stairs to set the flag.  Thus, we added a Ramp object — an invisible object before an overpass, or bridge, that increments the hero’s layerDepth.  The way the ramp works is if the player is traveling in a certain direction range towards the bridge (for example, down, we check the direction between 225 – 315), we would increment the layerDepth variable.  If the player is traveling in a certain direction range away from the bridge, we would decrement the layerDepth variable.  Thus, what we get is the hero standing on top of a bridge, because we incremented the layerDepth to be 1.

Bridge Prototype
Bridge Prototype

If we were to continue moving down past the bridge, our layerDepth would be set to 0.  Thus, if we were to jump into the water, the collisions of the bridge would be ignored (since they are checking for collision and layerDepth == 1), and thus, our hero would pass under the bridge.

There are still a few kinks to work out as well as needing to apply this to all other objects because the hero is the only object that works right now.  However, this concept seems to be working well, and theoretically scales beyond layerDepth‘s of 0 and 1 (though not sure how practical going more than two depths actually is).

Conclusion

If you made it through all the way, give yourself a gold star, because that was a lot of information to take in.  I think we are about a week out from beginning to build an actual game.  Stay tuned!

Item Pickups and Pause Screen

This past week was a bit lighter on new additions.  This was mostly from catching up on tasks related to adulting, as well as the power outage on Tuesday afternoon due to the ice storm.  Nevertheless here’s what’s new:

Forest and Swamp Updates

Two Saturday’s ago we had a team meeting, discussing updates to the story line, listening to new music, and of course discussing updated game play.  One of our discussions was over the current swamp graphics.  We decided that it wasn’t “swampy” enough.  Below is the updated swamp graphics:

Swamp
New Vanilla Swamp

We decided to add some more browns and have less greens.  Obviously when other assets are on the screen, such as water, trees, etc., the area will feel even more like a swamp.  The good news is the time spent on old swamp graphics were not in vain, as we are re-purposing that art to be for the forest area now.

Item Dialog, Collectibles and Chests

The majority of the week was spent on adding items and updating weapons.  Currently, the only “items” in the game before this past week was weapons.  We needed a mechanism that all items could handle.  However, not all items behave like weapons.  We needed to insert an Item object at the top of the hierarchy.  Now, Items have two children:  Weapons and CollectiblesWeapons work the same way as they did before, while Collectibles at the moment are just things the player collects.  Ultimately, there will be a purpose to collecting these collectibles.  But for now, they don’t have any function.  The beauty is now that we have a system in place, it should make adding these functions go very quick.

Collectibles
Collectibles

Since we have our new Item object, we were able to make a Chest object, which can contain treasure (an Item object).  If a treasure is a Collectible object, the treasure can have a quantity associated with it.  For example, an arrow that is not shot is considered to be a collectible.  One might open a chest and find 15 arrows inside.  Wahoo!

Chests
Chests

When a chest is opened, a new dialog screen pops up, informing the player the name of the item, the stat (damage for weapons, for example), the description, and a picture.  The same dialog screen appears for items being picked up for the first time as well:

First Time Item
First Time Item or Opening Chest

Pause Screen

The last major addition to the game this past week was adding a pause screen.  The game actually had a pause screen before, but it was just a placeholder, and was not very functional.  Though the new pause screen is not final, it at least is now usable.

Pause Screen
Pause Screen

I had the hardest time coming up with an adequate pause screen.  This is not because the programming was difficult — rather — trying to come up with a user interface that has a good user experience.  I studied Breath of the Wild’s pause screen for quite some time and concluded that pause screen was mostly perfect for what they were trying to accomplish.  Here are my reasons:

  1. Items, weapons, materials, etc. are put into their own categories or buckets.  These buckets are conveyed in a “mobile-like” tabular approach, where the name of the bucket is shown, as well as the bucket being highlighted (vs the other icons being dimmed).  Buckets with multiple “pages” are represented with a little “mobile-like” circle (not implemented currently).  This idea makes finding and sorting items and weapons quick and easy.
  2. Content is on the left and descriptions is on the right.  Since most languages are read left to right, it also makes sense that the buckets (or selections) are on the left, and what it does is on the right.
  3. The three main top level menus are controlled separately.  Currently, only “inventory” is built in the screenshot above, so it hasn’t made sense to build the functionality of the top level menus.  But I love the idea that L and R move these top level menus, since they are on the “top” of the controller.

Breath of the Wild’s pause menu is purposely simplistic, and feels like you’re on a mobile device, but the inputs are with a controller instead of gestures.  This is something I will continue to try to capture with our menu, and thus continue to iterate with these ideas in mind.

Conclusion

We are a little over halfway done with February.  These next couple weeks we hope to wrap up the bulk of the main “system” for the game.  From there, we will begin using these assets to start building out the actual game.  Stay tuned!

A Year Ago

With the ice storm we had last night, much of northwest Ohio and southeast Michigan are without power.  I had already planned on writing a post today — but not having electricity gives me more incentive to use my battery sparingly instead of consuming my battery compiling new builds every few minutes.

A year ago today marks the first commit to the original repository “game-idea”.

First Commit
First Commit

Thinking back, I actually started goofing around in Game Maker back in January of 2018.  Once I made a change I wanted to revert back to, I realized it was time to put the prototype into Git.  Since I am paying for Github for a few other side projects, this workflow made sense.

In the first post, I mentioned how and why I began this project.  But interestingly, I started this idea back in college in my Professional Ethics class (I know, very ethical of me, right?).  I wanted to come up with an fun combat system where the enemy (now know as the Soldier type enemy) could be made easy or difficult, given a few parameters, but running the same logic.

Old Old Prototype
Old Old Prototype

In this prototype, you could “swing” your sword around by moving the mouse.  The player would use the WASD keys and the player would always face the mouse.  If the player was moving in the direction of the mouse, they would move faster, and moving away from the mouse meant the player would walk slower.  It was a neat concept, but when I began rebuilding back in January of last year, I knew I wanted to build with a controller input in mind.

There really wasn’t much to show in the month of January 2018 as it was mostly porting the prototype from Game Maker 8 to GMS 1.4.  However, once ported, I began hammering out the main movement concepts I wanted to have, as well as nailing down an appropriate controller input system.

The first feature that was built was the slow motion dodge mechanic.  Game Maker has a concept of alarms, but they count down as whole integers.  To do slow motion correctly, timers and counters need to count in integers, and decimals when in slow motion mode.  I ended up making an object called obj_Core to support timers with integers and decimals, which all objects in the game inherit from.  It was great building that then because there are a lot of “core” features that all objects need in the game currently that we can simply tack onto obj_Core.

Old Test
Old Test

From there, it was all about honing in on making smooth, tight controls, as well expanding on the Soldier enemy.  Since my main inspiration was The Legend of Zelda: Breath of the Wild, I needed to build in the three main weapon styles — single handed, two handed quick, and two handed slow.  With that all working, I began adding a little bit of art to the game.  All the startup sprites can be found in this repo.  I am so thankful for them, because I would not have been able to make the game initially believable without them.

Old Screenshot
Old Screenshot

Another interesting thing from the original concepts was the hero was a girl.  Even though I had ideas of the game being called “Violet” by this point in time, I knew I did not want the hero to be a girl.  The main reason for the hero starting as a girl was because I didn’t want to stare at a guy all day — especially since the sprites I had then were very limited! 😀

By the end of March, I started to really have something that felt good.  Keep in mind, the only times available to build were in the evenings and on weekends.  Progress was being made, but at a very slow pace.

I was also getting input regularly from friends and co-workers to see what they thought.  There was (and is) always three questions I would ask:  “What did you like about it?”, “What did you not like about it?”, and “Did you have fun?”.  The last one is the most important as if the player was not having fun in the couple minutes they were playing, I knew we would need to start over.  Most of the time the answers to the “What did you not like about it?” were a feature not fully being fleshed out, to literally something I was about to add “not there.”  Most answers to the “What did you like about it?” were about the same as well — the controls felt good.  Hearing that the controls felt good to me meant there was a good foundation to continue building on.

The months of April and May showed a lot of polishing of the controls, as well as adding a few new controls and enemies, such as Shields and Violets.  Even with all the new enemies and features, my lack of graphical expertise was really beginning to show.  The sprite generator was great, but the “believablity” of the game began to drop as black squares and square boxes became more and more apparent.  Around June, one of my friends suggested to talk with Hannah about graphics.  Showing her the rough game play and explaining the ideas I had for the game, she decided to come aboard!

Older Screenshot
Older Screenshot

The “world” at the time was basically a big box with really no where to go.  It felt very claustrophobic.  In the month of July, we decided to “open the world” up and let people roam free.  The world would be 2 / 729 of the actual size of the game, but it was enough to make it “believable” again.  Opening the world meant adding some new features, like a day / night cycle, lighting, etc.  But it also meant some optimizations were needed.  The months of August and September were spent cleaning up, optimizing and polishing newer features.

The rest of the story has been or is currently being told in the blog.  It’s been quite an amazing journey so far building this game, and even more amazing to see how all of the pieces have come together.  I knew in the months leading up to January of 2018 that something needed to change with my life.  Simply coming home from work and vegetating on Netflix couldn’t be all there was to do in life.  I’ve always had a passion for gaming so I decided “why not try making one?”  I believe anyone’s passion and dreams can become a reality if you work hard enough for it.  But it can’t start tomorrow — it has to start today!

Thanks for letting me reminisce on the journey and I hope it was (and still is!) interesting to see and hear!

 

Audio Controller and More

This past week has been an interesting one as far as what we’ve added.  I feel like we were all over the spectrum with what new features were added.  Let’s get to it!

R-Stick Targeting

This past week or so we had some people play around with what had implemented.  A friend of mine had a suggestion about being able to use the R-Stick for targeting and manipulating the camera.  Interestingly, I had tried implementing an R-Stick selection feature many months ago, but did away with it because the algorithm I was using to “select” the target was not always consistent from a game play perspective.  However, many new features have been added to the system since then, so I thought we would give it another go.

The biggest problem we were trying to solve for was being able to target the enemy in the back who was sniping with arrows.  The current method of targeting is to select the closest enemy within reason.  If one presses the L Trigger, it will toggle to the next nearest.  If we have 3 or more enemies, one of them in the back snipping (as they are programmed to do), it makes it impossible to select these enemies without moving the hero towards the enemy snipping.

Updated Targeting System
Updated Targeting System

In the picture above, the bigger yellow triangles represent what the player is currently targeting.  The smaller white triangles to the left of the current target is the what we would select if we were to press L Trigger again.  We can think of this as the “next nearest”. To the south of the current target, and in the upper right of the picture are some even smaller tan triangles.  Along with the white triangles, these represent what we would select if we move the R-Stick in a certain direction.  For example, if the player were to press the R-Stick in the right or up direction, it would choose the Orc with the bow.  If the player were to press the R-Stick down, it would select the Orc with the sword.  And finally, if the player were to press the R-Stick in the left direction, it would choose the Minotaur.

The trickiest part of implementing the system was getting the UX down.  Originally we thought it would make most sense to color specific directions of the R-Stick.  But with so many different colors moving around, plus the “next nearest” concept, it became overwhelming and hard to keep track — especially when colors don’t really represent directions (I even tried googling to see if there was a set standard).  Currently we are using the small tan colored triangles, but those might end up going away.  We figured the best experience with the R-Stick method of was to make sure it “just works”.  If a player can simply know that if they press R-Stick right and it selects the “right” enemy, there is no need to have different color triangles, indicators, etc.

We believe this will work for combat because the player using the R-Stick to select a target is not focused on melee fighting, at that point in time.  This is because it is practically impossible to use the R-Stick at the same time as the face buttons (A, B, X, Y), thus making it impossible to fight with melee weapons (since melee weapons are bound to face buttons).  Therefore, the player who is using the R-Stick is focused on moving the target and not the combat at that point in time.  Colors, indicators, etc. then is not important, as long as selection in a certain direction with the R-Stick “just works”.

R-Stick Camera

My friend’s other suggestion from months ago was to have the ability to move the camera with the R-Stick.  My friend is a very stealthy player, and he wanted the ability to know what was coming up so that he can sneak better.  I’ve personally am not a stealthy player when it comes to games, but I still want to reward those who are.  Thus, we finally got around to building this feature out.  When moving the R-Stick when the player is not holding L Trigger for targeting, the player has the ability to move the camera until the hero is on the edge of the screen.  When the player releases the R-Stick the camera will “snap back” so the hero remains in the center of the screen.

The nice extra about this feature is there is now an object we’ve created for the camera follows.  Before it was always the hero.  Now it is just an invisible object, which during the R-Stick movement, gets controlled.  You may ask “what is so nice about this?”  Well, this gives us the ability to move the object wherever we want.  During a cutscene, for example, we can use that same object, give it some inputs where it should be, and walla!  We have a camera moving about in a cutscene.

Swamp / Long Grass / Fire Updates

Hannah supplied a few swamp graphics this week.  We decided to use the same grass tile, but color it differently.  I was okay with this approach as long as we added a lot more “decor” tiles.  Below is a screenshot of a “vanilla swamp” area:

Swamp
Vanilla Swamp

We still didn’t think it looked swampy enough, so we decided to add some long grass that could be laid over top background tiles.  I thought this idea could be used not just in the swamp, but in other regions as well.  By simply using the Color Palette Swapper, we were able to make this work very easily:

Long Grass
Long Grass

The player can now walk through the long grass.  When walking through long grass, speed is much slower.  This also applies to enemies, animals, and NPCs as well!  Grass can of course be cut down with a melee weapon.  The best part though is grass can easily catch on fire!  And when I say easily, it was causing a huge forest fire!  I ended up reworking the fire spreading algorithm a bit because the frame rate was plummeting.  Flames of fire can now “combine” into one other to form a bigger flame.  This drops the amount of fire objects on screen, which helps the frame rate.  In return, the combining of fire also makes it look less uniformed, and more “fire like”.

Fire!
Fire!

Audio Controller

The audio controller was the biggest new feature being worked on this past week.  I believe music and sound can make a game that much more memorable, if done right.  It’s like extra frosting on the cake, if you will.  Tyler and I met this past weekend to discuss how we wanted music to work.  We concluded that:

  1. We wanted our music to have the ability to change if a certain circumstance were to arise.  For example, if an enemy were to approach, we wanted the music to add more rhythm to the current song to make it sound more intense.  Another example is we wanted music to play the same melody, but change instruments during a day / night cycle.
  2. We wanted our music to have an introduction, and then for the music to loop after being completed.
  3. We wanted our music to naturally fade out when approaching the next area, and play hard when we reached the next area.

We ended up solving the first problem by having n variations of the same song playing in sync.  Then, for each variation, the system can control each volume separately.  When it is time for the enemy music to come in, we cross fade between variation 1 and variation 2, giving it the illusion that we’ve added instrument tracks — when in reality we are just playing a different song, that is the same song with different instruments.  This works awesome with the day / night cycle, as it will slowly cross fade as day ends and night starts, and vice-versa.

The second problem was tricky, but we ended up solving the problem with a little help from this video.  It’s actually from the same author who created the Color Palette Swapper.

TLDR; we essentially have one music file.  We note the length of the introduction and note the length of the loop.  Then, with our audio file, we add the first two seconds of the loop to the end of the loop as a “buffer”.  During game play, if an audio file’s position is greater than the total length (which can be summed by intro length and loop length), we set the music to it’s current position and subtract the loop length.  This was a very clever way of looping music on a certain frame rate cycle!

The final problem took the longest to get right.  Most games will start a new audio file when entering a new room.  However, since our game will only have one room, we needed a way to figure out if we are close to boundaries.  Currently, the system supports to methods of fading music out — entering a building, and entering a new section.  Both use similar approaches in that we need to figure out if we are close to the edge of the polygon.  The closer we get to an edge, the quieter the music becomes, until we cross the boundary.  Once we cross the boundary, we play the next song at full volume.  If we continue moving, no problem.  If the player doesn’t move away from the boundary, and immediately turns back, we cross fade from the current song back to the old song, but at the “distance away from the polygon” volume they are currently standing.

This solution is very hard to explain in writing, so it’s best if you play the game to get a better understanding of what we are talking about. 🙂

Music Samples

I asked Tyler if he was cool if I shared some of the audio he was working on.  I meant to post these Sunday.  It’s Friday. 😀

Below we will find 30 second snippets of audio we have been working on.  These are all working samples and are bound to change.  We’ve purposely reduced the quality a little as well as added some white noise in the sample.  But it shouldn’t be too distracting.  Let us know what you think!

Palm Paradise

Cold Mountain Song

Desert Depot

Desert Temple

Day 32

Well, the first month has come and gone.  I feel like we’ve made great progress so far.  It’s always hard to tell if one is on target when there isn’t really a “deadline”.  However, of the ever growing TODO list, half of the items are crossed off.  My goal was to spend the first two months building out enough of the system to the spend the last month making a game prototype.  If the list is half complete, and we wanted to be done with the list by the end of the second month, I would say we are on track.  Of course, the list is ever growing, and it’s programming, so anything can happen. 🙂

Displaying Hearts Lost When Damaged

One of the reoccurring issues we continue to hear was not knowing how much health was left when in battle.  At first this made sense because we didn’t have a “flash to red” color, signaling when the player was taking damage.  Once this was implemented, I thought the issue would be resolved.  Alas, there were still some feedback.  After having a conversation with a friend who was playing the game, I came to the realization as to why this was still a lingering issue.

First, I did some more thinking as to why this wasn’t necessarily a problem in older 2D Zelda games, as well as the 3D games.  For one, the 2D games had a resolution of 256×224.  With such a small resolution scaled up onto a TV, those hearts were always right within eyes view.  Newer 3D Zelda games of course have much higher resolutions.  Why do they work?  I think it has to do with the 3D perspective.  Since what we are looking at when playing those games “has depth”, our eyes aren’t necessarily fixed onto one part of the screen.  Thus, we still are subconsciously able to see the health meter (hearts).

Of course, there are other factors at play — such as larger icons, longer iframes, better animations to indicate when hit (we’ll be updating our animations when we polish 🙂 ), etc.  But the above was a conclusion I came to when trying to understand why older and newer games did not suffer this problem.

The life meter is represented by hearts in the upper left hand of the screen in the game.  Essentially, each heart represents 20 units of health.  If the player takes 5 units of damage, a quarter of a heart will display white.  If the player takes 10 units of damage, half of the heart will display white.  After taking a full 20 damage, the heart will be completely white, indicating the player lost the heart.  Rinse and repeat this process until all hearts are white, equaling no health.

One of the distinguishing factors of a “Zelda” game is the health being represented by hearts.  In our conversation, there were a few ideas tossed around.  One for example, was to move to a health bar underneath the player, like the enemies currently.  Since hearts need to represent health, this was non-negotiable.

Another idea came in the form where the hearts could be represented underneath the player.  Essentially, a heart would be placed like the health bar, with the number of hearts currently remaining.  Though I felt this UI would be too much “take-in” during battle, it sparked an idea.  “What if when taking damage, the number of hearts lost came out of the player?”  In fact, The Legend of Zelda, Skyward Sword did something similar I believe.

Lost Hearts
Lost Hearts

As we can see in the screenshot above, the particular attack just lost five hearts of damage.  We only display the “full” hearts that were lost in the attack.  What this does for the player is now they feel it necessary to take their eyes off the battle scene for a few milliseconds to see how much health they have remaining.  That way, they can decide whether to battle on, play it safe, or run away.

Button Mapping Support

There is not much to say here, other than we finally got around to adding button mapping support.  Those who prefer the button layout of the Xbox and Playstation will feel right at home when playing this game.  There isn’t an elaborate UI for this yet.  There are currently two themes to choose from:  Classic or ModernClassic feels like the old SNES and Nintendo layouts, while Modern feels more like the current button mapping of what Xbox and Playstation games do.  If the “theme” idea works, we of course will add other play style themes as well.  Perhaps in the game, we’ll let the player create their own too.

On Screen Tutorial

Another polish item we got around to this week was an on screen tutorial system.  The first type can actually be seen in the “Lost Hearts” screenshot.  This type, which I am calling Bottom Tutorial, can show a button label as well as a button icon.  This is helpful for the beginning of the game when learning the controls, as well as other actions the player can perform.

The next type is called Action Tutorial.  This will show whenever an A button (B button for the Xbox players) can do something.

Action Tutorial
Action Tutorial

For example, in the above screenshot, we can take the weapon obj_SpearLevel1 that does 8 damage.  Yes, the naming right now is just the object name, but just imagine it saying “Wooden Spear /8”.  Also, the UI has updated for dropped weapons as well.

The third type is what we call Tip Tutorial.  These types of messages come from the upper right of the screen to display a helpful message to the player, such as the one pictured below:

Tip Tutorial
Tip Tutorial

These of course will only display once and then disappear.  No annoying redundant messages here!

Finally, the last type, which is simply called Alert Message, will show in the upper-middle of the screen whenever something needs attention.

Alert Message
Alert Message

GML Textbox

Since we started doing so much with textboxes, we ended up refactoring the way we are rendering them.  With the exception of the NPC textbox, we originally were calling GML‘s draw_text function whenever we needed to draw text.  However, we needed a better way for handling text, within a certain width or height.  Below we are sharing the code to generate slick textboxes within GML.  This code will allow textboxes with a width and height, text shadows, left and right padding, border-radius, a fill color, alphas, and much more.  Of course, all of these parameters just mentioned are optional.  If we want to use the defaults, simply put -1 for the parameter.  We hope another developer stumbles upon this and makes their life easier.

**Update** Draw Container is much better 🙂

/// @description draw_textbox(xx, yy, str, [anchor, font, alignment, fillAlpha, textAlpha, width, height, radius, paddingLeftRight, lineHeight, fillColor, textColor, shadowColor])
/// @param xx
/// @param yy
/// @param str
/// @param [anchor
/// @param font
/// @param alignment
/// @param fillAlpha
/// @param textAlpha
/// @param width
/// @param height
/// @param radius
/// @param paddingLeftRight
/// @param lineHeight
/// @param fillColor
/// @param textColor
/// @param shadowColor]

var mandatoryParams = 3;
var numParams = 16;
var normalParams = numParams - mandatoryParams;

var prevAlpha = draw_get_alpha();
var prevColor = draw_get_color();

var xx = argument[0];
var yy = argument[1];
var str = argument[2];

var anchor;

var fillAlpha;
var textAlpha;

var font;
var alignment;

var width;
var height;

var radius;
var paddingLeftRight;
var lineHeight;

var fillColor;
var textColor;
var shadowColor;

var args = [];

for (var i=mandatoryParams; i<argument_count; i++)
{
  args[i - mandatoryParams] = argument[i];
}

for (var i=argument_count; i<numParams; i++)
{
  args[i - mandatoryParams] = -1;
}

var autoWidth = false;

for (var i=0; i<normalParams; i++)
{
  switch (i)
  {
    case 0:
      anchor = args[i] == -1 ? fa_center : args[i];
      break;

    case 1:
      font = args[i] == -1 ? font_Standard : args[i];
      draw_set_font(font);
      break;

    case 2:
      alignment = args[i] == -1 ? fa_center : args[i];
      break;

    case 3:
      fillAlpha = args[i] == -1 ? .8 : args[i];
      break;

    case 4:
      textAlpha = args[i] == -1 ? 1 : args[i];
      break;

    case 5:
      if (args[i] == -1)
      {
        autoWidth = true;
        width = string_width(str);
      }
      else
      {
        width = args[i]; 
      }
      break;

    case 6:
      height = args[i] == -1 ? string_height(str) : args[i];
      break;

    case 7:
      var smaller = min(width, height);
      var larger = max(width, height);

      var ratio = smaller / larger;
      var mag = magnitude(width, height);

      radius = args[i] == -1 ? round(ratio * mag * .5) : round(args[i]);
      break;

    case 8:
      paddingLeftRight = args[i] == -1 ? 0 : args[i];
      break;

    case 9:
      lineHeight = args[i] == -1 ? string_height(str) : args[i];
      break;

    case 10:
      fillColor = args[i] == -1 ? c_modern_black : args[i];
      break;

    case 11:
      textColor = args[i] == -1 ? c_white : args[i];
      break;

    case 12:
      shadowColor = args[i] == -1 ? c_black : args[i];
      break;
  }
}

if (autoWidth)
{
  width += paddingLeftRight; 
}

var halfWidth = width * .5;
var halfHeight = height * .5;

var halfPaddingLeftRight = paddingLeftRight * .5;

var startX;
var endX;

switch (anchor)
{
  case fa_left:
    startX = xx;
    endX = xx + width;
    break;

  case fa_center:
    startX = xx - halfWidth;
    endX = xx + halfWidth;
    break;

  case fa_right:
    startX = xx - width;
    endX = xx;
    break;
}

var x1 = startX;
var y1 = yy - halfHeight;

var x2 = endX;
var y2 = yy + halfHeight;

if (fillAlpha != 0)
{
  draw_set_alpha(fillAlpha);
  draw_set_color(fillColor);
  draw_roundrect_ext(x1, y1, x2, y2, radius, radius, false);
}

var textX;

switch (alignment)
{
  case fa_left:
    textX = startX + halfPaddingLeftRight;
    break;

  case fa_center:
    textX = xx;
    break;

  case fa_right:
    textX = endX - halfPaddingLeftRight;
    break;
}

draw_set_halign(alignment);
draw_set_valign(fa_middle);

draw_set_alpha(textAlpha);
draw_set_color(shadowColor);

var hashStr = string_hash_to_newline(str);

var strWidth = width - paddingLeftRight;

draw_text_ext(textX - 1, yy - 1, hashStr, lineHeight, strWidth);
draw_text_ext(textX - 1, yy + 1, hashStr, lineHeight, strWidth);
draw_text_ext(textX + 1, yy - 1, hashStr, lineHeight, strWidth);
draw_text_ext(textX + 1, yy + 1, hashStr, lineHeight, strWidth);

draw_set_alpha(textAlpha);
draw_set_color(textColor);

draw_text_ext(textX, yy, hashStr, lineHeight, strWidth);

//reset
draw_set_color(prevColor);
draw_set_alpha(prevAlpha);
draw_set_font(-1);
draw_set_halign(fa_left);
draw_set_valign(fa_middle);

A few assumptions to be made with the above:

  1. We are using font_Standard as our default font.  You may want to change that to be whatever you want as the default font.
  2. width and height are both optional.  If no width is supplied, the textbox will grow to be the size of the text width.
  3. When no width is supplied, font alignment will not do anything (since there is nothing to align to).
  4. height is essentially a padding top and padding bottom.  If text wraps because of a set width, make sure the height is set appropriately.

Reach out if you need help using!

Beach and Desert Scenery

Hannah has been on a role with art lately.  Here are a few screenshots of the “vanilla” areas with the tiles she has provided:

The Desert
The Desert
The Beach
The Beach (A Storm is on the Horizon)

New Enemy — Ambush

The final feature accomplished this week was a new enemy I am calling Ambush.  His behavior is much like the Octorok’s of Legend of Zelda: Breath of the Wild.  He hides under brush, and moves around underground.  When at the appropriate distance, he will pop up and shoot a rock at the player.

When I was imagining this enemy, I thought “how can I reuse the Knight Ghost?”  I ended up refactoring the Knight Ghost into a RandomMovement enemy type that now Knight Ghosts and Ambushes can reuse.  We may even refactor Reveels into this enemy type, as they use very similar functionality.

Ambush
Ambush

Conclusion

That concludes the month of January.  I am really beginning to see how all of the pieces are coming together to form a game!  I can’t wait to share more!

//TODO Refactor

I have a love-hate relationship with refactoring.  On one hand, refactoring is great because we get to clean up code in such a way where (hopefully) the outcome is having a more stable, reusable code base.  On the other hand, it is very tedious, time consuming, and mentally exhausting.

For those who don’t know what refactoring is, here is a good analogy from our writer, Julianna:

It’s kind of like shucking corn — programming style.  When you shuck corn; you keep what you want (the cob). Then, you can either throw away the husk, or keep it to make tamales. So, for example, the enemy system, you want to keep what you want for other villain characters, and leave what you don’t want with the original characters. Compartmentalizing, basically.

When refactoring, we want to keep the good parts, aka the cob.  However, to get to the cob, we have to tear through the husk to get to what we want.  Sometimes the husk isn’t all bad though — as we may want to use that for other things.

Imagine shucking corn, but with your brain — and for hours at a time.  If you “shuck” the wrong part, the whole system could break.  For example, a (new) bug could start occurring from removing the wrong part.  This is why I say it is tedious, time consuming, and mentally exhausting!

The reward though is worth the pain.  With a stabler foundation, we’re able to create more, faster.  There is generally no additional bugs or things to worry about, because the system is running through the same parts, which theoretically should be clean.

So yes, the past week or so has been mostly a refactoring session.  There were quite a few TODOs in my code that needed cleaning up before the Leave of Absence.  Now that we’ve been adding features at the rate we’ve been, there have been an even more TODOs added that needed attention.  The good news is most of these items are now complete, with the exception of a few far off TODOs that are more relevant once we decide how to build a certain feature.  The reward?  A more polished and functioning game.

What’s New?

There hasn’t been a whole lot “new” added to the game this past week.  However, much of what has been posted about in the last few weeks is now more stable and polished.  For example, I mentioned that there was Ice Physics when the player walks on ice.  But what about the enemies?  Shouldn’t they slip on it as well?  Well of course!  Part of refactoring was taking that code from the Player object and making it reusable for the Enemy object, and others as well.  And may I say, fighting enemies on ice while everyone is slipping is a lot of fun!

Looking past the “refactor” commits, one new thing that came through was the three main Soldier enemy types, as well as their color variations.  The idea here is very similar to The Legend of Zelda:  Breath of the Wild’s enemies.  For example, Bokoblin‘s are fairly straight forward, with not too much HP, or very smart.  Lizalfos are very fast, and chaotic and behavior.  Moblins are slow, but generally strong and a lot of HP.  For our game, Orcs are to Bokoblins, Reptiles are to Lizalfos, and Minotaurs are to Moblins.  In addition, Reptiles have projectile attacks and can evade attacks, while Moblins can perform a dash attack to knock the player over.  We also added color variations as well.  For each color variation, the enemy is a little stronger, smarter, and faster.

Enemy Variations
Enemy Variations

Hannah has also been sending me some additional part for the town and a snowy region.  Since I love snow, I thought I would share a quick screenshot of a snow scene (nothing here but the tiles and decor tiles).  It will look even more amazing once there are other assets on the screen!

Snow Lands
Snow Lands

I want to end this post with a sketch Hannah did of the hero, whose name we will not spoil right now:

Hero Sketch
Hero Sketch