If you're interested, here's where you can wishlist Isadora's Edge on Steam! store.steampowered.com/app/3125320/Isadoras_Edge/ And you can follow the Kickstarter here: www.kickstarter.com/projects/inboundshovel/isadoras-edge Thank you!
So glad I found this video now. I prototyped some different terrain, some with slopes and immediately noticed when going down hill triggers my falling animation. This video is very inspiring and informative. Thank you.
How have I never heard of this game before, till I got showed this Vid by The Girl from Arkanya's Dev...? :O It's on my Radar now. :) (Though the intended to be terrifyingly hard Bosses scares me more than a lot... that sounds like Dark Souls territory, which is a Realm of the Player Gods a skill-less idiot like me will never belong... 😔 )
Some games rather than fix the NPC interactions with slopes just turn it into a feature. I do admit that this solution isn't right for all game designs.
Just put them on a parallax layer in the background. I'm sure that the players will remember the game as having slopes, even though they never actually interacted with one.
Castlevania Adventure even has you jump from ledges when not even a pixel is left touching the ledge. You can't finish stage 1 if you don't jump that late. Go check out some walkthroughs at 0.25 speed and you'll see it very clearly.
@@whynologin I think they call that "Coyote time", a reference to Wile E. Coyote not falling until he looks down. Basically it means the programmers put in a little space at the ends of ledges where your characters looks like they aren't standing on the ground anymore, but you can still jump. It makes long, last-second jumps more forgiving.
@@Channel9001 Which is what made it so weird. Instead of implementing it to be more forgiving you are required to make jumps like or you wouldn't be able to reach the next platform. They could have either just made you jump farther or decreased the space between platforms, but for some reason decided to go with that.😕
@@whynologin It's a similar concept to having the last 20% of your health be equal to the other 80% of your health in modern games, you could have just given more health, or made the enemies do less damage, but you would have lost that cool factor of feeling like you just barely made it trough with only a sliver of health remaining and the adrenaline rush of feeling like you're about to die wouldn't have been part of the experience, making it more dull. A good game can easily be designed in a way that will look harder than it actually is and make you feel better than you really are to keep you hooked instead of making the game easier and less enjoyable.
One benefit to slopes is that if it's too obvious that a game world is built to a grid, that will make it feel a little too gamey. With more varied terrain, it can feel a lot more natural.
I agree. Enemies with floating feet has been a thing in both 2D and 3D for ages. Just like the player character standing with one side off a ledge. Generally people just accept it since it is still generally better than everything feeling blocky and inorganic.
just don't use tilemap and tileset everywhere. even if it's blocky world. hide the fact it's using tilemap by covering the world full of decorative sprites etc. no need for slopes.
I mean if you implement only slight slopes it won't be very noticeable that the player & enemies are floating off it, while still adding to the game looking natural
@@Juke172 Or better yet, use slopes but put stuff in front of the slopes like stair rails, bushes in forests, etc. to hide the floatiness. But yeah, I mean you can skip slopes, but it is still noticeable and gives the game a precision-platformer vibe whether you want it or not.
It's probably too late for this advice, but I think a lot of your physics problems aren't actually to do with slopes. Instead, I think it's because you're using a physics-based player controller instead of a kinematic one. Issues like speed on slopes, snapping and slopes, and so on are a lot easier to handle when you're not fighting physics. You wouldn't, for example, have to adjust player speed just to un-break running on slopes. You would simply move the player horizontally, then snap them to the slope. They get the vertical motion for free, and adjusting run speed on slopes becomes opt-in. Sure, you're handling gravity and momentum yourself, but that's often less work than fighting physics every time you fix a new edge case. None of this is to mention features like coyote time, asymmetrical jump arcs, and input buffering, all of which are easier to implement when your controller is the only thing driving player motion.
Yep, pretty much write your own simplified physics that fits the game logic, this is pretty much how every classic sidescroller did it. Unfortunately engines like Unity tend to encourage beginner developers down the path of yeah, using a full rigid body simulation which is just completely silly for a game like the one this guy is making.
100 percent. I would always recommend writing your own movement and game physics. Sure, it takes more time and effort, but it makes many things way easier and gives you so much more control over everything.
4 месяца назад+15
I scrolled down specifically to find this comment. Sliding down a slope would be extra work if you wrote minimal physics from scratch, rather than something you need to work around.
Commander Keen 4-6 and Keen Dreams and all the fan games built on the KEEN4 engine since 1992: Has isometric perspective and slopes with climbing (except Keen Dreams which didn't have climbing) and occasional fake z-axis movement. Enemies have the same abilities. The key: they didn't have enough memory for real physics, so they didn't do real physics.
3:16 literally all of those things are realistic tho, and would make slopes interesting instead of just something that acts exactly like normal ground but doesn't look like it. Having it take longer to come up, and you slide down fast, could be great for trying to escape an enemy, or sliding into a trap area full of them.
Ok, as someone that has been working in a Sonic fangame that has lots of slopes, here's how I did it for anyone who wants to try, aswell as some opinion as to why you SHOULD implement them :) 1. Ground Sticking Shoot a raycast from the players center of the body, not its feet/base. If it touches the ground then it's considered on ground, and we get it's normal. Align the players collider with the ground normal, if you don't want to visually rotate your character, create it in a separate object (or detach it when it starts) and give it a script that manages it's own rotation, by either copying the collider rotation, or doing whatever you want. Lerp the character rotation so it doesn't snap whenever there is a change in slope. Set the players position in the raycast hit point + the ground normal times whatever height you want. 2. Fix velocity If you're using rigidbody forces to move your collider, within the ground sticking process, project the velocity vector towards the ground plane. Unity has a function to easily do this, where you just give the velocity and ground normal as parameters (any other engine should have a similar function). To maintain your speed during the projection, create a temporal variable to store your speed, project the velocity, normalize it, and multiply it by the store speed. Finally make the rigidbody velocity this new created velocity vector. Convex edge cases can be solved by making the raycast long enough until there aren't any false negatives. As for concave cases, I made it so we shoot a raycast in the velocity direction (or the players forward direction) to check if there is a slope in front of us, making sure it isn't a wall by checking its angle and if it is a slope we can be on, project the speed on the new normal that its ahead of us (this is only necessary in games were the player goes in a variable running speed, like sonic games, in most games with set speeds this step can be skipped). 3. Air movement For jumping, we create a function that whenever we jump, we deactivate the ground sticking by 0.2 seconds or so. Gravity can be applied whenever we're not grounded, there is no need to apply gravity otherwise. 3. Visuals Personally, I haven't dealt with this myself, but here's my idea. Create a few standing animations depending on the angle of the slope (as few as two or as many as you want), and when running (detecting the rigidbody speed more than 0 or any other method) align the character rotation to the ground. The snapping to the ground normal/ to the up vector could be well hidden with a settle animation or running start frames, if it's still to noticeable. (Important in case you're making a 3D game, there's a technique called inverse kinematics to make sure that the feet are always glued to the ground). This should work pretty well with any type of floor perspective you use. 4. Enemy behavior The same for the enemies, if anything with less steps to fix the velocity as they don't have to be this precise. Aligning the enemies to the floor normal should fix any "floating" animations, if you're still not convinced that a big enemy would be almost sideways, just make a limit to the slope angle they'll be willing to walk on. More as an opinion piece now, I don't think that there has to be specific cases where slope are used for them to be important, I think it still adds value to having them for the sake of versatility at the time of creating levels, like creating a difficulty curve at the time of presenting challenges (slopes can make any challenge easier or harder to beat), creating variation on environmental gameplay (like more natural environments can have more slopes, and more mechanical/urban have less), and often times not implementing them it's just going to be more workload for the level designers. Not saying that every game should have them, the point of the video still stands. That's all, sorry for the probably bad english, not a native speaker, lol.
I love this writeup! I was thinking throughout the video that sonic games have slopes and really benefit from them. Any tricks to keep the art complexity low? For example Sonic turns into a ball shape sometimes, is that to keep art complexity low?
@@unique_twoSonic being a ball obviously makes things easier, since he's just rolling through stuff. But overall the sprites just rotate with the floor. Even in loops and such. You just have to take into account inertia and such when jumping or getting hit (enemies aren't usually near loops though).
One solution to visuals would be to use some kind of skeleton based procedural animation rather than sprites. You'd have to make that decision very early on tho
About the ground sticking, imo it depends a lot on your game mechanics. I'm thinking about games like Celeste specifically where the devs added a ton of leeway for the player when they're on a ledge. In celeste, only one of the bottom pixels of the hitbox is required to touch the ground for you to be in ground state, and you're also snapped to the ground if your vertical position is ±2 pixels off the ground. Raycasting from only the middle of your character might break things like that. Celeste doesn't use slopes however, so that solution wouldn't apply in it anyways 😅 Anyways, thank you for the good advice!
Sonic's slopes are much more robust than SMB3's and also much, much more flexible. The SMB series is also plagued with really janky implementations that tend to feature incomplete solutions that rely specifically on the game **being mario**, and the level design being from mario. Even in SMW, the slope code includes subroutines to physically teleport mario up and out of slopes, which calls for two tiles or mario can literally just walk through the floor and die.
@@hexidecimark lol good shit. Of course, Sonic developers got to shortcut around animation issues by rotating sprites - or literally just turning Sonic into a ball :)
@@RoboBoddicker The rotation is part of their solution- mario uses a flowchart for physics interactions and lots of teleports, sonic actually has a primordial physics engine that relies on a mixture of sonic's H shaped physics sensor grid (flips are due to either gravity variables or the middle bar of the H finding a tile under specific circumstances), a lot of different speed variables, and loading tile data in a specific way. Implementing mario's setup would have been much simpler, but any new interactions have to be stapled onto the flowchart and get nullified under very odd short-stop conditions (coin collection is baked into collisions, but collisions can't be calculated in the same tick that a coin is collected during), then made up for by a bunch of extra flowchart that specifies rules for corrective teleportations warps to combat subpixel miscalculations. Sonic's setup can be used in virtually any 2D environment, and this is why stages allow for so many varied gimmicks.
@@RoboBoddicker Genesis Sonic games didn't get to shortcut by rotating sprites. They had to make separate angled ones. Sonic Advance on GBA did rotate its sprites in realtime, and Sonic Rush uses 3D models.
@@npc_blob1609 Wow crazy. I just assumed they were doing sprite rotation as a fancy new 16-bit trick. I honestly wouldn't understand a thing about NES or Genesis code to look at it, so thank you guys for schooling me :D
If I recall correctly, Castlevania Symphony of the night only used slopes in... A. Rooms where the enemies don't interact with terrain. B. Rooms with enemies that are specifically made to interact with slopes in specific ways. (like the dragon skulls that roll down stairs.) And if there are any normal enemies in the rooms, they just don't go on the stairs or don't stay grounded. Clearly, even the devs of that game struggled with slopes. In fact, the entire early Castlevania series made stairs something that only the player interacts with. I've been brainstorming and making ideas for video games for years, and only ONCE have I ever thought about slopes, and it's a boss fight where the boss is stationary and uses attacks that don't interact with terrain XD
then area of sorrow had a lot of rooms where stairs and slopes were combined for great effect on a platform with calculating power of less then half of a modern calculator disk armor, sucubi, those rolling lion things, valkeries , dog dudes, were all used in both rooms with and without slopes also, in sotn there ARE rooms with slopes and enemies not designed for them, but in the inverted castle, where archways turn into bowls of death etc
@@Russian_engineer_bmstu There's a lot of NES games with slopes, hardware that's significantly weaker than the Nintendo DS. Like Super Mario Bros 3, Castlevania series, Super C (Contra 2) and the Wizards & Warriors series for some examples. Then you have crazy NES games like Gimmick! which includes a physics engine, but this is possible thanks to expansion hardware included in the game cartridge.
You are absolutely correct that if you don't really have a purpose for something in your game, it should be taken out. But I think a lot of the issues you are facing are due to you actually using the physics engine to do movement. In many of the games you have given as example, they only use simple collision checks and give the character a certain speed until collision says "no". Gravity would be a simple acceleration purely affecting the Y axis without any regard for slopes. A lot of the fixes you mentioned here are in fact extra steps to counteract previous steps that the physics engine did for you, that it shouldn't have been doing in the first place for your style of game. I highly recommend looking up some videos on how these classic games do movement and collision detection. It can be a huge help in creating the way the controls feel in these classic games.
Laugh-cries in Sonic-type physics But seriously, not only am i locked into using slopes, not only do i need to fight with the engine to get accurate collision angles, i need to also build LOOPS. Aka, slopes that go completely upside down, and also switch collision layer so you can phase thru a part that was previously solid.... AND build Rails, which are all of the above, and also semi-solid relative to player rotation The problem with trying to be faster than light is that you can only live in darkness
Honestly, from my own experience trying to make that style of game, I'd say just script the top half of the loop so if you're going above a certain speed it plays a canned animation of you going around it
@@Twisted_Logic Automation is the enemy for this project: actions MUST be able to chain their momentum into one another, and this isnt even considering how i would make rail grinding work without slope physics. And make no mistake, the PHYSICS to those rails are critical
My thoughts on a solution would be to make precisely 0 "ground" loops, and instead just make two rail loops with one using the grind animation, and the other using the run animation. For the actual rail mechanics, give the player a footbox if they don't already, and if the footbox collides with the rail it'll mount a sliding platform that inherits momentum from the player, follows the spline used for the rail, and can be dismounted with a jump or by reaching the end of the rail. It's a little obnoxious, but it also means you can create flat rails and momentum puzzles by using the components in different ways (nothing like having spring platforms and quarter pipes to encourage fast gameplay, and ice to be hell on earth) Getting the passing section to work will pretty much always come with some hassles and jank, but I'd probably just have the platform automatically ride any rail sufficiently close to it regardless of layer, and have it prioritise rails on the same layer over rails on a different layer, then just have the rail be on the front for the first quarter, briefly overlap with the one for the rest of the loop in the back (forcing the player into the background) then have a front layer exit from the end of the loop out about as far as the player can jump (or just have the player default to the front layer when they dismount, but that might result in some jank and clipping problems).
You're gonna hate hearing this but the "weee!" factor does make gameplay a lot more fun. It adds a kind of "flow" to movement that feels far more natural and intuitive than simple up or down movement can achieve. I was recently replaying Pitfall The Mayan Adventure for Sega CD which has slopes, and it adds a kind of dynamism to the gameplay which is a lot of fun. For one thing you can make slippery slopes which cause the player to slide down them which adds a fun platforming element. For another, it emphasizes terrain and makes it feel more lifelike. For example in the first level of Pitfall there is a small slope on the ground that allows you to double back to a slightly higher level behind you. One of the ways Pitfall often handles slopes is by putting grass or plants in front of the slope to hide the legs. This makes it seem like you're in a cave and adds a cool paralax effect. Yeah slopes are a big pain but they can also really level up a game in terms of quality. I think that's also one of the differences of why a lot of modern indie games "feel" different than their 2D ancestors from old consoles: Indie devs often have to take shortcuts meanwhile the older games had entire dev teams and sizable production budgets. Sea of Stars for example is very colorful, but lacks the writing quality that a big budget JRPG with a full editorial staff like FF7 had. There's a level of depth and polish in many older games that lots of indie games still don't achieve, even with modern tools.
I think the main problem for modern indie games here is an over-reliance on generic, built-in physics engines that weren't designed for 2D platforming, rather than having the gameplay programmer create bespoke physics suited to the game, similar to the development process for 16-bit titles. Mega Man X was mentioned in the video, as well as Sonic frequently in the comments, but also games like Super Mario World (or even SMB3 on the NES), Gunstar Heroes, Kirby Superstar and many other memorably used slopes to great effect without a perspective artstyle, while restricting larger or awkward enemies to areas without them. Regarding metroidvanias specifically, I think slopes are very valuable for both enabling physically varied and distinctive level geometry as well as the ability to compress map layouts by supporting smooth bi-directional connections between rooms that aren't orthogonal to each other. In Super Metroid, the room to the left of where you get the Speed Booster, which serves as its only entrance and exit, is a good example: because the room slants diagonally upwards, the player is able to just barely escape the vertical rising lava that is triggered by obtaining the power-up merely by running directly left, immediately demonstrating the value of the new ability, something that wouldn't be possible if the transition was manged by a series of elevated ledges. On the other hand, looking at something like Hollow Knight, while that game's eventual monotonous nature is primarily due to the size of the world being too large and the low cadence of ability acquisition after the first few hours, lacking slopes is still a notable secondary issue, as their addition could have gone a considerable way to diversify level design on either a micro level or between biomes.
Yeah I mean the main crux of the issue really is just the overabundance of game devs, even in the industry, who just don't know how to do things on their own. They are too comfortable relying on the tools that are fed to them. Nothing wrong with that if you're just making games for a hobby, but if you wanna make a commercial product, strap up and actually learn the necessary mathematics and computer science to understand the tiny details that make or break the game feel and performance.
it's wild that dude brings up Mega Man X (a game with an art style similar to his own) but later when talking about the art problems, only talks about Mega Man X4 a completely different art style, which a lot of people specifically dislike BECAUSE of the perspective! Like, from an art perspective, the simplest solution feels like it would just be to make the slopes hitbox actually start a little bit offset from the art, so the sprite starts descending earlier. it'll still look jank, but that's basically how it works in MMX and my dude literally cited that as a reason to use slopes so like... (yes, slopes also provide a complicated programming problem, but there's footage of that being solved for this project already so like...)
@@Senae I will say that making the "origin" of slope collision be the center of an object's collision is definitely trickier and has a lot more potential points of failure than just using the left/right edges, but plenty of devs have pulled it off since basically the start and it's definitely worth the effort for how much fun the result is.
I agree, and I don't think alot of modern engines are helping. Godot for instance, has a lot of ups and downs but one of the biggest issues I ran into when I tried it out is that it seems to completely reject basic attemps at pixel-based movement. Manually altering position frame by frame with the simplest code would cause some pretty crazy stutter.
The bottom line I feel is more "Always have a critical mindset about non-essential features that might cost a lot of work", than it is about slopes. I genuinely wish I could be like that because if I have a clear idea in mind when it comes to user experience, I will work towards that goal, regardless of complications.
That should be question 1, the second question should be "am I using the right tools for this job?" If you don't need them, don't use them. If you _do_ need or want them, make sure you're using tools that facilitate that. Using a character controller designed for flat platforms only is not going to be a great time when dealing with slopes. Use a solution designed from the start to support slopes.
I wonder how the folks at Moon Studios handled this issue with Ori. One of the things that stood out the most for me while playing Ori, is how fluid and beautiful it is. And it does have a lot of slopes, of different heights and angles.
Most likely, they didn't treat surfaces as dumb collision hulls. Treat it as a path. Why on earth would you do raycasts when you're on the floor? When Ori is on the ground (or climbing a wall), it's just following that path. In ori 1, I'm fairly sure Ori's just rotated to follow it too, and no floor is particularly steep, and the point where it becomes a wall is surprisingly shallow. Ori 1 probably had to do that because, well, 2d animation. All the slopes are shallow, and really what the effect is for, is detailing its surfaces. The Ginso Tree in particular makes it super obvious, when you slide past or run over a knot in the wood. Actual physics would have Ori flung away from the wall, you know? Very nice, fantastic effect, but there's never a 45 degree slope. Ori 2 can get away with a lot more because Ori's a 3d model, and therefore they can adjust the legs in real time, and therefore afford steeper slopes. Don't think they did, though, because, like... platforms are more fun to jump up, y'know?
If i remember correctly, Metroid Fusion and Zero Mission handled slopes by just not allowing most enemy types to enter them. Slopes were strategically placed, so it never felt odd
Metroid Fusion and more so Zero Mission also just placed stuff on the Front Layer to obfuscate any Art disparancies. They are also MANDATORY for Metroid. (At least any Metroid with a Speed Booster Mechanic. Think about it.) Similarly, they are quite Mandatory in Games where you have a Dash, like Megaman X or ZERO. Otherwise the flow of these games are completely ruined. (Or the Rooms will appear very flat, almost amateurish)
This video was coincidentally uploaded right when I was currently struggling with slope physics for my own game (specifically how they affect acceleration), too bad they‘re absolutely integral in mine. I have no clue what to take away from this.
@@Widdy123others have solved it, so with the internet youll be able to as well. It may still be hard and take a while, like you may even have to rewrite the physics to be cleaner but i think youll be able to get it working
@@HaydenTheEeeeeeeeevilEukaryote I‘ve already figured out the acceleration part, I just gotta figure out how to stick the player to them at the right times and how they affect jumps
Alternative: make floors basically work like defined paths and link together. Players and enemies can move freely along paths, and then can break free by going aerial. Path segments are given properties that affect jumping, landing, acceleration, friction, and so on.
this reminds me of a video essay i watched about hollow knight by ceave perspective that has a segment discussing how one of the reasons such a small team was able to make a game that big was because the game doesn't have any slopes, and therefore doesn't have to worry about all these problems
I don't think slopes would take that much to add into hollow knight. The knight's idle animation is very "straight" unlike OP's animations, where the character has the legs spread very wide, so making the knight stand on slopes wouldn't look weird. Most enemies are also confined to small areas, stationary, or fly, so there's no need for them to go on slopes (though most of them also wouldn't look too weird on slopes). As for the physics, honestly I don't think it's as hard as OP makes it seem. You can just get the ground normal (which in godot and unity is included in the raycast results) and if it isn't pointing straight up then you know it's a slope. You can also use the normal to rotate the movement vector according to the slope angle, so that movement is consistent. And it's pretty easy to just disable the gravity when the player is on the ground, and then turn it back on when the player is jumping.
The real root issue is using physics-based movement in a game where you don't want your player to effectively be a ball that rolls around. I'm exaggerating a bit for comedic effect but that's essentially it: if you want physics, momentum, etc... use the physics system to move around, but if you want a snappy platformer you're better off handling things yourself.
What you're describing is rigid bodies, which have simulated physics. But physics isn't just that, even a controller character will usually use built-in physics systems. If you don't, you'll need to code all manner of basic things like collisions on your own, and that sucks. And if you do code them yourself, guess where most of your time will go? Handling slopes.
@MewPurPur My bad, I tend to misuse words like physics system to talk about rigid bodies and friends out of habit, but it's true that that would include collision detection.
Actually, it makes physical sense to move up a slope more slowly and down a slope more quickly. So that isn't really something you necessarily have to "fix". And that somewhat mitigates the edge guarding problem you were talking about.
@@n3ppy632 probably because I think most people wouldn't expend constant effort in a similar situation so it feels floaty or unresponsive. Still I think it could feel fine if you make the effect more subtle. Especially if your movement system has momentum.
@@n3ppy632 depends on a game.. for exampe... didn't sonic have this slow down when going up and higher speed when going down (didn't matter if you were ball or still running)? or am i just remembering this incorrectly. Also iirc super mario bros 3 also slowed mario down when running uphill a slope (1st world had few stages that had them... after that iirc it was mostly used in cave levels and pipe shortcut mid-sections and iirc people mostly wanted to just spam jump when going up.. so yes it didn't feel good to go up but going down... there were 2 options: either you kept running which i think accelerates you faster or if you crouch in slope you actually slide down and most enemy types are deleted). Sonic especially didn't suffer from having sloped affecting your moving physics. Mario maybe did but the levels were created in ways that allowed players to have fun with them (there were enemies often near bottom of these longer slopes and sliding on them to knock em out was entertaining). It is all about how you design the levels and physics around the whole game. I do agree that some games would suffer from these as going up especially might not feel good if it is slow. But also it is totally possible to make slopes have purpose.
Yeah, this is true! However, the math I did to "fix" it actually just lessened the impact of the slopes. You still moved a little faster down the slope, and a little faster up the slope - based on the angle of the slope. The default physics was just /too much/ of an effect, which made it feel super weird to play!
@InboundShovel I feel like this is maybe an important lesson? It's a lot of work to make slopes behave like normal platforms... and the reward is that slopes are now normal platforms. All the cool stuff you can do with slopes is because they're different from flat platforms: ice slopes, launch ramps, rail grinding, loop-de-loops, momentum conservation during elevation changes, pendulum enemies that hug the ground, etc. Don't spend all the time to make slopes the same when you could be spending time to make them different.
2:55 It doesn't seem like it's necessarily an issue that the characters go uphill slower and downhill faster, right? This is totally a reasonable physics model that could be more a feature than a bug.
I love slopes, if you can build momentum of it as a player or as an enemy/obstacle. It also means that it always serves a purpose, the physics are temporary, enemies only use them if designed for them, and the rest is worth it if it is a real game essential mechanic.
Slopes are literally the reason why I had to change almost everything about my character, the physics, controls, and interactions. Either way I like slops and I'll try to fix everything with it.
I think the importance of slopes depends heavily on the movement of your player character. In Isadora's Edge, it looks like the movement abilities are more on the rigid and precise side end of the spectrum, rather than being flowy and momentum-based. A game like Sonic, for example, couldn't (and shouldn't) exist without slopes as they're fundamental to how the character moves - whereas Hollow Knight loses practically nothing from excluding them. In my case, I've decided to use them - albeit sparingly - and just compensate for any strange interactions as they come, since the game has no combat and is focused on speed and fluidity. Great video! Isadora's Edge went straight on my wishlist when the Steam page went live.
Thank you so much - and I completely agree with your analysis! I'd rather spend time focusing on the combat and other precise movement mechanics, in the same vein as Hollow Knight, rather than momentum maintenance gameplay a la Sonic! :D
This is issue only if you have very little to no experience in programming and solving platformer physics problems. You can have the slopes if you WANT to have the slopes. But there's no turn key solution to it, you must study more programming and basic platforming physics from SNES and SEGA mega-drive days to figure out what you can do with very little processing power...
I like your point about there being no turn key solution. It is very hard to tell what problems are simple and have a generic solution, and which problems' solutions depend sensitively on what you are trying to achieve. You really need experience to recognise that it's okay to develop solutions from scratch for things that seem like they should have an easy solution for how trivial it is. I imagine with more beginner-friendly game engines like Godot, people are less likely to recognise where they need to put in that effort? Like in this video, there seems to be an underlying assumption that the physics should never be turned off.
I know exactly why he likes slopes, he played super Metroid and shinesparking after running down that one slope near the start of crateria was probably a core memory
Any Metroid game with a Speed-Booster in it (Shinesparking or not) NEEDS SLOPES. Similarly, any game which has a Ground Dash (Like Megaman X or ZERO) NEEDS SLOPES. Play them, every time you encounter a slope, think about "what would it have been like if this game didn't have slopes now" and you quickly come to the conclusion that they are not just visual... They are inherently necessary for the gameplay to flow anywhere near as well as it does. Sonic is another good example. Smooth horizontal gameplay that is fun to traverse will always include slopes. Or super flat and boring level design.
Chrono Trigger uses multiple different perspectives. Most of the time it's a 3/4 perspective that has wide slopes for characters to walk up and down. But there are some areas with side-on perspective and a slope, and they just have a small foreground wall that covers the characters' feet to deal with the issue of feet not touching the ground on a slope.
Another common option for solving the slope problem is by adding some kind of foreground noise to hide part of the character's feet, which makes it easier. Like foliage, fencing, railing, trees. etc This can also be combined by animations that sink the character into the ground slightly. which extends how much room you have to work with before it reaches into the ground. Which makes senes for some character anyway because they're really heavy, and standing on mud...
Game Engines hate slopes, but you don't. Most people use game engines because they just don't know how the math works. Making the math yourself is crutial, Sonic the Hedgehog for example has 6 hitboxes fixed in a axis with a maximum distance from the pivot. The genesis games had the slope data integrated in the tiles, but in a modern enviroment there are ways to calculate the angle of the floor using atan2. Also for the art problem: just rotate the whole damn thang. The genesis games did actually have the rotated sprites baked, there are some issues with wider characters such as one feet having to be in a different angle.
@@lyraisnappingI hope you're not being sarcastic, because they know what they're talking about. If you're a game dev, you should really have a more open mind to other ways of doing things than relying on a default physics engine.
A lot of the physics concerns seem to come from having a system designed around flat floors and walls and trying to shoe-horn slopes into that system, rather than building the system with slopes in mind from the start. The collision logic should either be based around detecting floors, walls, ceilings, and slopes all as first-class categories of environment collision with their own logic for each of them, or based around a pure physics simulation of interacting appropriately with the normal vector of a generic surface. The easiest solution to the art problem is probably to tweak the collision. The Mario Maker 2 approach works well. When placing an object on a slope, you don't use the corners of its hitbox, because then it conspicuously juts out into the air. Instead use the center of the bottom edge of the hitbox. The object will still jut out slightly into the air, and also overlap slightly into the slope, but the severity of both effects is cut in half. And, up to a point, the overlap with the slope will read to the eye very similarly to the perspective style tileset, even without actually using such a tileset. That will surely introduce some headaches with getting collision to still work well with ledges and with transitions between slopes and flat floors, but that's definitely a solvable problem. For example, check for flat floors below the corners of the hitbox and check for a slope below the center of the hitbox, and make the slope the higher priority unless it's too far below a floor you detected. Something like that will allow you to stand on a ledge all the way to the corner of the hitbox, and still have smooth transitions when running along floors and slopes. The level design question is interesting. Certainly not every game needs slopes, but there are a number of ways they can be useful. Consider an enemy that fires simple horizontal projectiles. On a floor, there's no vertical distance to worry about, and you can easily jump over the projectiles as you close the horizontal distance. If the enemy is on a ledge, you can safely close the horizontal distance while the projectiles pass overhead, then jump and attack the enemy in between shots. But if the enemy is on a slope, you get an extra challenge. The shots are higher than usual, so it's difficult or impossible to jump over them, but at the same time you can't close the horizontal distance to the enemy without crossing through the line of fire. A situation like that forces the player to more aggressively take advantage of the gaps between shots. You might get a similar effect by putting the enemy on a staircase, but then the player's interaction with that terrain is very different. Slopes are also useful for controlling elevation of any objects or enemies that are based on moving along floors but not walls. Consider again the case of the horizontal-firing enemy above the player on a slope. You can add more pressure to that situation if there are ground-patrolling enemies coming from behind. Those enemies can climb the slope to put pressure on the player, but they wouldn't be able to climb a staircase. Or if the player has projectiles that roll or slide along the ground, like Mario throwing a koopa shell, then slopes create situations where those options are still useful against elevated enemies. Slopes can also just be another variety of terrain with different physics that the player has to account for. Just like slippery floors or sticky floors force the player to adapt to the physics being different, slopes can force the player to adapt to moving more easily in one direction than the other. The 'bug' you fixed with the player moving faster downhill and slower uphill doesn't strike me as a bug at all. That's a perfectly natural representation of the fact that running uphill is hard and running downhill is easy, and gives the player one more thing to think about when fighting on a slope.
To be frank most of sonic fangames are either using modded engines specifically made for sonic games or just are straight romhacks. So slope physics is a problem already being dealt with.
@@LockMatch Alternatively, there is a guide out there so all of classic Sonic's physics, so slopes aren't particularly troubling unless you aren't attempting to get an exact replica of the original physics, which can be easier for somethings but harder for others (e.g slopes).
Just wanted to make an edit to the editor. At 9:06, he puts up a note about z-index and z-axis. Both are valid terms. As a matter of fact, when programming layers for webpages, I would often use CSS's z-index property.
I personally really love games that make full use of the terrain with unique abilities. Case in point: The Speed Booster and Shinespark in Metroid games. Where you can either use them to rocket yourself at high speeds or to save a Shinespark charge for crazy puzzles/shortcuts.
Slopes, I think are mostly an artistic tool. You mentioned Megaman as an example, but I also bring up: Rayman - the first one. The game has slopes everywhere and it's considered one of the hardest PS1 games. One thing they do with the slopes in the game is add rolling balls and falling enemies but also make them slippery sometimes which makes physics work against you. But like said: almost every floor in the game meanders like 10-15 degree slopes. Level floors are reserved in the game.
I actually hate navigating through most of Hollow Knight's world because *everything is a staircase.* creating challenges aren't the only use case for slopes, for sure. Just making the world less tedious to navigate is nice. (Hope this doesn't come off as me telling you you're somehow wrong for taking out slopes or something, just wanted to throw my two cents onto that specific part since HK was brought up.)
That's actually a super insightful point, and it makes me think that there is potentially a stronger use case for slopes in Metroidvanias - or any game where exploration and backtracking is present, just to make the world nicer to navigate! I'm planning on having linear, level-based gameplay in Isadora's Edge, so hopefully that mitigates the issue, but it's actually a great point to bring up! :D
They're even buggy in geometry dash, where your horizontal movement is fixed. I still use them in my levels though, every time. Such fun gameplay if you can get it right.
16:33 Interesting, I've never felt any need to put a slope in my game, but now I want to add slopes to something just for the sake of it, one easy answer for the art problem is to make the character a blob which will look about the same no matter what they walk on. In the current game I'm working on it will actually be an interesting challenge just to render the slope itself because of the constraints of my 3d engine I made.
As someone making my own 2d action platformer, can confirm all of that's true. In my case I had to make a convoluted system to make tile-based collisions possible to begin with, then slope physics for just the player. Enemies get left out of this bc the system doesn't transfer to their varied sizes well. The result of this so far is that enemies can show up NEAR sloped areas, but they'll likely be enemies who either move only on nearby flat ground, don't move at all, or are enemies who float in the air. So why slopes in my game? They actually trigger a high speed state for the player that lets them one-shot enemies. In some places, this is used to increase the stakes for a level section because if you get hit, you lose out on that momentum and now have to play out that section at default speed (invoking a kind of "perfect player syndrome" motivating you to do better). They also make levels look more varied. Also, my player character is so comprehensively ridiculous in terms of movement mechanics that the high speed mode ironically can add difficulty instead of removing it. But "fun and jank" is exactly the kind of thing I'm going for so I don't at all mind the challenges that the slopes brought for me personally. Can also confirm I'm a solo dev.
@@NimArchivesYT Refer to Wario Land 2+. Basically they are used for rolling, and even in Super Mario World for running up walls. Specifically, Wario Land is known for hiding secrets, and unlocking or just using rolling down slopes can allow you to break small blocks in succession and find treasure in places nothing else can.
lol, slopes slopes basically turned my little prototype into a game actually worth developing. i definitely have spent a lot of time getting it all tuned right, including an entire rewrite to swap from raycasts to boxcasts. i didn't have any enemies walking around for a good while (since they didn't really mesh with the game concept well), but when i did finally have to implement ground detection for non-player objects, i basically took all of my player ground detection code and put it into a new class. now all of the non-player objects easily snap to ground, account for checking walls vs slopes, etc. also- one thing i found useful for determining if there's a slope below the player is to actually raycast under the front of the player, horizontally inward. that way you can check if there's a slope of any steepness below the player, without using a really long raycast. as for art, i'm a pixel perfect kinda person so i decided to opt for rotating sprites into that crunchy pixel weirdness that you'd get on the GBA. the pixel art emphasizes shapes over outlines most of the time anyways, so it's not too bad. for the most part, we try to reserve rotation for either pure shapes or for sprites that are constantly in motion. it helps mask that weirdness a bit. having a penguin sliding on a slope (~32x16px; a short / wide collider) did look weird even after rotating the sprite, so the sprite is offset towards the ground when the penguin is grounded. the 16x32px (tall / skinny) grounded idle animation is also rotated and offset, but not as much- it turned out to be important for conveying the penguin's jump direction, since the jump force is always pointed perpendicularly from the ground. with the level design side, slopes always became a way to go fast, preserve momentum, take cool shortcuts, and accentuate cool jumps. slopes aren't always useful when designing levels, but they help accentuate what makes my game unique. if i were in your level designing situation, i'd probably ask myself if there were any unique interactions you could have with slopes. since slopes are difficult and thus less common in indie games, it'd probably be worth it to spend some time jusifying them mechanically. maybe there could be a mole that pops out of the ground, but always perpendicular to the surface- so the spot that the mole is buried in is important. especially if it were inside a wall! of course, i'd also avoid using any enemies / mechanics that don't play well with slopes in a slopey area. ronktonk would be a no-go for example, but there'd be plenty of other areas where it could shine. but aside from aesthetic / uniqueness, i'm not sure if, i were in your shoes, if i'd continue work on slopes. it takes a lot of discipline to say no to something you really want, after all. this is a good vid and you present your reasoning very well. slopes aren't easy, and they're not beneficial for every game, but the different development needs and solutions for a genre as narrow as 2d pixel art platformers is interesting!
I hate working with slopes, but in the end it's all about the game. When you as a dev want to include them you have to check if you just want them because they are cool, or does the game benefit enough from slopes to justify all the crap you as a dev have to endure :D Thanks to your comment I just checked out your channel and with that, your game :) I looks cute and fun, it reminds me kinda Sonic (but not completely), and slopes there seems like they are actually a core mechanic - but that seems more like an exception than the rule :D
Now I really wanna make a sidescroller game that just has a siingle slope in it where there are no enemies. But at the top of the slop, is a sign that says "Why is this the only ramp in this world?"
You are spot on. Slopes are definitely a “feature” with extra costs that may not be worth it. You haven’t mentioned one possible art solution, provided you aren’t going for pixel art purism: tilting. The character can be angled so their up is perpendicular to the floor normal, so the wide ememy is simply rotated a bit. As you say, there are always more issues, e.g. smooth rotation on jumps and at slope beginnings and ends.
5 месяцев назад+2
That's how I did it in games I made with GODOT. Simply rotate the sprite image around the surface normal. It actually works pretty well, but GODOT has many physics problems that make using slopes an absolute inconsistent nightmare. The bad normal reads was an absolute deal breaker for me. You can't create consistentency from an inconsistent foundation!
I think that most of the issues related to physics are more related to how you are currently dealing with the movement. For instance, I'd recommend using test_motion() instead of raycasting to find cliffs and use is_on_wall() instead of raycasts to check for walls. As for art, yeah these are actual issues. Most of them we can just say that it's kinda standard issues and players are usually OK with them, but they are really annoying. And for level design, I think you will find out as a fellow Mega-Man X fan, that slopes do make a lot of difference and open up for tons of possibilities. For instance, you showed this tree-like enemy, the wide one, in a 'pit-like" design, where the player would be bellow it, player would be able to just do air attacks and hit it without taking any damage, I can imagine the attack patterns of this enemy and I can't think of one that hits below its feet. Every time you have a cliff or pit where this monster is used as a challenge for the player to move through, players can hit them from below. And the other way around is also true. I don't know if Isadora has an attack that angles top-buttom(like Zero's Crescent Sword or Quake Blazer in MMX5) but if this is not the case, Isadora will always be in disadvange when coming from a cliff to a lower segment of the level. With slopes you even this out. Not to account for vehicles or rides. For instance, if you want to add a "platform enemy", let's say a mushroom that Isadora can use its head as platform and be carried through spikes or other terrains or hazards, you will have a bad time implementing jump for this enemy, where with slopes you can just keep it moving. Vahicles as a good use case for slopes as well, think about Mega-Man X's Ride Chasers, I hate the fact that you can jump with them, this makes no sense to me. But if you think about them TAKING ADVANTAGE of slopes main issues(when you are not snapped your vertical and horizontal velocity sum up making you hop when coming from a slope to a flat ground) you can make very fun stuff like the pit jump we make in Mega-Man X2 Overdrive Ostrich stage which is epic. There are some of these jumps in Mega-Man X5 Squid Adler stage as well. Not to account for push-pull physics puzzles where you can push/pull objects like crates or rocks. With slopes you can have changes in terrain height, without them you will either push them through a cliff with no option to move it back or you can't move it pass a wall. So I can think about many good use cases for slopes regarding level design.
It is CRAZY to me that you still don't have a Checkmark. You are a staple within the Godot Community and your comment is BRUTALLY buried here, even though one of the most informal ones I've encountered!
So a few thoughts on this: 1. A player/sprite doesn't need to stay at the same speed when moving up/down a slope becuase thats not how they work in real life. 2. Seems odd that you designed it so you character is locked to the slope at all time, wouldn't you be better just doing that when you actively no they are a) in the air and b) moving down? 3. Sonic Physics Guide has really good logic for how to handle small steps, slopes, curved floors etc. Sure its more work BUT its really valuable knowing how this stuff used to have been done. 4. You can account for the floating feet issue but having the visual slope and the collision slope not being the same thing. Or offset the player on slopes so they're partly in the ground. I personally think worrying about the visual realism of pixel art is maybe a step too far in this regard. 5. You're trying to find a level design use case, but why does it seemingly always involve you having an enemy at the top of a slope? Sometimes navigation alone IS the use case. Blocky tunnels for example, aren't as natural as sloped tunnels so its one of the use cases in my game is so environments look more organic. Level design isn't all about mechanics it can also be about aesthetics. Interesting video though. Haven't seen too many people debating why you should/shouldn't use slopes. Most just explain how.
1. This is a video game, not real life. If he wants the ground control to feel a certain way, there is probably a reason why. 2. This can be exceedingly complicated depending on how collisions are handled. "When you're moving down" varies a lot between engines and methods of checking collisions. Think about when you're traversing up a slope; your vertical speed is technically moving you upwards. There are also just circumstances where you could collide with a slope while not moving down if your horizontal speed is high enough. 3. Sonic physics are well-known for being unique to Sonic games. The way they calculate movement is designed around maintaining momentum even at 90 degree angles, and it's completely different from how this game seems to play. 4. Both of these solutions are still just compromises that he didn't want to make on top of everything else. It would look especially odd in this game since the character has such a wide stance.
Yeah I didn't really understand why specifically that giant tree dudes gotta be walking up and down slopes I also felt like I missed something with the calculations but I figure that's the actual fun part of game dev tbh Further down someone shared the very interesting use case of allowing grounded enemies to threaten the player while approaching from lower ground
@@m0ng00se4 Slopes physics are complicated I'd never argue that thats not true. Understanding them can help a lot and I'd recommend working with them to come to the conclusion he did. Once you know you know. In my eyes all practise does contribute to the whole. As he said, slopes can be quite good if the gameplay is designed around it, e.g. Wario Land 4 allowing you to roll under blocks is a great mechanic for example. Adds a level of puzzle platforming of sorts. Rolling enemies that are specifically designed to roll up and down slopes can also be a fun enemy to tackle. Though I agree that if he's striving for more realistic pixel art design walking enemies require additional work. I personally would strive for slopes because it makes levels feel more naturally organic than blocky terrain. There's a fine line though, especially if you're using tiles rather than objects because it requires a bit more work to make extremely organic terrain. But adding a slope here and there into an otherwise blocky world can be good. But again it depends on the dev and the scope of the project. Hollow Knight avoided slopes but they compensated for that with a LOT of naturally shaped art assets for walls and do in fact have ceiling slopes in the game.
@@ДюсековИльясYou don't? I have been making a Metroidvania for 2 years now, and before I even made a single asset, I had decided slopes were essential during the planning phase. Slopes are fun, look good, and good games actually utilize them for various movement mechanics. You couldn't think of that? I thought Hollow Knight wasn't good.
Solutions from old that might help Slope: make it very tiny blocks that are one pixel big Interacting and movement: use an auto-jump like mechanic like minecraft has but purely for those tiny pixels Or just have it so that your character doesn’t move sideways unless you explicitly make the action to do so Legs: cut the sprite in half and have it be two (or more) sprites in reality so you only have to edit the legs Perspective: maybe tilt the sprite to accommodate for the slope Fake perspective: just don’t 12:00 It’s over, he has the high ground Level design: they look nice and maybe for the traps have it be a rolling Boulder (or something similar) that speeds up when going down
Never wrote physics for a 2d game, but what stops you from trying this? 1. Calculate new position after moving and check character collision. 2. If the position collides with terrain, snap character to first empty point above the terrain, only if the height difference between last position and current position is below a reasonable treshhold. 3. If that's not the case (you've likely collided with a wall), keep the last position of the character.
Good thing I stumbled across this video when I did. I’m working on a platformer game myself but it’s *extremely* early in development so I don’t have to worry about taking slopes out of the game because I haven’t added any yet. You saved me a great deal of annoyance!
I think a good example of a game which needs slope are the Sonic games, because it's the only way to gain height without losing your buildup speed, or even helping to get that speed when it's a downward slope. Aside from that exemple, yeah, you're right, slope don't deserve that much work, espacially when you are indie
You're right, and also you made me think of something else, I'm a huge metroid fan and in super metroid you get the speed booster ability, and yeah now that I think about it, this ability is the main reason slopes are in the game, so samus can run through walls and across many screens without stopping, and if we add the shine spark ability, it makes more sense.
There's a nice series of videos on RUclips where someone recreates Super Mario World in Godot. They talk about ground collision and slopes, how it's handled in SMW and what the best solution usually is for modern engines. Definitely worth a look!
In the Mario Maker troll-level community, slopes are well known for being one of the jankiest elements in the game, right under clown cars. And if you see both of them close together, you know there's gonna be some "unexpected fun" happening. The speedrunning community in general seems to agree that slopes never really work quite as expected in almost all games that have them. They quite often have some specific glitches associated with them. This goes for indie games just as much as big budget games like the Mario series.
There was also a broken mechanic where sideways Thwomps would slide up slopes they approached. This was later patched, so now they just stop if they reach a slope. Certain course elements, like pipes and bill blasters, also just can’t be placed on slopes without looking janky, because the game doesn’t know to connect them.
I actually REALLY appreciate you talking about this. It's such a small niche that no one pays much mind on, but I feel better about myself knowing that other people have encountered the same design issues.
I agree that you should only add slopes if they enhance the design of the game, and that in your game they don't really. but they do enhance a lot of games where the movement has more momentum and acceleration unlike Hollow Knight and more like Sonic and Mario. there slopes can make it hard to get momentum when going up a slope and allow you to gain a lot of momentum when going down a slope so that you'll be able to make larger jumps.
Slopes are "shockingly difficult for indie game devs" because most indie game devs rely on default game engine implementations of collision physics, however barebones or thorough those individual engines may have them, instead of making genuine efforts to spec the necessary math of what they want then implement it themselves. Platformers like Super Mario Bros 3 and Super Contra/Super C on the NES had slopes with 8x8 pixel tiles and 6502 assembly; Super Mario World, Contra 3, the Mega Man X trilogy, etc on the SNES had slopes with 65c816 assembly; the Sonic the Hedgehog trilogy/quadrilogy, Capcom's Strider (ported by Sega), Konami's Rocket Knight Adventures and Sparkster, among others, had slopes on the Sega Genesis with Motorola 68000 assembly and/or Zilog Z80 assembly. This isn't even taking into account arcade games of the time or Neo-Geo! These games often had programming teams of less than ten people, usually less than _five_ people, sometimes even just one or two, but they planned their calculations and knew what they wanted to get before putting in the work to do it. There are articles detailing reverse engineering of slopes in games like Mega Man X, Sonic, etc. I know they exist because I myself read them almost two decades ago when I was more hardcore into learning game dev with engines like RPG Maker and eventually branching out into other stuff long before Godot was a thing. On or before 2004, using the free open-source engine Sphere (which uses JavaScript for its scripting language and is still around, BTW) I had found a tech demo "Die Seesternkönigstochter" (basically "The Starfish Princess") by user SDHawk, a Sonic knockoff where you roll around on hilly terrain as a starfish). Sometime on or before 2009, Sphere user Kamatsu (IRL an Aussie computer science professor who also briefly worked at Google for a time) made a tech demo that recreated the basic slopes _and_ destruction physics of the Worms games. I myself was even making tech demos of things like 3D block-based map makers with basic rotation (before I even learned the proper matrix math for software-based 3D projection and rotation) as early as 2005 before Minecraft was even a thing. All of it using JavaScript, because that's what Sphere offered/still offers us as the scripting language and what drew us/still draws us to the engine. In short, slopes are "shockingly difficult for indie game devs" literally because "skill issue."
Tools allow devs to muddle through without knowing math, ergo you see more devs who don't know/like math Kinda straightforward development if you think about it, there's a lot of fairly short answers (that make intuitive sense and I've seen some work in unity2d personally) from people who understand vector math intuitively while OP is clearly not prepared for that kind of answer so, I dunno let him make his stairs
Personally I wouldn't want to use a regular '2d rigid body' for a character in a 2D game like in the video anyway except temporarily (say they are being affected by knockback). I'd want full control over their movement, because otherwise you run into a lot of issues with stuff like ladders as well. Same with enemies with special movement types, e.g. spiders that climb on walls/ceilings, or enemies that can sometimes dig through the level.
@@lyraisnapping Apollolux seems to know their stuff and even goes out of their way to source it. I don't see a reason for your scepticism. Their attitude is perhaps a bit aggressive with calling it a skill-issue, but honestly, that barely qualifies an banter at the studios I've worked at. ^_^;;
In my opinion, it completely depends on what type of platformer you’re making, if it’s a combat based, skill based platformer (which is what I’m assuming Isadora is) then yeah, slopes aren’t needed. They just add unnecessary complications. If it’s a fast spaced platformer where the goal is to move fast, it it’s a puzzle platformer where the difficulty isn’t really in the platforming, then slopes can really help.
It really depends on the rest of the design. If the player or enemies have attacks that interact with slopes in fun/intersting ways then they're worthwhile. It seems in his case they were kind of an afterthought, so there was no real damage in removing them.
Meele-Combat Based Platformers would warrant Slopes imo. Because you have to design around high elevation Changes with attacks for that purpose or the player will be ill-equipped to handle the situation. Balancing this can be an issue though. Because a move that is reserved for combatting foes on a high ground could potentially lead to way to easy engagements with other foes.
Totally a valid decision to simplify your features. Just wanted to throw this here for any devs looking to have rudimentary slopes. In Godot you can use SeperationRayShape2D instead of a box collider. These can be used as a simple way to handle slopes. Use vertical SeperationRays to define the height at which the character stands, and then add a horizontal SeperationRay above the base of the character. This way the horizontal ray misses low or sloped objects and the vertical ray places your character to the top. This will allow the character to step onto low objects or up gentle slopes.
one solution to cut down on art time for some sprites is to have a top and bottom parts of the sprite that can be swapped out, leg poses can be on a separate object that can be specifically programmed to handle any leg pose, while leaving the upper body for the more adventurous animations
It's in another video, but he already has this exact system implemented to handle attack animations when moving vs idle. I'm assuming he didn't mention it here since it doesn't really help with the major problem that he still has to *make* all of those unique sloped leg sprites which adds to the workload
Slopes are good for a few things from a gameplay perspective. 1) Momentum based movement. When you need the world to have physics that affect your player character, slopes add nuance to maintaining speed, overcoming challenges at forced variations of speed, etc. 2) they're good for slope specific challenges, such as the gun challenge you showed, but also things like charging enemies, since the change in elevation can make the challenge easier or harder for the player, since you have more or less space to get over the enemy depending on the slope. 3) slopes can be good for limited combat options. With wide, sweeping attacks, they're mostly just free kills. Your enemies may actually have more advantage from below you. Contrary to popular belief, having the low ground is often better for melee combat irl due to most people striking at chest level, so someone uphill is forced to strike downward at the enemies head, whereas the down slope enemy can strike your legs, which are already an open target due to footing, and your midsection, which is one of the widest spots on people that isn't usually fully guarded by a normal stance. This can be translated into gameplay with your default attacks not hitting low. This can be used to force the player into purposefully awkward or unfavorable combat situations. You can also have the enemies launch attacks perfectly down the hill that could throw off the player, or bouncing attacks down the hill could be threatening. These are just a few ideas. They aren't necessary, but hope they're some interesting ideas for you for next time you want to approach slopes with a game. Sometimes you just need a different perspective
Neat that you mention the irl combat example. This is exactly why we learned in Karate (or the specific subset of Karate that I was trained in) to have a very stable, very, very low stance.
@@hiiambarney4489 Yeah, I watched a shadiversity video where they practiced sword fighting on hills, it was fun and I always remember it whenever I hear people mentioning the high ground. High ground only really helps with projectile weapons
Gosh, slopes are some of the hardest things to work with when doing game development; even with built in help like with the Kinematicbody node in Godot or the "Platform" behavior in G-Develop. Because, once you change your platform at even ONE angle different from its original point, it could change how EVERYTHING in that scene block works when the character interacts with it and either it works correctly, or it becomes a mess. It's worse when slopes and other things in the scene depend on each other. And if you're using Godot, the Godot engine doesn't have an "undo" button and "Control Z" does always work!
1. Physics: Part of game programming is making your code more robust to deal with new elements you introduce like "slopes", breaking things is part of development. 2. Art: That is the cost of adding new elements to your games, more work is inevitable if you want more features, but it becomes a more robust base game because of it, which if you're looking to make sequels or continue development on releasing feature patches for a long period of time its totally worth it. 3. Level Design: It sounds like you weren't using slopes for what they're strong at, you're forcing them into situations you didn't need them. For example look at "Ori and the blind forest" it uses slopes incredibly well, boulders roll down towards you, certain enemies can roll after you and will speed up because of the slope downwards and even ramp up and over hills, all these new situations add to the gameplay because of it. You just didn't bother adding or lacked the vision to add the additional programming needed in your game to support and make use of the ramps to add to your base gameplay. And don't get me wrong you're right that features need to be cut as a solo dev, as you don't have the manpower or time to add everything you possibly want into the game, that's what sequels or feature updates are great for, but I think you're painting intricate features as something not to bother with as a solo dev and I think that limits the imagination and determination of a game design and developer
I mean.... His game is not Ori. It seems like it's more of a megaman game. And in mega man you simply NEVER need slopes. It's a precision based fight platformer. Slopes are useless for his project. He's not making a Sonic game where alopes are essential, so why bother with slopes. That basically invalidates all your points
@@ДюсековИльяс I understand his game is not ori, I was using it as an example of how slopes CAN be integrated into the gameplay and actually have use, rather than trying to convince the audience they objectively have no use, it all comes down to writing the code to support its use, prototyping and figuring out the fun in the interaction. And to use your own point against you, his game is not megaman either, its whatever game he decides to create, the systems and elements of a game makes a game whatever it wants to be.
@@Krahfty he himself said he wanted to create a hollow knight, megaman-esque game. Slopes only have a reason to be in a 2d game if your game is about fast movement and platforming. Like Sonic
Dude, thanks for your video. I'm actually doing research on slopes right now (for a game in which they would be an essential component). While watching I remembered the game Iconoclasts having slopes and went to look at it. It actually has a ton of sloped and curved terrain throughout. Im going to take some time and do a more thorough look at how they solved the problems you layed out here. They had some really neat traversal mechanics as well.
Anyone who knows "slopes" by their true, mathematical name, "gradients" will not be as surprised by the complexity, but DAMN! Did you make it a worthwhile journey. Nice vid, bruh!
huh, one thing to do is just turn off gravity when grounded, after all you don't need gravity if you're on the ground, so only when airborne do you need gravity. oh yeah the rest of those issues are a pain.
@@poleve5409 the issue where gravity was effecting the speed up and down slopes. tho you do need to add a system where 'forward' is changed to be perpendicular to the normal of the ground, which means getting said normal, so that you don't come off the ground every time you go down a slope. ok maybe this method is a bit complicated, but to get the speed consistent on slopes you'd need some kind of ground normal system anyways.
@@jamiek8123I mean you just modify the player's direction by the angle of the slope. It's a lot simpler than calculating the force needed to boost the player up the slope (I'm guessing for some reason you can only apply the force AFTER the physics engine in godot? Otherwise not sure why you wouldn't just apply it before...)
I agree with you...slopes introduces some issues but they are also something new in sidescroller type games. I think you had a good idea! I'm also a gamedev i understand your sense of satisfaction about it!
slopes in classic platformers like smw and megaman x center the character on the slope as it looks much nicer than just having your collider skim along the surface. but this causes the collider to basically spend half its time inside a wall! when people say slopes are complicated *this* is what they are talking about. i feel like your slope problems are just you treating a grid of tiles like they are an abritary physics mesh. but why? you don't need raycasts interact with a grid. you don't need to use normals and dot products to work out inclines when you can just store that information in the tile.
The physics problem is incredibly simple to solve. Get your character's total velocity, then project it onto the normal of the ground. The new vector is your direction.
Steep slopes could be a way to block off parts of the map until the player unlocks a way to traverse them, like how pokemon gen 3 had muddy slopes that required a really fast bike to climb up
If you use slopes, then you need to create specific use cases for them to justify them. Some ideas include projectiles or lasers that use the slope angle to determine bounce angle; hazards that use rolling objects to increase or decrease velocity and damage based on slope angle; special actions for characters when they are on slopes.
As a pixel artist. Slopes in tilesets are dreadful to make but when you finally manage to make them it's so satisfying to see the shapes smooth out in some sort of tilemap editor that tests the tileset.
3:30, I just don't use gravity on ground. 7:10, what contra does for the snes, it makes a different sprite for the on slope idles, most games do not change every sprites. alternatively you can lower the sprite down to its center point (it helps visually, some games just do this) save slopes for part 2 XD
If you're interested, here's where you can wishlist Isadora's Edge on Steam! store.steampowered.com/app/3125320/Isadoras_Edge/
And you can follow the Kickstarter here: www.kickstarter.com/projects/inboundshovel/isadoras-edge
Thank you!
Are you making this game only for Windows or other platforms like macOS too?
I second @lukchem - I hope you create a macOS build!
So glad I found this video now. I prototyped some different terrain, some with slopes and immediately noticed when going down hill triggers my falling animation. This video is very inspiring and informative. Thank you.
How have I never heard of this game before, till I got showed this Vid by The Girl from Arkanya's Dev...? :O
It's on my Radar now. :) (Though the intended to be terrifyingly hard Bosses scares me more than a lot... that sounds like Dark Souls territory, which is a Realm of the Player Gods a skill-less idiot like me will never belong... 😔 )
Some games rather than fix the NPC interactions with slopes just turn it into a feature. I do admit that this solution isn't right for all game designs.
Just put them on a parallax layer in the background. I'm sure that the players will remember the game as having slopes, even though they never actually interacted with one.
Brilliant!
Now we're cookin
Slopen't
Pay him!! 😂😂😂@@InboundShovel
this is literally what Hollow Knight does, it's brilliant
"You cant do that on a slope! The foot is off the ground!"
Meanwhile, all the classic platform games: *_(supports full weight on single toe)_*
Mario and Sonic didn't skip calf days
Castlevania Adventure even has you jump from ledges when not even a pixel is left touching the ledge. You can't finish stage 1 if you don't jump that late. Go check out some walkthroughs at 0.25 speed and you'll see it very clearly.
@@whynologin I think they call that "Coyote time", a reference to Wile E. Coyote not falling until he looks down. Basically it means the programmers put in a little space at the ends of ledges where your characters looks like they aren't standing on the ground anymore, but you can still jump. It makes long, last-second jumps more forgiving.
@@Channel9001 Which is what made it so weird. Instead of implementing it to be more forgiving you are required to make jumps like or you wouldn't be able to reach the next platform.
They could have either just made you jump farther or decreased the space between platforms, but for some reason decided to go with that.😕
@@whynologin It's a similar concept to having the last 20% of your health be equal to the other 80% of your health in modern games, you could have just given more health, or made the enemies do less damage, but you would have lost that cool factor of feeling like you just barely made it trough with only a sliver of health remaining and the adrenaline rush of feeling like you're about to die wouldn't have been part of the experience, making it more dull.
A good game can easily be designed in a way that will look harder than it actually is and make you feel better than you really are to keep you hooked instead of making the game easier and less enjoyable.
One benefit to slopes is that if it's too obvious that a game world is built to a grid, that will make it feel a little too gamey. With more varied terrain, it can feel a lot more natural.
I agree. Enemies with floating feet has been a thing in both 2D and 3D for ages. Just like the player character standing with one side off a ledge. Generally people just accept it since it is still generally better than everything feeling blocky and inorganic.
@@RedMattis Exactly. I can look past a character floating slightly if it means a more organic looking world.
just don't use tilemap and tileset everywhere. even if it's blocky world. hide the fact it's using tilemap by covering the world full of decorative sprites etc. no need for slopes.
I mean if you implement only slight slopes it won't be very noticeable that the player & enemies are floating off it, while still adding to the game looking natural
@@Juke172 Or better yet, use slopes but put stuff in front of the slopes like stair rails, bushes in forests, etc. to hide the floatiness.
But yeah, I mean you can skip slopes, but it is still noticeable and gives the game a precision-platformer vibe whether you want it or not.
It's probably too late for this advice, but I think a lot of your physics problems aren't actually to do with slopes. Instead, I think it's because you're using a physics-based player controller instead of a kinematic one. Issues like speed on slopes, snapping and slopes, and so on are a lot easier to handle when you're not fighting physics.
You wouldn't, for example, have to adjust player speed just to un-break running on slopes. You would simply move the player horizontally, then snap them to the slope. They get the vertical motion for free, and adjusting run speed on slopes becomes opt-in. Sure, you're handling gravity and momentum yourself, but that's often less work than fighting physics every time you fix a new edge case.
None of this is to mention features like coyote time, asymmetrical jump arcs, and input buffering, all of which are easier to implement when your controller is the only thing driving player motion.
Yep, pretty much write your own simplified physics that fits the game logic, this is pretty much how every classic sidescroller did it. Unfortunately engines like Unity tend to encourage beginner developers down the path of yeah, using a full rigid body simulation which is just completely silly for a game like the one this guy is making.
100 percent. I would always recommend writing your own movement and game physics. Sure, it takes more time and effort, but it makes many things way easier and gives you so much more control over everything.
I scrolled down specifically to find this comment. Sliding down a slope would be extra work if you wrote minimal physics from scratch, rather than something you need to work around.
thank you. I hoped someone would notice the severe over-engineering here.
Commander Keen 4-6 and Keen Dreams and all the fan games built on the KEEN4 engine since 1992: Has isometric perspective and slopes with climbing (except Keen Dreams which didn't have climbing) and occasional fake z-axis movement. Enemies have the same abilities. The key: they didn't have enough memory for real physics, so they didn't do real physics.
"it's over Anikin I have the high ground"
"You underestimate the power of the slope"
LMAO
3:16 literally all of those things are realistic tho, and would make slopes interesting instead of just something that acts exactly like normal ground but doesn't look like it. Having it take longer to come up, and you slide down fast, could be great for trying to escape an enemy, or sliding into a trap area full of them.
Ok, as someone that has been working in a Sonic fangame that has lots of slopes, here's how I did it for anyone who wants to try, aswell as some opinion as to why you SHOULD implement them :)
1. Ground Sticking
Shoot a raycast from the players center of the body, not its feet/base. If it touches the ground then it's considered on ground, and we get it's normal.
Align the players collider with the ground normal, if you don't want to visually rotate your character, create it in a separate object (or detach it when it starts) and give it a script that manages it's own rotation, by either copying the collider rotation, or doing whatever you want.
Lerp the character rotation so it doesn't snap whenever there is a change in slope.
Set the players position in the raycast hit point + the ground normal times whatever height you want.
2. Fix velocity
If you're using rigidbody forces to move your collider, within the ground sticking process, project the velocity vector towards the ground plane. Unity has a function to easily do this, where you just give the velocity and ground normal as parameters (any other engine should have a similar function).
To maintain your speed during the projection, create a temporal variable to store your speed, project the velocity, normalize it, and multiply it by the store speed. Finally make the rigidbody velocity this new created velocity vector.
Convex edge cases can be solved by making the raycast long enough until there aren't any false negatives.
As for concave cases, I made it so we shoot a raycast in the velocity direction (or the players forward direction) to check if there is a slope in front of us, making sure it isn't a wall by checking its angle and if it is a slope we can be on, project the speed on the new normal that its ahead of us (this is only necessary in games were the player goes in a variable running speed, like sonic games, in most games with set speeds this step can be skipped).
3. Air movement
For jumping, we create a function that whenever we jump, we deactivate the ground sticking by 0.2 seconds or so.
Gravity can be applied whenever we're not grounded, there is no need to apply gravity otherwise.
3. Visuals
Personally, I haven't dealt with this myself, but here's my idea.
Create a few standing animations depending on the angle of the slope (as few as two or as many as you want), and when running (detecting the rigidbody speed more than 0 or any other method) align the character rotation to the ground. The snapping to the ground normal/ to the up vector could be well hidden with a settle animation or running start frames, if it's still to noticeable. (Important in case you're making a 3D game, there's a technique called inverse kinematics to make sure that the feet are always glued to the ground).
This should work pretty well with any type of floor perspective you use.
4. Enemy behavior
The same for the enemies, if anything with less steps to fix the velocity as they don't have to be this precise. Aligning the enemies to the floor normal should fix any "floating" animations, if you're still not convinced that a big enemy would be almost sideways, just make a limit to the slope angle they'll be willing to walk on.
More as an opinion piece now, I don't think that there has to be specific cases where slope are used for them to be important, I think it still adds value to having them for the sake of versatility at the time of creating levels, like creating a difficulty curve at the time of presenting challenges (slopes can make any challenge easier or harder to beat), creating variation on environmental gameplay (like more natural environments can have more slopes, and more mechanical/urban have less), and often times not implementing them it's just going to be more workload for the level designers. Not saying that every game should have them, the point of the video still stands.
That's all, sorry for the probably bad english, not a native speaker, lol.
I love this writeup! I was thinking throughout the video that sonic games have slopes and really benefit from them. Any tricks to keep the art complexity low? For example Sonic turns into a ball shape sometimes, is that to keep art complexity low?
@@unique_twoSonic being a ball obviously makes things easier, since he's just rolling through stuff. But overall the sprites just rotate with the floor. Even in loops and such. You just have to take into account inertia and such when jumping or getting hit (enemies aren't usually near loops though).
One solution to visuals would be to use some kind of skeleton based procedural animation rather than sprites. You'd have to make that decision very early on tho
This is a really complete explanation, why nto make a documente or a video about it?
About the ground sticking, imo it depends a lot on your game mechanics. I'm thinking about games like Celeste specifically where the devs added a ton of leeway for the player when they're on a ledge. In celeste, only one of the bottom pixels of the hitbox is required to touch the ground for you to be in ground state, and you're also snapped to the ground if your vertical position is ±2 pixels off the ground. Raycasting from only the middle of your character might break things like that. Celeste doesn't use slopes however, so that solution wouldn't apply in it anyways 😅
Anyways, thank you for the good advice!
Everyone talking about Sonic, forgetting that Mario Bros 3 had full-on slope physics on the NES :D
Sonic's slopes are much more robust than SMB3's and also much, much more flexible. The SMB series is also plagued with really janky implementations that tend to feature incomplete solutions that rely specifically on the game **being mario**, and the level design being from mario.
Even in SMW, the slope code includes subroutines to physically teleport mario up and out of slopes, which calls for two tiles or mario can literally just walk through the floor and die.
@@hexidecimark lol good shit. Of course, Sonic developers got to shortcut around animation issues by rotating sprites - or literally just turning Sonic into a ball :)
@@RoboBoddicker The rotation is part of their solution- mario uses a flowchart for physics interactions and lots of teleports, sonic actually has a primordial physics engine that relies on a mixture of sonic's H shaped physics sensor grid (flips are due to either gravity variables or the middle bar of the H finding a tile under specific circumstances), a lot of different speed variables, and loading tile data in a specific way.
Implementing mario's setup would have been much simpler, but any new interactions have to be stapled onto the flowchart and get nullified under very odd short-stop conditions (coin collection is baked into collisions, but collisions can't be calculated in the same tick that a coin is collected during), then made up for by a bunch of extra flowchart that specifies rules for corrective teleportations warps to combat subpixel miscalculations.
Sonic's setup can be used in virtually any 2D environment, and this is why stages allow for so many varied gimmicks.
@@RoboBoddicker Genesis Sonic games didn't get to shortcut by rotating sprites. They had to make separate angled ones. Sonic Advance on GBA did rotate its sprites in realtime, and Sonic Rush uses 3D models.
@@npc_blob1609 Wow crazy. I just assumed they were doing sprite rotation as a fancy new 16-bit trick.
I honestly wouldn't understand a thing about NES or Genesis code to look at it, so thank you guys for schooling me :D
If I recall correctly, Castlevania Symphony of the night only used slopes in...
A. Rooms where the enemies don't interact with terrain.
B. Rooms with enemies that are specifically made to interact with slopes in specific ways. (like the dragon skulls that roll down stairs.)
And if there are any normal enemies in the rooms, they just don't go on the stairs or don't stay grounded. Clearly, even the devs of that game struggled with slopes. In fact, the entire early Castlevania series made stairs something that only the player interacts with.
I've been brainstorming and making ideas for video games for years, and only ONCE have I ever thought about slopes, and it's a boss fight where the boss is stationary and uses attacks that don't interact with terrain XD
then area of sorrow had a lot of rooms where stairs and slopes were combined for great effect on a platform with calculating power of less then half of a modern calculator
disk armor, sucubi, those rolling lion things, valkeries , dog dudes, were all used in both rooms with and without slopes
also, in sotn there ARE rooms with slopes and enemies not designed for them, but in the inverted castle, where archways turn into bowls of death etc
Seems like Metroid Dread also only uses slopes where enemies aren't touching them.
@@Russian_engineer_bmstu There's a lot of NES games with slopes, hardware that's significantly weaker than the Nintendo DS. Like Super Mario Bros 3, Castlevania series, Super C (Contra 2) and the Wizards & Warriors series for some examples.
Then you have crazy NES games like Gimmick! which includes a physics engine, but this is possible thanks to expansion hardware included in the game cartridge.
You are absolutely correct that if you don't really have a purpose for something in your game, it should be taken out. But I think a lot of the issues you are facing are due to you actually using the physics engine to do movement. In many of the games you have given as example, they only use simple collision checks and give the character a certain speed until collision says "no". Gravity would be a simple acceleration purely affecting the Y axis without any regard for slopes. A lot of the fixes you mentioned here are in fact extra steps to counteract previous steps that the physics engine did for you, that it shouldn't have been doing in the first place for your style of game. I highly recommend looking up some videos on how these classic games do movement and collision detection. It can be a huge help in creating the way the controls feel in these classic games.
Laugh-cries in Sonic-type physics
But seriously, not only am i locked into using slopes, not only do i need to fight with the engine to get accurate collision angles, i need to also build LOOPS. Aka, slopes that go completely upside down, and also switch collision layer so you can phase thru a part that was previously solid.... AND build Rails, which are all of the above, and also semi-solid relative to player rotation
The problem with trying to be faster than light is that you can only live in darkness
Honestly, from my own experience trying to make that style of game, I'd say just script the top half of the loop so if you're going above a certain speed it plays a canned animation of you going around it
@@Twisted_Logicthat sucks since jumping off a loop early to gain speed is a well known mechanic.
@@Twisted_Logic
Automation is the enemy for this project: actions MUST be able to chain their momentum into one another, and this isnt even considering how i would make rail grinding work without slope physics. And make no mistake, the PHYSICS to those rails are critical
My thoughts on a solution would be to make precisely 0 "ground" loops, and instead just make two rail loops with one using the grind animation, and the other using the run animation. For the actual rail mechanics, give the player a footbox if they don't already, and if the footbox collides with the rail it'll mount a sliding platform that inherits momentum from the player, follows the spline used for the rail, and can be dismounted with a jump or by reaching the end of the rail.
It's a little obnoxious, but it also means you can create flat rails and momentum puzzles by using the components in different ways (nothing like having spring platforms and quarter pipes to encourage fast gameplay, and ice to be hell on earth)
Getting the passing section to work will pretty much always come with some hassles and jank, but I'd probably just have the platform automatically ride any rail sufficiently close to it regardless of layer, and have it prioritise rails on the same layer over rails on a different layer, then just have the rail be on the front for the first quarter, briefly overlap with the one for the rest of the loop in the back (forcing the player into the background) then have a front layer exit from the end of the loop out about as far as the player can jump (or just have the player default to the front layer when they dismount, but that might result in some jank and clipping problems).
Sonic games are physic simulators disguising themselves as platformers lol
You're gonna hate hearing this but the "weee!" factor does make gameplay a lot more fun. It adds a kind of "flow" to movement that feels far more natural and intuitive than simple up or down movement can achieve. I was recently replaying Pitfall The Mayan Adventure for Sega CD which has slopes, and it adds a kind of dynamism to the gameplay which is a lot of fun. For one thing you can make slippery slopes which cause the player to slide down them which adds a fun platforming element. For another, it emphasizes terrain and makes it feel more lifelike. For example in the first level of Pitfall there is a small slope on the ground that allows you to double back to a slightly higher level behind you. One of the ways Pitfall often handles slopes is by putting grass or plants in front of the slope to hide the legs. This makes it seem like you're in a cave and adds a cool paralax effect. Yeah slopes are a big pain but they can also really level up a game in terms of quality.
I think that's also one of the differences of why a lot of modern indie games "feel" different than their 2D ancestors from old consoles: Indie devs often have to take shortcuts meanwhile the older games had entire dev teams and sizable production budgets. Sea of Stars for example is very colorful, but lacks the writing quality that a big budget JRPG with a full editorial staff like FF7 had. There's a level of depth and polish in many older games that lots of indie games still don't achieve, even with modern tools.
It is a slippery slope to frustration
I think the main problem for modern indie games here is an over-reliance on generic, built-in physics engines that weren't designed for 2D platforming, rather than having the gameplay programmer create bespoke physics suited to the game, similar to the development process for 16-bit titles. Mega Man X was mentioned in the video, as well as Sonic frequently in the comments, but also games like Super Mario World (or even SMB3 on the NES), Gunstar Heroes, Kirby Superstar and many other memorably used slopes to great effect without a perspective artstyle, while restricting larger or awkward enemies to areas without them.
Regarding metroidvanias specifically, I think slopes are very valuable for both enabling physically varied and distinctive level geometry as well as the ability to compress map layouts by supporting smooth bi-directional connections between rooms that aren't orthogonal to each other. In Super Metroid, the room to the left of where you get the Speed Booster, which serves as its only entrance and exit, is a good example: because the room slants diagonally upwards, the player is able to just barely escape the vertical rising lava that is triggered by obtaining the power-up merely by running directly left, immediately demonstrating the value of the new ability, something that wouldn't be possible if the transition was manged by a series of elevated ledges. On the other hand, looking at something like Hollow Knight, while that game's eventual monotonous nature is primarily due to the size of the world being too large and the low cadence of ability acquisition after the first few hours, lacking slopes is still a notable secondary issue, as their addition could have gone a considerable way to diversify level design on either a micro level or between biomes.
Thats my thought too. Bloke is creating a generic pixel art platformer #42069 and is looking for excuses to make it even more genericer.
Yeah I mean the main crux of the issue really is just the overabundance of game devs, even in the industry, who just don't know how to do things on their own. They are too comfortable relying on the tools that are fed to them. Nothing wrong with that if you're just making games for a hobby, but if you wanna make a commercial product, strap up and actually learn the necessary mathematics and computer science to understand the tiny details that make or break the game feel and performance.
it's wild that dude brings up Mega Man X (a game with an art style similar to his own) but later when talking about the art problems, only talks about Mega Man X4 a completely different art style, which a lot of people specifically dislike BECAUSE of the perspective!
Like, from an art perspective, the simplest solution feels like it would just be to make the slopes hitbox actually start a little bit offset from the art, so the sprite starts descending earlier. it'll still look jank, but that's basically how it works in MMX and my dude literally cited that as a reason to use slopes so like...
(yes, slopes also provide a complicated programming problem, but there's footage of that being solved for this project already so like...)
@@Senae I will say that making the "origin" of slope collision be the center of an object's collision is definitely trickier and has a lot more potential points of failure than just using the left/right edges, but plenty of devs have pulled it off since basically the start and it's definitely worth the effort for how much fun the result is.
I agree, and I don't think alot of modern engines are helping. Godot for instance, has a lot of ups and downs but one of the biggest issues I ran into when I tried it out is that it seems to completely reject basic attemps at pixel-based movement. Manually altering position frame by frame with the simplest code would cause some pretty crazy stutter.
The bottom line I feel is more "Always have a critical mindset about non-essential features that might cost a lot of work", than it is about slopes.
I genuinely wish I could be like that because if I have a clear idea in mind when it comes to user experience, I will work towards that goal, regardless of complications.
It is always valid to ask the question "why does this exist?"
That should be question 1, the second question should be "am I using the right tools for this job?"
If you don't need them, don't use them. If you _do_ need or want them, make sure you're using tools that facilitate that. Using a character controller designed for flat platforms only is not going to be a great time when dealing with slopes. Use a solution designed from the start to support slopes.
I've never wanted to make a game with slopes more than after watching this video
You and me both!
same. lol
It's because his reasoning is so far from the reality. It kinda upsets me a bit.
@@hiiambarney4489 how
I wonder how the folks at Moon Studios handled this issue with Ori. One of the things that stood out the most for me while playing Ori, is how fluid and beautiful it is. And it does have a lot of slopes, of different heights and angles.
Most likely, they didn't treat surfaces as dumb collision hulls. Treat it as a path. Why on earth would you do raycasts when you're on the floor? When Ori is on the ground (or climbing a wall), it's just following that path. In ori 1, I'm fairly sure Ori's just rotated to follow it too, and no floor is particularly steep, and the point where it becomes a wall is surprisingly shallow.
Ori 1 probably had to do that because, well, 2d animation. All the slopes are shallow, and really what the effect is for, is detailing its surfaces. The Ginso Tree in particular makes it super obvious, when you slide past or run over a knot in the wood. Actual physics would have Ori flung away from the wall, you know? Very nice, fantastic effect, but there's never a 45 degree slope.
Ori 2 can get away with a lot more because Ori's a 3d model, and therefore they can adjust the legs in real time, and therefore afford steeper slopes. Don't think they did, though, because, like... platforms are more fun to jump up, y'know?
If i remember correctly, Metroid Fusion and Zero Mission handled slopes by just not allowing most enemy types to enter them. Slopes were strategically placed, so it never felt odd
Yes but you forgot one crucial fact: most indie developers don't wanna have to do any proper, in depth level design :)
Metroid Fusion and more so Zero Mission also just placed stuff on the Front Layer to obfuscate any Art disparancies.
They are also MANDATORY for Metroid. (At least any Metroid with a Speed Booster Mechanic. Think about it.) Similarly, they are quite Mandatory in Games where you have a Dash, like Megaman X or ZERO. Otherwise the flow of these games are completely ruined. (Or the Rooms will appear very flat, almost amateurish)
This video was coincidentally uploaded right when I was currently struggling with slope physics for my own game (specifically how they affect acceleration), too bad they‘re absolutely integral in mine. I have no clue what to take away from this.
Hi, just curious! What type of game are you making that absolutely *needs* slopes? :o
@@fochti 3D Platformer
@@Widdy123others have solved it, so with the internet youll be able to as well. It may still be hard and take a while, like you may even have to rewrite the physics to be cleaner but i think youll be able to get it working
@@HaydenTheEeeeeeeeevilEukaryote I‘ve already figured out the acceleration part, I just gotta figure out how to stick the player to them at the right times and how they affect jumps
@@Widdy123 i wish i could do something to actually help lol, i cant even give vague advice as i myself struggle with everything coding
Alternative: make floors basically work like defined paths and link together. Players and enemies can move freely along paths, and then can break free by going aerial. Path segments are given properties that affect jumping, landing, acceleration, friction, and so on.
Adds support for stuff like curves and consequently quarter pipes and loops, perfect for Sonic style games.
And when using tile-based levels, you get those paths automatically. All that raycasting is overkill when you simply can look at the tile grid...
this reminds me of a video essay i watched about hollow knight by ceave perspective that has a segment discussing how one of the reasons such a small team was able to make a game that big was because the game doesn't have any slopes, and therefore doesn't have to worry about all these problems
Makes me wonder if Silksong will have slopes and that's why it takes them that long........huffs copium
@@T4ll4hassee nah. it's taking long because they are writing lore for it. xD
@@T4ll4hassee its because silksong is a myth
@@Juke172 These item descriptions aren't going to write themselves.
I don't think slopes would take that much to add into hollow knight. The knight's idle animation is very "straight" unlike OP's animations, where the character has the legs spread very wide, so making the knight stand on slopes wouldn't look weird. Most enemies are also confined to small areas, stationary, or fly, so there's no need for them to go on slopes (though most of them also wouldn't look too weird on slopes).
As for the physics, honestly I don't think it's as hard as OP makes it seem. You can just get the ground normal (which in godot and unity is included in the raycast results) and if it isn't pointing straight up then you know it's a slope. You can also use the normal to rotate the movement vector according to the slope angle, so that movement is consistent. And it's pretty easy to just disable the gravity when the player is on the ground, and then turn it back on when the player is jumping.
The real root issue is using physics-based movement in a game where you don't want your player to effectively be a ball that rolls around. I'm exaggerating a bit for comedic effect but that's essentially it: if you want physics, momentum, etc... use the physics system to move around, but if you want a snappy platformer you're better off handling things yourself.
Yes
What you're describing is rigid bodies, which have simulated physics. But physics isn't just that, even a controller character will usually use built-in physics systems. If you don't, you'll need to code all manner of basic things like collisions on your own, and that sucks. And if you do code them yourself, guess where most of your time will go? Handling slopes.
@MewPurPur My bad, I tend to misuse words like physics system to talk about rigid bodies and friends out of habit, but it's true that that would include collision detection.
Actually, it makes physical sense to move up a slope more slowly and down a slope more quickly. So that isn't really something you necessarily have to "fix". And that somewhat mitigates the edge guarding problem you were talking about.
Yeah but it doesn’t feel “right” gameplay-wise.
@@n3ppy632 probably because I think most people wouldn't expend constant effort in a similar situation so it feels floaty or unresponsive. Still I think it could feel fine if you make the effect more subtle. Especially if your movement system has momentum.
@@n3ppy632 depends on a game.. for exampe... didn't sonic have this slow down when going up and higher speed when going down (didn't matter if you were ball or still running)? or am i just remembering this incorrectly. Also iirc super mario bros 3 also slowed mario down when running uphill a slope (1st world had few stages that had them... after that iirc it was mostly used in cave levels and pipe shortcut mid-sections and iirc people mostly wanted to just spam jump when going up.. so yes it didn't feel good to go up but going down... there were 2 options: either you kept running which i think accelerates you faster or if you crouch in slope you actually slide down and most enemy types are deleted). Sonic especially didn't suffer from having sloped affecting your moving physics. Mario maybe did but the levels were created in ways that allowed players to have fun with them (there were enemies often near bottom of these longer slopes and sliding on them to knock em out was entertaining).
It is all about how you design the levels and physics around the whole game. I do agree that some games would suffer from these as going up especially might not feel good if it is slow. But also it is totally possible to make slopes have purpose.
Yeah, this is true! However, the math I did to "fix" it actually just lessened the impact of the slopes. You still moved a little faster down the slope, and a little faster up the slope - based on the angle of the slope. The default physics was just /too much/ of an effect, which made it feel super weird to play!
@InboundShovel I feel like this is maybe an important lesson? It's a lot of work to make slopes behave like normal platforms... and the reward is that slopes are now normal platforms.
All the cool stuff you can do with slopes is because they're different from flat platforms: ice slopes, launch ramps, rail grinding, loop-de-loops, momentum conservation during elevation changes, pendulum enemies that hug the ground, etc.
Don't spend all the time to make slopes the same when you could be spending time to make them different.
2:55 It doesn't seem like it's necessarily an issue that the characters go uphill slower and downhill faster, right? This is totally a reasonable physics model that could be more a feature than a bug.
I love slopes, if you can build momentum of it as a player or as an enemy/obstacle. It also means that it always serves a purpose, the physics are temporary, enemies only use them if designed for them, and the rest is worth it if it is a real game essential mechanic.
3:10 No good?.. This is how slopes are _expected_ to work :D
0:36 Now let's see Paul Allen's slope
Slopes are literally the reason why I had to change almost everything about my character, the physics, controls, and interactions. Either way I like slops and I'll try to fix everything with it.
I think the importance of slopes depends heavily on the movement of your player character. In Isadora's Edge, it looks like the movement abilities are more on the rigid and precise side end of the spectrum, rather than being flowy and momentum-based. A game like Sonic, for example, couldn't (and shouldn't) exist without slopes as they're fundamental to how the character moves - whereas Hollow Knight loses practically nothing from excluding them. In my case, I've decided to use them - albeit sparingly - and just compensate for any strange interactions as they come, since the game has no combat and is focused on speed and fluidity.
Great video! Isadora's Edge went straight on my wishlist when the Steam page went live.
Thank you so much - and I completely agree with your analysis!
I'd rather spend time focusing on the combat and other precise movement mechanics, in the same vein as Hollow Knight, rather than momentum maintenance gameplay a la Sonic! :D
7:25
What if *fat* enemies just refuse slopes, because they're fat, and lacking stamina, and would tumble down a slope.
This is issue only if you have very little to no experience in programming and solving platformer physics problems.
You can have the slopes if you WANT to have the slopes. But there's no turn key solution to it, you must study more programming and basic platforming physics from SNES and SEGA mega-drive days to figure out what you can do with very little processing power...
I like your point about there being no turn key solution. It is very hard to tell what problems are simple and have a generic solution, and which problems' solutions depend sensitively on what you are trying to achieve. You really need experience to recognise that it's okay to develop solutions from scratch for things that seem like they should have an easy solution for how trivial it is.
I imagine with more beginner-friendly game engines like Godot, people are less likely to recognise where they need to put in that effort? Like in this video, there seems to be an underlying assumption that the physics should never be turned off.
@@sploofmcsterra4786 Exactly.
I know exactly why he likes slopes, he played super Metroid and shinesparking after running down that one slope near the start of crateria was probably a core memory
Any Metroid game with a Speed-Booster in it (Shinesparking or not) NEEDS SLOPES.
Similarly, any game which has a Ground Dash (Like Megaman X or ZERO) NEEDS SLOPES. Play them, every time you encounter a slope, think about "what would it have been like if this game didn't have slopes now" and you quickly come to the conclusion that they are not just visual... They are inherently necessary for the gameplay to flow anywhere near as well as it does. Sonic is another good example. Smooth horizontal gameplay that is fun to traverse will always include slopes.
Or super flat and boring level design.
Chrono Trigger uses multiple different perspectives. Most of the time it's a 3/4 perspective that has wide slopes for characters to walk up and down. But there are some areas with side-on perspective and a slope, and they just have a small foreground wall that covers the characters' feet to deal with the issue of feet not touching the ground on a slope.
Another common option for solving the slope problem is by adding some kind of foreground noise to hide part of the character's feet, which makes it easier. Like foliage, fencing, railing, trees. etc
This can also be combined by animations that sink the character into the ground slightly. which extends how much room you have to work with before it reaches into the ground. Which makes senes for some character anyway because they're really heavy, and standing on mud...
5:13 is game developing in one sentence
I think even if it doesnt add to the challenge, it adds to the appeal of the level, not only aesthetically but bc it makes the level feel more natural
Game Engines hate slopes, but you don't. Most people use game engines because they just don't know how the math works. Making the math yourself is crutial, Sonic the Hedgehog for example has 6 hitboxes fixed in a axis with a maximum distance from the pivot. The genesis games had the slope data integrated in the tiles, but in a modern enviroment there are ways to calculate the angle of the floor using atan2. Also for the art problem: just rotate the whole damn thang. The genesis games did actually have the rotated sprites baked, there are some issues with wider characters such as one feet having to be in a different angle.
Another genius spotted. Can you teach us how to "make" the math?
@@lyraisnappingI hope you're not being sarcastic, because they know what they're talking about. If you're a game dev, you should really have a more open mind to other ways of doing things than relying on a default physics engine.
A lot of the physics concerns seem to come from having a system designed around flat floors and walls and trying to shoe-horn slopes into that system, rather than building the system with slopes in mind from the start. The collision logic should either be based around detecting floors, walls, ceilings, and slopes all as first-class categories of environment collision with their own logic for each of them, or based around a pure physics simulation of interacting appropriately with the normal vector of a generic surface.
The easiest solution to the art problem is probably to tweak the collision. The Mario Maker 2 approach works well. When placing an object on a slope, you don't use the corners of its hitbox, because then it conspicuously juts out into the air. Instead use the center of the bottom edge of the hitbox. The object will still jut out slightly into the air, and also overlap slightly into the slope, but the severity of both effects is cut in half. And, up to a point, the overlap with the slope will read to the eye very similarly to the perspective style tileset, even without actually using such a tileset.
That will surely introduce some headaches with getting collision to still work well with ledges and with transitions between slopes and flat floors, but that's definitely a solvable problem. For example, check for flat floors below the corners of the hitbox and check for a slope below the center of the hitbox, and make the slope the higher priority unless it's too far below a floor you detected. Something like that will allow you to stand on a ledge all the way to the corner of the hitbox, and still have smooth transitions when running along floors and slopes.
The level design question is interesting. Certainly not every game needs slopes, but there are a number of ways they can be useful. Consider an enemy that fires simple horizontal projectiles. On a floor, there's no vertical distance to worry about, and you can easily jump over the projectiles as you close the horizontal distance. If the enemy is on a ledge, you can safely close the horizontal distance while the projectiles pass overhead, then jump and attack the enemy in between shots. But if the enemy is on a slope, you get an extra challenge. The shots are higher than usual, so it's difficult or impossible to jump over them, but at the same time you can't close the horizontal distance to the enemy without crossing through the line of fire. A situation like that forces the player to more aggressively take advantage of the gaps between shots. You might get a similar effect by putting the enemy on a staircase, but then the player's interaction with that terrain is very different.
Slopes are also useful for controlling elevation of any objects or enemies that are based on moving along floors but not walls. Consider again the case of the horizontal-firing enemy above the player on a slope. You can add more pressure to that situation if there are ground-patrolling enemies coming from behind. Those enemies can climb the slope to put pressure on the player, but they wouldn't be able to climb a staircase. Or if the player has projectiles that roll or slide along the ground, like Mario throwing a koopa shell, then slopes create situations where those options are still useful against elevated enemies.
Slopes can also just be another variety of terrain with different physics that the player has to account for. Just like slippery floors or sticky floors force the player to adapt to the physics being different, slopes can force the player to adapt to moving more easily in one direction than the other. The 'bug' you fixed with the player moving faster downhill and slower uphill doesn't strike me as a bug at all. That's a perfectly natural representation of the fact that running uphill is hard and running downhill is easy, and gives the player one more thing to think about when fighting on a slope.
Sonic fangame developers sweating profusely
My heart goes out to all the Sonic developers
It's not that bad 😭
To be frank most of sonic fangames are either using modded engines specifically made for sonic games or just are straight romhacks. So slope physics is a problem already being dealt with.
@@LockMatch Alternatively, there is a guide out there so all of classic Sonic's physics, so slopes aren't particularly troubling unless you aren't attempting to get an exact replica of the original physics, which can be easier for somethings but harder for others (e.g slopes).
Just wanted to make an edit to the editor. At 9:06, he puts up a note about z-index and z-axis.
Both are valid terms. As a matter of fact, when programming layers for webpages, I would often use CSS's z-index property.
i love when a developer or musician just dumps information about their projects. I barely understand it but I love their excitement.
I personally really love games that make full use of the terrain with unique abilities. Case in point: The Speed Booster and Shinespark in Metroid games. Where you can either use them to rocket yourself at high speeds or to save a Shinespark charge for crazy puzzles/shortcuts.
Slopes, I think are mostly an artistic tool. You mentioned Megaman as an example, but I also bring up: Rayman - the first one. The game has slopes everywhere and it's considered one of the hardest PS1 games. One thing they do with the slopes in the game is add rolling balls and falling enemies but also make them slippery sometimes which makes physics work against you. But like said: almost every floor in the game meanders like 10-15 degree slopes. Level floors are reserved in the game.
3:05 You're right it doesnt feel good, but its more realistic :D
I actually hate navigating through most of Hollow Knight's world because *everything is a staircase.* creating challenges aren't the only use case for slopes, for sure. Just making the world less tedious to navigate is nice.
(Hope this doesn't come off as me telling you you're somehow wrong for taking out slopes or something, just wanted to throw my two cents onto that specific part since HK was brought up.)
That's actually a super insightful point, and it makes me think that there is potentially a stronger use case for slopes in Metroidvanias - or any game where exploration and backtracking is present, just to make the world nicer to navigate!
I'm planning on having linear, level-based gameplay in Isadora's Edge, so hopefully that mitigates the issue, but it's actually a great point to bring up! :D
The laugh just disconnects him temporarily from a human to an awkward 90s NPC, than his soul zaps back to his body when he gets his composure back.
They're even buggy in geometry dash, where your horizontal movement is fixed. I still use them in my levels though, every time. Such fun gameplay if you can get it right.
16:33 Interesting, I've never felt any need to put a slope in my game, but now I want to add slopes to something just for the sake of it, one easy answer for the art problem is to make the character a blob which will look about the same no matter what they walk on. In the current game I'm working on it will actually be an interesting challenge just to render the slope itself because of the constraints of my 3d engine I made.
As someone making my own 2d action platformer, can confirm all of that's true. In my case I had to make a convoluted system to make tile-based collisions possible to begin with, then slope physics for just the player. Enemies get left out of this bc the system doesn't transfer to their varied sizes well. The result of this so far is that enemies can show up NEAR sloped areas, but they'll likely be enemies who either move only on nearby flat ground, don't move at all, or are enemies who float in the air.
So why slopes in my game? They actually trigger a high speed state for the player that lets them one-shot enemies. In some places, this is used to increase the stakes for a level section because if you get hit, you lose out on that momentum and now have to play out that section at default speed (invoking a kind of "perfect player syndrome" motivating you to do better). They also make levels look more varied. Also, my player character is so comprehensively ridiculous in terms of movement mechanics that the high speed mode ironically can add difficulty instead of removing it. But "fun and jank" is exactly the kind of thing I'm going for so I don't at all mind the challenges that the slopes brought for me personally.
Can also confirm I'm a solo dev.
Wario Land 2 uses slopes. Smash Bros uses slopes. So the moral of the story is, have a use case, which is mostly platformer or puzzle related
Yay, Wario Land 2 mention!
Doesn’t pizza tower have slopes too?
@@NimArchivesYT Refer to Wario Land 2+. Basically they are used for rolling, and even in Super Mario World for running up walls. Specifically, Wario Land is known for hiding secrets, and unlocking or just using rolling down slopes can allow you to break small blocks in succession and find treasure in places nothing else can.
@@ArtisanAspirationWorks Thank you
The art issues with slopes are way easier to handle in 3d
lol, slopes
slopes basically turned my little prototype into a game actually worth developing.
i definitely have spent a lot of time getting it all tuned right, including an entire rewrite to swap from raycasts to boxcasts. i didn't have any enemies walking around for a good while (since they didn't really mesh with the game concept well), but when i did finally have to implement ground detection for non-player objects, i basically took all of my player ground detection code and put it into a new class. now all of the non-player objects easily snap to ground, account for checking walls vs slopes, etc.
also- one thing i found useful for determining if there's a slope below the player is to actually raycast under the front of the player, horizontally inward. that way you can check if there's a slope of any steepness below the player, without using a really long raycast.
as for art, i'm a pixel perfect kinda person so i decided to opt for rotating sprites into that crunchy pixel weirdness that you'd get on the GBA. the pixel art emphasizes shapes over outlines most of the time anyways, so it's not too bad. for the most part, we try to reserve rotation for either pure shapes or for sprites that are constantly in motion. it helps mask that weirdness a bit.
having a penguin sliding on a slope (~32x16px; a short / wide collider) did look weird even after rotating the sprite, so the sprite is offset towards the ground when the penguin is grounded.
the 16x32px (tall / skinny) grounded idle animation is also rotated and offset, but not as much- it turned out to be important for conveying the penguin's jump direction, since the jump force is always pointed perpendicularly from the ground.
with the level design side, slopes always became a way to go fast, preserve momentum, take cool shortcuts, and accentuate cool jumps. slopes aren't always useful when designing levels, but they help accentuate what makes my game unique.
if i were in your level designing situation, i'd probably ask myself if there were any unique interactions you could have with slopes. since slopes are difficult and thus less common in indie games, it'd probably be worth it to spend some time jusifying them mechanically. maybe there could be a mole that pops out of the ground, but always perpendicular to the surface- so the spot that the mole is buried in is important. especially if it were inside a wall!
of course, i'd also avoid using any enemies / mechanics that don't play well with slopes in a slopey area. ronktonk would be a no-go for example, but there'd be plenty of other areas where it could shine.
but aside from aesthetic / uniqueness, i'm not sure if, i were in your shoes, if i'd continue work on slopes. it takes a lot of discipline to say no to something you really want, after all. this is a good vid and you present your reasoning very well.
slopes aren't easy, and they're not beneficial for every game, but the different development needs and solutions for a genre as narrow as 2d pixel art platformers is interesting!
I hate working with slopes, but in the end it's all about the game. When you as a dev want to include them you have to check if you just want them because they are cool, or does the game benefit enough from slopes to justify all the crap you as a dev have to endure :D
Thanks to your comment I just checked out your channel and with that, your game :) I looks cute and fun, it reminds me kinda Sonic (but not completely), and slopes there seems like they are actually a core mechanic - but that seems more like an exception than the rule :D
Now I really wanna make a sidescroller game that just has a siingle slope in it where there are no enemies. But at the top of the slop, is a sign that says "Why is this the only ramp in this world?"
You are spot on. Slopes are definitely a “feature” with extra costs that may not be worth it.
You haven’t mentioned one possible art solution, provided you aren’t going for pixel art purism: tilting. The character can be angled so their up is perpendicular to the floor normal, so the wide ememy is simply rotated a bit. As you say, there are always more issues, e.g. smooth rotation on jumps and at slope beginnings and ends.
That's how I did it in games I made with GODOT. Simply rotate the sprite image around the surface normal. It actually works pretty well, but GODOT has many physics problems that make using slopes an absolute inconsistent nightmare. The bad normal reads was an absolute deal breaker for me. You can't create consistentency from an inconsistent foundation!
I think that most of the issues related to physics are more related to how you are currently dealing with the movement. For instance, I'd recommend using test_motion() instead of raycasting to find cliffs and use is_on_wall() instead of raycasts to check for walls.
As for art, yeah these are actual issues. Most of them we can just say that it's kinda standard issues and players are usually OK with them, but they are really annoying.
And for level design, I think you will find out as a fellow Mega-Man X fan, that slopes do make a lot of difference and open up for tons of possibilities.
For instance, you showed this tree-like enemy, the wide one, in a 'pit-like" design, where the player would be bellow it, player would be able to just do air attacks and hit it without taking any damage, I can imagine the attack patterns of this enemy and I can't think of one that hits below its feet. Every time you have a cliff or pit where this monster is used as a challenge for the player to move through, players can hit them from below. And the other way around is also true. I don't know if Isadora has an attack that angles top-buttom(like Zero's Crescent Sword or Quake Blazer in MMX5) but if this is not the case, Isadora will always be in disadvange when coming from a cliff to a lower segment of the level.
With slopes you even this out. Not to account for vehicles or rides. For instance, if you want to add a "platform enemy", let's say a mushroom that Isadora can use its head as platform and be carried through spikes or other terrains or hazards, you will have a bad time implementing jump for this enemy, where with slopes you can just keep it moving.
Vahicles as a good use case for slopes as well, think about Mega-Man X's Ride Chasers, I hate the fact that you can jump with them, this makes no sense to me. But if you think about them TAKING ADVANTAGE of slopes main issues(when you are not snapped your vertical and horizontal velocity sum up making you hop when coming from a slope to a flat ground) you can make very fun stuff like the pit jump we make in Mega-Man X2 Overdrive Ostrich stage which is epic. There are some of these jumps in Mega-Man X5 Squid Adler stage as well.
Not to account for push-pull physics puzzles where you can push/pull objects like crates or rocks. With slopes you can have changes in terrain height, without them you will either push them through a cliff with no option to move it back or you can't move it pass a wall.
So I can think about many good use cases for slopes regarding level design.
It is CRAZY to me that you still don't have a Checkmark. You are a staple within the Godot Community and your comment is BRUTALLY buried here, even though one of the most informal ones I've encountered!
@@hiiambarney4489 I'm clearly doing something wrong 😂
So a few thoughts on this:
1. A player/sprite doesn't need to stay at the same speed when moving up/down a slope becuase thats not how they work in real life.
2. Seems odd that you designed it so you character is locked to the slope at all time, wouldn't you be better just doing that when you actively no they are a) in the air and b) moving down?
3. Sonic Physics Guide has really good logic for how to handle small steps, slopes, curved floors etc. Sure its more work BUT its really valuable knowing how this stuff used to have been done.
4. You can account for the floating feet issue but having the visual slope and the collision slope not being the same thing. Or offset the player on slopes so they're partly in the ground. I personally think worrying about the visual realism of pixel art is maybe a step too far in this regard.
5. You're trying to find a level design use case, but why does it seemingly always involve you having an enemy at the top of a slope? Sometimes navigation alone IS the use case. Blocky tunnels for example, aren't as natural as sloped tunnels so its one of the use cases in my game is so environments look more organic. Level design isn't all about mechanics it can also be about aesthetics.
Interesting video though. Haven't seen too many people debating why you should/shouldn't use slopes. Most just explain how.
1. This is a video game, not real life. If he wants the ground control to feel a certain way, there is probably a reason why.
2. This can be exceedingly complicated depending on how collisions are handled. "When you're moving down" varies a lot between engines and methods of checking collisions. Think about when you're traversing up a slope; your vertical speed is technically moving you upwards. There are also just circumstances where you could collide with a slope while not moving down if your horizontal speed is high enough.
3. Sonic physics are well-known for being unique to Sonic games. The way they calculate movement is designed around maintaining momentum even at 90 degree angles, and it's completely different from how this game seems to play.
4. Both of these solutions are still just compromises that he didn't want to make on top of everything else. It would look especially odd in this game since the character has such a wide stance.
Yeah I didn't really understand why specifically that giant tree dudes gotta be walking up and down slopes
I also felt like I missed something with the calculations but I figure that's the actual fun part of game dev tbh
Further down someone shared the very interesting use case of allowing grounded enemies to threaten the player while approaching from lower ground
@@m0ng00se4 Slopes physics are complicated I'd never argue that thats not true. Understanding them can help a lot and I'd recommend working with them to come to the conclusion he did. Once you know you know. In my eyes all practise does contribute to the whole.
As he said, slopes can be quite good if the gameplay is designed around it, e.g. Wario Land 4 allowing you to roll under blocks is a great mechanic for example. Adds a level of puzzle platforming of sorts.
Rolling enemies that are specifically designed to roll up and down slopes can also be a fun enemy to tackle. Though I agree that if he's striving for more realistic pixel art design walking enemies require additional work.
I personally would strive for slopes because it makes levels feel more naturally organic than blocky terrain. There's a fine line though, especially if you're using tiles rather than objects because it requires a bit more work to make extremely organic terrain. But adding a slope here and there into an otherwise blocky world can be good. But again it depends on the dev and the scope of the project. Hollow Knight avoided slopes but they compensated for that with a LOT of naturally shaped art assets for walls and do in fact have ceiling slopes in the game.
@@neonswift I mean hollow knight has no slopes amd it's worls still feels organic? I don't see how just not having slopes becomes such a deal breaker
@@ДюсековИльясYou don't? I have been making a Metroidvania for 2 years now, and before I even made a single asset, I had decided slopes were essential during the planning phase. Slopes are fun, look good, and good games actually utilize them for various movement mechanics. You couldn't think of that? I thought Hollow Knight wasn't good.
Solutions from old that might help
Slope: make it very tiny blocks that are one pixel big
Interacting and movement: use an auto-jump like mechanic like minecraft has but purely for those tiny pixels
Or just have it so that your character doesn’t move sideways unless you explicitly make the action to do so
Legs: cut the sprite in half and have it be two (or more) sprites in reality so you only have to edit the legs
Perspective: maybe tilt the sprite to accommodate for the slope
Fake perspective: just don’t
12:00 It’s over, he has the high ground
Level design: they look nice
and maybe for the traps have it be a rolling Boulder (or something similar) that speeds up when going down
0:08 No, I'm leaving
Please leave and never come back
Ok, farewell.
Never wrote physics for a 2d game, but what stops you from trying this?
1. Calculate new position after moving and check character collision.
2. If the position collides with terrain, snap character to first empty point above the terrain, only if the height difference between last position and current position is below a reasonable treshhold.
3. If that's not the case (you've likely collided with a wall), keep the last position of the character.
Good thing I stumbled across this video when I did. I’m working on a platformer game myself but it’s *extremely* early in development so I don’t have to worry about taking slopes out of the game because I haven’t added any yet. You saved me a great deal of annoyance!
Same (not a platformer exactly but still 2D), thanks @InboundShovel
Haha, glad I could help!
I stay away from any long Metroidvanias/platformers without slopes. They feel cheap.
@@CrAzYpotpieWhat a weird thing to do
@@internetguy7319 How is me staying away from games I don't find enjoyable a "weird thing to do?"
2:53 I think you should've keep speed change in a slope. It's realistic. Also horizontal speed can be made as a bonus to the melee damage.
I think a good example of a game which needs slope are the Sonic games, because it's the only way to gain height without losing your buildup speed, or even helping to get that speed when it's a downward slope. Aside from that exemple, yeah, you're right, slope don't deserve that much work, espacially when you are indie
Oh yeah, you're totally right! A super momentum-based movement platformer would absolutely /need/ slopes, lmao
You're right, and also you made me think of something else, I'm a huge metroid fan and in super metroid you get the speed booster ability, and yeah now that I think about it, this ability is the main reason slopes are in the game, so samus can run through walls and across many screens without stopping, and if we add the shine spark ability, it makes more sense.
I think slopes do add a lot to games, like how in Mario games they're a primary way to gain momentum faster than your run.
There's a nice series of videos on RUclips where someone recreates Super Mario World in Godot. They talk about ground collision and slopes, how it's handled in SMW and what the best solution usually is for modern engines. Definitely worth a look!
6:48 just make different tilted sprites for the legs depending on the angle of the slope, like sonic
In the Mario Maker troll-level community, slopes are well known for being one of the jankiest elements in the game, right under clown cars. And if you see both of them close together, you know there's gonna be some "unexpected fun" happening.
The speedrunning community in general seems to agree that slopes never really work quite as expected in almost all games that have them. They quite often have some specific glitches associated with them. This goes for indie games just as much as big budget games like the Mario series.
Slopes, clown cars, and broken tracks. tons of contraptions use these a lot
There was also a broken mechanic where sideways Thwomps would slide up slopes they approached.
This was later patched, so now they just stop if they reach a slope.
Certain course elements, like pipes and bill blasters, also just can’t be placed on slopes without looking janky, because the game doesn’t know to connect them.
Dude, I LOVE your content. I feel like it can be hard to find well-presented, digestible game-dev content -and you are checking that box phenomenally.
1:12 missed opportunity to say “slopamine”
I actually REALLY appreciate you talking about this. It's such a small niche that no one pays much mind on, but I feel better about myself knowing that other people have encountered the same design issues.
I agree that you should only add slopes if they enhance the design of the game, and that in your game they don't really. but they do enhance a lot of games where the movement has more momentum and acceleration unlike Hollow Knight and more like Sonic and Mario. there slopes can make it hard to get momentum when going up a slope and allow you to gain a lot of momentum when going down a slope so that you'll be able to make larger jumps.
I love game dev content like this that dig into the meaty details of overlooked aspects of how a game is put together.
Slopes are "shockingly difficult for indie game devs" because most indie game devs rely on default game engine implementations of collision physics, however barebones or thorough those individual engines may have them, instead of making genuine efforts to spec the necessary math of what they want then implement it themselves. Platformers like Super Mario Bros 3 and Super Contra/Super C on the NES had slopes with 8x8 pixel tiles and 6502 assembly; Super Mario World, Contra 3, the Mega Man X trilogy, etc on the SNES had slopes with 65c816 assembly; the Sonic the Hedgehog trilogy/quadrilogy, Capcom's Strider (ported by Sega), Konami's Rocket Knight Adventures and Sparkster, among others, had slopes on the Sega Genesis with Motorola 68000 assembly and/or Zilog Z80 assembly. This isn't even taking into account arcade games of the time or Neo-Geo! These games often had programming teams of less than ten people, usually less than _five_ people, sometimes even just one or two, but they planned their calculations and knew what they wanted to get before putting in the work to do it.
There are articles detailing reverse engineering of slopes in games like Mega Man X, Sonic, etc. I know they exist because I myself read them almost two decades ago when I was more hardcore into learning game dev with engines like RPG Maker and eventually branching out into other stuff long before Godot was a thing. On or before 2004, using the free open-source engine Sphere (which uses JavaScript for its scripting language and is still around, BTW) I had found a tech demo "Die Seesternkönigstochter" (basically "The Starfish Princess") by user SDHawk, a Sonic knockoff where you roll around on hilly terrain as a starfish). Sometime on or before 2009, Sphere user Kamatsu (IRL an Aussie computer science professor who also briefly worked at Google for a time) made a tech demo that recreated the basic slopes _and_ destruction physics of the Worms games. I myself was even making tech demos of things like 3D block-based map makers with basic rotation (before I even learned the proper matrix math for software-based 3D projection and rotation) as early as 2005 before Minecraft was even a thing. All of it using JavaScript, because that's what Sphere offered/still offers us as the scripting language and what drew us/still draws us to the engine.
In short, slopes are "shockingly difficult for indie game devs" literally because "skill issue."
Tools allow devs to muddle through without knowing math, ergo you see more devs who don't know/like math
Kinda straightforward development if you think about it, there's a lot of fairly short answers (that make intuitive sense and I've seen some work in unity2d personally) from people who understand vector math intuitively while OP is clearly not prepared for that kind of answer so, I dunno let him make his stairs
Personally I wouldn't want to use a regular '2d rigid body' for a character in a 2D game like in the video anyway except temporarily (say they are being affected by knockback).
I'd want full control over their movement, because otherwise you run into a lot of issues with stuff like ladders as well. Same with enemies with special movement types, e.g. spiders that climb on walls/ceilings, or enemies that can sometimes dig through the level.
wow aren't you lovely. Show us your game bud let us see how you solve problems with your massive skill set.
@@lyraisnapping Apollolux seems to know their stuff and even goes out of their way to source it. I don't see a reason for your scepticism.
Their attitude is perhaps a bit aggressive with calling it a skill-issue, but honestly, that barely qualifies an banter at the studios I've worked at. ^_^;;
In other words the price of _reducing_ the barrier of entry is having a *reduced* barrier of entry.
3:01 have you ever tried climbing a mountain or running down a hill?
I love seeing slopes, I hate using slopes
You nailed it perfectly, I can't think of a better summary of how I feel about slopes lmao
You make a compelling argument, but I would counter with -- "Wheeee!!!"
In my opinion, it completely depends on what type of platformer you’re making, if it’s a combat based, skill based platformer (which is what I’m assuming Isadora is) then yeah, slopes aren’t needed. They just add unnecessary complications.
If it’s a fast spaced platformer where the goal is to move fast, it it’s a puzzle platformer where the difficulty isn’t really in the platforming, then slopes can really help.
It really depends on the rest of the design. If the player or enemies have attacks that interact with slopes in fun/intersting ways then they're worthwhile. It seems in his case they were kind of an afterthought, so there was no real damage in removing them.
Meele-Combat Based Platformers would warrant Slopes imo.
Because you have to design around high elevation Changes with attacks for that purpose or the player will be ill-equipped to handle the situation.
Balancing this can be an issue though. Because a move that is reserved for combatting foes on a high ground could potentially lead to way to easy engagements with other foes.
Totally a valid decision to simplify your features.
Just wanted to throw this here for any devs looking to have rudimentary slopes. In Godot you can use SeperationRayShape2D instead of a box collider. These can be used as a simple way to handle slopes. Use vertical SeperationRays to define the height at which the character stands, and then add a horizontal SeperationRay above the base of the character. This way the horizontal ray misses low or sloped objects and the vertical ray places your character to the top. This will allow the character to step onto low objects or up gentle slopes.
one solution to cut down on art time for some sprites is to have a top and bottom parts of the sprite that can be swapped out, leg poses can be on a separate object that can be specifically programmed to handle any leg pose, while leaving the upper body for the more adventurous animations
It's in another video, but he already has this exact system implemented to handle attack animations when moving vs idle. I'm assuming he didn't mention it here since it doesn't really help with the major problem that he still has to *make* all of those unique sloped leg sprites which adds to the workload
Bro I'm just procedurally animating everything cos I suck at art 😂
Extremely entertaining and informative, but my like and subscribe were due to your personality. I just couldn't stop smiling through the whole thing!
Thank you so much! :D
Slopes are good for a few things from a gameplay perspective. 1) Momentum based movement. When you need the world to have physics that affect your player character, slopes add nuance to maintaining speed, overcoming challenges at forced variations of speed, etc. 2) they're good for slope specific challenges, such as the gun challenge you showed, but also things like charging enemies, since the change in elevation can make the challenge easier or harder for the player, since you have more or less space to get over the enemy depending on the slope. 3) slopes can be good for limited combat options. With wide, sweeping attacks, they're mostly just free kills. Your enemies may actually have more advantage from below you. Contrary to popular belief, having the low ground is often better for melee combat irl due to most people striking at chest level, so someone uphill is forced to strike downward at the enemies head, whereas the down slope enemy can strike your legs, which are already an open target due to footing, and your midsection, which is one of the widest spots on people that isn't usually fully guarded by a normal stance. This can be translated into gameplay with your default attacks not hitting low. This can be used to force the player into purposefully awkward or unfavorable combat situations. You can also have the enemies launch attacks perfectly down the hill that could throw off the player, or bouncing attacks down the hill could be threatening.
These are just a few ideas. They aren't necessary, but hope they're some interesting ideas for you for next time you want to approach slopes with a game. Sometimes you just need a different perspective
Neat that you mention the irl combat example.
This is exactly why we learned in Karate (or the specific subset of Karate that I was trained in) to have a very stable, very, very low stance.
@@hiiambarney4489 Yeah, I watched a shadiversity video where they practiced sword fighting on hills, it was fun and I always remember it whenever I hear people mentioning the high ground. High ground only really helps with projectile weapons
2:09 "Just snap the player to the floor"
Why not just add friction?
Gosh, slopes are some of the hardest things to work with when doing game development; even with built in help like with the Kinematicbody node in Godot or the "Platform" behavior in G-Develop. Because, once you change your platform at even ONE angle different from its original point, it could change how EVERYTHING in that scene block works when the character interacts with it and either it works correctly, or it becomes a mess. It's worse when slopes and other things in the scene depend on each other. And if you're using Godot, the Godot engine doesn't have an "undo" button and "Control Z" does always work!
My guy definitely has the laughs of somebody who just had to scrap a LOT of hours of work
1. Physics: Part of game programming is making your code more robust to deal with new elements you introduce like "slopes", breaking things is part of development.
2. Art: That is the cost of adding new elements to your games, more work is inevitable if you want more features, but it becomes a more robust base game because of it, which if you're looking to make sequels or continue development on releasing feature patches for a long period of time its totally worth it.
3. Level Design: It sounds like you weren't using slopes for what they're strong at, you're forcing them into situations you didn't need them. For example look at "Ori and the blind forest" it uses slopes incredibly well, boulders roll down towards you, certain enemies can roll after you and will speed up because of the slope downwards and even ramp up and over hills, all these new situations add to the gameplay because of it. You just didn't bother adding or lacked the vision to add the additional programming needed in your game to support and make use of the ramps to add to your base gameplay.
And don't get me wrong you're right that features need to be cut as a solo dev, as you don't have the manpower or time to add everything you possibly want into the game, that's what sequels or feature updates are great for, but I think you're painting intricate features as something not to bother with as a solo dev and I think that limits the imagination and determination of a game design and developer
100% this.
I mean.... His game is not Ori. It seems like it's more of a megaman game. And in mega man you simply NEVER need slopes. It's a precision based fight platformer. Slopes are useless for his project. He's not making a Sonic game where alopes are essential, so why bother with slopes. That basically invalidates all your points
@@ДюсековИльяс re-read the comment
@@ДюсековИльяс I understand his game is not ori, I was using it as an example of how slopes CAN be integrated into the gameplay and actually have use,
rather than trying to convince the audience they objectively have no use, it all comes down to writing the code to support its use, prototyping and figuring out the fun in the interaction.
And to use your own point against you, his game is not megaman either, its whatever game he decides to create,
the systems and elements of a game makes a game whatever it wants to be.
@@Krahfty he himself said he wanted to create a hollow knight, megaman-esque game. Slopes only have a reason to be in a 2d game if your game is about fast movement and platforming. Like Sonic
Dude, thanks for your video. I'm actually doing research on slopes right now (for a game in which they would be an essential component). While watching I remembered the game Iconoclasts having slopes and went to look at it. It actually has a ton of sloped and curved terrain throughout. Im going to take some time and do a more thorough look at how they solved the problems you layed out here. They had some really neat traversal mechanics as well.
Just getting started on my first game and this was really informative. Also this gave me an idea for a slope based mechanic that I have to try ^^
the editor whoever he is had fun with the physics part
Anyone who knows "slopes" by their true, mathematical name, "gradients" will not be as surprised by the complexity, but DAMN! Did you make it a worthwhile journey. Nice vid, bruh!
huh, one thing to do is just turn off gravity when grounded, after all you don't need gravity if you're on the ground, so only when airborne do you need gravity.
oh yeah the rest of those issues are a pain.
I don't get what this is supposed to fix?
@@poleve5409 the issue where gravity was effecting the speed up and down slopes. tho you do need to add a system where 'forward' is changed to be perpendicular to the normal of the ground, which means getting said normal, so that you don't come off the ground every time you go down a slope.
ok maybe this method is a bit complicated, but to get the speed consistent on slopes you'd need some kind of ground normal system anyways.
@@jamiek8123I mean you just modify the player's direction by the angle of the slope. It's a lot simpler than calculating the force needed to boost the player up the slope (I'm guessing for some reason you can only apply the force AFTER the physics engine in godot? Otherwise not sure why you wouldn't just apply it before...)
Also, way less computationally costly to turn off the physics rather than perform more calculations to counter it.
I agree with you...slopes introduces some issues but they are also something new in sidescroller type games. I think you had a good idea! I'm also a gamedev i understand your sense of satisfaction about it!
They aren't new at all. NES games from the 80s have slopes. Do you just say things?
slopes in classic platformers like smw and megaman x center the character on the slope as it looks much nicer than just having your collider skim along the surface. but this causes the collider to basically spend half its time inside a wall! when people say slopes are complicated *this* is what they are talking about.
i feel like your slope problems are just you treating a grid of tiles like they are an abritary physics mesh. but why? you don't need raycasts interact with a grid. you don't need to use normals and dot products to work out inclines when you can just store that information in the tile.
The physics problem is incredibly simple to solve. Get your character's total velocity, then project it onto the normal of the ground. The new vector is your direction.
Steep slopes could be a way to block off parts of the map until the player unlocks a way to traverse them, like how pokemon gen 3 had muddy slopes that required a really fast bike to climb up
Great comment - that's a really good use case! :D
Good luck on your game!
If you use slopes, then you need to create specific use cases for them to justify them. Some ideas include projectiles or lasers that use the slope angle to determine bounce angle; hazards that use rolling objects to increase or decrease velocity and damage based on slope angle; special actions for characters when they are on slopes.
I am playing it takes 2 witha friend and it is filled with slopes that the game wouldn't feel the same without them
This man refuses to do slopes sloppily.
As a pixel artist. Slopes in tilesets are dreadful to make but when you finally manage to make them it's so satisfying to see the shapes smooth out in some sort of tilemap editor that tests the tileset.
3:30, I just don't use gravity on ground. 7:10, what contra does for the snes, it makes a different sprite for the on slope idles, most games do not change every sprites. alternatively you can lower the sprite down to its center point (it helps visually, some games just do this) save slopes for part 2 XD
This topic is a slippery slope