Support for SVG images could also make the UI system more flexible considering scaling. I made the current default UI’s theme entirely in Inkscape, but it is read from a PNG. Using the SVG directly could make the default UI more suitable for HDPI, for instance.
Compare:
…and…
SVG support for UI
data:image/s3,"s3://crabby-images/46286/46286511a1a3dd908bc25dd8221a6e3d7b2bd7a2" alt=""
data:image/s3,"s3://crabby-images/e21a1/e21a140f65f9db5e07d2fbd186868f96fbc75224" alt=""
SVG basically means that the images would have to be generated on the fly, which I believe is a costly operation. But on the bright side, you would have specific resolution optimized images. Some POC of this would be great tho
data:image/s3,"s3://crabby-images/a82e6/a82e68875727a8a1ea730112fea5e6131d2d7210" alt=""
dual support! png for 728- and svg for hdpi?
data:image/s3,"s3://crabby-images/46286/46286511a1a3dd908bc25dd8221a6e3d7b2bd7a2" alt=""
They could be stored; you’d only have to render them when the size of an element changes. Elements of the same size and style could share the rasterized image.
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
I’d like to see the enture UI system move toward NDC, but thats just me. Scale that.
data:image/s3,"s3://crabby-images/46286/46286511a1a3dd908bc25dd8221a6e3d7b2bd7a2" alt=""
@Leith What do you mean by NDC?
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
NDC coordinates are normalized device coordinates - 0 to 1
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
works for any resolution
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
we should never specify anything in pixel coords, we should translate image coords to ndc and vice versa
data:image/s3,"s3://crabby-images/46286/46286511a1a3dd908bc25dd8221a6e3d7b2bd7a2" alt=""
For crisp rendering of raster images you do want pixel sizes and coordinates, but I agree it makes sense to have normalized coordinates at your disposal as well.
Maybe some convenience functions could be a start? Like:
Vector2 UIElement::toNormalizedScreenPos(IntVector2)
IntVector2 UIElement::toPixelCoordinates(Vector2)
float UIElement::toNormalizedSize(int)
int UIElement::toPixelSize(float)
These would take things into account like parent-child structures and window or screen size.
There’s already:
IntVector2 UIElement::ScreenToElement(const IntVector2&)
IntVector2 UIElement::ElementToScreen(const IntVector2&);
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
The conversion is generally simple enough, but it takes some thinking for pixel artists - still, done once, it works on any resolution.
data:image/s3,"s3://crabby-images/1d776/1d776747570ad59fe9acc6598083f987f1b77530" alt=""
Isn’t having multiple sizes per platform a better approach? @2x.png, @4x.png, etc. That has the performance benefit. You can still have an SVG and just bake the bitmaps with appropriate sizes, which is what the engine reads. Efficiency first.
data:image/s3,"s3://crabby-images/46286/46286511a1a3dd908bc25dd8221a6e3d7b2bd7a2" alt=""
Maybe there could be an automated form of exactly that. You’d want to prevent anti-aliasing leaks anyway.
data:image/s3,"s3://crabby-images/1d40e/1d40e0025e14a6b3c0b9b5183ec6c8b24c93c8a3" alt=""
Most engine’s I’ve worked with have the option to use both at the same time, why can’t we.
data:image/s3,"s3://crabby-images/b663e/b663e21edc5a4218a13594be413ce02ae10d2b51" alt=""
I’ll consider writing up some utility methods to convert between NDC and pixel coords, but to change the entire UI system to use NDC as an option? I am optimistic, but I recognize that it’s likely to be non-trivial.
Most things that are easy, are not worth doing. Some things that seem hard, are definitely worth the effort.