-
Notifications
You must be signed in to change notification settings - Fork 149
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
synchronizing with screen updates #1749
Comments
thanks michael, super helpful to have these issues. i'll take on #1747; deciding a solution to that might inform this too. the first thought i had was to add a new main-thread event type to be raised from the cairo thread. i guess that would be solution no. 2, with the addition of a callback to lua. (maybe that wouldn't work for timing purposes, i didn't look closely.) double buffering seems like not a bad idea also. i think solution 3 is out. don't want to deal with synchronizing/mirroring lua interpreter state across the threads. i'm not super familiar with how offscreen images came together or what the deal is with pixel formats etc. so hopefully others can step in there. |
i can look at the offscreen drawing when i get a chance as i have interest in understanding the async screen changes better. i'm not sure why a mod would want to or need to hook into off screen drawing. a script which is doing that would invariably be doing it for specific reasons that (i'd think) are tightly coupled to its ui logic and not something that would make sense to consume in a mod. another thing to consider instead of double buffering all the time is to actually expose a system level function that enabled it and then emit an event when the buffers are swapped. the buffer swap event could be consumed in either lua or a custom c based module like |
Consider the following use cases:
Scenario A: a mod wants to know when the screen has been updated, whether by script, menu, or otherwise, and also wants to read an up-to-date Cairo surface or pixel buffer with the latest contents. Examples: ndi-mod sending the screen over the network, a video recorder mod, other hypothetical screen output mods.
Scenario B: a script or mod wants to read the latest contents of an offscreen image after drawing to it. The script knows when it has drawn to the offscreen image, so notification is not strictly necessary like in Scenario A, but the result still needs to be read. Examples: scripts using ndi-mod to send offscreen images over the network, scripts or mods to interact with hardware devices with small screens like the Ableton Push or Elgato Streamdeck.
Challenges:
refresh()
gives you the update notification necessary in Scenario A, but isn't relevant for Scenario B.screen.draw_to()
with separate Cairo thread #1747)Some possible solutions:
ssd1322.c
(either the local copy of the Cairo ARGB buffer, or the 8-bit SPI buffer) and swap between the two every frame. Expose the most recently drawn one to the C API. Mods could then hookrefresh()
and then get the latest frame from a C function. This is probably the smallest and most performant fix to Scenario A, but does not address Scenario B.screen_update()
.screen_update()
only callsssd1322_update()
if the primary context is current. This would address Scenario A and Scenario B (assuming Supportscreen.draw_to()
with separate Cairo thread #1747 is fixed), but only for mods.screen.update()
providing a Lua function to be run synchronously on the Cairo thread after the update is finished and the Cairo surface is valid. Solves Scenario A and B for both mods and scripts, but requires invoking Lua from the Cairo thread, opening several cans of worms.screen.update()
that provides a Lua function to be run on the main thread, using thescreen_results_wait()
system that supportsscreen.peek()
etc.screen.peek()
immediately afterscreen.update()
. Works from mod or script. However,screen.peek()
has never worked with offscreen image contexts, so that will need to be implemented (screen.peek() does not peek into the context selected with screen.draw_to() #1748.)2 seems the most straightforward, and you can imagine efficient support for alternate screen hardware being implemented as a mod, should that ever become necessary.
5 is also attractive because it requires nothing new, just fixing #1747 and #1748, but the latter could get thorny.
The text was updated successfully, but these errors were encountered: