Blender Git Commit Log

Git Commits -> Revision d6525e8

Revision d6525e8 by Jeroen Bakker (master)
September 11, 2020, 06:08 (GMT)
Use DrawManager for Image/UV Editor

This project moves the current UV/Image editor drawing to the draw manager.
Why would we do this:

**Performance**:

Current implementation would draw each texel per time. Multiple texels could be
drawn per pixel what would overwrite the previous result. You can notice this
when working with large textures. Repeat image drawing made this visible by
drawing for a small period of time and stop drawing the rest. Now the rendering
is fast and all repeated images are drawn.

**Alpha drawing**:

Current implementation would draw directly in display space. Giving incorrect
results when displaying alpha transparent images.
This addresses {T52680}, {T74709}, {T79518}
The image editor now can show emission only colors. See {D8234} for
examples.

**Current Limitations**

Using images that are larger than supported by your GPU are resized (eg larger
than 16000x16000 are resized to 8k). This leaves some blurring artifacts. It is
a low priority to add support back of displaying individual pixels of huge
images. There is a design task {T80113} with more detail.

**Implementation overview**
Introduced an Image Engine in the draw module. this engine is responsible for
drawing the texture in the main area of the UV/Image editor. The overlay engine
has a edit_uv overlay which is responsible to draw the UV's, shadows and
overlays specifically for the UV Image editor. The background + checker pattern
is drawn by the overlay_background.

The patch will allow us to share overlays between the 3d viewport and UV/Image
editor more easily. In most cases we just need to switch the `pos` with the `u`
attribute in the vertex shader.

The project can be activated in the user preferences as experimental features.
In a later commit this will be reversed.

Reviewed By: Cl�ment Foucault

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

Commit Details:

Full Hash: d6525e8d133b787655bdb2c2fcef218591a457c3
Parent Commit: d023c41
Lines Changed: +2288, -149

17 Added Paths:

/source/blender/draw/engines/image/image_engine.c (+304, -0) (View)
/source/blender/draw/engines/image/image_engine.h (+25, -0) (View)
/source/blender/draw/engines/image/image_private.h (+69, -0) (View)
/source/blender/draw/engines/image/image_shader.c (+77, -0) (View)
/source/blender/draw/engines/image/shaders/engine_image_frag.glsl (+91, -0) (View)
/source/blender/draw/engines/image/shaders/engine_image_vert.glsl (+31, -0) (View)
/source/blender/draw/engines/overlay/overlay_edit_uv.c (+393, -0) (View)
/source/blender/draw/engines/overlay/shaders/common_overlay_lib.glsl (+5, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_edges_frag.glsl (+77, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_edges_geom.glsl (+63, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_edges_vert.glsl (+32, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_faces_vert.glsl (+22, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_face_dots_vert.glsl (+18, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_stretching_vert.glsl (+98, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_tiled_image_borders_vert.glsl (+12, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_verts_frag.glsl (+33, -0) (View)
/source/blender/draw/engines/overlay/shaders/edit_uv_verts_vert.glsl (+44, -0) (View)

31 Modified Paths:

/release/datafiles/userdef/userdef_default_theme.c (+1, -0) (Diff)
/release/scripts/startup/bl_ui/space_userpref.py (+1, -0) (Diff)
/source/blender/blenkernel/intern/image_gpu.c (+11, -1) (Diff)
/source/blender/blenloader/intern/versioning_userdef.c (+2, -0) (Diff)
/source/blender/compositor/operations/COM_ViewerOperation.cpp (+1, -1) (Diff)
/source/blender/draw/CMakeLists.txt (+16, -0) (Diff)
/source/blender/draw/DRW_engine.h (+4, -0) (Diff)
/source/blender/draw/engines/overlay/overlay_background.c (+5, -2) (Diff)
/source/blender/draw/engines/overlay/overlay_engine.c (+47, -0) (Diff)
/source/blender/draw/engines/overlay/overlay_grid.c (+43, -10) (Diff)
/source/blender/draw/engines/overlay/overlay_private.h (+60, -0) (Diff)
/source/blender/draw/engines/overlay/overlay_shader.c (+149, -0) (Diff)
/source/blender/draw/engines/overlay/shaders/background_frag.glsl (+6, -1) (Diff)
/source/blender/draw/engines/overlay/shaders/grid_vert.glsl (+5, -2) (Diff)
/source/blender/draw/intern/draw_common.c (+4, -1) (Diff)
/source/blender/draw/intern/draw_common.h (+3, -1) (Diff)
/source/blender/draw/intern/draw_manager.c (+283, -31) (Diff)
/source/blender/draw/intern/draw_manager_text.c (+80, -50) (Diff)
/source/blender/draw/intern/draw_view.c (+60, -0) (Diff)
/source/blender/draw/intern/draw_view.h (+1, -0) (Diff)
/source/blender/draw/intern/DRW_render.h (+5, -3) (Diff)
/source/blender/draw/intern/shaders/common_globals_lib.glsl (+2, -0) (Diff)
/source/blender/draw/tests/shaders_test.cc (+20, -0) (Diff)
/source/blender/editors/render/render_internal.c (+1, -0) (Diff)
/source/blender/editors/space_image/image_draw.c (+22, -9) (Diff)
/source/blender/editors/space_image/image_intern.h (+1, -0) (Diff)
/source/blender/editors/space_image/space_image.c (+43, -34) (Diff)
/source/blender/makesdna/DNA_image_defaults.h (+2, -0) (Diff)
/source/blender/makesdna/DNA_image_types.h (+4, -2) (Diff)
/source/blender/makesdna/DNA_userdef_types.h (+2, -1) (Diff)
/source/blender/makesrna/intern/rna_userdef.c (+10, -0) (Diff)
By: Miika HämäläinenLast update: Nov-07-2014 14:18MiikaHweb | 2003-2021