-
Notifications
You must be signed in to change notification settings - Fork 7
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
A scattering of color concepts we're investigating for Graphite #4
Comments
Thanks, I think this is useful for discussion. Here is a quick response, though a lot of these topics deserve a more detailed discussion. Some of the things are natural, some are orthogonal, and others are deliberately out of scope. Definitely handling CMYK colors or more than 3 components is out of scope for this crate, though certainly an interesting problem (and plausibly feature gated). We have missing channels, transparency, types for premultiplied and separated alpha, methods for calculating luminance. Transfer functions are implicit in color spaces. I deliberately didn't include white point because I think it's unneeded complexity; the Bradford linear chromatic adaptation transform should be good enough for almost all uses, and that is what CSS Color 4 specifies. We have HDR color spaces represented, most especially DisplayP3, which will be the main focus for HDR rendering in Vello. I imagine some methods for gamut mapping as well, but haven't figured out the details of what that would look like. We do the color math needed for gradients, but don't deal with gradient geometry. That's in scope for peniko, which almost certainly will take on a dep to the new crate for color (replacing the existing limited rgba8 stuff). We don't deal with bit depth because I consider packing to be an orthogonal issue, and likely to be quite specific to an image format or GPU integration (I think f16 is a desirable target, and that's an expensive dep). I also consider chroma subsampling to be a detail of an image encoding format. PBR and other appearance correlates feel out of scope. Probably a good layering is for a crate dealing with PBR materials to depend on this color crate for the color-specific stuff. Other things that I think of as out of scope include ICC color profiles and ACES transforms. All these decisions are subject to revision, though I would be wary of anything that dramatically increases complexity for the main use cases we care about. |
Looking at the design we should be able to basically just implement our color traits for this representation to allow our nodes to work with the types without too many changes. But I'll need to do a deeper dive to check if it would make sense to adapt it further. We could also consider using a fixed repr (e.g. #[derive(Clone, Copy, Debug)]
pub struct AlphaColor<T> {
pub components: [f32; 4],
pub cs: PhantomData<T>,
} Should be equivalent to our |
One immediately actionable item is slapping I personally feel that representing alpha mask values is out of scope for this crate, but I am open to concrete proposals that would help unify things for clients. |
Just pasting this here so it's something that can be referenced more publicly. These are a number of loosely organized concepts we've been brainstorming for potential future use with Graphite's use of color. @TrueDoctor was specifically interested in investigating how far it might be possible to encode some or all of these using Rust's traits system.
Separately, gradients should be considered for how they interpolate and how mapping operations can be applied to them.
The text was updated successfully, but these errors were encountered: