#438 posted by babgo on 2016/01/03 23:31:37
You guys seem to over-emphasize smaller differences in rendering from GL to Software. I mean, what most people really want, and notice, are the pixeled textures. And that's it.
Babgo
#439 posted by Kinn on 2016/01/03 23:36:45
Without simulated 8-bit rendering (i.e. every pixel you see on screen is in the quake palette) I'd be reluctant to say it looks anything like software quake.
The quake palette is not up to the task of rendering most modern maps which have been designed with coloured lighting. They look like garbage in anything but mark_v and quakespasm.
I Know
#441 posted by Kinn on 2016/01/03 23:51:03
#442 posted by Lunaran on 2016/01/04 03:34:07
I mean, what most people really want, and notice, are the pixeled textures. And that's it.
overbright lighting is hugely important. glquake doesn't support it, which is why everyone complained about it being "dark", and the idgamma fix which just wrecked the palette instead was ugly and didn't address the real problem.
metlslime began supporting it in fitzquake 0.70 or so.
Software Quake
#443 posted by mh on 2016/01/04 12:11:18
There's also R_DrawSurfaceBlock8_mip0, R_DrawSurfaceBlock8_mip1, R_DrawSurfaceBlock8_mip2 and R_DrawSurfaceBlock8_mip3.
nearest_mipmap_nearest looks fine, but nearest_mipmap_linear can look better; it retains the pixel crunchiness but gives a smoother transition between mip levels. Of course that's moving away from how software Quake looked again, but that's no bad thing IMO in cases where software Quake actually did look worse (is anybody really and seriously going to argue that particles that get smaller nearer the viewpoint look better, for another example).
Of course, some people confuse aliasing with detail, which is why some may actually prefer gl_nearest on it's own.
All that aside, the pixel crunchiness of software Quake has other advantages too, aside from just pixel-crunchiness for the sake of pixel-crunchiness. One of them is that the texture art is actually quite finely detailed down to a per-texel level to begin with, with a lot of those details being as small as a single texel. Look at the health pickup box textures, for example. When you blur those with linear filtering all of that fine texture art just turns into a mushy mess.
@Fifth
#444 posted by mh on 2016/01/04 12:17:02
The quake palette is not up to the task of rendering most modern maps which have been designed with coloured lighting. They look like garbage in anything but mark_v and quakespasm.
I'm sorry, but Quakespasm doesn't do anything special with either the Quake palette or with textures. It's just an absolutely standard 2x modulate blend using built-in GL functionality.
#445 posted by necros on 2016/01/04 12:42:50
(is anybody really and seriously going to argue that particles that get smaller nearer the viewpoint look better
This is one of the things that bothers me with most modern engines that "fix" it...
#446 posted by Kinn on 2016/01/04 13:26:40
(is anybody really and seriously going to argue that particles that get smaller nearer the viewpoint look better
What like e.g. in QuakeSpasm? A particle near the player's face is a quake unit in size I think, but the same particle the other side of the room has to be drawn bigger otherwise it would be completely invisible.
Particles
#447 posted by mh on 2016/01/04 13:56:50
A particle near the player's face is a quake unit in size I think, but the same particle the other side of the room has to be drawn bigger otherwise it would be completely invisible.
Nope, that's not what I mean at all.
It's evidently been quite a while since people have actually used software Quake, and have forgotten how it really looks... :)
What I mean is that in software Quake particles on the other side of a room start out small enough, but still visible. As they get closer they increase in size normally with perspective. Then once they get so close they start getting smaller again. So a particle that's, say, 10 units from the viewpoint is actually substantially smaller than one that's, say, 100 units from the viewpoint.
That's how software Quake looks and that's what I mean.
#448 posted by Lunaran on 2016/01/04 20:44:47
To try to retain the distance cue of particle size without occasionally obscuring the view with a gigantic square of color? Makes sense.
Lunaran
#449 posted by mankrip on 2016/01/04 22:23:56
No. It was due to the particles of the vanilla software renderer being fully broken.
Everything about their maths is fucking wrong. From the top of my head, here's a list:
� They're not scaled to the screen resolution. They were developed for a 320*240 video mode, with a double height version for the obscure 320*480 video mode, and that's it. Their dimensions will always be wrong on any other video mode, including 320*200.
� They were hardcoded for FOV 90, and go wrong on any other FOV. This makes them get actually *smaller* when zoomed in, which is bloody awful.
� Their origin in 3D space is *not* in the center of their square, but in its top-left point. If you freeze them by pulling down the console and then rotate the camera around, their squares will move around their top-left point, instead of staying at the center of their previous 3D space position.
� Their maximum size is 8 pixels, IIRC. Again, the actual screen resolution is ignored, which means that in lower resolutions, they'll be able to get closer to the camera before being clamped. So, this "feature" doesn't make sense at all, it's just some weirdness that people got used to.
I'd actually challenge people to play WinQuake at 320*240 fullscreen for several hours doing everything the vanilla game can do and try to compare it to how the game look & behave on their regular engine & config setups. But I don't want to be that annoying. :P
Addendum
#450 posted by mankrip on 2016/01/04 22:40:59
The main purpose of the mipmaps in the software renderer is not to make the game prettier, but to conserve surface cache memory, which is used for the lighting.
Since the liquids in the vanilla renderer doesn't use lightmaps, they don't use mipmaps either. And hardware rendering with mipmaps will also mipmap the liquids.
And GL_NEAREST doesn't disable the lightmap filtering, not to mention that hardware rendering doesn't feature the same color banding of Quake's colormap, unless explicitly coded for it (FTE is one of the rare hardware-accelerated engines that does this, but I haven't tested it).
#451 posted by mh on 2016/01/04 22:45:41
To try to retain the distance cue of particle size without occasionally obscuring the view with a gigantic square of color? Makes sense.
Seems more like you're trying to retroactively justify incorrect behaviour. That's not going to fly. Again, I'd encourage you to actually go back and run the original software Quake to see exactly what it is you're trying to support.
#452 posted by mh on 2016/01/04 23:12:16
The main purpose of the mipmaps in the software renderer is not to make the game prettier, but to conserve surface cache memory, which is used for the lighting.
For anyone interested in learning more about the reasons behind many of the decisions in the software Quake renderer (and those reasons are often "it had to run in 8mb on a P60") the latter chapters of Michael Abrash's Graphics Programming Black Book are a valuable reference: http://www.drdobbs.com/parallel/graphics-programming-black-book/184404919
Mankrip's statement here is confirmed by chapter 68, the section on mipmapping, by the way.
#453 posted by Kinn on 2016/01/24 14:19:37
Can a charitable gentleman remind me which Quake engines have external file reading/writing ability via QuakeC?
#454 posted by mankrip on 2016/01/24 17:03:47
Makaqu (and therefore Super8) does, IIRC.
Darkplaces and FTEQW certainly does.
Noice
#455 posted by Kinn on 2016/01/24 17:15:35
Any idea whether they follow a standard, or just do it in different ways?
#456 posted by mankrip on 2016/01/24 17:37:40
Most engines with QC file access probably uses Frik_File.
Right Cheers
#457 posted by Kinn on 2016/01/24 17:38:57
If that's a kind of standard, and QuakeSpasm were to implement it, it would be AWESOME
BSP Trees
Not an engine programmer per say, but was curious if its possible to put in an engine hack which recalculates collisions against regular bsp and treats them as if they were q3 bsp, so that the point, player and shambler hitboxes can be overcome?
RE: BSP Trees
#459 posted by Spike on 2016/01/25 09:14:34
No.
Q2/Q3 BSP does not use the bsp tree for culling, it only uses it to find the nearby brushes.
The information needed just isn't in the file...
With the 'smoothnstuff' branch of ericw's branch of tyrutils, the 'stuff' part that I snuck in includes an -wrbrushes argument to qbsp. This causes the qbsp to insert brush info into the bsp file, this can be used with a supporting engine (read: FTE only for now) for brush collisions in a similar way to q2 or q3 brush collisions.
(you also need to use the matching vis+light tools in order to prevent the extra info getting stripped).
Add -noclip if you want to break every other engine but compile your bsp a bit faster, but without this second arg, the bsp will still work in other engines, just using vanilla-style collisions.
#460 posted by metlslime on 2016/01/25 09:26:12
bsp leaves are convex, in theory the engine could treat each solid leaf as a brush, then use that brush to do the q2/q3 brush expansion logic to handle arbitrary sized boxes.
that's also how collision should be handled on rotating brushmodels.
#461 posted by Spike on 2016/01/25 09:57:17
in theory, you can do something like that (a little more complex though).
in practise, you lose all clip brushes.
The other option is to use trisoup collision. Again, no clip brushes, so again not a real option (imho).
#462 posted by metlslime on 2016/01/25 10:11:30
ah right, clip brushes. I guess you could pull them out of hull1, but they would only be useful against entitys at least player size (since you can't shrink them, only expand.)
|