Fix a Bug and More Will Appear

Hello my readers! It’s been another exciting week in FTD development. Those collision problems I had last week? No more. Those weird issues I had with the character’s movement? Vanquished! I’m happy to say that most of the problems I struggled with last week are gone, but as is always true in game development more have emerged. However, before I delve into what problems I’m running into currently, I’m going to cover how I ended up fixing previous issues.

Last week, I struggled with two issues: one, collision with the Light character and the walls, and two, the Light character continuing to move, despite the player releasing the movement key. I realized that the Light wasn’t colliding with the walls because only the wall object had instructions for colliding with the Light. For collision between a character and a hard surface to work in Game Maker Studio both objects, the surface and the player, must feature collision events referencing each other. By defining collision with the wall in the Light object, I was able to fix the first problem.

lightObject001

The second issue, the character’s continual movement, was fixed by assigning a key release event to the movement buttons. After a key is released, the character stops moving, until a key is pressed again.

lightObject002

Now that I have those issues out of the way, I have several other problems I must tackle. Bugs aside, there were two things I wanted to get done last week. I wanted to implement all four characters into the game and set up the mechanic for the Darkness appearing randomly in rooms. I was successful in getting the four characters into the game, but I do not have their abilities functional (except for the Runner). I also don’t have the ability to control one character at a time and switch between them on the fly. Currently, the player is in control of all four players at once. When one moves, they all move in the same direction, and I don’t want that.

While I have a few ideas about how to go about fixing the character control issue, I’m not entirely sure how I’ll get the Darkness to appear randomly in the rooms. In my own pseudocode, this is what I think needs to happen.

  • Create a global timer object (timer1)
  • Create another global timer object (timer2)
  • Create Darkness object and sprite
  • Set time1 object to count down from 60
  • Create a room object and sprite
  • Create multiple instance of the room object, but assign them different names, ie Room1, Room2, Room3 etc.
  • Link room object to timer1
  • Assign randomize function to room object
  • Assign replace sprite function to room object
  • When timer1 reaches zero, replace room sprite with Darkness object and sprite
  • Have timer2 go off so that timer1 is repeated

I think this approach is the best way to get the random Darkness appearance function to work. At this point I’m not going to code the Darkness to kill anything or destroy rooms, I just need to make sure that I got the random mechanic working. I need to get the random mechanic working perfectly, because later I’ll be implementing the glyphs, which determine the chance that the Darkness will appear in a certain room.

Problems aside, I ended up getting a little sidetracked and started messing with some of the basic HUD elements of the game. Below is a mock-up of what the HUD might look like.

gameplayHUDmockUp

As useful as HUDs are, even the best designed ones get in the way sometimes. One of the functions I want the player to have is the ability to toggle the HUD on and off. I went ahead and created one of the HUD elements to test out the toggle feature, in this case the game’s timer.

lightObject003

Now I know once I work on the HUD in the future, I can give the players the ability to toggle the HUD on and off at their own whim. So what’s on the FTD development menu for this week? I have three items I want to have implemented by next Sunday.

  1. Get the randomized Darkness appearance mechanic working.
  2. Limit player’s control to one character at a time
  3. Get some of the other character’s abilities implemented.

Well, that about wraps things up for this week. There are a few official Game Maker tutorials that I think will help with the development of FTD, but I am open to suggestions and tutorials on Youtube/Vimeo/etc. If you see a tutorial that you think will help, by all means, send it my way! It will be appreciated. USCF over and out.

Post commandeered by the US Claire Force

Game Maker & Collision Fun

Hello my readers!  From now on, I’ll be updating the USCF blog each Sunday with development progress on Fight the Darkness. Cheers!

Last week I purchased Game Maker Studio Professional, and since then I’ve been stumbling through the free tutorials. Now that I’ve got a little hands-on knowledge with the engine, I’ve been working on a prototype of FTD. For the prototype, I’m just making one level, using the layout from last week’s diagrams.

roomComparisonProgress

Right now, I have the prototype built so that the player can control the “Light” character and open doors. Unfortunately, the player character likes to ignore the collision on walls (despite the walls having collision), so I’m going have to find a way to fix that. What’s interesting is that the player character ignores wall collision, but responds to the collision of doors (both open and closed). While I want the door’s collision to impede the player character’s movement while closed, I’m going to have to find a way to switch off collision once they’ve been opened.

progress003

Also, the player character will take keyboard input from the player in any WASD direction, but they never stand still. I think this might happen because I have one of the actions in the Light object set to fixed movement, as opposed to free movement.

I haven’t implemented the other four characters, the Darkness, or the glyphs yet, as I’m still learning Game Maker as I go. I really wish I could accomplished more mechanically this week, but the collision bug is tripping me up in particular.

I guess it’s not all that bad, because working on one feature at a time allows me to check for as many bugs as I can, fix those bugs, and save that version before I go adding any new features. It also allows me to pinpoint at what point exactly a bug appears and what feature is instigating the issue.

Back when Comrade Quest was in development, there were times when multiple features were added to the game and many bugs appeared. It caused a lot of headache for my programmers and designers because it was difficult for them to get a reading on what feature was causing an error. Granted, when you’re working on a team and you have deadlines to meet, sometimes adding multiple features at once is a must, but I try to keep additions incremental when possible.

It’s way ahead of my pipeline development-wise, but I’ve been contemplating FTD’s aesthetics. I’ve thought about rendering the game in pixel art similar to the old Pokemon games, but I also would really like to emulate the style of Kikiyama’s Yume Nikki. I want FTD to have a surreal, nightmarish aesthetic to it, and both styles could work quite well.

yumenikki

creepomon

Honestly, I know I can’t spend too much time thinking about the art direction at this point, because I get so wrapped up in the visuals of the game sometimes that forget about the game. For now I’ll just keep all that on the back burner.

As far as what I’d like to get done this week for FTD, I’d like to get all the collision kinks worked out and the other characters implemented (not necessarily their abilities, just the ability to control them and switch between them). If I get all that done I’ll move on to getting the Darkness and game timer implemented.

Well, That about wraps it up this week for the dev blog. Until next Sunday, USCF signing out.

Post commandeered by the US Claire Force

UI Design & Weapons Concept

I’m going to keep this post short and sweet, because I’m applying for jobs and have a lot coming up in the next post. I finished the weapons concept I’ve been working on, as well as a UI page for the fictional game Dragoon Chronicles.

ClaireLewoczko_DragoonChroniclesUI_2

claire_weapons

I’ve included a time lapse of my work flow for the electric sword, for your viewing pleasure.

weaponTimeLapse

Later in the week I’ll post about the new game that I’m going to develop in Game Maker, either for PC or mobile devices. Until then, stay tuned, and thanks for reading!

Post commandeered by the US Claire Force

Adventures in Portfolio Building & Learning

Hello my readers! I hope everyone’s doing well in their game development quests!

In my most recent adventures, I’ve attended several portfolio reviews and received valuable feedback. Of my current three portfolios, game design, concept art, and user interface design, I’ve learned that my game design portfolio is the strongest. Huzzah! However, I do need to beef up my skills in concept art and user interface design, so to do this I’ve started doing more work in those areas.

Currently I’m working on weapon concepts for an urbanpunk setting, either for a game or comic. Pictured left from right I have a drill axe, an electric sword, and a katar. The electric sword I’m most proud of, and if I were ever to face a horde of zombies, it’d be my go-to weapon of the three.

lewoczko_weapons Rough

Progress after importing the image to Photoshop. I’m a little odd in that I like to work right to left. I’m finished with the katar, but I’m still working on the electric sword and haven’t even started yet on the axe.

claire_weaponsWIP1

In addition to building up my concept art repertoire, I’ve been working on my user interface portfolio. Currently I primarily do just the art and design side of user interfaces, but I’m learning how to code and implement them using Scaleform. I love working in Unreal Development Kit (I find the node based system for materials to be extremely useful), and learning Scaleform will greatly increase my capabilities in the engine.

The menu below is a main menu screen for a fictional game called Dragoon Chronicles. I wanted to create a menu for a game with a dark fantasy setting, like Infinity Blade or Diablo. Currently I only have a static image, but I plan on importing individual buttons and states into Scaleform and see what all I can do with them.

ClaireLewoczko_DragoonChroniclesUI_1

It’s a bit daunting, having to learn software and languages, especially when it seems like a new one emerges every several months. It’s getting better though; I’m realizing that with both engines and programming, many concepts remain the same, despite the addition of new features and versions. In a way it keeps development from getting stale, as there’s always something new to be learned.

A couple of months ago Vinton Cerf, one of the founders of the Internet, came to give a presentation at my college. After his presentation, he allowed students to come up, shake his hand, and ask him questions. I was a bit shy, and introduced myself as “just a student”. I will never forget his reply, in which he told me

  “You are never just a student. A student is one of the most important things you can be. You should never stop being a student. You should always be learning.”

Even when formal education ends, it’s always important to be learning: learning from experiences, learning from other people, learning new ways to do things. From my experience, I’ve seen that the happiest people are those who continue to learn and grow. Those who refuse to open to new ideas become stagnant and depressed.

It makes me incredibly happy to know that I am in a field that is constantly evolving. It’s been a journey so far and as far as I can see, adventure stretches into the horizon. I have a lot to learn, but I am excited about all the discoveries that lie ahead. Stay passionate comrades, and always be willing to learn.

Until next time, US Claire Force signing out.

Post commandeered by the US Claire Force

 

Comrade Quest Final Release

It’s finally reached the end of the semester, and Comrade Quest’s development is over. It makes me sad that everyone on my team is going their separate ways, but I’m glad that I got the chance to lead a group of talented artists, programmers and designers to realize my vision. Also, I’m quite proud that one of the designers on my team will have her own game in Game Production Lab next semester.

Now that my directing days in GPL have come to a close, I’ve been reflecting on what I’ve learned in the past five months. Developing Comrade Quest has taught me a lot about game development and managing a team, but the most important thing I’ve learned can be summed up in a single statement: have confidence in your original vision. There’s a reason why most successful games don’t change their mechanics mid-development, and that’s because most creative directors have the utmost confidence in their vision.

The biggest upset in Comrade Quest’s development came when we tried replacing the melee combat system with a turn based one, similar to Paper Mario’s turn-by-turn combat. Part of reasoning behind the mechanics change was based off feedback that we got from the alpha test. Many of our testers complained that Olaf’s attacks didn’t feel like “attacks”. As they were, Olaf’s attacks felt mechanical and lacked the rewarding visceral sensation featured in published games.

Comrade Quest Shot 6

By changing the fighting mechanics to turn based, we wouldn’t have to worry about achieving that visceral quality. However, while a turn-based approach would solve our current system’s problems, it would bring unanticipated problems of its own. How would turn order be calculated? How would current attacks translate into the new system? How would we make a turn-based system cooperative? We were not adequately prepared to answer these questions.

The decision to change the combat to a turn-based system was also influenced by my own worries. I was worried that we wouldn’t be able to improve the physics and animation of the character’s attacks in time for beta release. Instead of being confident in my original plan and in my team’s capabilities, I chose what seemed like an easy way out.

Thankfully we changed back to the melee system, but we lost a week-and-a-half worth of production time. This cost us Olaf’s combo attack. If I had stuck with my original plan, the time the animators spent animating buttons for the turn-based user interface could have been used to animate Olaf’s combo. If I had stuck with my original plan, the time the programmers spent programming queues could have been appropriated to improve attacks physics. This is why it is so important to have confidence in your vision. If I had remained confident in my original plan, we would have used that week-and-a-half of production time to create a better product.

Comrade Quest Shot 5

The finished executable of Comrade Quest may not feature a combo, but overall I’m satisfied with how the game turned out. I’m glad that we were able to create an entire level and feature a boss fight at the end. I’m also very pleased with the audio and visual aesthetics of the game. Our sound designers really pulled out all the stops in creating great sound effects and an ambient track. Above all else though, I’m delighted that people find Comrade Quest fun. Almost everyone I’ve seen looks like they are enjoying their playthrough and interacting with their partner. I created Comrade Quest to foster this in-person interaction and camaraderie, and to see its players have such fun together confirms the game has achieved its original intent.

I would like to continue Comrade Quest’s productionin the future, but now that I no longer have a team, it will be difficult to do. I envision getting a team of talented individuals together to work on Comrade Quest and pitching the game to Kickstarter. I can also see going to one of the existing game companies and pitching the game directly to them. However, developing Comrade Quest further will have to wait for a while, as right now I have to build up my portfolio and find steady employment. To summarize, I haven’t given up on Comrade Quest, it will just have to float around in the “things I’d like to develop someday” pool for a while. So what will I do with this blog in the mean time? I have to build up my portfolio, so I’ll be posting concept art, UI designs, mini games made in Game Maker, and other game development portfolio pieces.

Cashtaroth Battle

Thank you all my dear readers for following Comrade Quest’s development. It’s been a pleasure blogging about its production, and I hope you all continue to read about my future projects. It’s been a fun and eye-opening journey so far, and I can’t wait to see all the places my passion for game development will take me.

If you want to play Comrade Quest, go to this link to download it. Comrade Quest Download

Post commandeered by the US Claire Force

Successful Beta!

Beta was a success!

As a matter of fact, out of the previous three GPL’s that I’ve been in, I’m pleased to say that this has been the most successful beta. I’m also happy to say that the playtesters congregated around Comrade Quest’s test space first thing when the beta started! It’s great to know that Comrade Quest is so highly anticipated!

money lava
Scene from the game, minus the Olafs. We use money for our lava!

Now with beta out of the way, there’s roughly two-and-a-half weeks left till final release. By final release I hope to have one very polished level ready, with polished mechanics, visuals and audio. By final release I hope to get in:

  • Cleaned up animations for characters
  • Better physics and collision detection for platforming and combat
  • A combo attack for Olaf, our current protagonist
  • Sound for the menus, characters, and attacks
  • An upgrade menu at the end of the level, for players to upgrade their attacks, buy outfit changes, etc.
  • Cleaned up Communist summon (no more Marx clipping between layers)
  • Ambient background track
  • Background and foreground that moves with along with the camera. Think how objects moved around in DrinkBox Studio’s Guacamelee. This will probably be the most time intensive, since it deals with parallax.
  • Animated menus and improved HUD
  • And a special little surprise for everyone on the team!

Since this is the “polish” period, I want to make sure my animators and environment artists are spending as much time revising assets and creating new animations. I’ll be stepping in a bit to help with the UI side of things, since that’s a specialty of mine, and something I don’t mind doing on the side. This list isn’t all that large and I’m quite confident we’ll get most, if not all of it done in time for the final release.

Post commandeered by the US Claire Force

Night of Beta

Less than eleven hours remain before beta release. I’m nervous, happy, excited, stressed and sleepless all at the same time. It’s an odd mix of feelings, but I like it. Guess I picked the right industry to get into, because from what I heard, this atmosphere of high tension is pretty common in the world of video game development.

Last weekend, Team Comrade had its all-night beta crunch/work-in party. From 9 PM on Saturday to roughly 9 AM the next day, we did nothing but work on Comrade Quest. Okay, so that’s a little bit of a lie- some whiteboard shenanigans were had, and a few brusque Russian phone calls to the local pizza company were made. Even still, a lot of work got done.

The game designers worked with the level designer and programmers to firm up combat. Players and enemies alike have better physics, improved attacks, and combat feels more inclusive to the game experience. Much progress was made on the layout of the level as well. Our alpha release was criticized because it contained a lot of empty spaces. We addressed this problem by compressing certain areas of the level that were too long, and adding challenges and collectible beets to empty areas.

screenshot beta
The smashers that gave us problems. In this photo, they have been fixed.

A lot of interesting bugs were found, like Olaf being able to moonwalk in certain areas, and an insane amount of enemies spawning in the arenas. The game designers also sorted out a collision problem with the metal smashers. When the new art asset for the smashers was imported, it messed up the smasher’s collision. Rather than killing players caught underneath it, it only pushed them into the ground. The problem was rooted in the shape of the smasher’s collision- the edges at the bottom were slightly beveled. This was to match the art asset, which featured beveled edges. By changing the beveled corners of the smasher’s collision box to 90 degree corners, we were able to get around some of the smasher’s collision problems with player.

Now, we’re half a day away from beta release and Comrade Quest is looking really good. We’ve come across more bugs since our work party, but most of them have been resolved. One of the funniest involved Olaf getting absorbed into the smashers. We also have most of the main menu working, which is great. You can see what it should look like once it’s finished here.

My biggest concern lies with the camera transitions and the way players trigger them when moving from area to area. Earlier, one player was able to move into a new area without the other player. Once in the new area, the slower player would remain off-screen, ruining the gameplay experience. This transition issue was largely fixed by adjusting the camera and implementing invisible barriers. However, there’s some camera popping and I don’t know how much it will affect player feedback in the beta.

Camera popping aside, I feel very confident about Comrade Quest’s beta release. It amazes me that six months ago, Comrade Quest was just an idea in my head. Now, that idea has materialized into a playable level with working mechanics, animation, menus and most importantly, gameplay. I’m grateful to have such a dedicated, hardworking team to bring Comrade Quest this far.

Post comandeered by US Claire Force

Comrade Quest Checkpoint Animations

I’ve been working more on the menus, and animations for the different objects in the level. Here are the assets for the checkpoints- the banner says контрольная точка (kontrol’naya tochka), or checkpoint. I’m going off of what one of my Russian-speaking friends said, hopefully it doesn’t mean “capitalism for life” or “Donald Trump is awesome”

This one is just the “floating” checkpoint, used for when players haven’t yet reached a location.

Comrade Quest Checkpoint
Floating checkpoint for Comrade Quest’s levels.

This is the animation for the activated checkpoint, for when a player dies and respawns. Both animations are much higher quality in the game, these are just pixelated because GIFs are lossy.

activated checkpoint
Triggers when a player respawns.

A Lesson in Leadership

Whew.

Yesterday was crazy stressful. We had a huge meeting with the professors, and we’re back to the original melee system. Essentially the whole group got called in to discuss why we shouldn’t go forward with the turn based system. I thought the turn based system would solve the problems reported in alpha, but it implementing an entirely new system just creates new problems.

The lesson learned?

Stick with your original plan. Especially when you’re a leader, have confidence in what you set out to do in the beginning. Be confident even when you receive negative feedback- it’s better to fix or improve a current feature than to plaster over a problem with a revolutionary, game-changing solution. Generally, your original idea is the best idea, because you’ve thought it out the longest.

In other Comrade Quest related news, beta is little under two weeks away, and we’re starting to crunch. I’m excited about our group all-nighter we’re going to pull on Saturday. I’m thinking about preparing dinner and some baked goods for the team.

Also, I’ve been working on menus. Here’s the pause menu, which is underway right now.

Comrade quest pause menu WIP
Pause menu in progress for Comrade Quest

Comrade Quest History Part 4

Continued from previous post

I got up on stage, calmly pulled up the PowerPoint presentation for Comrade Quest, and began my pitch. In the first two slides, I knew the audience was at least listening. The next four slides I introduced the four playable characters of the game. With each new character, the audience became increasingly intrigued and attached. By the time I introduced Yuri the Bearserker, the entire audience roared with laughter. I can’t remember who said it, but someone once said that if you’ve made people feel something, you’ve won. I knew I had done a good job.

Concept art for the Gluttony Crapitalist demon.
Concept art for the Gluttony Crapitalist demon.

After the live pitches were over, I was swarmed by people asking me about Comrade Quest and if they could be on my team if I made it into GPL. I received many comments that my presentation was the only one that made the audience laugh. I was very thankful that I garnered so much interest my game, but a little dismayed that I had to explain to some people that Comrade Quest was strictly 2D (I had a lot of modelers ask if they could model for me). As the crowds faded and everybody made their way home, all I had to do now was wait until next Tuesday for the Spring 2014 games for GPL to be announced.

The weekend quickly passed, followed by Monday, and then Tuesday. At the time, I was in GPL as a 2D artist on my friend Josh Miller’s game, Control Room. Instead of sitting down to work immediately that day, I was called over to room 3.910 for Spring 2014 GPL announcements, along with all the other current GPL members and live pitch presenters. A little bit of anxiety swelled up in my stomach, but it quickly released when Comrade Quest was the first game announced for Spring 2014 GPL. Dr. Evans even added that it was an automatic shoe-in for GPL, and that the real difficulty was deciding what other four games would make it in for the upcoming semester.

Concept art for one the Crapitalist demon minibosses, Derek the Micro-Manager
Concept art for one the Crapitalist demon minibosses, Derek the Micro-ManagerAs odd as it may sound, I was happy that Comrade Quest was accepted, but not surprised. Ever since the semester started, I sensed I was on the precipice of something great. I didn’t know what form the greatness would come in, but I once found it, I knew it would be unstoppable.

Now it is spring and Comrade Quest is in development in GPL. My hope for Comrade Quest is for it to continue in development outside of class and become available on Playstation Network and Xbox Live. I wish for Comrade Quest to be successful, but most of all, I want it to be downloaded by people all across the world, to play with their friends, or to make some new ones.  To this day, I still believe in the power behind Comrade Quest, and with perseverance, dedication, and hard work, I will use Comrade Quest to make this world more fun.

Post commandeered by the US Claire Force