Aside from bad programming on Gravity's part, why is that RO runs so badly even with an "ultra" high end system? (Example: a 6700k, low latency DDR4, PCIe SSD, 1080 GTX 8GB)
I'm looking for solid information about this, since I don't really know how else to measure it and I don't have deep knowledge about gaming or systems programming. From what I could find, the client is still using DX7 (or some kind of DX9 adapter, not sure). Gravity was working on a DX11 port but I can't find any information if they will ever release a complete version of it.
Anyway, here's what I concluded in my tests in the system mentioned:
None of this have significant impact on getting constant 60+ FPS without drops and decent frame times, if they are properly configured or installed: drivers or Windows library versions, anti-aliasing or anisotropic filter settings, CPU priority, screen resolution, fullscreen on or off (if you have the ddraw fix installed, it's the same as borderless window fullscreen, since the low fps here is caused by a bug), custom dinput, any of the ingame settings like /skip /lightmap, power settings that might cap resources turned off, GPU shader caching. What I mean is, none of this is going to magically solve the FPS problems. It's not hard to get 60 FPS, the problem is frame drops and bad frame times. And the cause for that is something else!
Some hack shields can make your average FPS worse, but I don't think they are the root cause since a pure hexed still suffers from the same problems.
Replacing all the spr/act files (for player visual items) with empty one's have almost zero impact on FPS. Same thing for effects (str, bmp, tga). At the same time, if you stand still in a city like prontera with a lot of autotraders, your FPS will drop to 30 or less, screen tearing all over the place. Turning packetfilter on doesn't help. What causes this?
At the same time, turning effects off does help with the frame drop problem. Why is that loading close to 0 bytes files doesn't help but turning effects off does? Even after they are alreaded loaded (and in memory) you don't get the same benefits. Does it turn off some kind of indexing?
Grey world GRF does help but only if you would have less than 60 fps, so again, it doesn't help improving frame drops and latency.
Water cells are indeed one of the problems, I wish I could remove them all without editing maps or using grey world. If you know how to do it, please share.
Some maps like arug/schg runs like complete shit.
Some, but not all, older systems suffers less from frame drops and tearing (while having lower average FPS). Probably has something to do with newer GPUs and drivers losing optimizations.
So, what exactly causes the game to drop frames, have weird screen tearing (even with some kind of vsync forced with double or triple buffering), stutter or have bad frame times? What is the resource that the game client needs? What's the bottleneck? What can I feed this dog for it to stop barking?