Blender Git Commit Log

Git Commits -> Revision e06a346

Revision e06a346 by Pablo Dobarro (master)
July 15, 2020, 14:33 (GMT)
Fix T78747: Fix mesh boundary detection and automasking

This issue was produced by a hack in the sculpt mode code from 2.80
when the sculpt API for connectivity info was not available.
The smooth brush was the only brush that needed connectivity info,
so there were 3 different smooth functions with the connectivity
queries implemented for dyntopo, meshes and grids. The mesh version
of smoothing was checking the number of connected faces to a vertex
to mask the mesh boundaries, which was not covering all cases and
was hardcoded in the smooth function itself.

This patch removes all those legacy functions and unifies all
smooth functions into a single one using the new API and the
automasking system. In order to achieve this, there were needed
some extra changes:

- The smooth brush now does not automasks the boundaries by default,
so its default preset needs to be updated to enable automasking

- The mesh boundary info is extracted once and cached in a
bitmap, similar to the disconnected elements IDs. This makes
boundary detection work as expected in all cases, solving a lot
of known issues with the smooth brush. In multires, this info is
extracted and cached only at the base mesh level, so it is much
more memory efficient than the previous automasking system.

- In order to keep the brushes responsive as they were before,
the automasking system can now skip creating the cache when it
is not needed for the requested options. This means that for
high poly meshes and simple automasking options the brushes
won't lag on start.

Reviewed By: sergey

Maniphest Tasks: T78747

Differential Revision: https://developer.blender.org/D8260

Commit Details:

Full Hash: e06a346458fa898e137cc984f23975f5572d94fb
Parent Commit: 10cacbb
Lines Changed: +165, -251

8 Modified Paths:

/source/blender/blenkernel/BKE_paint.h (+4, -0) (Diff)
/source/blender/blenkernel/intern/brush.c (+1, -0) (Diff)
/source/blender/blenkernel/intern/paint.c (+2, -0) (Diff)
/source/blender/editors/sculpt_paint/sculpt.c (+36, -20) (Diff)
/source/blender/editors/sculpt_paint/sculpt_automasking.c (+72, -12) (Diff)
/source/blender/editors/sculpt_paint/sculpt_filter_mesh.c (+7, -14) (Diff)
/source/blender/editors/sculpt_paint/sculpt_intern.h (+20, -8) (Diff)
/source/blender/editors/sculpt_paint/sculpt_smooth.c (+23, -197) (Diff)
By: Miika HämäläinenLast update: Nov-07-2014 14:18MiikaHweb | 2003-2021