-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Align shapes to physical pixel grid #5164
Comments
* Closes emilk#5173 * Part of emilk#5163 * Related to emilk#5164
Additional thoughts Feathering and rounding is separate issuesFeathering (a form of AA) is for soothing out the edges of shapes. For instance: a line that is 1.3 physical pixels wide should maybe be rounded to be centered on a physical pixel, but still use feathering so that it appears wider than a line that is 0.7 physical pixels wide. However, for a thick and filled box, rounding all the corners to be on the corners of physical pixels results in the same effect as turning off anti-aliasing. Always round thin vertical and horizontal lines to the physical gridAnti-aliasing is always useful for diagonal lines. For vertical and horizontal lines (like the borders of a rectangle) it is usually unnecessary, except for the case when these lines are thick AND animated (either moving or growing/shrinking). Consider a thick box moving sideways. Without AA, a new column of pixels gets turned on at regular intervals, which is an annoying discontinuity. If we turn on AA, each new column "fades in", removing the jarring "popping". So AA should be ON in the this case. BUT in the case of a thin line moving to the right, then AA will turn a solid column of pixels into two columns of gray pixels, and then into a another column of solid pixels again, and so on. This will cause the line to appear to "blink" or "pulsate" as it moves, which is very annoying. If we round to physical pixels, then we will always have a solid column of pixels turned on, so at each point in time the line will have the same brightness and width. Yes, it will still jump in discreet steps, but in my experience, this is much more desirable. I'll try to generate a video to motivate this further. In any case, this leaves us with the conclusion that thin vertical and horizontal lines should always be rounded to physical pixels, and nothing else. What is the cutoff for "thin"? My instinct says it should be somewhere around two physical pixels, but this may require experimentation (and should be a setting of LimitationsPrefect tiling of thick rectangles still require turning off AA (or rounding the corners to physical pixels, which amounts to the same thing). Where to do the rounding?We could do the rounding in |
I just realized that rounding in So we're back to rounding in the tessellator again… |
* Merge this first: #5517 This aligns all rectangles and (horizontal or vertical) line segments to the physical pixel grid in the `epaint::Tessellator`, making these shapes appear crisp everywhere. * Closes #5164 * Closes #3667 This undoes a lot of the explicit, egui-side aligning added in: * #4943 The new approach has several benefits over the old one: * It is done automatically by epaint, so it is applied to everything (no longer opt-in) * It is applied after any layer transforms (so it always works) * It makes line segments crisper on high-DPI screens * All filled rectangles now has sides that end on pixel boundaries
When painting shapes, it is sometimes preferably to align them to the physical pixel grid.
There are a few different ways we can attack this:
A) A document and make it easy for users to align
B) Always align shapes, and opt-in to non-aligned shapes
C) Always align all shapes
I think
B
is preferable, the question is how to accomplish it on a per-shape basis.We could add a
bool
flag to each shape, and have the tessellator do the alignment, unless the flag is set.Or the
Painter
aligns all shapes, unless you callpainter.add_unaligned(…)
or something like that.When to align
Sharpness
We always align text to the physical grid (unless rotated), because otherwise it looks blurry.
Similarly we align many vertical lines, horizontal lines, and rectangle frames to make them sharper:
Tiling
When painting many rectangles that should seamlessly tile:
#4928 (comment)
In this case, the end results would look better if the rectangle was aligned to the physical pixel grid.
When not to align
When you want to smoothly animate something.
The text was updated successfully, but these errors were encountered: