00:00
00:00
TomFulp
Hi there! In case you didn't know, I created newgrounds. No, it wasn't made by some giant company - just some dumb kid who now has help. I also co-founded the Behemoth; we made Alien Hominid and Castle Crashers. Icon by Pegosho, banner by OmenaKettu.

Age 46, Male

NG Webmaster

Drexel

Glenside, PA

Joined on 12/15/99

Level:
51
Exp Points:
28,386 / 28,880
Exp Rank:
450
Vote Power:
9.19 votes
Audio Scouts
10+
Art Scouts
10+
Rank:
Sup. Commander
Global Rank:
243
Blams:
2,949
Saves:
31,498
B/P Bonus:
60%
Whistle:
Normal
Trophies:
131
Medals:
3,677
Supporter:
12y 3m 19d
Gear:
15

Solving Game Design Problems

Posted by TomFulp - October 3rd, 2013


While making games, I come across all sorts of interesting problems that don't have clear answers. Sometimes these problems have been figured out by other people on-line but I don't search for that sort of thing unless I'm looking for a specific math equation, in which case I usually just ask Mike.


When I finally come to a solution for these problems, or a "good enough" fix, I get tempted to post about what I did online, because it might be an interesting read... But then I imagine someone replying, "Why didn't you just do X, Y ,Z; that's what all the other game developers do." I have this fear that my problem is totally pedestrian and all the other game developers will be laughing at my stupidity because I spent hours solving something the wrong way.


The reality is there probably isn't one true "right" way and a lot of people might benefit from seeing the process I went through to get from A to B... But then I still have that fear that if people actually turn to me for advice, they'll actually be learning the wrong way to do something.


The fear of looking stupid or teaching other people to be stupid is the big thing that holds me back from sharing more about my game development process. I'm not a math or programming genius and I feel like most of my results come from the sheer determination to make something. And that's probably how most games get made, although I still think they have better code and better math.


The problem I've been working on this week is multiplayer camera with free roaming platforming. It becomes clear why games like 4 player Mario and Guacamelee use "bubbles" to float lost players back into the action. I've been trying to avoid that, although I'll likely have some sort of "teleporting" as a last resort. Still, I really liked the bubbles in Guacamelee because I could play with my son and he could keep up with me in bubble form when things got hairy. That alone makes me see how bubbles are a "right" way to do it, because they let you maintain momentum with a dominant player, in addition to solving other quirks.


Beyond that, I've been trying to have a really nice camera system based on "camera zones." Right now it's all actually working really well, until it doesn't. I'm in awe of how most 2D console games don't have noticeable camera flaws... I feel like I'm overcomplicating things.


I'd like to show the game but JohnnyUtah and I are keeping it under wraps so we can have a big reveal when the time comes. It's our biggest team-up ever!


Comments

Very great Tom, I hope get really surprised coming from you :D.
Good luck and, fear don't help anyone, it's just more one obstacle.

Sometimes we need to check our egos when we're working. Yes, you might of found a work around but what's the shame in learning a more efficient method? Or maybe your method might be the better solution. It doesn't hurt to throw it out there.

What I always loved about Newgrounds, and especially the developer forums, were the people willing to offer advice and have a conversation about solutions to problems. Having that conversation where you might be proven wrong is a good thing. Hopefully people can be respectful instead of condescending.

But I don't know jack all about game development but I still love to hear how artists in the field are able to reconcile problems. I love to see the sharing of ideas and tips.

That's something I forgot to mention in the post - if people point out the RIGHT way to do something, I'd benefit from that long-term!

I find the process of being creative comes with a similar price. A good chunk of my work on a game goes into preproduction, trying to create art directions that are new and experimental. But time and again, I tend to stick to the norm because of two factors - familiarity and trends. Art styles - for demand , by demand.

When a game is published I would also love to show gamers the different concept and art styles that game has evolved though and how the final visual treatment came about.Most of the work being very rough, doesn't look very appealing since they are generally very fast scribbles. I have a very clear idea of those concepts in my mind, but I find it unnecessary to fully render them to save on time.

I would like to break out of this comfort zone, experiment with new styles and, and brace some professional and end-user critics. Only time will tell if I could do this and have the energy to answer everyone's questions.
Yup, that said - all the best on your new game. Looking forward to it

I don't think you're stupid, Tom.

Write up a post--or I guess peri--mortem talking about what you've done so far and any challenges and stuff. You don't even have to post it if you want it to stay under wraps; it just helps to clear my mind after coding or solving a problem.

I feel the exact same way. I honestly think I suck as a programmer and I get really frustrated when I observe how easy it is for other people to solve problems that took me days to figure out. I often look at all the games I've made and I don't even know how I ended up with the final product. Just sheer drive and motivation to create something that compensates for the lack of knowledge how to do it exactly. As long as it works and it doesn't crash, I don't think anyone cares. If we agree that the only way to evaluate something is to compare it to similar things, I think you are a programming genius compared to many of us around here.

Well, as for the first part of you're post all I can say both you and I know that making a game no matter how big or small, simple or complex is far from an exact science. It's all about problem solving and big companies like Nintendo have the befit of having lots of people to bounce Ideas off of, and they still don't have a better solution the the bubbles or atleast to my knowledge.

As far as a camera for 4 player platformers it's a problem I pondered myself on how to deal with it, unfortunately I not working on a project so haven't put that much thought into it but for what I have I quickly realized it's a much more difficult issue then it may seem at first.

I had the idea to have for players who were falling behind to have a window pop up in place of a little Icon to signify where they were, in the window they would have they're own, yet smaller view, it would move around based on they're elevation and things like that and merge with the main camera as they caught back up. But that Idea presents more issues, how much screen space do you allow for players lagging behind, what if the window blocks important information for the players up ahead, what does the main camera favor? Not to mention what does a system like that mean on a technical and hardware level. It just makes more and more questions, questions that can be answered in many different ways.

The way I see just do what you think feels right.

The little window would be kinda fun if you had a tile system and could render their progress out as 8-bit style art, so they can run and jump over obstacles while they try to catch up. I have arrows that pop up if you go off-screen, so you can at least track where you are off-screen - the goal is to not need them but we'll see how that goes! I have things like, if a player drops off the bottom of the screen, they just auto-bounce back up... Which does the trick pretty well but I worry about it becoming gratuitous in some parts... Still better than nothing. Alternative is to follow them down and make the other players drop down after them... I feel like it's almost zone specific, where I should base it on where players are TRYING to go and not just have it as a global rule.

This is an interesting read. The insecurities you mention here are probably common and not specific to programming or mathematics. Personally, I emphasize with what you wrote about the fear of looking stupid. I feel that way about sharing my creative process with other people. That fear goes doubly for me when it comes to sharing anything that seems unfinished or poorly executed.

The camera in multiplayer platformers is a difficult problem. I like to solve it by zooming out (but I'm going to ignore it in my platformer, because multiplayer levels are only a bit larger than the stage size).

I can write my method for that, and all equations. I am not afraid to share my thoughts. There is no "right" way for anything. The Greek Sophists thought that every man has his own knowledge about the world. You cannot hurt by sharing an advice, even if it is bad. Because when you teach, you make people think about their problems and move forward, instead of coming up with their own solution... daaaamn I messed up my entire speech! :(((

I admitted a long time ago I have no idea what i'm doing. And I really don't...

Excited to see what you 2 have in store.

I'll test your game on your bugs and crashes if needed

One thing I've always loved about the games you and JohnnyUtah make is how utterly unique they are. Working with roundabout solutions is undoubtly a big part of that. After all; restriction is the mother of creativity.

It'd be interesting to see a game focused entirely around the "difference in skillset" aspect of co-operative multiplayer, now I think about it. Hrm...

We'll take care of the "difference in THRILLset"

When are we getting Battleblock theater DLC

Haha, 90% of tutorials out there are made by people who just figured something out and wanted to make it easier for other people. Math is one of those things where there ALWAYS seems to be a better way to do it. That's why Google pays big money for optimization professionals to come in and speed up their back end.

The rule I've seen stated across the internet is that you should only worry about optimizing when you need the speed. Of course, as an optimization fan, I follow the opposite rule of "optimize for the most speed, then fill it all up with graphics XD."

At the end of the day, if the code works, it's right. Post without fear! Anyway, you're Tom Fulp, who's going to make fun of you? :D

Maybe you can turn it into a gameplay element? If it's co-operative multiplayer, maybe the player lagging behind could use a button or a combo to sort of boost back on screen. It could even have some advantages, killing enemies in its path, or giving the 'Leader' a step up to unreachable platforms.
If it's versus multiplayer, the 'Leading' player could be surrounded by a 'Safe Zone', which is the maximum zone the camera will stretch. Players lagging behind will take damage outside the Zone, like in Metroid Prime 2 or Final Fantasy: Crystal Chronicles?
I've never designed a game, but perhaps these ideas will give you some inspiration.

I consider programming an art form, however, many people don't treat it like that. They say there is a right way to do it, and that makes them generic. There is very little more unique than a flaw. Its so odd how intensely game developers have stripped "flaws" out of games, but when I was a kid "flaws" were a mayor function of game play. Here is a quick for instance. Games like Odd world or flash back had extremely unforgiving controls, I am sure many an asshole stepped in an complained about that with those games, but to me to that is easily one of my favorite parts.... As for your Bubbles thing, I think multiplay gaming is still very much in its infant state and no one has even scratched the surface on getting it right so far, so please experiment like crazy to pioneer those missing gaps.

In the 2 player mode of Abobo's contra level, we made the screen stop scrolling if anyone lagged behind horizontally, and killed them if they went off the bottom... brutal, but for those who want to cooperate they talk in real life, and for the jerks, they can constantly kill their partner... Doesn't account for difference in skill level between players though... Oh, I know, put the lagging player's game on the wii-mote screen until they catch up!

I forgot to ask, is this for the wii-u? :-D

Not for Wii-U :(

And yeah this game has cases where one player might want to explore something below the bottom of the screen, while another player is running off to the right - so if other player is climbing down a ladder, it simply stops letting them climb down any further - but if they jump off the ladder, they fall off the bottom of the screen and auto-bounce back up, so it's like they are bouncing on an off-screen trampoline.

You know @BomToons and @kkots ideas sound wonderful, what about zooming out the screen to a point where all the players are on screen, and if the player(s) is(are) too far away the screen "cracks" and it divides into smaller screens, with the bigger one taking the main stage, then as they get closer they start to merge, i'm thinking something like cellular mitosis here.

As for the epistemology problem, again Kkots had the right point there, except that and advice or teaching should lead to the person to reflect on its own methods, in the beginning is true they wouldn't be thinking by their own tools, but that was in the lectures where the role of the student was to remain silent and listen, once whit their annotations they would develop their own ideas, then with the ideas once polished they will engage into dialectics to point out an argument, in the very classic Sophists method a lot of appeals to metaphysics matters where allowed, but with the arrival of Euripides and Socrates a more rational method of dialectics was implemented, where rationality was put on front of it all making something like not "coming up with their own solution" impossible, this is then known as the Socratic method, which of course has it flaws a discourse that is too good, and seemingly clean, may persuade people into mistakes, that is one of the critics that Foucault makes to the dialectics as he analyses the relations of "power" between the parties engaged into a dialogue, what he proposes is to identity these things and intent to reduce their influence, that way it will proceed in a more truthful way. In this version people wouldn't be learning the wrong way to do things because part of it is to reform the system that you are teaching them, as for the shame of being laughed at, it shouldn't be, since indeed there is not a "true" right way to do things just, as the shortest phat may not be the best path, so the pressure may come purely with pride and status, what we known recognition, but if is our interest is to teach this shouldn't be a concern.

Sorry for the wall text, is all my fault for trying to complete kkots speech.

I might have screen zooming in specific areas but I don't want to rely on it everywhere because the levels aren't meant to be viewed from far away like that. Also the split screen would be more tempting if the game was a much more open world, ala Castlevania, but the levels are still pretty linear so there isn't a huge need for everyone to run off and explore on their own.

Say Tom, I noticed a checkbox option under the project manager for games that says "Login Required". What is that exactly?

That is for games that use our user-authentication API to power in-game user accounts. If you check that box, it blocks non-registered NG users from playing / voting / reviewing your game and instead encourages them to create an account so they can play.

I think this happens to me. I doubt any of my methods for making games are the most efficient or logical ways, so I don't want to share my process with other people because I might be teaching them the wrong things, or inviting criticism I won't be able to do anything with. But you can take comfort in knowing that what you do works.

More Results