Skip to content
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

Optimiser : Chair meshes get skipped #11

Open
neomonkeus opened this issue Nov 27, 2014 · 2 comments
Open

Optimiser : Chair meshes get skipped #11

neomonkeus opened this issue Nov 27, 2014 · 2 comments

Comments

@neomonkeus
Copy link
Member

I recently did a complete mesh optimization (vanilla + SI), and found out that all chair meshes were skipped.
My conclusion:
Any file that contains "hair" in the filename will get skipped. That's why the script skips all "chair" meshes. Simple temporary renaming of the mesh does the trick, but one has to be aware of this limit when working with large number of meshes.

.. same goes for "hood", "helmet" and "emperor".
Helmet - skips _gnd meshes and static helmet meshes. Also, there are helmets that are not used with egms, so those should be safe too.
hood - _gnd meshes, and any path containing "hood" (like dark brotherhood)
emperor - Makes script skip whole "clothes\upperclass\emperor" subfolder.
There are probably more problematic filters.

The optimizer aims to be conservative and avoids anything that might cause trouble. You can edit the list of keywords that cause nifs to be skipped: it's in the file
C:\Program Files (x86)\PyFFI\utilities\toaster\oblivion_optimize.ini
Does this help?

Well, I've already did that and it got the job done.
So, is there any detailed listing of which vanilla meshes are not to be optimized?
It's obvious that meshes with egm/tri files must be skipped, but there are helmets that don't use egm/tri files (ones that obscure the face, so no face-fitting is done). Those are safe to optimize, to the best of my knowledge.

The ini file is supposed to be that list :-)
If you disable everything, it will automatically skip all meshes which have a tri or egm file attached to them. The problems occur when you have installed a mod with a nif that refers to an egm file in a bsa file - the script cannot detect this. Hence the failsafe heuristics (which are obviously overly conservative!). If you run the optimizer on a fully extracted folder (all bsa files etc.) then it should be quite safe.
Does that explain?

I think there should be 2 lists.
One that lists all the known (as in vanilla) mehses that have BSA-d EGM/TRI counterparts.. but with full paths, and not keywords, and a second list with all the keywords..
Just a thought.

I see - but IMO two lists would just make things confusing. What I think is needed is a way to specify keywords that also match parts of paths. Turning this into a feature request...

@kormgar
Copy link

kormgar commented Nov 27, 2014

One possibility might be to update the corresponding egm / tri files with any vertex index and/or tri list changes immediately after the nif was optimized.

I was just working on a seam cutter for an updated version of Seam Mender that requires very similar functionality. In a nutshell, I've written a routine for Seam Mender that allows it to automatically add or delete vertices to allow it to automatically merge dissimilar seams.

The piece I'm working on right now is code to automatically update any associated egm or tri files with the modified indices and tri list.

I'll let you know how it goes and post the code.

@neomonkeus
Copy link
Member Author

@kormgar this is actually a migrated issue from sf.net.

I am not sure what the .TRI & .EGM format support is like with pyffi, so that would need investigating. I think the main issue here was the pattern matching came up with false positives so meshes which were say were ignored.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants