1
1
Fork 0
mirror of https://github.com/FellippeHeitor/InForm.git synced 2025-01-15 03:49:56 +00:00

Update GIF_IsLoaded() to return true only when the GIF is fully loaded

This commit is contained in:
Samuel Gomes 2023-11-30 10:31:22 +05:30
parent 9e7b10b283
commit 08121bfb4f
6 changed files with 57 additions and 36 deletions

View file

@ -280,9 +280,9 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
' Walk through the animation chain and find the frame we have to render based on the tick we recorded the last time ' Walk through the animation chain and find the frame we have to render based on the tick we recorded the last time
DO UNTIL currentTick < __GIFPlay(idx).lastTick + __GIFPlayFrame(__GIFPlay(idx).frame).duration DO UNTIL currentTick < __GIFPlay(idx).lastTick + __GIFPlayFrame(__GIFPlay(idx).frame).duration
' Add the current frame duration to the lastTick so that we can do frame skips if needed ' Add the current frame duration to lastTick so that we can do frame skips if needed
__GIFPlay(idx).lastTick = __GIFPlay(idx).lastTick + __GIFPlayFrame(__GIFPlay(idx).frame).duration __GIFPlay(idx).lastTick = __GIFPlay(idx).lastTick + __GIFPlayFrame(__GIFPlay(idx).frame).duration
' We cross the duration of the current frame, so move to the next one ' We crossed the duration of the current frame, so move to the next one
__GIFPlay(idx).frame = __GIFPlayFrame(__GIFPlay(idx).frame).nextFrame ' this should correctly loop back to the first frame __GIFPlay(idx).frame = __GIFPlayFrame(__GIFPlay(idx).frame).nextFrame ' this should correctly loop back to the first frame
' Increment the frame counter and loop back to 0 if needed ' Increment the frame counter and loop back to 0 if needed
__GIFPlay(idx).frameNumber = __GIFPlay(idx).frameNumber + 1 __GIFPlay(idx).frameNumber = __GIFPlay(idx).frameNumber + 1
@ -373,8 +373,11 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
' Returns TRUE if a GIF with Id is loaded ' Returns TRUE if a GIF with Id is loaded
FUNCTION GIF_IsLoaded%% (Id AS LONG) FUNCTION GIF_IsLoaded%% (Id AS LONG)
SHARED __GIFPlayHashTable() AS HashTableType SHARED __GIFPlayHashTable() AS HashTableType
SHARED __GIFPlay() AS __GIFPlayType
GIF_IsLoaded = HashTable_IsKeyPresent(__GIFPlayHashTable(), Id) IF HashTable_IsKeyPresent(__GIFPlayHashTable(), Id) THEN
GIF_IsLoaded = __GIFPlay(HashTable_LookupLong(__GIFPlayHashTable(), Id)).isReady
END IF
END FUNCTION END FUNCTION
@ -597,6 +600,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
HashTable_InsertLong __GIFPlayHashTable(), Id, idx ' add it to the hash table HashTable_InsertLong __GIFPlayHashTable(), Id, idx ' add it to the hash table
' Reset some stuff ' Reset some stuff
__GIFPlay(idx).isReady = FALSE
__GIFPlay(idx).firstFrame = -1 __GIFPlay(idx).firstFrame = -1
__GIFPlay(idx).lastFrame = -1 __GIFPlay(idx).lastFrame = -1
__GIFPlay(idx).frame = -1 __GIFPlay(idx).frame = -1
@ -719,8 +723,8 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
END IF END IF
__GIFPlay(idx).lastFrame = frameIdx ' make the last frame to point to this __GIFPlay(idx).lastFrame = frameIdx ' make the last frame to point to this
__GIFPlayFrame(frameIdx).disposalMethod = rawFrame.disposalMethod __GIFPlayFrame(frameIdx).disposalMethod = rawFrame.disposalMethod
IF rawFrame.duration = 0 THEN rawFrame.duration = 10 ' 0.1 seconds if no duration is specified (this behavior is from the erstwhile GIFPlay library) IF rawFrame.duration = 0 THEN rawFrame.duration = 10~% ' 0.1 seconds if no duration is specified (this behavior is from the erstwhile GIFPlay library)
__GIFPlayFrame(frameIdx).duration = rawFrame.duration * 10 ' convert to ticks (ms) __GIFPlayFrame(frameIdx).duration = 10~&& * rawFrame.duration ' convert to ticks (ms)
__GIFPlay(idx).duration = __GIFPlay(idx).duration + __GIFPlayFrame(frameIdx).duration ' add the frame duration to the global duration __GIFPlay(idx).duration = __GIFPlay(idx).duration + __GIFPlayFrame(frameIdx).duration ' add the frame duration to the global duration
__GIFPlay(idx).frameCount = __GIFPlay(idx).frameCount + 1 __GIFPlay(idx).frameCount = __GIFPlay(idx).frameCount + 1
@ -787,6 +791,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
__GIFPlay(idx).lastTick = __GIF_GetTicks __GIFPlay(idx).lastTick = __GIF_GetTicks
DIM dummy AS LONG: dummy = GIF_GetFrame(Id) DIM dummy AS LONG: dummy = GIF_GetFrame(Id)
__GIFPlay(idx).isPlaying = FALSE __GIFPlay(idx).isPlaying = FALSE
__GIFPlay(idx).isReady = TRUE ' set the ready flag
__GIF_Load = TRUE __GIF_Load = TRUE
EXIT FUNCTION EXIT FUNCTION

View file

@ -12,6 +12,7 @@ $IF GIFPLAY_BI = UNDEFINED THEN
' This is the master animation type that holds info about a complete animation ' This is the master animation type that holds info about a complete animation
TYPE __GIFPlayType TYPE __GIFPlayType
isUsed AS _BYTE ' is this slot being used (this is only here to assist slot allocation) isUsed AS _BYTE ' is this slot being used (this is only here to assist slot allocation)
isReady AS _BYTE ' this is set if the GIF is fully loaded (helps fix issues with InForm-PE TIMERs)
image AS LONG ' the rendered 32bpp frame image image AS LONG ' the rendered 32bpp frame image
bgColor AS _UNSIGNED _BYTE ' background color bgColor AS _UNSIGNED _BYTE ' background color
firstFrame AS LONG ' index of the first frame in the frame data array firstFrame AS LONG ' index of the first frame in the frame data array

View file

@ -7,36 +7,36 @@ $IF MESSAGEBOX_BI = UNDEFINED THEN
$LET MESSAGEBOX_BI = TRUE $LET MESSAGEBOX_BI = TRUE
'Messagebox constants 'Messagebox constants
CONST MsgBox_OkOnly = 1 CONST MsgBox_OkOnly& = 1&
CONST MsgBox_OkCancel = 2 CONST MsgBox_OkCancel& = 2&
CONST MsgBox_AbortRetryIgnore = 4 CONST MsgBox_AbortRetryIgnore& = 4&
CONST MsgBox_YesNoCancel = 8 CONST MsgBox_YesNoCancel& = 8&
CONST MsgBox_YesNo = 16 CONST MsgBox_YesNo& = 16&
CONST MsgBox_RetryCancel = 32 CONST MsgBox_RetryCancel& = 32&
CONST MsgBox_CancelTryagainContinue = 64 CONST MsgBox_CancelTryAgainContinue& = 64&
CONST MsgBox_Critical = 128 CONST MsgBox_Critical& = 128&
CONST MsgBox_Question = 256 CONST MsgBox_Question& = 256&
CONST MsgBox_Exclamation = 512 CONST MsgBox_Exclamation& = 512&
CONST MsgBox_Information = 1024 CONST MsgBox_Information& = 1024&
CONST MsgBox_DefaultButton1 = 2048 CONST MsgBox_DefaultButton1& = 2048&
CONST MsgBox_DefaultButton2 = 4096 CONST MsgBox_DefaultButton2& = 4096&
CONST MsgBox_DefaultButton3 = 8192 CONST MsgBox_DefaultButton3& = 8192&
CONST MsgBox_Defaultbutton4 = 16384 CONST MsgBox_Defaultbutton4& = 16384&
CONST MsgBox_AppModal = 32768 CONST MsgBox_AppModal& = 32768&
CONST MsgBox_SystemModal = 65536 CONST MsgBox_SystemModal& = 65536&
CONST MsgBox_SetForeground = 131072 CONST MsgBox_SetForeground& = 131072&
CONST MsgBox_Ok = 1 CONST MsgBox_Ok& = 1&
CONST MsgBox_Yes = 2 CONST MsgBox_Yes& = 2&
CONST MsgBox_No = 3 CONST MsgBox_No& = 3&
CONST MsgBox_Cancel = 4 CONST MsgBox_Cancel& = 4&
CONST MsgBox_Abort = 5 CONST MsgBox_Abort& = 5&
CONST MsgBox_Retry = 6 CONST MsgBox_Retry& = 6&
CONST MsgBox_Ignore = 7 CONST MsgBox_Ignore& = 7&
CONST MsgBox_Tryagain = 8 CONST MsgBox_TryAgain& = 8&
CONST MsgBox_Continue = 9 CONST MsgBox_Continue& = 9&
$END IF $END IF

View file

@ -8,6 +8,7 @@ DEFLNG A-Z
OPTION _EXPLICIT OPTION _EXPLICIT
': Controls' IDs: ------------------------------------------------------------------ ': Controls' IDs: ------------------------------------------------------------------
DIM SHARED AboutBT AS LONG
DIM SHARED gifplaySample AS LONG DIM SHARED gifplaySample AS LONG
DIM SHARED PictureBox1 AS LONG DIM SHARED PictureBox1 AS LONG
DIM SHARED LoadBT AS LONG DIM SHARED LoadBT AS LONG
@ -36,6 +37,9 @@ END SUB
SUB __UI_Click (id AS LONG) SUB __UI_Click (id AS LONG)
SELECT CASE id SELECT CASE id
CASE AboutBT
MessageBox "GIFPlay library + InForm-PE demo." + STRING$(2, 10) + "Get it from https://github.com/a740g/InForm-PE", "About " + Caption(gifplaySample), MsgBox_OkOnly + MsgBox_Information
CASE gifplaySample CASE gifplaySample
CASE LoadBT CASE LoadBT
@ -43,6 +47,9 @@ SUB __UI_Click (id AS LONG)
IF LEN(fileName) > 0 THEN IF LEN(fileName) > 0 THEN
IF GIF_LoadFromFile(PictureBox1, fileName) THEN IF GIF_LoadFromFile(PictureBox1, fileName) THEN
' Calculate picturebox width based on the aspect ratio of the GIF
Control(PictureBox1).Width = GIF_GetWidth(PictureBox1) / GIF_GetHeight(PictureBox1) * Control(PictureBox1).Height
Control(gifplaySample).Width = Control(PictureBox1).Width + Control(LoadBT).Width + 24
Control(PlayBT).Disabled = FALSE Control(PlayBT).Disabled = FALSE

View file

@ -7,13 +7,13 @@ SUB __UI_LoadForm
DIM __UI_NewID AS LONG, __UI_RegisterResult AS LONG DIM __UI_NewID AS LONG, __UI_RegisterResult AS LONG
__UI_NewID = __UI_NewControl(__UI_Type_Form, "gifplaySample", 300, 281, 0, 0, 0) __UI_NewID = __UI_NewControl(__UI_Type_Form, "gifplaySample", 425, 339, 0, 0, 0)
__UI_RegisterResult = 0 __UI_RegisterResult = 0
SetCaption __UI_NewID, "GIFPlay Sample" SetCaption __UI_NewID, "GIFPlay Sample"
Control(__UI_NewID).Font = SetFont("arial.ttf", 12) Control(__UI_NewID).Font = SetFont("arial.ttf", 12)
Control(__UI_NewID).HasBorder = False Control(__UI_NewID).HasBorder = False
__UI_NewID = __UI_NewControl(__UI_Type_PictureBox, "PictureBox1", 230, 230, 36, 12, 0) __UI_NewID = __UI_NewControl(__UI_Type_PictureBox, "PictureBox1", 320, 320, 95, 10, 0)
__UI_RegisterResult = 0 __UI_RegisterResult = 0
Control(__UI_NewID).Stretch = True Control(__UI_NewID).Stretch = True
Control(__UI_NewID).HasBorder = True Control(__UI_NewID).HasBorder = True
@ -21,18 +21,25 @@ SUB __UI_LoadForm
Control(__UI_NewID).VAlign = __UI_Middle Control(__UI_NewID).VAlign = __UI_Middle
Control(__UI_NewID).BorderSize = 1 Control(__UI_NewID).BorderSize = 1
__UI_NewID = __UI_NewControl(__UI_Type_Button, "LoadBT", 123, 23, 36, 247, 0) __UI_NewID = __UI_NewControl(__UI_Type_Button, "LoadBT", 80, 40, 10, 10, 0)
__UI_RegisterResult = 0 __UI_RegisterResult = 0
SetCaption __UI_NewID, "&Load" SetCaption __UI_NewID, "&Load"
Control(__UI_NewID).HasBorder = False Control(__UI_NewID).HasBorder = False
Control(__UI_NewID).CanHaveFocus = True Control(__UI_NewID).CanHaveFocus = True
__UI_NewID = __UI_NewControl(__UI_Type_Button, "PlayBT", 80, 23, 186, 247, 0) __UI_NewID = __UI_NewControl(__UI_Type_Button, "PlayBT", 80, 40, 10, 55, 0)
__UI_RegisterResult = 0 __UI_RegisterResult = 0
SetCaption __UI_NewID, "&Play" SetCaption __UI_NewID, "&Play"
Control(__UI_NewID).HasBorder = False Control(__UI_NewID).HasBorder = False
Control(__UI_NewID).CanHaveFocus = True Control(__UI_NewID).CanHaveFocus = True
__UI_NewID = __UI_NewControl(__UI_Type_Button, "AboutBT", 80, 40, 10, 100, 0)
__UI_RegisterResult = 0
SetCaption __UI_NewID, "&About"
Control(__UI_NewID).Stretch = True
Control(__UI_NewID).HasBorder = False
Control(__UI_NewID).CanHaveFocus = True
END SUB END SUB
SUB __UI_AssignIDs SUB __UI_AssignIDs
@ -40,4 +47,5 @@ SUB __UI_AssignIDs
PictureBox1 = __UI_GetID("PictureBox1") PictureBox1 = __UI_GetID("PictureBox1")
LoadBT = __UI_GetID("LoadBT") LoadBT = __UI_GetID("LoadBT")
PlayBT = __UI_GetID("PlayBT") PlayBT = __UI_GetID("PlayBT")
AboutBT = __UI_GetID("AboutBT")
END SUB END SUB

Binary file not shown.

After

Width:  |  Height:  |  Size: 221 KiB