document going directly to display with ondiskgif

This commit is contained in:
Jeff Epler 2023-03-01 17:50:02 -06:00
parent 965caa0302
commit ac0bf1049a
No known key found for this signature in database
GPG Key ID: D5BF15AB975AB4DE

View File

@ -36,6 +36,8 @@
//| class OnDiskGif: //| class OnDiskGif:
//| """Loads one frame of a GIF into memory at a time. //| """Loads one frame of a GIF into memory at a time.
//| //|
//| The code can be used in cooperation with displayio but this mode is relatively slow:
//|
//| .. code-block:: Python //| .. code-block:: Python
//| //|
//| import board //| import board
@ -69,6 +71,32 @@
//| # minus the overhead measured to advance between frames. //| # minus the overhead measured to advance between frames.
//| time.sleep(max(0, next_delay - overhead)) //| time.sleep(max(0, next_delay - overhead))
//| next_delay = odg.next_frame() //| next_delay = odg.next_frame()
//|
//| The displayio Group and TileGrid layers can be bypassed and the image can
//| be directly blitted to the full screen. This can give a speed-up of ~4x to
//| ~6x depending on the GIF and display. This requires an LCD that uses
//| standard codes to set the update area, and which accepts RGB565_SWAPPED
//| pixel data directly:
//|
//| .. code-block:: Python
//| # Initial set-up the same as above
//|
//| # Take over display to drive directly
//| display.auto_refresh = False
//| bus = display.bus
//|
//| # Display repeatedly & directly.
//| while True:
//| # Sleep for the frame delay specified by the GIF,
//| # minus the overhead measured to advance between frames.
//| time.sleep(max(0, next_delay - overhead))
//| next_delay = odg.next_frame()
//|
//| display_bus.send(42, struct.pack(">hh", 0, odg.bitmap.width - 1))
//| display_bus.send(43, struct.pack(">hh", 0, odg.bitmap.height - 1))
//| display_bus.send(44, d.bitmap)
//|
//| d.next_frame()
//| """ //| """
//| //|
//| def __init__(self, file: str) -> None: //| def __init__(self, file: str) -> None: