-
Notifications
You must be signed in to change notification settings - Fork 840
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
[EuiIcon] Icon asset paths/content off center from viewbox #7723
Comments
@nickofthyme: I'm guessing the 1px offset for this icon was used to ensure the 1px line portion stays perfected on the pixel grid. As the viewbox for EUI icons are 16x16px, this requires an offset of 1px. The reason we try to stick to the pixel grid as often as possible is because subpixels rendered on monitors that aren't a high pixel density end up looking blurry. As for this particular icon, we can either:
I'll explore both later today and let you know what I'd recommend. |
@nickofthyme: Does something like this work for your needs? I made some adjustments to allow the icon to be perfectly center in the viewbox while still adhearing to the pixel grid. If this works for you, I'll make a PR to update EUI with it. Also, we seeing as your Material icon example used a more traditional flat-top push pin, I just wanted to note that we also have |
Oh gotcha, that makes more sense why it was done that way. I don't have any need for the pin specifically, I just noticed that the it along with other icons were off center, the Material pin was just an example of a centered icon. I wonder if it's worth expanding the icons to a |
Ideally, yes, they would always be perfectly vertically and horizontally centered. In reality though, if we merely centered them, those 1px lines within each of the icons you reference would become blurry on low pixel density displays (i.e. non-retina). Here's an example on my lower pixel density monitor (~110ppi) at 100% scale. Notice that the perfectly centered icon on the right is a bit less crisp and blurrier than the one on the left with the 1px offset.
Unfortunately, we would still likely encounter this problem even if we increased the source SVG viewboxes to 24x24px due to the nature of attempting to center a 1px element on an plane that has an even-numbered width. Additionally, these 24x24px icons would still be rendered at a scaled down size of 16x16px or 12x12px across many areas of Kibana. This downscaling could create even more instances where subpixels would be antialiased and appear blurry on these lower density displays. Ultimately, I think we need to ask ourselves which is the lesser evil? Is it better for us to have perfectly centered icons and risk them being a bit blurrier on the majority of displays? Or is it better to keep the icons appearing as crisp as possible with the occasional offset as needed? Historically, we've opted for the latter, but happy to discuss further if there are differing opinions. |
The way I see it, the only real solution is to redraw all icons that don't take the whole 16x16 grid or take an odd number of pixels on any axis, so they can't be centered using the remaining number of pixels without introducing sub-pixel rendering. The quality of sub-pixel rendering depends on pixel density, display sub-pixel layout, display rotation, video signal compression, operating system, browser, and even drivers. We don't control any of these, but we should always try to render the best view possible. I also want to note here that sub-pixel rendering doesn't only apply to our icons. Some of our font sizes also fall into this category—our rem units resolve to values like It's a lot of work for a relatively tiny difference. Just for fun: nearest pixel rounding diffs |
Thanks for those additional points, @tkajtoch. I was actually just recently wondering about our EUI font size values. All that said @nickofthyme, do you feel it's still worth it for us to update the |
No I just wanted to make you all are aware of it, if we can fix/consider it progressively as we add new icons or update old ones. As for the sub-pixel blurring, those are really good points, though it seems like the vast majority of kibana users are using HD screens. So I personally would favor centering icons over avoiding sub-pixel blurring, possibly in a
Anyways I'll go ahead and close this issue for now. |
Is your feature request related to a problem? Please describe.
Looking at an alignment issue in charts I noticed the icon was just slightly offset from the chart
LineAnnotation
.Then looking at the raw eui svg, I could clearly see an offset to the left.
Comparing this to other public libraries like Material Symbols, I see the icons correctly centered.
I'm not sure how many of the icons are affected but this is quite noticeable on icons which are horizontally symmetrical in design.
I'm no
svg
expert here and could be missing something but thought I'd share.Describe the solution you'd like
Go through all icons and center them as needed.
Desired timeline
Whenever
cc: @MichaelMarcialis
The text was updated successfully, but these errors were encountered: