Refactor/Rewrite overlay wire colors #110097
No reviewers
Labels
No Label
Interest
Alembic
Interest
Animation & Rigging
Interest
Asset System
Interest
Audio
Interest
Automated Testing
Interest
Blender Asset Bundle
Interest
BlendFile
Interest
Collada
Interest
Compatibility
Interest
Compositing
Interest
Core
Interest
Cycles
Interest
Dependency Graph
Interest
Development Management
Interest
EEVEE
Interest
Freestyle
Interest
Geometry Nodes
Interest
Grease Pencil
Interest
ID Management
Interest
Images & Movies
Interest
Import Export
Interest
Line Art
Interest
Masking
Interest
Metal
Interest
Modeling
Interest
Modifiers
Interest
Motion Tracking
Interest
Nodes & Physics
Interest
OpenGL
Interest
Overlay
Interest
Overrides
Interest
Performance
Interest
Physics
Interest
Pipeline, Assets & IO
Interest
Platforms, Builds & Tests
Interest
Python API
Interest
Render & Cycles
Interest
Render Pipeline
Interest
Sculpt, Paint & Texture
Interest
Text Editor
Interest
Translations
Interest
Triaging
Interest
Undo
Interest
USD
Interest
User Interface
Interest
UV Editing
Interest
VFX & Video
Interest
Video Sequencer
Interest
Viewport & EEVEE
Interest
Virtual Reality
Interest
Vulkan
Interest
Wayland
Interest
Workbench
Interest: X11
Legacy
Asset Browser Project
Legacy
Blender 2.8 Project
Legacy
Milestone 1: Basic, Local Asset Browser
Legacy
OpenGL Error
Meta
Good First Issue
Meta
Papercut
Meta
Retrospective
Meta
Security
Module
Animation & Rigging
Module
Core
Module
Development Management
Module
Grease Pencil
Module
Modeling
Module
Nodes & Physics
Module
Pipeline, Assets & IO
Module
Platforms, Builds & Tests
Module
Python API
Module
Render & Cycles
Module
Sculpt, Paint & Texture
Module
Triaging
Module
User Interface
Module
VFX & Video
Module
Viewport & EEVEE
Platform
FreeBSD
Platform
Linux
Platform
macOS
Platform
Windows
Severity
High
Severity
Low
Severity
Normal
Severity
Unbreak Now!
Status
Archived
Status
Confirmed
Status
Duplicate
Status
Needs Info from Developers
Status
Needs Information from User
Status
Needs Triage
Status
Resolved
Type
Bug
Type
Design
Type
Known Issue
Type
Patch
Type
Report
Type
To Do
No Milestone
No project
No Assignees
8 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: blender/blender#110097
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "Gilberto.R/blender:temp-fresnelpref"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
The main goals of this rewrite are to add a Userpref that toggles the fresnel effect on mesh overlays(wireframes, vertices, facedots), improve the fresnel effect, and enable colored wires on any shading mode.
In order to add the option to toggle the object mode Fresnel. I've had to rewrite the code for wire color in 'overlay_wireframe_vert.glsl', which resulted in a simplified code with less branching, less calculations, some fixes, and allowed the feature of wireframe colors in any shading mode.
The fresnel was added in 2.80, but was one of the little things that added up for worse selection visibility overall when comparing to Blender 2.79. That's why I wanted to remove it. It was also terrible for the visibility of colored wires. To improve it I simplified the code and applied it to the wire opacity, and it worked well even on colored wires and has a more noticeable effect that is more useful for shape readability. So now it is improved and optional.
The edit mode fresnel is only a bit useful in edge cases, like very dense photogrametry, and the problem is that it causes more eye strain when modeling for many hours. And it's benefit on shape readability is small compared to it's negative impact on selection visibility. It makes the selection color to a darker less saturated color instead of the theme color, which leads to worse contrast between the selection and the mesh or with the background, and also makes the unselected (black) brighter, also reducing contrast. So it's off by Default.
Changes:
I couldn't remove the fresnel from Grease Pencil objects because it is a bit complicated. I won't be able to fix that.
I have decided to not apply the object color alpha to the wire opacity because there already is a wireframe opacity slider that serves this purpose and because faded object with color, and wire colors looks cool.
Based on discussion from https://devtalk.blender.org/t/blender-2-8-wireframes-discussion/
and on Jeroen's original Diff https://archive.blender.org/developer/differential/0010/0010436/
is this patch an implementation of this request https://blender.community/c/rightclickselect/yXY6/?
@sanek122005 Actually it is not an implementation of that request. Though I agree that that disabling that gradient should be themeable, and is important specially for people that come from a certain software. cough cough M.... It's not what this patch is about. The fresnel affects the whole mesh, not only the unselected edges around vertices. In fact, with this patch, those unselected edge gradients will be even a little stronger by default, like in 2.79. But it's for your health.
Some changes of passing the setting to the shader.
float
toGlobalUboStorage
namedfresnel_factor
.non_linear_blend_color
calls with the input using this factor.Any changes in user prefs and its defaults I recommend to pass by Pablo.
in Edit mode it is okay to have markers of selection.
But whats about object mode with wireframe look? Or for wireframe objects?
Fresnel sometimes makes them less visible and managable.
Look at this! Wire mode for mesh line On/Off
Add Toggle for Edit Mode Fresnelto Add Slider for Edit Mode FresnelI expected it still to be a boolean in the user pref, just when sending it to the shader fill the fresnel_effect_factory with 0.0 or 1.0. Codewise the rest seems as expected, we still need approval from Pablo when he is back and want to test drive it to make sure it is working on other devices as well.
That will be good, thanks!
Add Slider for Edit Mode Fresnelto Add Userpref to toggle the fresnel effect on mesh overlaysAdd Userpref to toggle the fresnel effect on mesh overlaysto WIP: Add Userpref to toggle the fresnel effect on mesh overlaysWIP: Add Userpref to toggle the fresnel effect on mesh overlaysto WIP: Rewrite overlay's wire colorsWIP: Rewrite overlay's wire colorsto WIP: Rewrite overlay wire colorsWIP: Rewrite overlay wire colorsto WIP: Refactor/Rewrite overlay wire colorsWIP: Refactor/Rewrite overlay wire colorsto Refactor/Rewrite overlay wire colors@blender-bot package
Package build started. Download here when ready.
Hi, thanks for working on this. An initial +1 for this idea, with some notes and mockups below.
At first I was undecided about having two separate settings for Edit and Object modes, since we should always strive for having a good experience for everyone. After using it for a while it is clear that mesh density is key, and these settings are tailored for different workflows, so +1 on having both.
However, the name
Object Mode
is misleading since it also applies to Sculpt, Weight Paint, and all other modes except Edit. So how about having two options:To turn all Fresnel off, disable both
All Modes
andEdit Mode
.When
All Modes
is enabled butEdit Mode
is disabled,All Modes
's checkbox uses the new intermediate state by Harley.Defaults
Regarding defaults, I think Edit Mode is indeed much better without the fresnel effect because we are constantly working on the topology. While in other modes or workflows it can be useful depending on the use case, for example to see the volume of dense meshes. So the last example image where
All Modes
is on butEdit Mode
is off, would be a good balance as default.Tooltips would need to be reworded, also the words
Toggle
can be excluded since it's implied by the widget.I can't give feedback regarding the code itself, but I think since these options are booleans they should start with
use_
? Likeuse_fresnel
anduse_fresnel_edit
.IMO it looks too obscure and unobvious
Partial check is okay when there is a hierarchy under the main checkbox.
And «All modes» that «not actually all» confuses me.
So I suggest another approach:
So it looks like two parts of whole set: one + others.
@pablovazquez Hi, thank you for testing! I agree it's wrong to call it 'object mode', so I changed it, but I went with @Vyach suggestion, ok?
I think the fresnel is too strong to be on by default as it is, because it makes flat surfaces like a subdivided plane, or grease pencil object harder to see in wireframe view with wire color black. I can lower the fresnel intensity, to look subtle like the old fresnel and make it the default, but it becomes less useful to see the object's shape, so I am thinking of adding a slider to control the intensity of the fresnel.
By the way why is there fresnel on grease pencil objects wireframe?? I will try to remove that.
@Gilberto.R I've tried out the patch.
Imo the object mode fresnel should be turned way down to how it looked like before. It makes it subtle but just useful enough to help with readability on high res meshes, especially when selecting objects.
If people want to have the wireframes more subtle, they are able to turn down the wireframe opacity.
If the wireframe opacity is turned down, the shading of the surface will contribute heavily to the sense of curvature. The wires don't need to contribute that much to that with fresnel.
But here's a comparison on the wireframes on a sculpted character with flat shading, as well as lowered wireframe opacity with shading.
Note how it becomes entirely pointless to lower the opacity on the new fresnel.
There's various other models this can be tested on of course. The topology could be way denser than this or way lower. But the effect is still the same.
Apart from that:
@JulienKaspar thank you for testing! I'm looking into how to hide the "attribute" and "texture" from wire color . I agree on changing the name from 'Single' to 'Theme', but I would have to create a different enum, because right now both color_type and wire_color_type share the same enum. Edit: Done.
Yes, please, because visible power of effect depends on few things:
Color of frame,(that depends too)
Density
User’s monitor
User’s taste/sight ofc
Type of workflow
Complexity of scene
So there is no best solution once for all. Also I know, Paul (@1dinc) suggested amplifier for effect, so slider may be from 0 to 2 4 example, where 1 is default and as it is before.
@blender-bot package
Package build started. Download here when ready.
@JulienKaspar I will lower the fresnel to be subtle like the old fresnel by default. But we will still need the fresnel slider as an option for stronger fresnel. Reducing wireframe opacity in wireframe shading mode would make the bright wires look muted, so it wouldn't be possible to achieve this result:
@ -112,2 +65,2 @@
if (isObjectColor || isRandomColor) {
wire_object_color_get(rim_col, wire_col);
/* Base Color */
if (isRandomColor) { /* Dim random color. */
We might want to split this into multiple functions for readability.
We currently store 3 uniform bools what can due to changes in this patch be reduced
to a single int (colorType). For reference on a GPU a bool is 32 bits same as an int. Although not important for OpenGL, but when all uniforms space together are smaller then 256 bytes it can be optimized by the backend as push constants so we try to keep them as small as possible.
We should always test uniform values before local variables as these are constant in all cores of the same compute unit (for GPU hardware this can matter)
The defines can be added to
overlay_shader_shared.h
This part would then be reduced to
@ -136,1 +136,4 @@
float size_vertex_gpencil;
float fresnel_mix_edit;
float fresnel_mix;
float _padd[2];
typo
Now I just have to add the Versioning.
@Gilberto.R I've been testing this out a bit more. The fresnel slider is still, not really solving the issues I've mentioned.
One reason is because the slider is for both the edit and object mode, even though their look and behavior is very different.
For Edit Mode a value between 0.3 or 0.4 is already enough and helps readability without making wires too transparent. It's easy to get the old fresnel look.
But for object mode any value below 0.6 is not having any perceivable effect on the overall fresnel and instead just overall opacity. Any value above is visibly affecting the fresnel but at that point having too big of an impact on the opacity to be readable.
A notable difference is that the fresnel effect is inverted in the old behavior.
The silhouette of the object mode has muted wires instead of the center when using colored wires. This is crucial.
The example image that you showed above is also not ideal imo. While the strong fresnel is making the silhouette of objects very readable, the actual wires are not.
Any wires that face the view directly or halfway are too transparent, making it necessary to toggle fresnel in the preferences when working with wires. With this behavior the wireframes are just becoming a colored outline, losing the usefulness of visualizing the wires.
The old fresnel also seemed to have a much different effect on selected objects while in solid shading. So there was already some different behavior depending on the color of the wireframes.
Notable here is:
If it would just be the preferences to toggle the fresnel, I'd be happy to have this in Blender already. The new fresnel will take some more time.
@JulienKaspar thanks for the feedback.
The sides of the mesh wireframe often look more dense because of the view perspective, so the silhouette boundaries seem "brighter" with colored wires, and "darker" with black wires. I had tried making the fresnel more sinergic with that, as doing it the other way, the fresnel on opacity would flatten the wireframe for low fresnel intensity values. But that isn't a big deal as the fresnel wasn't really noticeable with low fresnel intensity, so I have inverted it back to look more like the old behavior, now most of the opacity of colored wires should be controlled with the wire opacity slider.
The fresnel is inverted for selection in the old behavior though (boundary is brighter than center). Should I do that? I think it can help differentiate selection from unselected.
I'd like us to take a few steps back and have a look at what we're trying to fix or improve in the first place.
Why is the fresnel now using transparency instead of just changing the wire color?
This has a very bad negative impact. The wires lose a lot of contrast the moment they turn transparent. This was already an issue when using the opacity slider in the overlays.
We should aim to avoid this.
This is a comparison when using a value of 0.03 for the fresnel preferences. It shows the change in contrast quite clearly.
Why are the wires overlayed additive instead of overlaying them normally?
Especially with the recent changes this is even more clear. The old behavior shifted the colors of the wires instead of blending them with whatever is underneath.
As it stands right now I vastly prefer the old fresnel for readability, so there's not much improved on that front.
If we can address the core complaints that were raised on the readability we can also leave the fresnel enabled by default without the need for a slider.
For example it would help to reduce the fresnel effect or strengthen the contrast of the colors for selected wires specifically. Fine tweaking it to achieve something that's readable in more cases.
I think a good way to continue for now is to split the PR up.
These aspects of the PR are all good to me on the usability side:
It would be a shame for this discussion to block the these to get in.
Any big changes or fine tweaks to the fresnel drawing can be handle separately:
Ok, I will split it. The first part, the edit mode toggle, is here #111494
Another part. Colored wireframes option on all shading modes #111502
Object mode still need both appearances. Fresnel helps read volume in wire mode, no Fresnel helps to see silhoettes/areas.
So it should be overlay setting, not a general setting IMO
@Vyach they probably won't let me add anything to that panel, because it is too cluttered. For seeing just the sillhoette, it is better to set Solid mode Lighting from Studio to Flat on the shading panel.
Yes, it is loaded full. But Fresnel is still overlay.
And in 4.0 overlay panel was splitted into 2 menus and freed from clutter.
There is no flat coloring in wire mode.
And it will not help with wire contours in solid mode. Issue shown here: #110097 (comment)
Pull request closed