Godot Experimentation Log

Started by Jubal, November 26, 2024, 11:23:24 AM

Previous topic - Next topic

Jubal

I've started messing around with Godot a bit.

My ultimate aim is to see if I can use it to build a sort of classic RPG engine of some kind, though I'm at very, very early stages indeed and right now I'm doing things like working out how the animation blending works and how to control it through code and so on and so forth.

I've downloaded a little pack of animated cartoonish guys - I am very much not becoming an animator for this or any other project - and I've got one with some movement code, jump, turn, and attack anims all running more or less properly though the transitions could be more fluid. That said, ultimately I want something fairly zoomed out so I'm not too bothered about building smooth real-time combat or anything.

Thoughts so far: gdscript is pretty similar to python though I've got a lot to learn about how it interacts with game structure more generally, I've been scripting on individual objects but much less on world state and interactions and so on. Some stuff I'm just unused to like passing vectors to functions, it's a very vector-y system which feels odd in that I'm probably going to have to try and workout adding grids for movement calculations etc to an essentially fluid-ish world. I'm occasionally getting frustrated because so much less is directly script-controlled and I'd sometimes rather use a script than have things in clicky draggy boxes, but I'm making progress all the same.

Will post some screenshots and thoughts as I go :)
The duke, the wanderer, the philosopher, the mariner, the warrior, the strategist, the storyteller, the wizard, the wayfarer...

Jubal

So I did a chunk more of this in early December. For the initial first person stuff I've not added too much, but I didn't give a picture in the last post so here goes:



The main addition, though really is that I've also created a tactical view:



The idea here is that the tactical view might allow me to make a system for some kind of turn-based combat, it has a free camera and I've got code to switch between the tactical and first person cameras.

I've also got pathfinding grids working, though I need to write myself some notes on doing it and, equally, I need to work out a few more advanced bits like jump points.

Another advance was being able to select a second character and move them around when in tactical mode. This gives us some potential for having a party-based system, which is what I imagined when I started this testing.

My most recent addition was a "lock" that detects when the player is close to an enemy and stops their movement until another signal is given (at the moment this is selecting another unit, but I guess it should ultimately be refreshed on a new turn in a turn-based mode). This is useful because it means that we can click on an enemy and move to them without continually trying to run through them forever.

I think upcoming plans to add include:
  • Have 3 player cameras to switch between during first person movement, plus maybe 1-2 side cameras that can be switched to in conversations.
  • Actually implement some combat! I think I'm about halfway there on this, adding simple close combat attacks, a turn order, and death are the next steps. Probably the biggest problem, though, is getting some AI (in the old computer game sense not the modern LLM sense) working so the enemy models can actually find the player character(s) and fight back.
  • Have party members follow you around in "explore" mode (should be viable I think).
  • See if I can make "jump points" for allowing characters in tactical mode to jump between levels/disconnected sections of the movement grid (may be very difficult).
  • Add conversations and some UI, not really tried Godot's UI system yet.
  • Add multiple locations and check I can respawn player & party in a new area.

I have to admit that other than "make an RPG engine" I'm still not sure what I'm doing this for:
The duke, the wanderer, the philosopher, the mariner, the warrior, the strategist, the storyteller, the wizard, the wayfarer...

Jubal

Well, a lot has been happening, including a lot I cannot show yet :)

But as for the experiment log and things I can report: I've mostly continued to work on the combat stuff, I now have turn order and attacks in a basic sense working, and I have most recently gotten to the point where the enemies run at the player characters and have a step counter so their movement range each turn is limited. I now really just need to add enemy attacks and we have a combat engine!

At least, sort of, because there's still some big elements missing: the biggest ones are ranged attacks, any AoE abilities or attacks, and then also more generally any kind of resolution system. BUT I'll get there, and I'm having some interesting ideas about how to handle things which I'm looking forward to exploring when the underlying system allows for it.
The duke, the wanderer, the philosopher, the mariner, the warrior, the strategist, the storyteller, the wizard, the wayfarer...

Jubal

Well, it's been several months but I'm finally playing with things again - I'm skipping out on finishing the combat system right now in favour of starting building my dialogue system and playing with UI elements, which also needs doing. I've got buttons that can change text in a label, so that's a start, just got to get the data structures for the actual dialogues in there now and then make things look less horrible and appear/disappear/trigger when needed.
The duke, the wanderer, the philosopher, the mariner, the warrior, the strategist, the storyteller, the wizard, the wayfarer...

Antiquity

Sounds like you have done a lot so far.  What kind of mechanisms are you using for defining and executing events like combat and dialogue and picking up items?  Or are those systems yet to be integrated into the main game loop?

Jubal

Quote from: Antiquity on June 30, 2025, 08:02:46 AMSounds like you have done a lot so far.  What kind of mechanisms are you using for defining and executing events like combat and dialogue and picking up items?  Or are those systems yet to be integrated into the main game loop?
Oops, I somehow missed this ages ago!

I've not done item pickups yet. Essentially I've got some different "modes" of gameplay defined by a general "movemode" variable, which can be switched between and which have different camera controls etc. So there's one mode for dialogue, one for combat, one for general movement and exploration. The transitions between them are only partly defined thus far: I've got some of the triggers in place but I'm using a manual button to switch modes right now, whereas in the eventual game then e.g. a dialogue or spatial trigger will begin a combat and a dialogue or TPK of either side will end it (nb TPK here potentially including fleeing which will be mechanically important in this game).

Most behaviours of the player and NPCs are tied to specific modes, so you have click-to-move in tactical combat mode and arrow key movement out of combat.



Anyhow recently I've started working on ranged weapons which are much more complex than close combat. In melee, I can basically check if there's someone close enough to hit, trigger the hit animation, and have the defender's reaction to the hit take place effectively instantly, and it looks more rather than less fluid if I do so. Range has a lot more steps: I need to do the animation, then create the projectile object, then move the projectile object, detect when it hits, and then finally I can trigger the reaction. This will also be a bit more complex for the turn ordering because I need to not trigger the end of the turn until the projectile has done its thing. There are also a couple of other problems like not having NPCs shoot each other in the back which I haven't really thought through yet.

I've also had some pretty funny bugs when my early attempts have gone very wrong...
The duke, the wanderer, the philosopher, the mariner, the warrior, the strategist, the storyteller, the wizard, the wayfarer...