-
-
Notifications
You must be signed in to change notification settings - Fork 13
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
Newly added door entities - collision problem #95
Comments
Unfortunately this is a known issue. I'm not entirely sure on the fix just yet, and think it's something I'm yet to reverse engineer. In the meantime, you may be able to get around it by modifying the CollisionBarrier entities within the door composite? |
Thank you for reading! I'll definitely try to play around with the CollisionBarrier. Hope it gets resolved soon! |
Let me know if you have any success. The only other lead I have atm is that doors are based on a It's something that has been on the roadmap for a while and will be a focus soon! |
I was looking through the properties of a door composite (DOOR_MED to be exact), but I couldn't find anything related to collisions. Only when I click on "Door_Package_1" and then selecting "Go To". Then I can find 2 collision-related entities: I have also found some small differences between existing and new doors. There are 2 that I know of:
With those two issues shown, I think that there might be very small differences between the existing and added doors' mechanisms and animations. If you are going to put doors on your priority list, I recommend you check in a detailed way packages and animations. |
The "delayed animation" you mention is actually an indicator that the game is loading in content behind the door. This loading is done via the scripting system's use of Door packages lingering are again related to the Mover descriptors - changing the package will break the link to the package listed in the MVR file, which will cause it to take all info from the MVR and become a static renderable in the world. You should be able to fix this in the new update by using the "Edit Movers" button and positioning the mover for the package far off in the level. It's not an ideal solution, but one that works for now while I better figure out the contents of the Mover descriptor so that I can add/remove them. |
Made a discovery related to this today which I'll post here to keep my thoughts in one place:
|
I made a discovery with collisions. When an existing door is being hit with a wrench it makes a sound (can be also a glass sound if you are hitting its glass part with doors that have glass on them), but with new doors it does nothing. Flares and collisions work properly with both doors - they bounce off when closed, but when new doors are open flares keep bouncing off the opened part. Shooting at a closed existing door leaves a bullet hole and shooting a new one doesn't (the bullets might be still getting stopped by the door tho, because if I shoot it at an angle where it would go through the door an hit the ceiling it doesn't. That means it is probably only swallowing the bullet without a trace). Flamethrower fire collides with existing doors and goes through newly added ones when they are closed, like they are not there. In the video shown below (on level: ENG_TowPlatform) the door in its frame is the existing one to the airlock and the badly positioned one is the newly added one: File size too big so unfortunately it had to be done with YT https://youtu.be/uMTc1oqzMqU |
Thanks! RE the collisions: I think these were used at map compile time in order to generate the level's collision mesh in Havok. The IDs usually relate to collision meshes which'd be compiled into the whole collision mesh. Changing them now doesn't do anything as the script tool doesn't re-compile the Havok collision mesh yet (although I hope it to someday). For now, when they're unresolved they just go blank - this could either be a issue with how I'm resolving them or just deleted collisions within the game - it's something I'm still looking into. On a broader topic of collisions, you should be able to use You wouldn't get any AI support for the custom collision, but again this is something I'm looking into (generating navmeshes on save of Commands). |
Ok, I've found some more out about this! Doors contain a It's a similar system to how the While looking into this I've also figured out that the All of these resource definitions appear to then also be referenced within I'm not parsing or using any of the above files just yet, which explains why more complex composites that rely on resources are sometimes working incorrectly when created from scratch, and indeed why the doors don't work properly when added via a new composite instance rather than just moving existing ones. Commands is apparently only one piece of the puzzle when it comes to the data read-in by the engine. I've figured all of this out off of the back of the work done for #194, which was caused by Character entities requiring a separate file to define their instanced data in a similar way to this. Figuring out how that extra file linked to commands has unearthed this plethora of new stuff to reverse engineer - and also is very similar to the issue in #144, in that the MVR file contains instance specific material overrides for instances of entities (which I also now know how to link up to commands thanks to #194). Unforuntately, I don't think it's gonna be as simple as just reverse engineering the files, as the way I display data in the script editor currently is pretty poor in regards to understanding the actual hierarchies of instanced nodes - for example:
My script editor is great at showing the composites individually, but it's bad at letting you get an understanding of how those hierarchies will populate at runtime. For example, what if I wanted to colour one instance of the To display it better in my editor I need to do a lot of reworks, to be able to jump down hierarchies and have a better conceptual understanding of where you are (as well as just editing the actual composite itself to apply changes across the board). It'd be better backed up by a 3D interface too. And here you see my issue - as I try to implement one thing, the list grows and grows 😂 The dream would be a full-on prefab system similar to something you'd find in Unity. I might be able to get away with doing some simpler auto-calculations for this data in the meantime, but first I need to reverse engineer the file formats & then have a think about how I could automate all of it in the background. I might end up just displaying it similar to how the MVR & Character instance-specific stuff is done currently, while I work on the nicer instance display. TL;DR: I think there's a whole load of additional files to reverse engineer, notably |
In the spirit of keeping this issue updated - #268 has been created to cover the ground work for implementing the above changes. |
Pinning this issue to mark that it's currently top priority. |
I've been back looking at this again, and I've definitely narrowed it down to the PhysicsSystem entity. Its DYNAMIC_PHYSICS_SYSTEM resource (which actually gets applied to the entire composite) is defined via the PHYSICS.MAP file, which itself is then linked to commands via a separate RESOURCES.BIN file. If I clear out the PHYSICS.MAP file, the game doesn't crash, but also none of the doors collisions work, in exactly the same way as if you add a new door. So this is definitely the missing info the game is after. The file contains a big matrix for each entry, and if you mess with the matrix all the physics in the level goes bizarre - I'm assuming because colliders are flying around the place. Basically, I need to figure out what this matrix is defining, and then we can make new ones. As always with this reverse engineering, this is now also presenting other issues, as I need to figure out what all the other stuff in RESOURCES.BIN is pointing to in order to add new entries to it as well. It's seemingly connected to MODELS.MVR, which is the bane of my existence :D |
I'm now correctly writing out to RESOURCES.BIN, COLLISION.MAP, and PHYSICS.MAP - and newly added doors are working! I'll tidy up the code and push it to staging soon. |
When a composite entity is added through the Cathode editor with the path AYZ\DOORS<Any door type> the door does show and it has its functions, but the collisions are a problem:
There are no problems with the already existing doors on the level, only with the added ones.
Attempted on level: Tech_Hub
The door composites are added to AYZ\LEVELS\SEVASTOPOL\TECHNICAL\TRANSITSTATION\TRANSITSTATION_SECTION
The way I entered this level isn't by loading a mission, but I used the "Select Level" from the Debug Checkpoint mod, that way it completely refreshes and the changes from the editor can properly apply, but it still doesn't fix the collision problem with the new doors.
(I am not sure if this is an issue or it requires extra modifications to fix)
OpenCAGE version: 0.9.3.02
The text was updated successfully, but these errors were encountered: