2D Moving Hitbox Collision Detection And Tunnelling

  Рет қаралды 18,693

PothOnProgramming

PothOnProgramming

Күн бұрын

Пікірлер: 32
@PothOnProgramming
@PothOnProgramming 6 жыл бұрын
Hey, everybody! Thanks for watching this video. If you have any questions or suggestions, please comment! I'm currently investigating solutions for 2D collision detection and response for arbitrary convex polygons, so please be patient as these examples take a bit longer to code.
@Angry-Panda-Studios
@Angry-Panda-Studios 6 жыл бұрын
omg finally!! I've been breaking my head trying to figure out how to do collisions, I even tried to check for imaginary points in front of a rectangle to see if they were inside of the platforms. Thank you!
@PothOnProgramming
@PothOnProgramming 6 жыл бұрын
Just keep in mind that this approach is susceptible to tunneling. It's still a decent way to do platform collision though.
@hawkbirdtree3660
@hawkbirdtree3660 5 күн бұрын
Thank you. I actually got out of tutorial hell by taking your tutorial of the Tile Based Collisions and translating it to C using Raylib. You did such a good job explaining this code that It was the first time I understood programming, and it felt so good. I now code my own games in custom game engines.
@FleMoo
@FleMoo 4 жыл бұрын
Thank you so much for this Video! A little addition: If you have 2 collisions at once while sliding aorund a collider wich transitions into another collider, it could happen that you stuck on the first collider based on wich collider you check first. The solution is to check that collider first you are overlapping the most with.
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
Yeah, the only real way to prevent tunneling is if you start from a scene with no collisions and move objects back along the vector they moved into collision on until all collisions are resolved.
@WerdOriginss
@WerdOriginss Жыл бұрын
you just ended days of frustration trying to figure out collisions in Flutter Flame Game. Thank you.
@brianoh5301
@brianoh5301 3 жыл бұрын
very helpful love the visualizing examples
@floskater99
@floskater99 4 жыл бұрын
Good Video and Explanation, but I would've enjoyed to hear more about of sweeping / swept volumes, instead of tips like "make it move less".
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
That is way more interesting but also way more complex. The good thing about it is that swept shapes are always convex, so you can use something like SAT or GJK to test for collision. I have a GJK example on the website, but I never implemented a collision response system for it. It only detects collision. For the response, you would have to figure out the amount of time it takes to move each shape back along its vector of movement in order to move it to the exact position just before it entered collision. It would be a fun project if I had a few weeks to fry my brain on integrated physics math. Not sure it's worth it, though. Most games are way less complicated or just use a physics engine.
@grishakek
@grishakek 4 жыл бұрын
this is a really good collision detection, but here is a problem. So if platforms are snapped to grid like a tile map and when the player is sliding on walls, it just gets stuck by top or bottom collision. Are there any solutions how to fix this?:)
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
Absolutely. This method is best for independent bodies, but when it comes to tiles there's a few ways to do it. One way is to do y collision first, then x or vis versa. That is taught in a lot of tutorials I've seen. The way I like to do it is to have specific collision shapes for my tiles. If your tile is only able to be collided with on the left side, only let it do collision on the left side. If you have a big wall on the right side of your level, those collision tiles should never result in a collision with the player's top, bottom, or left sides. You can have collision types that do top collision, top and bottom collision, left, top and bottom collision, or all sides collision if it's exposed on all 4 sides. If you are procedurally generating your level, you can determine what type a tile should be by checking its neighboring tiles to see if they are exposed or blocked by another tile and choose the appropriate collision type. I have a tutorial on this. Go to the website and search for "tile" and it should come up. I think it's "tile types".
@soundrogue4472
@soundrogue4472 3 жыл бұрын
That's what I should do for monogame! Use an object rectangle! Not a sprite list class! This makes sense!
@Elit3dGaming
@Elit3dGaming 10 ай бұрын
I don't really understand the old and new position. I am trying to re-create it in my code but both values read the same
@rataV7517
@rataV7517 5 ай бұрын
for simple discrete AABB vs AABB you can replace the old position with the velocitiy, something like this: if(collision_detected_x) { if(velocity.x > 0) //coming from the left { //resolve collision on x } else /coming from the right { //resolve collision on x } } if(collision_detected_y) { if(velocity.y > 0) //coming from the top { //resolve collision on y } else /coming from the bottom { //resolve collision on y } }
@asyncasync
@asyncasync 2 жыл бұрын
Sweeping wont work if either of the cubes rotate during the journey, will it? I mean, if the cubes can be rectangles.
@abhinavsinghchauhan1951
@abhinavsinghchauhan1951 4 жыл бұрын
can we not use loop to solve tunneling to some extent? But it will slow down the game.
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
You can. It's not a perfect solution mainly due to the slow down you mentioned, but also because tunneling is still possible, it's just really reduced.
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
The most effective solution I have seen is "sweeping" or "swept shapes". To get the swept shape, you basically form a convex hull around the points in the shape's last position and current position to form a big polygon, then test for collision with the swept shape of your other collision object. If you have a collision you move your shapes back along their movement vector until it is resolved. You can use GJK collision detection and EPA collision response to do this. That's a rather complex method, however.
@abhinavsinghchauhan1951
@abhinavsinghchauhan1951 4 жыл бұрын
@@PothOnProgramming GJK and EPA? Those are new terms, i will look into them. Thanks
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
@@abhinavsinghchauhan1951 I have a working GJK implementation here: pothonprogramming.github.io/content/gjk/gjk.html
@CaioLesnock
@CaioLesnock 6 жыл бұрын
But, check for collision with all objects in each frame is not bad? If I want, for example, the objects to collide with another objects, it would make the game performance bad... We would had a n² number of checks in each frame What should I do in this case? Thanks for the video man!
@PothOnProgramming
@PothOnProgramming 6 жыл бұрын
That is an excellent point and it's a real issue to consider. The solution is spatial partitioning. There are many ways to implement this in a game, but some common ways are binary, quad, and oct-trees. You can use a grid as well. Tile based games naturally take care of spatial partitioning for the world's boundaries. Many games simply limit the number of objects on screen at any given time. Your choice should depend on what type of game you are making. I personally lean towards grids and limiting sprites because those go well with tile based games. I may make videos on this topic because it is so important.
@CaioLesnock
@CaioLesnock 6 жыл бұрын
@@PothOnProgramming Thanks for the answer! I'm trying to make a grid, but the problem I have been dealing with is that it's difficult to update the objects position on the grid I would be really thankfull if you do a video about that!
@PothOnProgramming
@PothOnProgramming 6 жыл бұрын
I plan to, but it will be some time. An important part of that is knowing how to determine what grid cells an object occupies. Remove objects from the grid when they move and reinsert them when they stop on each cycle. But it's also important to consider that it may not pay to implement a spatial partitioning system if it's going to cost more to run than the collision checks.
@necrowizzard1569
@necrowizzard1569 4 жыл бұрын
Thank you for the video, unfortunately I was already wondering why the collideRectangle discards any non-colliding rectangles. In the figure showing the sweeping iteration, it can be clearly seen that tunnelling can also occur without any intersection in either the previous frame or the current frame. Also, I think not using a library for 2D vectors is not the most elegant decision. (I have to admit, I did not watch the video to the end.)
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
I try to stay away from libraries for the sake of keeping the js as pure as possible, but for production, yeah, it's safer and easier to use a library. Also, this doesn't cover sweeping. That would require convex polygon collision because the swept shape is no longer a rectangle. That would be the ideal way to eliminate tunneling, though. And I see your point about the early out. If you early out based on simple checks and then test the more complex cases, you might miss a more complex collision. Eventually i want to get back into making videos and a lot of my existing videos are going to get tuned up. This is probably one of those things that needs revision. Thanks for catching it.
@necrowizzard1569
@necrowizzard1569 4 жыл бұрын
@@PothOnProgramming Hi there, I've managed to find a working version for the sweeping problem today in Christer Eriscons Real-Time Collision detection book. Basically the IntersectMovingAABBAABB (pp. 231-232) is more or less the necessary code. It is based on the seperating axis theorem. But his example is not 100% complete (as the collision response is missing) and there is a typo in the code. A less restrictive test for intersection can be the bounding box/rectangle around the previous and the current bounding box/rectangle. In the book it is also described that it might be possible to do a sort of binary search between time positions between the previous and the current frame (which he terms interval halving). About the video, maybe I was just confused to see the sweeping figure while the problem wasn't covered initially. On the other hand it was good to have a figure to show some things that can go wrong.
@PothOnProgramming
@PothOnProgramming 4 жыл бұрын
@@necrowizzard1569 That's good info. The way i eventually wanted to implement it was to get the convex hulls of the two swept shapes using their current and previous positions, then use GJK collision detection to test collision. I don't think you'd need a binary tree to work out where to place shapes for the collision response. You know the amount of overlap and the direction to move both shapes. Seems like it could be done with a formula in one shot. No recursion or iteration. Just make the convex hulls, test the collision, get the response positions using the formula. Of course i don't know what that formula is. I have a working GJK implementation, but never got around to doing swept AABBs.
@live_destin-3408
@live_destin-3408 2 жыл бұрын
pog
@gabriel_wingard
@gabriel_wingard 2 жыл бұрын
I don't think this is an example of tunneling. I thought tunneling were when the program doesn't run quick enough so if you for example have a really tiny platform in a 2D game you can fall through it if you have enough speed because as you kind of explained it skipped the collision by moving with a big step.
@danieln7777
@danieln7777 6 жыл бұрын
Lit fam
How To Collide 2D Polygons With Flat Surfaces And Sloped Lines
33:48
PothOnProgramming
Рет қаралды 4,4 М.
REAL or FAKE? #beatbox #tiktok
01:03
BeatboxJCOP
Рет қаралды 18 МЛН
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН
It’s all not real
00:15
V.A. show / Магика
Рет қаралды 20 МЛН
Сестра обхитрила!
00:17
Victoria Portfolio
Рет қаралды 958 М.
Collision Detection Between Rectangles in JavaScript
5:53
Franks laboratory
Рет қаралды 33 М.
How Collisions Work in Games
5:54
TheHappieCat
Рет қаралды 201 М.
How 2D Game Collision Works (Separating Axis Theorem)
7:29
Skeffles
Рет қаралды 13 М.
Wall Collision Tile Map JavaScript
22:09
Chuck's Resume
Рет қаралды 2,3 М.
Collision Detection with SAT (Math for Game Developers)
32:08
Implementing collisions from scratch! Indie Game Devlog #5
7:55
Thibs Workshop
Рет қаралды 8 М.
BSP Trees: The Magic Behind Collision Detection in Quake
8:53
Matt's Ramblings
Рет қаралды 103 М.
How Video Games Work - Platformer Collisions
4:08
WesOfX
Рет қаралды 1,6 М.
2D Game Physics 4: Pre-Collision Detection Optimizations
12:52
Josh Sideris
Рет қаралды 9 М.
Overview of Simple Collisions Detection Types in 2d games
4:59
REAL or FAKE? #beatbox #tiktok
01:03
BeatboxJCOP
Рет қаралды 18 МЛН