Asset Browser: Add pre+post handlers to asset drag & drop #113658
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
11 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: blender/blender#113658
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "GregZaal/blender:asset-drop-handlers"
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?
This is intended for add-ons to be able to hook into the drag & drop event and run additional code to augment the default behavior when dropping assets from the asset browser.
For example, with our Poly Haven add-on, we have a number of feature requests which depend on this functionality:
Implementation notes:
This is my first PR :)
I'm unsure if my changes to the
return WM_file_append_datablock...
blocks andBLI_assert_unreachable
are the right approach, but it seems necessary here to avoid returning early so that we can run the handler after appending and then return the result after.Much needed feature! Great to see you work on this!
I know that studios also really want this, to do post processing of imported assets which is often crucial for pipeline tools to work. @Mets could you give us a specific example from the Blender Studio?
It seems incorrect to me to only do this for assets. While this may be the more desired way to import assets nowadays, what about regular link/append? Otherwise studios would have to use the asset browser to ensure their tools keep working, and wouldn't be able to use regular link/append anymore.
@mont29 @ideasman42 I've also wondered in the past if there is a particular reason why this is not there yet? I know it's an often requested feature from studios.
Having handlers around link/append in general would make total sense to me yes. I guess it's 'just' that nobody did it?
But isn't the 'append/link pre/post handlers' topic different than the 'drag-n-drop pre/post handlers' one? Imho they would have different covering of cases (and therefore be complementary)?
What's described here doesn't seem to be tied to drag & drop really, more to importing.
Also worth considering: Should this run when temporarily importing data-blocks? We have the feature to import data-blocks nowadays temporarily, without adding them to the current file's
Main
. Useful for example for poses, where we import an action, copy its parameters to another action, and throw it away again. Same with the upcoming brush assets. Or to easily remove the data-block again if using it failed in some way.In my case I prefer to hook into asset drag & drop, but adding handlers for link/append as well (or instead) seemed to be fairly trivial. I already tested this before finding the right methods for the asset browser specifically.
What's the reason for that?
Great to see someone working on this indeed, I've been asking for this since I arrived in Amsterdam in 2019! 😅
Our use cases (all post-handler):
Imaginary use case for pre-handler:
Suggestions (sorry):
bpy.ops
andbpy.data.libraries.load()
should trigger the handlers. I think it would be nicer if the latter didn't, but I guess that might be confusing. In any case, at least those behaviours should be conscious decisions in this PR.In our case we care only about drag & drop from the asset browser, not general append/link from other places. I feel there's likely to be unintended behaviors, now or in the future, if we hook into append/link rather than drag/drop.
If a user is simply appending data from the file menu as normal, I would say they don't expect (or want) any special behavior from an add-on to invade the process, even if this file they are appending from happens to be inside an asset library. Rather the expected behavior from an add-on that creates and manages an asset browser library should remain isolated to the asset browser UX only.
It's not a train smash to have only an append/link handler, but I feel there are likely more possible use cases for having drag/drop handlers as well that might not have that much to do with append/link that we haven't thought of.
Sidenote: Maybe general drag/drop handlers (e.g. to catch dropping files/URLs from outside Blender) are more helpful too? E.g. to auto-detect which format importer to use, or to allow dragging URLs from a browser for some download & import behavior. Maybe this is offtopic :)
Congrats on the 4.0 release :) Any chance we can try to get this patch into 4.1? It'd be great if we could include these improvements in the next update of our add-on.
I think the discussion on whether to also add append/link handlers and generic drag+drop handlers (from outside Blender) is separate and doesn't block this implementation.
@JulianEisel @ideasman42 Hey, can you please follow up on this for 4.1? :)
This would be so good 🙏
Very much waiting for this, the lack of many handlers and callbacks is really a big miss for Blender Addon development!
Hi, Cindy here,
I am blender user for my short film project. I have a difficult time on large environments because my RTX3080 card has 10gbs of memory. I wrote Greg, from polyhaven.com, that I was confused by his asset browser addons that contained LOD 0,1,2,3 inside a single instance. In my project I made such instances real, and then separated out the LOD I needed, (so as not to burden my graphics card).
Greg replied that he knew this was a big problem, and that a patch he submitted 6 months ago would allow the user to select the correct LOD version from the asset browser BEFORE dragging into a blender project. This would greatly help users with limited computer graphics cards, like me. I appreciate the amount of work all blender developers have on their plate and I love version 4.0. If any developer can spare the time, please look at this change for addons.
Thanks again for making Blender for all of us!
Cindy
Here's a quick and dirty proof of concept of what can be done with this patch:
https://u.polyhaven.org/pHw/2024-05-16_14-00-57.mp4
Any chance we can get this in 4.2 @JulianEisel @ideasman42
This is an awesome addition! Great work Greg.
This (the more general link/append) came up in #122357 again
Made a PR for this more general case, see !122365 in case someone is interested
One drag/drop specific use case I’ve wanted is the ability to apply custom or asset-specific snapping behavior when dragging an asset in from the browser.
For example, when dragging a cabinet asset onto a wall, I want it to snap so it’s sitting on the floor with the back of the cabinet against the wall.
With a drag pre-handler, this may be possible to preview while you drag, as opposed to applying only when you drop the asset.
It would be good to handle !122365 before this patch since we may be able to support detection of dropping assets in a more generic way (see my reply there).
Checkout
From your project repository, check out a new branch and test the changes.