Arrocito Posted September 20, 2021 Posted September 20, 2021 Hey Sheson I have no idea what would be blocking access to the folder for the texgen output and I'm more confused since it it happens mid process and not right away with the first textures. I'm seriously stumped and never had these issues before. It's getting pretty demoralizing.
sheson Posted September 20, 2021 Author Posted September 20, 2021 7 hours ago, Arrocito said: Hey Sheson I have no idea what would be blocking access to the folder for the texgen output and I'm more confused since it it happens mid process and not right away with the first textures. I'm seriously stumped and never had these issues before. It's getting pretty demoralizing. Programs use standard OS function to read and write files. If the OS function fails it returns an error message. The program can only relay that message. It is either the UAC or some the tied-in antivir or something is already accessing by another program etc. In the process it is the first time that a texture is being copied from that data folder / BSA to the output folder. AntVirs also check the contents of data being written. One file might be fine, while another isn't. Start xEdit with entire load order. Start the Asset Browser with CTRL+F3. Put the source filename into the filter field. The first listed container is the winning BSA or teh data folder for loose files. Right click and select Save As (from the winning container). See what happens.
Phlunder Posted September 21, 2021 Posted September 21, 2021 (edited) Hey sheson! Thanks for all the latest improvements to DynDOLOD 3.0. The renderer for custom object and tree LOD textures is really something else, perfect match now! Having trees with normal maps in object LOD helps a lot too, once they are matched in terms of brightness of the diffuse, they blend well in every situation! Good stuff! I still have issues with blending the damn glaciers, even with custom made LOD textures to match, their horrible UVs make it hard to make them look good. For mountains/unique, I used a suggestion of yours from a while ago, creating a ruleset that pushes certain LOD stages farther out. The LOD4 step of mountain LOD almost always uses the full mountainslab texture, so pushing that step out to LOD8 helps a lot. Could a similar thing be done with glaciers as well? Their LOD4 model already uses custom textures though. Maybe pushing the full model (they are not very complex in terms of shape) out to LOD4 or LOD8? Would that be possible with rules? Performance impact is a given of course. Edited September 21, 2021 by Phlunder
sheson Posted September 21, 2021 Author Posted September 21, 2021 34 minutes ago, Phlunder said: Hey sheson! Thanks for all the latest improvements to DynDOLOD 3.0. The renderer for custom object and tree LOD textures is really something else, perfect match now! Having trees with normal maps in object LOD helps a lot too, once they are matched in terms of brightness of the diffuse, they blend well in every situation! Good stuff! I still have issues with blending the damn glaciers, even with custom made LOD textures to match, their horrible UVs make it hard to make them look good. For mountains/unique, I used a suggestion of yours from a while ago, creating a ruleset that pushes certain LOD stages farther out. The LOD4 step of mountain LOD almost always uses the full mountainslab texture, so pushing that step out to LOD8 helps a lot. Could a similar thing be done with glaciers as well? Their LOD4 model already uses custom textures though. Maybe pushing the full model (they are not very complex in terms of shape) out to LOD4 or LOD8? Would that be possible with rules? Performance impact is a given of course. Of course, just create a mesh mask rule that targets part of the path/filename of the full model of whatever it is you want to target with custom rules. However, keep in mind that LOD does not support parallax, so using such full models for object LOD is probably not going to look as expected.
Phlunder Posted September 21, 2021 Posted September 21, 2021 4 hours ago, sheson said: Of course, just create a mesh mask rule that targets part of the path/filename of the full model of whatever it is you want to target with custom rules. However, keep in mind that LOD does not support parallax, so using such full models for object LOD is probably not going to look as expected. Thanks for the quick response! Yes, I noticed, due to the missing capability I had to make changes to the LOD textures to take the visual impact of the parallax effect on full models into account. Now that I think of it, to give those full models as LOD a different texture, I would have to make them a different mesh with unique texture path assigned. I wonder if it would make sense to just replace the LOD models with the full ones, and assign a special texture to it. Not sure why they've gone through the trouble of making so many unique LOD meshes for those glaciers, they don't really have much shape complexity to begin with. Thanks for the ideas! I'll try to figure something out. Best way would be to create new reduced LOD models for the glaciers of course... Just beyond my capabilities.
sheson Posted September 21, 2021 Author Posted September 21, 2021 1 hour ago, Phlunder said: Thanks for the quick response! Yes, I noticed, due to the missing capability I had to make changes to the LOD textures to take the visual impact of the parallax effect on full models into account. Now that I think of it, to give those full models as LOD a different texture, I would have to make them a different mesh with unique texture path assigned. I wonder if it would make sense to just replace the LOD models with the full ones, and assign a special texture to it. Not sure why they've gone through the trouble of making so many unique LOD meshes for those glaciers, they don't really have much shape complexity to begin with. Thanks for the ideas! I'll try to figure something out. Best way would be to create new reduced LOD models for the glaciers of course... Just beyond my capabilities. Consoles. Also, full modes and LOD models not having to closely matching 3D shapes helps to reduce texture z-fighting while both show for that brief second. Sure, you can just take the 3D shape data (maybe do a slight decimation) from the full model and update shader + textures.
DoubleYou Posted September 22, 2021 Posted September 22, 2021 I am making custom rules that load with a mod, but the following rules are always overridden as follows: fxwaterfallbody,None,Level1,Level2,None,FarLOD,Unchanged,1,DynDOLOD_SSE_all_dynamic.ini dlc2cliffbasalt,Level0,Level1,Level1,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini dlc2dwecluttercolmlarge01,Full,None,None,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini dlc2dwe,Level0,Level1,Level1,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini redorantemple01,Level0,Level1,Level1,None,FarLOD,Unchanged,1,DynDOLOD_SSE_High.ini windhelmbridge,Level0,Level1,Level2,None,None,Unchanged,5,DynDOLOD_SSE_High.ini All the other rules load fine. I have attached my rules INI file. DynDOLOD_SSE_maptweaksesp_high.ini
z929669 Posted September 22, 2021 Posted September 22, 2021 If I'm not mistaken, your rule additions have conflicting priority with the default preset. I believe that you could use a spreadsheet to interleave your custom rules with the default, merging and renumbering in the wanted priority. You will need to remove default rules matching your new ones also, I'd say. Seems faster than inputting via the gui anyway. Oof ... I guess I didn't know that the preset INIs allowed 'append' of custom mesh rules via mod-included rules. Duh. I assumed that the line numbering like "LODGen 202" actually indicated priority ... but it seems like it's just a line counter that must update internally (without duplication) when eternal rules are appended/injected/interleaved.
sheson Posted September 22, 2021 Author Posted September 22, 2021 6 hours ago, DoubleYou said: I am making custom rules that load with a mod, but the following rules are always overridden as follows: fxwaterfallbody,None,Level1,Level2,None,FarLOD,Unchanged,1,DynDOLOD_SSE_all_dynamic.ini dlc2cliffbasalt,Level0,Level1,Level1,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini dlc2dwecluttercolmlarge01,Full,None,None,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini dlc2dwe,Level0,Level1,Level1,None,FarLOD,Unchanged,0,DynDOLOD_SSE_High.ini redorantemple01,Level0,Level1,Level1,None,FarLOD,Unchanged,1,DynDOLOD_SSE_High.ini windhelmbridge,Level0,Level1,Level2,None,None,Unchanged,5,DynDOLOD_SSE_High.ini All the other rules load fine. I have attached my rules INI file. DynDOLOD_SSE_maptweaksesp_high.ini 14.72 kB · 3 downloads Post the debug log as explained in the first post.
Unilythe Posted September 22, 2021 Posted September 22, 2021 (edited) Heya. I decided to try DynDOLOD 3 for the grass LOD's, but they're not showing up. Or at least, my theory is that only a very tiny amount of it is showing up, but in game, I really can't make any out at all. Even when I set fov to 20 or so, to zoom in on far away LOD terrain. I see some bushes, but no grass. I went through the checklist. Everything was fine (including Gathering grass data for object LOD), until this part: Quote Check the object LOD atlas ..\DynDOLOD_Output\Textures\DynDOLOD\LOD\DynDOLOD_[Worldspace].dds contains some of the grass LOD billboards generated by TexGen. Couldn't find any in Tamriel Worldspace dds... I think? I looked for a while, but I know it's supposed to be tiny compared to the other billboards in there. Check the export file ..\DynDOLOD\Edit Scripts\Export\LODGen_SSE_Export_[Worldspace].txt contains a line like GrassMap=..\DynDOLOD\Edit Scripts\Export\LODGen_SSE_Grass_Map_[Worldspace].txt. Check that GrassDensity is not 0. If it is very low, grass LOD may be very thin to non-existent. This is all exactly as it should be. GrassDensity is 100. Check that ..\DynDOLOD\Edit Scripts\Export\LODGen_SSE_Grass_Map_[Worldspace].txt contains lines with grass LOD billboard texture names and paths in it. It does, but it's just 2 lines... 2 billboards from Verdant grass. Surely that's not enough? There's a lot more billboards generated by TexGen than just those 2. EGrass10_00003337.dds textures\terrain\lodgen\verdant - a skyrim grass plugin sse version.esp\egrass10_00003337_1.dds EGrass10_00025008.dds textures\terrain\lodgen\verdant - a skyrim grass plugin sse version.esp\egrass10_00025008_1.dds Open ..\DynDOLOD_Output\Meshes\Terrain\[Worldspace]\Objects\[Worldspace].4.x.y.bto and check visually if there is grass LOD in there. The many tiny X planes will be obvious. There are some X's for the grass LOD, but it doesn't seem like it's enough. I made a screenshot below with an LOD with the most grass I could find, but it doesn't seem to be enough there either. MinGrassSize is 60 I think, so it should be pretty dense. The majority of bto files I checked had practically no grass in it at all, even in locations where I would expect there to be. I'm showing the best case here, maybe it's a location in Tamriel that has a lot of the grass of the 2 billboards that seem to be generated properly. Hope someone can help, I'm at a loss. Could this be the object bounds thingy? That it causes a lot of different grass types to not be included in the LOD? Seems to be the case, I see lot of lines end with ";False". If so, this is where my knowledge ends, not sure what I'm supposed to edit in xEdit. I'm fairly confident in using xEdit itself, just don't know what I'm supposed to edit. If you need any other log files, I'm happy to provide them. DynDOLOD_SSE_Debug_log.txt Edited September 22, 2021 by Unilythe
DoubleYou Posted September 22, 2021 Posted September 22, 2021 3 hours ago, sheson said: Post the debug log as explained in the first post. Here you go. https://mega.nz/file/ZY4EVBiK#gdZBEuJ2-gnR6cYyW55Et9NpRSsphJcW9mzzNzDzttU
Unilythe Posted September 22, 2021 Posted September 22, 2021 (edited) 55 minutes ago, Unilythe said: Heya. I decided to try DynDOLOD 3 for the grass LOD's, but they're not showing up. Or at least, my theory is that only a very tiny amount of it is showing up, but in game, I really can't make any out at all. Even when I set fov to 20 or so, to zoom in on far away LOD terrain. I see some bushes, but no grass. I went through the checklist. Everything was fine (including Gathering grass data for object LOD), until this part: Hope someone can help, I'm at a loss. Could this be the object bounds thingy? That it causes a lot of different grass types to not be included in the LOD? Seems to be the case, I see lot of lines end with ";False". If so, this is where my knowledge ends, not sure what I'm supposed to edit in xEdit. I'm fairly confident in using xEdit itself, just don't know what I'm supposed to edit. If you need any other log files, I'm happy to provide them. DynDOLOD_SSE_Debug_log.txt 134.14 kB · 0 downloads Never mind, I got it. Writing this all down was a rubber duck experience for me I suppose. I need to fix the object bounds by recalculating it in the creation kit. Lots of Verdant grasses have 0's on all the object bound values, so I guess that causes these issues. First I'm going to test setting MinGrassModelVolume=0 and MinGrassModelHeight=0 to see if that indeed fixes the problem. Edited September 22, 2021 by Unilythe
sheson Posted September 22, 2021 Author Posted September 22, 2021 1 hour ago, DoubleYou said: Here you go. https://mega.nz/file/ZY4EVBiK#gdZBEuJ2-gnR6cYyW55Et9NpRSsphJcW9mzzNzDzttU The debug log shows that these rules are being used for the ones you listed: [00:11] <Debug: 299 fxwaterfallbody None Level1 Level2 Level2 FarLOD Unchanged> [00:11] <Debug: 300 dlc2cliffbasalt Level0 Level1 Level1 Full FarLOD Unchanged> [00:11] <Debug: 295 dlc2dwecluttercolmlarge01 Full None None Full FarLOD Unchanged> [00:11] <Debug: 296 dlc2dwe Level0 Level1 Level1 Full FarLOD Unchanged> [00:11] <Debug: 301 redorantemple01 Level0 Level1 Level1 Level0 FarLOD Unchanged> [00:11] <Debug: 302 windhelmbridge Level0 Level1 Level2 Level0 None Unchanged> This seems to match the rules loaded for the maps tweaks plugin. Does that not match what is automatically saved to ..\DynDOLOD\Edit Scripts\DynDOLOD\Presets\DynDOLOD_SSE_Default.ini? If a rule gets replaced by a rule file that is loaded afterwards, consider using a slightly different mesh mask. For example, instead of fxwaterfallbody use \fxwaterfallbody or fxwaterfallbodyslope and fxwaterfallbodytall or just waterfallbody etc., instead of dlc2cliffbasalt use \dlc2cliffbasalt. If those rules are loaded before the other ones they will match first and be used.
AiElias Posted September 22, 2021 Posted September 22, 2021 I'm still having some issues with LOD Mipmap alphas and Skyrim 3D trees. In the vanilla mod, there are a total of 16 trees I'm aware of which have crown transparency issues with DynDOLOD 3.00 Alpha 44 generation. These are as follows: S3DTrees_DLC1TreeWinterAspenSnow01.nif S3DTrees_TreePineForestAsh01 - 05.nifs S3DTrees_TreePineForestAshL01 - 05.nifs S3DTrees_TreePineForestDeadAshL01 - 05.nifs Here's an example of what that looks like. I have omitted the trunks for the purposes of testing in this instance. These tree's and their respective LODs point to the same texture, the original one from the mod. So unlike before there's no texture replacement done on my end. The NiAlphaProperty value for all the crowns of these trees is '16'. Since I've noticed the issues, I've also tested resaving the textures and regenerating mipmaps with the Nvidia Texture Tools Exporter PS plugins with various kaiser and box mipmap generation techniques and cutout alphas then regenerating DynDOLOD from those. I do recall however that you said that DynDOLOD generates it's mipmapped textures. Is there something I'm missing here or is this infact a bug? Debug Log Link: https://cdn.discordapp.com/attachments/610980524818694191/890219634308022272/DynDOLOD_SSE_Debug_log.txt DynDOLOD_SSE_log.txt
sheson Posted September 22, 2021 Author Posted September 22, 2021 1 hour ago, AiElias said: I'm still having some issues with LOD Mipmap alphas and Skyrim 3D trees. In the vanilla mod, there are a total of 16 trees I'm aware of which have crown transparency issues with DynDOLOD 3.00 Alpha 44 generation. These are as follows: S3DTrees_DLC1TreeWinterAspenSnow01.nif S3DTrees_TreePineForestAsh01 - 05.nifs S3DTrees_TreePineForestAshL01 - 05.nifs S3DTrees_TreePineForestDeadAshL01 - 05.nifs Here's an example of what that looks like. I have omitted the trunks for the purposes of testing in this instance. These tree's and their respective LODs point to the same texture, the original one from the mod. So unlike before there's no texture replacement done on my end. The NiAlphaProperty value for all the crowns of these trees is '16'. Since I've noticed the issues, I've also tested resaving the textures and regenerating mipmaps with the Nvidia Texture Tools Exporter PS plugins with various kaiser and box mipmap generation techniques and cutout alphas then regenerating DynDOLOD from those. I do recall however that you said that DynDOLOD generates it's mipmapped textures. Is there something I'm missing here or is this infact a bug? Debug Log Link: https://cdn.discordapp.com/attachments/610980524818694191/890219634308022272/DynDOLOD_SSE_Debug_log.txt DynDOLOD_SSE_log.txt 38.84 kB · 0 downloads DynDOLOD adjusts the alpha threshold and mipmaps when adding textures to the tree or object LOD atlas. LOD has a fixed alpha threshold of 128. If a LOD model is added to an object LOD mesh and it uses a source texture directly instead of the texture atlas for whatever reason, then in fact it uses that unmodified source texture in all its glory with the fixed alpha threshold of 128.
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now