Interested in advertising on Derpibooru? Click here for information!
Sky Railroad Merch Shop!

Help fund the $15 daily operational cost of Derpibooru - support us financially!

Description

Uploading old videos :  
v0.07  
Sorry for the cursor capture
 
First functional version of a custom path-finding solution.  
Here I was mostly testing the “I need to crouch to take this path” behavior.
 
<- PREVIOUS  
NEXT ->

safe2276466 artist:unnameddev22 oc1006640 oc:filly anon4354 earth pony549125 pony1705924 3d131338 animated132902 artificial intelligence233 city6793 cityscape1304 crawling233 crouching992 development93 falling3746 female1906921 filly105577 following47 game4999 jumping4927 looking at each other38759 no sound7773 not sfm3102 running8616 unity144 video game6393 webm28834
Source

Comments

Syntax quick reference: **bold** *italic* ||hide text|| `code` __underline__ ~~strike~~ ^sup^ ~sub~

Detailed syntax guide

redweasel
Duck - "someone befriended them, saved them, coaxed them out of their shell, and showed them that sex is nothing to be afraid of. I’m kind of envious of that rape victim"

Fuzzbutt
Classic Sonic-type gameplay isn’t really my focus,
 
didn’t you have one of the earlier demos where she got the power up to run around a loop-the-loop without falling?
UnnamedDev
Artist -

int Horses = 1 / 0;
@Background Pony #5C91  
@Background Pony #5C91  
 
Classic Sonic-type gameplay isn’t really my focus, but the engine can already handle looping and be setup to work in 2D mode.  
There will probably be a Sonic-ish section at some point for shit and giggle, but since I intend the game to be relatively moddable you should be able to make entire levels of it if you wish.
Background Pony #394F
I mean this is original and cool. But a sonic style Pony fangame would be epic
Background Pony #394F
What if you ripped off a Sonic 3d engine and then made an amazing MLP fangame?
redweasel
Duck - "someone befriended them, saved them, coaxed them out of their shell, and showed them that sex is nothing to be afraid of. I’m kind of envious of that rape victim"

Fuzzbutt
@UnnamedDev
 
I try for A* but I’ve never really been able to get my head around that algorithm. probably just a math error somewhere. haven’t worked on it in years anyway. was trying to figure out client side automining in minetest.
UnnamedDev
Artist -

int Horses = 1 / 0;
per model
What ? No.  
It’s generated once when the level load and then everyone use it.  
All NPCs get their info from the same node array, they just filter them based on their stats.  
chunk boundaries.
*Shudder*  
Yeah, chunk boundary issues are why I’m only working with one giant chunk for now. Especially since I want my levels to have significant verticality (castle, skyscrapper, etc) and having situations like most of the floor in one chunk and the stairs in an other would lead to paths that are nearly unsolvable.  
then they get lost anyway because there’s a zillion possible paths and only a few good ones.
… what algorithm are you using ?  
Mine is A*, with added Greed-first (much faster for a small risk of not picking the 100% best path) and hard-capped node exploration (pretty much mandatory on big maps otherwise they will explore ALL of it if the target is actually unreachable).  
In my experience it’s extremely reliable.
redweasel
Duck - "someone befriended them, saved them, coaxed them out of their shell, and showed them that sex is nothing to be afraid of. I’m kind of envious of that rape victim"

Fuzzbutt
@UnnamedDev
 
oh, yeah that makes sense. you wouldn’t want a big thing pathfinding through a small space. still, that’s 380k nodes per map, per model. definitely want that “multi-chunk” thing if it’s an open world game.
 
I have trouble with those though, because if they’re static chunks, your pathfinding gets hung up on chunk boundaries. but if they’re centered on the model, then when the model moves, the array has to be updated, and so predicting a path, you also have to predict new arrays of possible positions with every step. it always ends up being less work to predict one possible position with every step, i.e. just using immediate collision detection.
 
so I just have the model try various paths with basic “what’s the easiest way to move” collision for their immediate surroundings, then pick the path that works the best. then they get lost anyway because there’s a zillion possible paths and only a few good ones.
UnnamedDev
Artist -

int Horses = 1 / 0;
that makes for a lot of possible positions
Yeah, that’s grid-based pathfinding for you.  
To give you an idea, the Gmod Ponyville map I’m doing my current tests on end up being a 380k nodes array (0.5m accuracy)  
I will switch to a proper multi-chunk system if I ever decide to make the game open-world-ish.  
immediate collision detection
Wouldn’t really work here as I want NPCs with different size, so the pathfinding algorithm need to know if the pony will fit before it even get there. Otherwise Celestia/TroubleShoes-sized characters would take paths they can’t actually complete.
redweasel
Duck - "someone befriended them, saved them, coaxed them out of their shell, and showed them that sex is nothing to be afraid of. I’m kind of envious of that rape victim"

Fuzzbutt
@UnnamedDev
 
oh, so it quantizes the positions, and has them crouch roughly around the right place. not sure if that’s the greatest idea since even divided up roughly that makes for a lot of possible positions in really big levels. can you have it only scan the geometry nearby the pony, like a big cube around them?
 
having a list of all positions would be handy if you had a lot of ponies all over the place though, since all their cubes would merge into the whole level anyway.
 
the few auto-repositioning algorithms that I’ve run into use immediate collision detection, rather than an array of all possible positions in space.
UnnamedDev
Artist -

int Horses = 1 / 0;
@redweasel  
The pathfinding system scan the level’s geometry to make a rough list of all positions where a pony could fit. When it find one, it also check if there is some obstacles above, and how far.  
So each position has a “ceiling height” value, that get checked against the NPC’s own standing/crouching height (since they won’t all be the same size). This way they know if they can even pass at all, and/or if they need to crouch to fit.
 
This should also be re-used for flying NPCs, but I haven’t started working on that at all yet.
rautamiekka
Lunar Supporter - Helped forge New Lunar Republic's freedom in the face of the Solar Empire's oppressive tyrannical regime (April Fools 2023).
King Sombra - Celebrated the 10th anniversary of The Crystal Empire!
Elements of Harmony - Had an OC in the 2022 Community Collab
Magical Inkwell - Wrote MLP fanfiction consisting of at least around 1.5k words, and has a verified link to the platform of their choice
Speaking Fancy - Badge given to members that help with translations
Cool Crow - "Caw!" An awesome tagger
Magnificent Metadata Maniac - #1 Assistant
Preenhub - We all know what you were up to this evening~
Twinkling Balloon - Took part in the 2021 community collab.
My Little Pony - 1992 Edition

It’s coming together.
Spoiler alert : it’s really not.
That video is nearly 2 months old, I’m still working on that goddamned Pathfinding.
In insight, I probably should have just gave up the few special features I wanted out of it and used Unity’s default one.
But eh, now it’s nearly ready.
… except my computer half-died, so new devs are slowed to a crawl until I can buy a new one.
 
Never coded pathfinding myself, but I can easily imagine it’s nothing of the sort of easy.
UnnamedDev
Artist -

int Horses = 1 / 0;
It’s coming together.
Spoiler alert : it’s really not.  
That video is nearly 2 months old, I’m still working on that goddamned Pathfinding.  
In insight, I probably should have just gave up the few special features I wanted out of it and used Unity’s default one.
 
But eh, now it’s nearly ready.  
… except my computer half-died, so new devs are slowed to a crawl until I can buy a new one.