1
1
Fork 0
mirror of https://github.com/FellippeHeitor/InForm.git synced 2025-01-14 19:49:33 +00:00

GIFPlay cleanup 1

This commit is contained in:
Samuel Gomes 2023-11-20 12:16:45 +05:30
parent ce2d98fb3e
commit 3867088da3
12 changed files with 84 additions and 73 deletions

View file

@ -2,9 +2,9 @@
***By Zom-B*** ([QB64-PE Wiki](https://qb64phoenix.com/qb64wiki/index.php/GIF_Images))
*Adapted for use with InForm's PictureBox controls by @FellippeHeitor*
***Adapted for use with InForm's PictureBox controls by @FellippeHeitor***
*Refactored and enhanced by a740g to use include guards, conditional compiles and cleaner API*
***Fixed, refactored and enhanced by @a740g***
## Usage instructions
@ -74,3 +74,9 @@ FUNCTION GIF_GetWidth~% (ID AS LONG)
```
Returns the width of the GIF in pixels.
```vb
SUB GIF_HideOverlay (ID AS LONG)
```
Hides the **GIF** overlay image when the GIF is not playing or paused.

View file

@ -7,7 +7,7 @@
'
' Adapted for use with InForm's PictureBox controls by @FellippeHeitor
'
' Refactored and enhanced by a740g to use include guards, conditional compiles and cleaner API
' Fixed, refactored and enhanced by @a740g
$IF GIFPLAY_BAS = UNDEFINED THEN
$LET GIFPLAY_BAS = TRUE
@ -29,13 +29,13 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
GifOverlay = __GIF_LoadOverlayImage
END IF
IF __GIFData(i).IsPlaying OR __GIFData(i).LastFrameServed = 0 THEN
IF __GIFData(i).LastFrameUpdate > 0 AND TIMER - __GIFData(i).LastFrameUpdate < __GIFData(i).LastFrameDelay THEN
IF __GIFData(i).isPlaying OR __GIFData(i).lastFrameServed = 0 THEN
IF __GIFData(i).lastFrameUpdate > 0 AND TIMER - __GIFData(i).lastFrameUpdate < __GIFData(i).lastFrameDelay THEN
'Wait for the GIF's frame delay
ELSE
__GIFData(i).Frame = __GIFData(i).Frame + 1
__GIFData(i).LastFrameServed = __GIFData(i).Frame
__GIFData(i).LastFrameUpdate = TIMER
__GIFData(i).frame = __GIFData(i).frame + 1
__GIFData(i).lastFrameServed = __GIFData(i).frame
__GIFData(i).lastFrameUpdate = TIMER
END IF
END IF
@ -45,7 +45,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
newFrame = __GIF_GetFrame(i)
IF newFrame THEN _PUTIMAGE , newFrame
IF __GIFData(i).IsPlaying = FALSE AND __GIFData(i).HideOverlay = FALSE AND __GIFData(i).totalFrames > 1 THEN
IF __GIFData(i).isPlaying = FALSE AND __GIFData(i).hideOverlay = FALSE AND __GIFData(i).totalFrames > 1 THEN
_PUTIMAGE (_WIDTH / 2 - _WIDTH(GifOverlay) / 2, _HEIGHT / 2 - _HEIGHT(GifOverlay) / 2), GifOverlay
END IF
@ -60,7 +60,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
GIF_IsPlaying = __GIFData(i).IsPlaying
GIF_IsPlaying = __GIFData(i).isPlaying
END FUNCTION
@ -69,7 +69,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
GIF_GetWidth = __GIFData(i).width
GIF_GetWidth = __GIFData(i).W
END FUNCTION
@ -78,7 +78,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
GIF_GetHeight = __GIFData(i).height
GIF_GetHeight = __GIFData(i).H
END FUNCTION
@ -95,7 +95,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
__GIFData(i).HideOverlay = TRUE
__GIFData(i).hideOverlay = TRUE
END SUB
@ -104,7 +104,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
__GIFData(i).IsPlaying = TRUE
__GIFData(i).isPlaying = TRUE
END SUB
@ -113,7 +113,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
__GIFData(i).IsPlaying = FALSE
__GIFData(i).isPlaying = FALSE
END SUB
@ -122,8 +122,8 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM i AS LONG: i = __GIF_GetIndex(ID)
__GIFData(i).IsPlaying = FALSE
__GIFData(i).Frame = 1
__GIFData(i).isPlaying = FALSE
__GIFData(i).frame = 1
END SUB
@ -155,8 +155,8 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
OPEN filename$ FOR BINARY AS __GIFData(Index).file
GET __GIFData(Index).file, , __GIFData(Index).sigver
GET __GIFData(Index).file, , __GIFData(Index).width
GET __GIFData(Index).file, , __GIFData(Index).height
GET __GIFData(Index).file, , __GIFData(Index).W
GET __GIFData(Index).file, , __GIFData(Index).H
GET __GIFData(Index).file, , byte~%%
__GIFData(Index).bpp = (byte~%% AND 7) + 1
__GIFData(Index).sortFlag = (byte~%% AND 8) > 0
@ -179,7 +179,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
palette$ = SPACE$(3 * __GIFData(Index).numColors)
GET __GIFData(Index).file, , palette$
__GIFData(Index).palette = palette$
__GIFData(Index).pal = palette$
DO
GET __GIFData(Index).file, , byte~%%
SELECT CASE byte~%%
@ -198,10 +198,10 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
__GIFFrameData(__TotalGIFFrames).ID = ID
__GIFFrameData(__TotalGIFFrames).thisFrame = __GIFData(Index).totalFrames
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).left
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).top
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).width
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).height
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).L
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).T
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).W
GET __GIFData(Index).file, , __GIFFrameData(__TotalGIFFrames).H
GET __GIFData(Index).file, , byte~%%
__GIFFrameData(__TotalGIFFrames).localColorTableFlag = (byte~%% AND 128) > 0
__GIFFrameData(__TotalGIFFrames).interlacedFlag = (byte~%% AND 64) > 0
@ -252,7 +252,7 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
REDIM _PRESERVE __GIFFrameData(0 TO __TotalGIFFrames) AS __GIFFrameDataType
__GIFData(Index).IsPlaying = FALSE
__GIFData(Index).isPlaying = FALSE
GIF_Open = TRUE
EXIT FUNCTION
@ -324,27 +324,27 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
DIM img&, actualFrame&
DIM prevDest AS LONG
IF __GIFData(Index).Frame > __GIFData(Index).totalFrames THEN
__GIFData(Index).Frame = 1
IF __GIFData(Index).frame > __GIFData(Index).totalFrames THEN
__GIFData(Index).frame = 1
END IF
FOR i = 1 TO UBOUND(__GIFFrameData)
IF __GIFFrameData(i).ID = __GIFData(Index).ID AND __GIFFrameData(i).thisFrame = __GIFData(Index).Frame THEN
IF __GIFFrameData(i).ID = __GIFData(Index).ID AND __GIFFrameData(i).thisFrame = __GIFData(Index).frame THEN
frame = i
EXIT FOR
ELSEIF __GIFFrameData(i).ID = __GIFData(Index).ID AND __GIFFrameData(i).thisFrame < __GIFData(Index).Frame THEN
ELSEIF __GIFFrameData(i).ID = __GIFData(Index).ID AND __GIFFrameData(i).thisFrame < __GIFData(Index).frame THEN
previousFrame = i
END IF
NEXT
__GIFData(Index).LastFrameDelay = __GIFFrameData(frame).delay - (__GIFFrameData(frame).delay / 10)
__GIFData(Index).lastFrameDelay = __GIFFrameData(frame).delay - (__GIFFrameData(frame).delay / 10)
IF __GIFFrameData(frame).addr > 0 THEN
prevDest = _DEST
w = __GIFFrameData(frame).width
h = __GIFFrameData(frame).height
w = __GIFFrameData(frame).W
h = __GIFFrameData(frame).H
img& = _NEWIMAGE(w, h, 256)
actualFrame& = _NEWIMAGE(__GIFData(Index).width, __GIFData(Index).height, 256)
actualFrame& = _NEWIMAGE(__GIFData(Index).W, __GIFData(Index).H, 256)
_DEST img&
__GIF_DecodeFrame __GIFData(Index), __GIFFrameData(frame)
@ -354,11 +354,11 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
_COPYPALETTE img&
ELSE
FOR i = 0 TO __GIFData(Index).numColors - 1
_PALETTECOLOR i, _RGB32(ASC(__GIFData(Index).palette, i * 3 + 1), ASC(__GIFData(Index).palette, i * 3 + 2), ASC(__GIFData(Index).palette, i * 3 + 3))
_PALETTECOLOR i, _RGB32(ASC(__GIFData(Index).pal, i * 3 + 1), ASC(__GIFData(Index).pal, i * 3 + 2), ASC(__GIFData(Index).pal, i * 3 + 3))
NEXT
END IF
IF __GIFData(Index).Frame > 1 THEN
IF __GIFData(Index).frame > 1 THEN
SELECT CASE __GIFFrameData(previousFrame).disposalMethod
CASE 0, 1
_PUTIMAGE , __GIFFrameData(previousFrame).addr
@ -373,12 +373,12 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
IF __GIFFrameData(frame).transparentFlag THEN
_CLEARCOLOR __GIFFrameData(frame).transColor, img&
END IF
_PUTIMAGE (__GIFFrameData(frame).left, __GIFFrameData(frame).top), img&
_PUTIMAGE (__GIFFrameData(frame).L, __GIFFrameData(frame).T), img&
_FREEIMAGE img&
__GIFFrameData(frame).addr = actualFrame&
__GIFData(Index).LoadedFrames = __GIFData(Index).LoadedFrames + 1
__GIFData(Index).GifLoadComplete = (__GIFData(Index).LoadedFrames = __GIFData(Index).totalFrames)
__GIFData(Index).loadedFrames = __GIFData(Index).loadedFrames + 1
__GIFData(Index).isLoadComplete = (__GIFData(Index).loadedFrames = __GIFData(Index).totalFrames)
_DEST prevDest
END IF
@ -477,11 +477,11 @@ $IF GIFPLAY_BAS = UNDEFINED THEN
FOR i = stackPointer - 1 TO 0 STEP -1
PSET (x, y), colorStack(i)
x = x + 1
IF x = __GIfFRAMEDATA.width THEN
IF x = __GIfFRAMEDATA.W THEN
x = 0
IF __GIfFRAMEDATA.interlacedFlag THEN
y = y + interlacedStep
IF y >= __GIfFRAMEDATA.height THEN
IF y >= __GIfFRAMEDATA.H THEN
SELECT CASE interlacedPass
CASE 0: interlacedPass = 1: y = 4
CASE 1: interlacedPass = 2: y = 2

View file

@ -7,7 +7,7 @@
'
' Adapted for use with InForm's PictureBox controls by @FellippeHeitor
'
' Refactored and enhanced by a740g to use include guards, conditional compiles and cleaner API
' Fixed, refactored and enhanced by @a740g
$IF GIFPLAY_BI = UNDEFINED THEN
$LET GIFPLAY_BI = TRUE
@ -22,8 +22,8 @@ $IF GIFPLAY_BI = UNDEFINED THEN
ID AS LONG
file AS INTEGER
sigver AS STRING * 6
width AS _UNSIGNED INTEGER
height AS _UNSIGNED INTEGER
W AS _UNSIGNED INTEGER ' width
H AS _UNSIGNED INTEGER ' height
bpp AS _UNSIGNED _BYTE
sortFlag AS _BYTE ' Unused
colorRes AS _UNSIGNED _BYTE
@ -31,27 +31,27 @@ $IF GIFPLAY_BI = UNDEFINED THEN
bgColor AS _UNSIGNED _BYTE
aspect AS SINGLE ' Unused
numColors AS _UNSIGNED INTEGER
palette AS STRING * 768
pal AS STRING * 768 ' global palette
firstFrame AS LONG
totalFrames AS _UNSIGNED LONG
IsPlaying AS _BYTE
Frame AS LONG
LoadedFrames AS LONG
GifLoadComplete AS _BYTE
LastFrameServed AS LONG
LastFrameUpdate AS SINGLE
LastFrameDelay AS SINGLE
HideOverlay AS _BYTE
isPlaying AS _BYTE
frame AS LONG
loadedFrames AS LONG
isLoadComplete AS _BYTE
lastFrameServed AS LONG
lastFrameUpdate AS SINGLE
lastFrameDelay AS SINGLE
hideOverlay AS _BYTE
END TYPE
TYPE __GIFFrameDataType
ID AS LONG
thisFrame AS LONG
addr AS LONG
left AS _UNSIGNED INTEGER
top AS _UNSIGNED INTEGER
width AS _UNSIGNED INTEGER
height AS _UNSIGNED INTEGER
L AS _UNSIGNED INTEGER ' left
T AS _UNSIGNED INTEGER ' top
W AS _UNSIGNED INTEGER ' width
H AS _UNSIGNED INTEGER ' height
localColorTableFlag AS _BYTE
interlacedFlag AS _BYTE
sortFlag AS _BYTE ' Unused

View file

@ -72,15 +72,15 @@ $IF MESSAGEBOX_BAS = UNDEFINED THEN
DIM __caption AS STRING: __caption = caption
$IF INFORM_BI = DEFINED THEN
IF __UI_CurrentTitle <> "" THEN
IF LEN(__UI_CurrentTitle) > 0 THEN
__caption = __UI_CurrentTitle
ELSEIF _TITLE$ <> "" THEN
ELSEIF LEN(_TITLE$) > 0 THEN
__caption = _TITLE$
ELSE
__caption = COMMAND$(0)
END IF
$ELSE
IF _TITLE$ <> "" THEN
IF LEN(_TITLE$) > 0 THEN
__caption = _TITLE$
ELSE
__caption = COMMAND$(0)

View file

@ -39,21 +39,26 @@ SUB __UI_Click (id AS LONG)
CASE gifplaySample
CASE LoadBT
'file 'globe.gif' comes from:
'https://en.wikipedia.org/wiki/GIF#/media/File:Rotating_earth_(large).gif
IF GIF_Open(PictureBox1, "globe.gif") THEN
Control(PlayBT).Disabled = False
IF GIF_GetTotalFrames(PictureBox1) > 1 THEN
Caption(PlayBT) = "Play"
DIM fileName AS STRING: fileName = _OPENFILEDIALOG$(Caption(gifplaySample), , "*.gif|*.GIF|*.Gif", "GIF Files")
IF LEN(fileName) > 0 THEN
GIF_Close PictureBox1 ' close any previously opened GIF
IF GIF_Open(PictureBox1, fileName) THEN
Control(PlayBT).Disabled = False
IF GIF_GetTotalFrames(PictureBox1) > 1 THEN
Caption(PlayBT) = "Play"
ELSE
Control(PlayBT).Disabled = True
END IF
ELSE
Caption(PlayBT) = "Static gif"
Control(PlayBT).Disabled = True
MessageBox fileName + " failed to load!", "", MsgBox_Exclamation
END IF
Caption(LoadBT) = "globe.gif loaded"
Control(LoadBT).Disabled = True
ELSE
MessageBox "File 'globe.gif' could not be found.", "", MsgBox_Exclamation
END IF
CASE PlayBT
IF GIF_IsPlaying(PictureBox1) THEN
GIF_Pause PictureBox1
@ -62,6 +67,7 @@ SUB __UI_Click (id AS LONG)
GIF_Play PictureBox1
Caption(PlayBT) = "Pause"
END IF
CASE PictureBox1
GIF_HideOverlay PictureBox1
END SELECT

View file

@ -3,7 +3,6 @@
': Fellippe Heitor, 2016-2023 - fellippe@qb64.org - @fellippeheitor
': https://github.com/FellippeHeitor/InForm
'-----------------------------------------------------------
SUB __UI_LoadForm
DIM __UI_NewID AS LONG, __UI_RegisterResult AS LONG
@ -24,13 +23,13 @@ SUB __UI_LoadForm
__UI_NewID = __UI_NewControl(__UI_Type_Button, "LoadBT", 123, 23, 36, 247, 0)
__UI_RegisterResult = 0
SetCaption __UI_NewID, "Load globe.gif"
SetCaption __UI_NewID, "&Load"
Control(__UI_NewID).HasBorder = False
Control(__UI_NewID).CanHaveFocus = True
__UI_NewID = __UI_NewControl(__UI_Type_Button, "PlayBT", 80, 23, 186, 247, 0)
__UI_RegisterResult = 0
SetCaption __UI_NewID, "Play"
SetCaption __UI_NewID, "&Play"
Control(__UI_NewID).HasBorder = False
Control(__UI_NewID).CanHaveFocus = True

Binary file not shown.

After

Width:  |  Height:  |  Size: 301 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 978 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 53 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 MiB