DRW: Selection Occlusion #105498
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#105498
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "bonj/blender:retopology-select"
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?
Summary
Occlude edit mode selection behind objects in object mode.
Problem
When doing retopology, you want to be able to select your edit mesh,
but only when you can see it.
Being able to select geometry behind reference objects is not
desirable.
Solution
Make it so reference objects occlude selection, while the edit mesh is
pushed towards the view using retopology offset.
Limitations
Poly Build is not supported, because it doesn't use the depth buffer.
It behaves the same as normal, unoccluded by reference meshes.
Notes
Selection occlusion is not used when xray is enabled. This is
intentional.
c7f5073002
todfe02741ff
WIP: Selection Occlusionto Selection Occlusion@blender-bot build
I don't think it's appropriate to create an array with all objects visible because:
DRW_object_is_in_edit_mode(ob)
check limits what the caller can do by forcing it to use a specific array.A more ideal solution in my view would be to change the
DRW_draw_select_id
to do the same as the other draw loops and traverse all objects.Somehow it is necessary to tag the objects that are in
SELECTID_Context::objects
.Thanks, this is exactly the info I needed!
I'll make it use the depsgraph iterator.
Perhaps that would allow it to support non-mesh solid objects (such as metaballs) too.
9aea413b6e
toef85581bdf
The history became so messy I decided to reset and redo only the necessary changes.
This way it's easier to keep up to date with main without merge conflicts, and easier to review.
You can find the old commits here: https://projects.blender.org/bonj/blender/src/branch/retopology-select-old
@mano-wii I've implemented your feedback, and as a result the code is much simpler, and works better too 🙂
@blender-bot package
Package build started. Download here when ready.
ef85581bdf
to38293cd17c
My cleanup got merged before this PR so I rebased this branch to avoid merge conflicts.
The changes look reasonable to me, but I don't have experience in this area, so I'll leave the review to others. Thanks for working on this and for simplifying it so nicely!
The change seems safe. But there are a few things that I found odd since I'm not familiar with the latest changes made to the mesh editing overlay.
The selection engine should have matrices and depths matching the edit overlay. But I noticed that
get_homogenous_z_offset
is only being added to the selection engine in this patch. Does this indicate that they are not currently matching?Overall it looks OK.
It's actually not a safe change. It doesn't seem that there are guarantees that
DEG_OBJECT_ITER_BEGIN (°_iter_settings, ob) {...}
and the objects insel_ctx->objects
are in the same order.Note that it is important to follow an order to return the correct index of the selected object.
Also testing
DRW_object_is_in_edit_mode(ob)
does not guarantee that we are drawing objects are the same as the array.These same changes are already done for the edit overlay in commit
dcad51dfc3
.Though there it pushes the overlay towards the view, and here it pushes background objects away from the view, because it's simpler to implement in this case.
While it seems to work exactly as intended already, I'll take your word for it.
I suppose I could loop over the objects list first, then through the depsgraph iterator to cache any non-edit objects.
The order of background objects shouldn't matter because they only affect the depth pass.
@mano-wii What do you think of that solution? Implemented now in commit
f8c26304d7
.The objects array is populated from bases in edit mode, so checking if an object is not in edit mode at least guarantees that it's not in the list, and I think the inverse is also true.
Do you have any examples where it doesn't work this way?
It doesn't seem the most ideal as the
sel_ctx->objects
array doesn't necessarily have to be all!DRW_object_is_in_edit_mode(ob)
objects, but it should work fine now.@ -2780,0 +2786,4 @@
}
}
DEG_OBJECT_ITER_END;
It might be interesting to put this code inside a condition that checks if it's not X-Ray or wireframe. It may even improve readability.
Why only objects of type
OB_MESH
have the depth drawn? It may be good to comment on the reason.Checking if an object is not in edit mode gives you background objects, used for occlusion.
These are not in the selection context objects array.
If the objects array did contain a non-edit object, it would crash, so I'm confident that never happens.
It doesn't occlude in xray so I didn't add an extra check, but I suppose I could check that, and check if retopology is enabled, then remove that check from the select engine cache function.
Because the depsgraph iterator contains evaluated meshes for every object, but also non-mesh versions, which are superfluous and don't have triangles to cache.
Re-requesting review from @mano-wii because I made several changes.
They're all based on your feedback from the last review, and I don't expect you to find any problems, but just in case.
LGTM in general.
@ -2780,0 +2786,4 @@
* It also has non-mesh objects however, which are not supported here.
*
* Only background (non-edit) objects are used for occlusion. */
if ((ob->type == OB_MESH) && !DRW_object_is_in_edit_mode(ob)) {
Not that it's a problem, but another way to make comments more localized could be:
I'm wondering if Grease Pencil and Image-type Empties couldn't contribute to the depth. But if it matches what you see in the Meshes edit overlay then it's OK.
@ -1335,6 +1335,7 @@ void ED_view3d_shade_update(struct Main *bmain, struct View3D *v3d, struct ScrAr
#define RETOPOLOGY_ENABLED(v3d) (OVERLAY_RETOPOLOGY_ENABLED((v3d)->overlay))
#define RETOPOLOGY_OFFSET(v3d) (OVERLAY_RETOPOLOGY_OFFSET((v3d)->overlay))
#define RETOPOLOGY_OCCLUSION(v3d) (RETOPOLOGY_ENABLED(v3d) && !XRAY_ENABLED(v3d))
picky: I don't see much advantage in this macro. It makes it look like the retopology has a specific occlusion test, but seeing the definition, it's the same occlusion as the rest of the 3D View.
It might be more understandable to just
bool use_occlusion = !XRAY_ENABLED(v3d);
and use that bool in combination withRETOPOLOGY_ENABLED(v3d)
.But I can be wrong.
@mano-wii Replying doesn't seem to work properly so I'll just comment here.
To your first comment about localized comments and grease pencil objects:
Sure, I suppose two comments would be more readable, so I'll do it.
The depsgraph iterator has evaluated meshes for things like metaballs and surfaces.
I'm afraid I can't support empties or grease pencil objects though, because they have no triangles to cache.
I think it would require quite an overhaul to the selection engine to make this work.
Having your selection occluded by reference images actually sounds quite inconvenient anyway though.
Does make me think, I need to see how it currently behaves with translucent objects, and decide how it should behave with them.
I'll ask Julien what he thinks.
Update: Translucent meshes occlude the retopology overlay visually too, so it makes sense that they occlude selection. Basically I'm leaving this as it is.
To your second comment about the occlusion macro:
I made it mainly because it could be easy to forget the xray check.
If you use it in one place but not the other, it will crash.
I suppose since it's only used in two places though, I'll get rid of it.
Overall I think this works great! This is definitely the desirable behavior imo.
The only issues I noticed are:
The selection is also occluded if the
retopology_offset
is set to 0. That should maybe not be the case.Cases like when 'In Front' is enabled should be factored into the selectability of the mesh
There is a small difference between the selectability and the visibility as shown in the attached images.
I did a full box selection and even though many vertices are not visually occluded, they are not selectable.
There seems to be a disconnect between all the three below
The difference in what is selectable is also very noticable when switching between vert/edge/face selection.
I also think there needs to be a mention of this behavior in the tooltip of the overlay, but the tooltip is not very descriptive anyway right now.
Perhaps the tooltip could be rewritten to something like
@JulienKaspar Thanks for your feedback!
I don't see why not. The slider is just for offset, if you don't want the overlay / occlusion, use the checkbox.
And if you want the overlay but no selection occlusion, use xray.
That's fair, but I'm not sure how I'd go about fixing it.
This may just be a limitation to put in the documentation.
In my defense, it doesn't make any sense to use the retopology overlay and in front at the same time, as they are two different solutions to the same problem.
That's like wearing a blindfold and sunglasses at the same time.
Update: The edit selection engine doesn't understand in front, and adding that is out of scope. I wouldn't mind looking into this in a future PR though.
If you tested with the buildbot build, I've since changed the depth code, so it should be aligned perfectly with what's visible now.
Fair, I could mention the occlusion behavior in the tooltip of the checkbox.
@blender-bot package
Package build started. Download here when ready.
@bonj I've tested the latest builds and yes the selection is way more consistent with the visible mesh. There's still a small difference between the three selection modes but that's to be expected 👍
I see your point with the other notes. Let's keep it how it is.
I'll keep an eye out what people say once it's merged with main, especially about the selection occlusion when set to 0.
It might be a good idea to make the selection occlusion optional, but I would do that with a new checkbox, rather than making it part of the slider behavior.
For now I don't want to add that because this PR has been open for long enough.
I agree let's wait for feedback after merge and go from there.
@ -2774,6 +2774,25 @@ void DRW_draw_select_id(Depsgraph *depsgraph, ARegion *region, View3D *v3d, cons
drw_engines_cache_populate(obj_eval);
}
if (RETOPOLOGY_ENABLED(v3d) && !XRAY_ENABLED(v3d)) {
Draw manager should be as functionality agnostic as much as possible. Adding this if-statement might be ok as we also check if bone overlay is enabled. But the if statements inside the iterator should be done by the draw engines.
Selection engine is currently being redesigned. I think @fclem @pragma37 can do a better review of this part keeping in mind the new design.
@Jeroen-Bakker reply to your review.
This one I could move if necessary, though it would be inefficient.
I could probably move the object type check, if that doesn't break the edit mode check.
I can't move the edit mode check, because then edit mode objects, which are also in the selection context object list, would be cached twice.
Another solution would be to get rid of the edit mode check, but not iterate over the selection context objects list at all.
That way the order would not be guaranteed though, and edit mode objects that are not in the list would also get cached.
The reason the code is the way it is, is because it needs edit mode objects from the list, then object mode objects, preferably in that order.
I suppose if the engine is changed to work differently, this aspect can change too.
I was hoping this feature could make it in before that.
I just see a small simple cleanup to do. Otherwise looks good to me.
@ -144,0 +150,4 @@
if (retopology_occlusion) {
pd->shgrp_occlude = DRW_shgroup_create(sh->select_id_uniform, psl->depth_only_pass);
DRW_shgroup_uniform_int_copy(pd->shgrp_occlude, "id", 0);
This feels weird to me. Why is this group using
id == 0
whenshgrp_depth_only
doesn't? I think it is better to be consistent and set it for both cases. Also I wouldn't mind adding a comment saying this id isn't actually used since the pass is written on a depth only framebuffer.@ -2774,6 +2774,25 @@ void DRW_draw_select_id(Depsgraph *depsgraph, ARegion *region, View3D *v3d, cons
drw_engines_cache_populate(obj_eval);
}
if (RETOPOLOGY_ENABLED(v3d) && !XRAY_ENABLED(v3d)) {
Well this is extending the already existing edit mode selection path. I really don't see the problem as other part of the draw-manager are state aware of the View3D. Obviously this will need to be fitted to the new selection engine but that's not a project for the 3.6 release.
Also note that #102177 is only targeting object selection mode.
Selection Occlusionto DRW: Selection Occlusion