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

πŸ—οΈ Rework vertex data #73

Merged
merged 4 commits into from
Feb 13, 2024
Merged

πŸ—οΈ Rework vertex data #73

merged 4 commits into from
Feb 13, 2024

Conversation

paulcscharf
Copy link
Member

✨ What's this?

I started with wanting to support integer vertex attributes.

Doubles looked supported but were broken because of the wrong GL method call and because of a copy-paste error.

Refamiliarising myself with the relevant GL methods, I also realised that integer normalisation works differently than I thought, and decided that it should default to not normalise anything - except Color, which is specifically intended to be normalised.

I also believed there was confusion about how byte sizes were calculated - though then realised it was working correctly after all and undid the changes, replacing the previous dictionary with a switch expression due to likely compiler optimisations.

Caveat

This latter point highlights a bigger issue, which is that the vertex attribute stride is currently calculated as the sum of vertex attribute sizes, which is not necessarily correct and depends on the struct layout and packing settings. Instead, it would be more correct to inspect the structs with reflection and other methods to get the actual byte offsets of fields annotated with attributes for names and format settings and alignment in arrays. I would also like to have an attribute that forces a check, perhaps at compile time or with an analyser, or if needed at runtime, to see if vertices are optimally laid out and aligned, so that they waste no space, no performance due to bad alignment inside arrays, and can be copied to GPU memory AS IS, instead of requiring expensive transformation of the data.

However, none of that is inside the scope of this PR.

πŸ” Why do we want this?

  • Fixes bugs and unclear behaviour around normalisation
  • Enable integer and double attributes

πŸ’₯ Breaking changes

IVertexData and VertexData public interfaces have changed, requiring all vertices to be updated, though most of them only require making the interface method static, and changing its return type - source compatibility is otherwise largely maintained, as long as the previous optional normalisation parameter was not specified.

The default for all integer attributes is now not to be normalised, whereas before signed and unsigned bytes were.

πŸ”¬ Why not another way?

Could have done it without breaking changes, but it would have made interfaces less clear and perhaps even ambiguous.

While the above caveat remains the same, at least this new version is less and clearer code, easier to use, etc. and should not require any more changes until we perhaps redo it all again as indicated in the caveat.

- make IVertexData.VertexAttributes static and immutable
- support double and integer vertex attributes
- remove automatic normalisation for integer types
- fix attribute size being incorrectly calculated based on attribute pointer type, instead of source data
- make vertex attributes and templates structs and improve method signatures to reduce allocations
- move all parameter validation to helper class
@paulcscharf paulcscharf merged commit 3ff71f9 into master Feb 13, 2024
1 check passed
@paulcscharf paulcscharf deleted the vertexdata-rework branch February 13, 2024 11:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants