Monday, December 9, 2013

Production

The first four months of Push-It

Push-It as a game began significantly different than what we have now. When we began, we knew we wanted to create a cooperative multiplayer experience, and that was about all we had. We had not yet determined what the gameplay, objective, or visual style would be, but knew we wanted to forge something that would bring players together to achieve a shared goal. With this in mind, our first idea for gameplay was shared control of a ship.

Many people have heard of the games Artemis and Guns of Icarus Online, both of these games places a set number of players, 6 and 3 respectively, on teams to jointly crew a ship. Each player relies on the others to complete their objectives and perform their duties. If one player fails, the entire crew may fail. While these games provide players a strong sense of cooperation and urgency, Artemis fails to place players directly in the action, instead viewing it through 2D displays while Icarus players spend just as much time running around the ship in 1st person as actually performing actions on or with it. We wanted liked the cooperative aspects of both, and created our first iteration based on a melding of these two ideas. Our players would take direct control of stations on a ship, providing 1st person views from gunnery batteries as well as the helm to work together to control, navigate and protect the ship.

As we progressed with the idea of players jointly controlling a ship, we asked ourselves “Is every role fun and engaging to play? Would people be happy to be locked into a single role or should be allow variation in what each player can do?” What we came back with was a resounding “No” to the first and “Allow variation” to the second. With that in mind, we began developing ideas to allow players to do more than one thing and not be locked in a single role, thus we came up with the idea of drones. Drones would be a secondary mechanic for the gunners to use. Rather than having a dedicated mechanic making repairs to the ship, each gunner could choose to exchange their offensive potential for defensive. When controlling their drone, the gunner would be able to repair gunnery batteries on the hull of the ship, raise shield walls and perform other supportive actions to assist the ship and their team in non-offensive capacity.

With drones, we solved the “Being a gunner can get boring” issue, but had not touched the role of the helmsman. How could we make being in charge of navigation and moving the ship more fun and engaging for that player? After long discussion of the issues that faced being a helmsman, as well as taking a deeper look into the drone gameplay, we determined that we needed to make a dramatic change. With it determined that playing as a dedicated helmsman would likely get boring for a majority of players, we decided to remove the role. With that, we now had gunnery batteries on the hull and defensive drones for support. How would the ship move? The drones would be able to push it with a beam of some sort.

With this change, Push-It as it is now truly began. Multiple players working together to defend and push their broken hull of a ship through a maze of enemies to return “home.” Looking at where it was now, we questioned the need for the offensive batteries at all, and so we removed them. Players now all took control of their own drone, pushing their ship to safety while fighting off and avoiding enemies and dangers. Why complicate the gameplay with combat, though? Why not just make all the danger the players, and their ship, face come from the environment? Many games add combat mechanics “just because” without necessarily having a sound reason for them, thus we decided to remove them. They weren't needed, we decided, and testers agreed when we brought a combat-less build to QA with the only goal being to use your “push beam” to get an object from the start of the level, through various environmental puzzles and dangers, to the end of the level. We didn't impose a time limit or any other requirements, just “get there.” They loved it.

With the new change, however, we realized we just had an incredibly simple game, one that wasn't particularly innovative. It was fun to play, yes, because of the player interactions and the cooperation requirements, but not innovative. We also had the issue of being limited to 4 players on a single machine, using Xbox 360 controllers. Around the same time, I was working on a side project using mobile phones with gps to make a “hunger games” style hide and seek game. When I mentioned it to my group, we had a groundbreaking idea to “combine” the two. We would have players use their smart phones as controllers. It took only a few days to set up a system in which players could download an app to their android device and easily connect to the game through wifi giving them a virtual controller on the screen of their device. The versatility of smart phones has also provided us with the ability to make a range of control schemes, from a “twin-stick” scheme to a gyroscope based “tilt-to-move” scheme, with many more possibilities for additional schemes.

Push-It had now moved beyond something you might play in your living room with your family and friends to a game that could be played on nearly any screen anywhere, with little setup. It could be deployed in movie theaters before a screening or in a park or even on Time Square, the possibilities for deployment were endless because players could seamlessly drop in and out of the game without affecting the ability to complete the levels.


The process of reaching the point where we are now with Push-It has been extremely educational about the true process of game development. We started with just a simple idea of making a cooperative experience, we progressed through so many different iterations and ideas before we reached this point. In addition, although I only focused on the iterations that directly led to Push-It where it is today, we also had alternative ideas that we developed alongside the cooperative experience that also provided ideas for thing to do and not do in Push-It.

Tuesday, November 19, 2013

Production

Presentation

Last night we finally reached the pinnacle of the semester, the senior show. 14 teams brought forward all of their progress and achievements over the course of the semester to vie for one of the slots going forward to next semester.

We saw a wide range of games, and most of them looked great. A few of the more memorable for me were Sunbots, Phantom Mansion and Lucid Delusion, as well as our own game, BusyBots, of course.


Monday, November 4, 2013

Production

Stage 3: Proving Your Core Experience

As we progress in developing our game concept, we reach the point where we must flush out the aesthetics of our game. We have tossed around many different ideas for what our game will look like, ranging from ghosts in a haunted house to wizards pushing a dragon egg, from ants protecting larvae to fat princes, but none really seemed right, or quite fit. We finally fell upon the idea of Rube Goldberg machines as the backdrop of our game.

Using Rube Goldberg machines as the backdrop of our game opens up a wide range of possibilities for both level visuals and puzzle mechanics. Levers, balloons, and pulleys allow for many different interactions between various puzzle elements as well as means for the players to interact with the puzzles.

Monday, October 21, 2013

Production

Workshop One


Increasing the innovation of games is a constant and difficult struggle. As games become more and more advanced, the range of possibilities also increases, but with that advancement comes the sheer volume of previous creations. Developing games that are unique and innovative, yet fun, can be very difficult.

In the case of our game, it isn't the gameplay that is particularly innovative, but the method of play. Using mobile phones as a default input method is an uncommon scheme. While games on mobile devices are taking the industry by storm, ours isn't quite a game ON a mobile device, but just uses it as a controller. There exist apps for achieving such a goal, most commonly used for emulating retro game pads and arcade style inputs for use in single player games on computers. Our design, on the other hand, is to use such input in public spaces, allowing anyone to download an app and jump into the game, quickly and easily.

While games in public spaces exist, many require special hardware or non-digital input to participate in, such as Renga.
Renga requires players to use a laser pointer, something not many people carry with them in day-to-day life, as well as a specialized projector to detect the points on the screen. None the less, the player interactions are something we wish to emulate. A larger number of people working together to achieve a shared goal through the successful execution of related tasks.

By using a mobile device, we will break down the divide between those who can and cannot play, because of the hardware requirement. These days, nearly everyone carries a mobile device of some kind with them in their day to day activities. Using this fact, we can reach a larger audience and allow our game to truly be pick-up-and-play.

Monday, October 14, 2013

Production

Stage 3: Proving Your Core Experience

As our game concept has developed into a large scale cooperative experience in public spaces, we have considered in what direction to take the visuals. As our game is intended to be open for anyone to play, we must strike a delicate balance between drawing in current gamers through recognizable influences and presenting a game that any non-gamer who sees would be interested in participating in.

We are focusing on two directions to take it, in terms of theme. The first is that of ghosts pushing around a coffin or skull, think Casper the Friendly Ghost. The second is wizards with the object being a dragon egg. We also want to make sure that whichever theme we pursue, we maintain a comical and friendly aspect, which would not be difficult to do with their theme.

Tuesday, October 1, 2013

Production

Stage 2: Building the Conceptual Foundation

As we proceed with the idea of a "massively multiplayer local game", we now begin to explore what games are already present in this space. Our game, when complete, will be able to be played on nearly any screen in a public or private space. With its wide range of potential players, we are not limited in our audience, but work to open up the medium to anyone who has a smart phone and desires to play.

As of this writing, we have not found any other examples of large scale cooperative games in public spaces that use a similar interface as our game. We did find Renga, which is a similar target, but played with laser pointers on a projected screen, which detects the points of light and converts it to input for the game. This game, however, requires players to have a specific interface, the laser pointer, and specialized equipment that detects the pointers on the screen.

One of the interesting problems we may face with a concept such as this, which requires mass coordination and cooperation, is that inevitably, some small number of players will want to "troll" other players by doing what they can to prevent or slow progress in the game.

I feel really good about where we are now and where our concept is heading. We have a lot of potential in our sights and are all excited about where we can take this game.

Monday, September 30, 2013

Networking: Clone War

As a project we were tasked with working in pairs to emulate the 1985 game Spacewar in XNA. We had to maintain all of the core gameplay of Spacewar, although were were told to specifically not include a few aspects.

Overall, Lou and I did a pretty good job. My previous project in Networking already provided most of the core systems and elements needed to create the game. As such, within an hour or so of starting, we were quite far along.

One of the requirements the initially seemed like an obstacle was synchronizing "game mode" data across all clients. XNA doesn't provide an interface for automatically synchronizing settings or options that are not directly related to the network session. As such, I had to use a bit field stored in a byte to transfer game mode related data from the server to the clients.

Lou's blog: http://lounetworkingforgamesblog.blogspot.com/
Professor: http://prof.johnpile.com/

Tuesday, September 24, 2013

Production

Stage 1: Establishing the Foundation

As we slowly get closer to challenging Stage 1, our initial ideas have fallen away to leave one our Push mechanic. Although it is a single mechanic that we are focusing on, it leaves a wide range of possibilities to explore and iterate on.

Mobile Device Controllers

One of the biggest and most interesting ideas we are pursuing with the Push mechanic is that idea of a "Massively Multiplayer Local" game. The idea is that everyone has a controller in their pocket, even if they don't realize it, they would just need to download an app, connect to the game, and play.

The largest hurdle with this idea, currently, is designing and implementing a strong and reliable input setup. We have two iterations on the mobile controller currently, one with dual virtual joysticks and the other using tilt rotation and a throttle control. We have brought both to QA and received positive feedback on both, with some issues brought up that still need to be looked further into.

Monday, September 16, 2013

Production

Stage 1: Establishing the Foundation

As we have continued to meet and discuss our ideas, the concept of Coop-Push has itself been pushing to the forefront of our thoughts. On the other hand, we are concluding that the Space Combat concept leaves much to be desired and would quickly rise out of scope.

Coop-Push

Through the last week, we settled down on what experience we really want to promote with this concept. By focusing on the cooperative mechanic of the game, players will connect with one another and see each other of valuable to their own success, rather than an obstacle to be removed. This view is often lost in games which more often then not, put players on opposing teams or create huge gaps in ability and power between two players on the same team. We want all of our players to have similar, if not identical, abilities that much be amplified in power by working with other players.

GPS

Another idea that has risen over the last week is that of a GPS game. The initial idea rose from the idea of Hunger Games, where players must collect resources to survive. This alone, wouldn't make for a very interesting game, let alone any reason to use GPS, but the idea expanded to be a "hide and seek" type game. The initial concept is that players would be randomly assigned roles, Seekers and Hiders. The number of Seekers would scale with total players, but would generally be one.

Hiders would be given an initial amount of [resource] to survive on. As time progresses, their [resource] depletes and they must find and collect more. [Resource] would be shown on the GPS map to all hiders(perhaps seekers as well) for them to collect to stay alive. This would mean they have to stay on the move and would not be able to just hide away for the entire game.

Seekers would also use a GPS enabled device, their [resource] would be replenished by finding Hiders. Their GPS would also show "blips" on the map whenever a Hider made "noise", measured by the accelerator of their device.

Whenever any players' [resource] was depleted, they would lose the game, sending a message to all other players. The game would end when either all Hiders are found or deplete their resource, or when all Seekers deplete their resource, which would determine the winning "team".

Tuesday, September 10, 2013

Production

Stage 1: Establishing the Foundation

Over the last week, we have fleshed out, revamped and reworked our concepts. We still have a handful of potential candidates, but are more heavily focusing on two of them, dubbed Coop-Push and Space Combat.

Coop-Push

Last week, when we presented our cooperative space combat game, it was suggested that we take a better look about the actual cooperative experience and focus in on that aspect of the game, rather than on the combat side of it. We decided to do both, what we now call Coop-Push is what came out of the deeper look into the cooperative experience.

The core mechanic, as is currently envisioned, is a group of players working together to achieve some goal, generally by moving some object around as a team. Each player on their own would be unable to meaningfully move this object, but by working together, to either move obstacles out of the way or to push the object, they can progress through the puzzles.

Space Combat

While we were iterating on what the cooperative experience meant, and how we could focus in on players really working together and relying on one another, we didn't want to drop our idea of a cooperative space combat game. We have had further discussions on what directions we could potentially take it and how we can make it more engaging and fun for all of the players.

Monday, September 2, 2013

Production

Stage 1: Establishing the Foundation

With the start of our Senior Production experience, we have set out to develop a handful of concepts, one of which will eventually develop into our production target. Each of these concepts must be fully explored and properly planned before we decide on one to set our sites on. As of this week, we have two ideas that have been our initial focus, among a set of five.

Growth and Reduction

This idea is about size as a resource to manage. As a cooperative puzzle game, the two players must work together to manage and utilize their size as best as they can. Each player controls a character, one always grows when they move, the other always shrinks. They can, however, switch sizes with the press of a button.

This idea manifested while we were initially discussing possible mechanics that we hadn't seen before in senior games. We also threw around the possibility of it being a competitive puzzler, but decided that it would work better if they players worked cooperatively.

With each player depending on the other to provide them with the resource they need, their size, it will foster companionship and agreement between the two players. They will rely on one another to progress and will find that if they try to go it alone, they are either too small to handle the challenges or two big to achieve the finesse they need.

Cooperative Space Combat

Our second idea is about a team of players, we are unsure of the exact size, but are thinking around 5, cooperatively controlling a space ship. One player would act as the helmsman, and captain, which each other player would assume command of a turret on the hull of the ship. They would be tasked with completing certain objectives, while fending off AI controlled enemies and environmental hazards, such as asteroids and solar flares.

This idea developed from both Mitchel and my interest in space games and Mark's interest in imagining and modeling ships. The core of the game, a cooperative experience of controlling a space ship, also manifested from an interest in games like Artemis, while questioning their lack of real action, as they are much more often based on bridge stations, rather than players taking a direct role in the action.

One of the things I like most about this concept is how open it is to change, as the core aspect of the game is just the idea of cooperatively controlling something, in whatever form that may take.

Networking

TCP vs UDP

The question of whether to use TCP or UDP for a networked game is generally the first network related question that needs to be answered. Each have advantages and disadvantages to them, and some games use one, while some use the other. Overall, it is probably safe to say, most networked games use UDP.

None the less, there are some games, and certain genres of games in particular, that often rely on TCP for the guarantee that packets will arrive, even if they do take longer. Often MMO games, such as WoW and Rift rely on the reliability of the TCP protocol.

Why TCP?

There are certain aspects of the game that developers want to have much more control over, in regard to server-client interactions. In particular, Chat will often use TCP as when a player sends a message, they expect it to arrive properly and in full. Similarly, when a player uses an ability in any game, they have a certain expectation that it will be executed in the game world. These are places where the reliability of TCP trumps the potential loss in speed, in many cases.

What should use UDP?

Similarly to the uses of TCP in MMOs, they also rely on the speed of UDP for interactions such as movement between the client and the server. This is often done through the client sending its direction and speed to the server, which will respond with where the player should be located based on that information. The client, while waiting for the server's response, will do what is called Client Side Prediction, where it will use the data it sent to the server to predict where the server will tell it to be. In these cases, a missing packet will often have a much less noticeable impact on the player than the loss of a packet related to the use of an ability, for instance.

If movement used TCP, rather than UDP, it would likely increase the latency between when a player changed their input and when their character responded to that change, which would impact the sense of immersion in the world. As above, the reliability of a single movement packet isn't nearly as important as a chat message or a ability, but requires more speed.

Wednesday, August 28, 2013

The time has finally come. After 3 years of hearing about the excitement, strife, fun and horror of Senior Production, now it is my turn to partake in this yearly ritual.