VSE: indicate missing media in timeline/display #116869
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
5 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: blender/blender#116869
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "aras_p/blender:vse-missing-media"
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?
Implements most of #116821 (except sine wave tone for missing audio during playback), but using design from the more recent #118288.
Sequencer timeline displays red tint & appropriate icons for strips that are missing media file (images, movies, audio, or meta strips that contain such). Before:
And in this PR:
How it looks like in a large timeline when zoomed out (Sprite Fright edit bundle - it is actually missing some media):
Sequencer preview and rendering displays missing media strips as magenta, similar to missing textures elsewhere in Blender. This is on by default, sequencer view settings have an option to turn it off:
Some implementation details:
MediaPresence
that is part of sequencerEditingRuntime
. The cache is invalidated when invalidating other strip caches during editing (changing media files, swapping inputs, reloading strips etc.), or when doing Refresh All sequencer operator.BLENDER_FILE_SUBVERSION
had to be bumped so that previously made files could be changed to "show missing media" flag on.SEQ_sequence_has_source
toSEQ_sequence_has_valid_data
to better reflect that the function is only about referenced data blocks.@blender-bot build
WIP: VSE: indicate missing media in timeline/displayto VSE: indicate missing media in timeline/displayI probably wont do full review today, just checked the code quickly. It's nice approach to use drawing loop for this and don't attempt to open file.
When you rename the file instead of pointing strip to new file, the cache would not be updated. This could be a bit annoying. A solution would be to invalidate whole cache if previously unavailable file can be rendered. Not 100% solution, but I think, it would be good enough.
Also it could work other way around - if file is lost during runtime, update the cache at least for this file. But chances are, more files would go missing then.
Looking at
check_media_missing()
I would say, that it covers 99.999% of use cases, but multiview can complicate filenames. Just look at horror ofseq_open_anim_file()
orseq_render_image_strip_view()
. It's good, that you don't have to check for proxies :)Finally I am not very happy about using
Scene.seq_flag
. The existingR_SEQ_OVERRIDE_SCENE_SETTINGS
is for 3D pipeline or engine (not exactly sure) that signifies, that render settings of VSE scene are to be used for rendering of target 3D scene.I would much rather make flag in
Editing
struct.@ -256,1 +257,4 @@
}
/* Clear sequencer media presence caches. */
blender::ed::seq::media_presence_free_all(bmain);
Sequencer is relatively well separated between UI(editor) and core code. Looking at nodes, they do have separate namespaces where
ed
signifies editor code. so I would expectblender::seq
namespace here.Editing and core code is also separate by cmake so you can't include editor headers in BKE code. Besides conventions, not sure if these namespaces needs to be separated in such case.
Indeed, brainfart on my part, should have been a
blender::seq
namespace.Done, moved it there.
VSE: indicate missing media in timeline/displayto WIP: VSE: indicate missing media in timeline/displayThis time, I have reviewed this patch fully. Got some more issues/suggestions. Just to be complete I will reiterate previous point:
I think that fixing or breaking file path outside from Blender should be handled when render code attempts to read file.
@ -189,6 +189,7 @@ static SeqRenderData sequencer_thumbnail_context_init(const bContext *C)
SEQ_render_new_render_data(bmain, depsgraph, scene, 0, 0, sseq->render_size, false, &context);
context.view_id = BKE_scene_multiview_view_id_get(&scene->r, STEREO_LEFT_NAME);
context.use_proxies = false;
context.never_show_missing_media = true;
Nitpick: Could this be called "ignore missing media" or something like that? Currently it's not double negative, but reads strange to me.
@ -112,7 +112,6 @@
\
.seq_prev_type = OB_SOLID, \
.seq_rend_type = OB_SOLID, \
.seq_flag = 0, \
I guess missing DNA defaults would be initialized to 0 anyway, but this is technically unrelated change and should not be done here.
@ -0,0 +53,4 @@
}
char filepath[FILE_MAX];
const char *basepath = get_seq_base_path(seq);
for (int i = 0; i < paths_count; i++, elem++) {
Suggestion: This may not be worth to implement, but it would be great if we could emit log warning to console with number of missing files and filenames of missing files if there are not too many (like < 5). This would make it easier for user to debug if few images from sequence are missing.
See
CLG_log.h
for logging.Not sure how useful would this be in practice though.
My thinking is that
File -> External Data -> Find Missing files
already achieves that functionality, if user actually wants to have a report of missing file paths. Just logging it without user asking for it sounds like it could be spammy.Makes sense. Good idea to use existing feature to solve this issue.
@ -0,0 +76,4 @@
return false;
}
struct MediaPresence {
Looking at presence cache structure, it makes sense, that this is optimized for sound IDs, so that it needs to do check only once.
Suggestion:
I think, that this could be also done for movie strips, but you would use file path as key. Unfortunately image sequences would be a bit problematic. But you could make hash function even for these.
This way you don't need 2 maps, but hashing would perhaps overcomplicate things, so again not sure if this is worth implementing.
Using media path as hashtable key would be like an order of magnitude more costly lookup though -- right now it's just a "the key is a pointer", which is super cheap. Using path, would mean that to get the key, it needs to do work of: "concat dir name and file name, turn that into absolute path, compute hash of resulting string", and then if there are hashtable collisions in the hash bucket, compute more string equalities. Sounds like a lot of extra work, for dubious benefit.
If it's the "we should have just one hashtable" that you want, then the key could be just
void*
that is either to Sequence or to bSound, at some loss of type safety (only internally in the implementation). Not sure if worth it either.Yeah that is correct probably. We could have cache that would map pointer to hash though :D (just kidding)
@ -1042,3 +1060,3 @@
if (ibuf == nullptr) {
return nullptr;
return create_missing_media_image(context, s_elem);
There is problem with generating image of missing media here - It is put into image cache, so if you recover the issue, it will still show pink. Even if this is done in
seq_render_strip()
, it could be cached as composite or final image, which is not great.Only solution I see is to flag the
ImBuf
somehow, then make exception in image cache for images with this flag.There is flag
IB_DISPLAY_BUFFER_INVALID
, but I am not sure how exactly is used, so it could affect code downstream. Also comment suggests different use-case, but from cache point of view it would be almost correct meaning.That would effectively mean, that frames, whereimage is missing can not be cached if the option to show them is enabled, but I think, that's OK.
Is that a problem though?
I mean, today if you have a missing media file, then e.g. the composite image is still cached, yet the result is arguably "wrong" (it is missing something!). And if you recover the file, then it still has the cached composite image with "missing parts". So overall, this does not change things, just depending on your viewing options, you either get result with "missing parts" or with "pink parts" into the cache. And the way to "kick sequencer into a refresh" operator (Refresh All) throws away the cache, and rebuilds it, as far as I understand, thereby fixing the issue.
The refresh all operator is a workaround for various issues and would be removed, if those issues are resolved. I personally see this as undesired behavior, other users or devs may see it as such too. @ZedDB what do you think?
I asked for this to be moved into the "Refresh all" operator as that is what we use to "kick" the VSE.
Some issues that the "Refresh all" operator is used to workaround could of course be solved. However in this case there is a scenario where it is impossible to solve.
For files that are stored locally on the computer, we could use "file listeners" to get callbacks when the file was changed or removed and refresh the relevant strips.
However this can not be done reliably for network drives as many of them (like SAMBA and NFS) does not communicate changes or deletion of files to the client computers automatically.
Therefore we will probably always need a "kick" command to have the VSE manually go over the files again and get the current status of them.
Edit:
My brain was a bit fried so I didn't answer the actual question. 😅
I have made a mistake here - it's not as easy as flagging imbuf. The cache would need to track if any image used to make final image was pink, so it's probably fine to not implement it here.
I still think, that it would be better to not cache these images. I think I will wait for user feedback for this case.
What we did in another product I worked previously to "refresh what has changed externally outside the app", was a combination of:
This setup works quite well in practice, but it also needs an option to get turned off (e.g. in user's preferences), since "go over all the file paths and cheir their timestamp" can get slow at scale and/or on a high latency network share.
But to me it feels like if such a system ("automatically reload data that has changed behind blender's back") would be implemented, it should be done more holistically across the board, i.e. not only for sequencer, but also for reloading material textures, etc. etc.
Right, that, why I don't suggest to use OS notifications - it isn't done anywhere else. It could be done in VSE first, but it's not top of list of priorities.
But image cache can look at previous images in particular frame and discard all of them if there is pink image. It is bit more complicated to do than simple flag, but fairly trivial. My assumption is, that missing files is something you resolve once and then work normally, so making this part of workflow is nice, but fairly unnecessary if it's too complicated. So if I get reports, that this is hindering, I can make it work, otherwise, it's probably not bothering anybody.
@blender-bot build
WIP: VSE: indicate missing media in timeline/displayto VSE: indicate missing media in timeline/display@ -2475,0 +2476,4 @@
RNA_def_property_boolean_sdna(
prop, nullptr, "show_missing_media_flag", SEQ_EDIT_SHOW_MISSING_MEDIA);
RNA_def_property_ui_text(
prop, "Show Missing Media", "Render missing images/movies as solid color");
"...as solid color" might not be clear enough. Because this color is not customizable we could mention it directly in the tooltip?
Something like: "Render missing images/movies as a solid magenta block"
@HooglyBoogly what do you think? It doesn't English enough to me.
How about
Render missing images/movies with a solid magenta color
Fantastic!
Other than the tooltip change that Hans suggested for "Show Missing Media":
Render missing images/movies with a solid magenta color
It's good to go from the UI point of view. Thanks!