-
Notifications
You must be signed in to change notification settings - Fork 16
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
A couple minor homing fixes #3
Comments
Hi, thank you for the bug report. I see, it's true that change_property might cause some issues. When I added it, I didn't think there would be much use for it. Can you detail me your use case ? Just so I know why you need it and if I can't make a better solution. I will look into what would be the best fix. I was just planning an update with a change to the homing so it will be a part of the next release. |
Happy to share more! Sorry if this is too long-winded! If you want to chat more I can jump in a Discord or something. I'm working on my first ever Bullet Hell, so I'm happy to be told my use-case is not typical. I'm still exploring, not sure what exactly the game is yet. I'm doing a quick game jam, and hope to have something done in the next couple days. My first goal was to spawn bullets from my enemy instances, and have them hone in on a target that they had detected, which could be the player, or a little 'sheep' that follows the player. In general this is the approach I want to use - defining some kind of attack pattern than an enemy instance owns, and being able to drop a bunch of these enemies anywhere in a level. At first I added the bulletPattern/spawnPattern/spawnPoint to the enemy scene itself, which worked fine for a single enemy - but adding multiple enemies to one scene runs into trouble b/c the bullet/spawnPatterns were being created with the same ID multiple times. After some thinking, I realized I could create the patterns once in an autoload, and reference them from a spawnPoint on the enemy instance. This seems to be working fine, and probably works for my purposes with just the changes I linked. The tricky part I hit was dynamically assigning the homing_target to the bulletPattern. I was happy to find I also ended up adding a new 'sharedArea' to the Spawning autoload so that I could get the bullets on my enemy-projectiles collision layer. Maybe there's a better way to do this? I'd like to be able to define patterns on an instance, and have them be unique for that instance, rather than shared. This can probably be done completely in the code - instead of working with the nodes in the editor, I could create a bullet/spawnPattern in each instance's I have a few other ideas I'll try this morning - for example, I think it might be possible to include the patterns as nodes in the enemy scene, and perhaps update the IDs before their ready functions are called - this could let us overwrite the IDs per instance. I'm not sure how simple/possible that is. |
Turns out you can update the ids in _enter_tree()! So now I have per-instance bulletPatterns/spawnPatterns the way I hoped.
For some reason the homing doesn't work on the first few bullets tho - I'm not sure why, still debugging to learn more. I also just found the alternative homing options for groups, not just node_paths - that might solve my use-case much better than |
Confirming that switching to homing in on groups works great for my use-case! So now that I'm getting unique patterns per instance (with the above _enter_tree id updates) and honing on groups, I don't need change_property - though it may come in handy at some point. |
Indeed, but be sure to call Spawning.reset(true) if you have resources loaded globally and those resources' ID must start with @ or else they will be destroyed when changing scene. If you want to avoid doing that, it's better to keep your resources in your level's scene and not globally.
Be warned that using change_property will affect every bullet linked to the resource and not a single bullet.
That's what it's for 👍 |
That's actually really interesting ! I'll write it in the documentation. |
Good to know, I'll keep this in mind going forward. Thanks for the info and for all the effort on this library! I'm excited to make some games! |
Thank you :) If you need help, I'm more reactive on discord so you can post in #plugin-help-chat |
Hey there! Very cool library, thanks for putting it together and open-sourcing it!
I ran into a few crashes integrating it yesterday/this morning, I thought I'd share the commit in my repo: russmatney/dino@56fbfc2.
I can create a proper PR if you want, this was just a lower-lift share, and maybe you prefer a different solution and/or can get to it sooner.
I prefer to do more things from code in general, which might explain why I hit some of these. For now I'm creating bullet and spawn patterns in an autoloaded scene, then updating and firing bullets from enemy instances this:
This usage seems reasonable to me. It feels like the lib may expect some homing setup is expected to happen in _ready(), but it's too late if we decide afterwards that a bullet should be homing. Maybe I should just create the bullet and spawn pattern in the code as well, to resolve that?
--
I also spent a bit trying to figure out why some spawns never fired, and eventually figured out that nothing fires unless a spawner is in a positive x and y position. Moving a spawner left of the y axis or above the x axis results in no bullets at all. Maybe this is just a bug on my end? I dug into it briefly, but wasn't able to find a clear reason/solution for this yet.
Let me know what you think and if you'd like an actual PR!
The text was updated successfully, but these errors were encountered: