Animation, Image Format, Containers
Forum rules
Be kind.
Be kind.
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Animation, Image Format, Containers
So: whether you like it or not, I have an obsession with achieving some sort of unclunky, unjuddery animations inwith OXT without using either:
on-the-spot image renderings using code, or animated GIF images (mainly because the control of these strikes me as tedious and not very good).
So . . . I am returning to my lolloping wolf . . .
- -
And am going to "fool around" with both image formats and containers.
My original stack (viewtopic.php?p=6793#p6793) used PNG images in a graphic container.
Each 'wolf' PNG image weighed in at about 3 KB.
Each 'wolf' converted to a static GIF weighs in at about 1 KB.
The three "background" images weigh in like this:
"1.png" is 22 KB
"2.png" is 19 KB
"3.png" is 25 KB
This is slightly ridiculous as they were resized and locked AFTER they were imported into the stack.
Having done a bit of judicious pruning:
"2.png" is 14 KB
"3.png" is 30 KB ! (which is bonkers)
I shall now rebuild the stack with NO changes in the code, but using the static GIF images instead of the PNG images.
--
There is NO noticeable difference in the clunkiness of the animation.
Therefore the problem MAY lie in the coarse-grained nature of the movements.
on-the-spot image renderings using code, or animated GIF images (mainly because the control of these strikes me as tedious and not very good).
So . . . I am returning to my lolloping wolf . . .
- -
And am going to "fool around" with both image formats and containers.
My original stack (viewtopic.php?p=6793#p6793) used PNG images in a graphic container.
Each 'wolf' PNG image weighed in at about 3 KB.
Each 'wolf' converted to a static GIF weighs in at about 1 KB.
The three "background" images weigh in like this:
"1.png" is 22 KB
"2.png" is 19 KB
"3.png" is 25 KB
This is slightly ridiculous as they were resized and locked AFTER they were imported into the stack.
Having done a bit of judicious pruning:
"2.png" is 14 KB
"3.png" is 30 KB ! (which is bonkers)
I shall now rebuild the stack with NO changes in the code, but using the static GIF images instead of the PNG images.
--
There is NO noticeable difference in the clunkiness of the animation.
Therefore the problem MAY lie in the coarse-grained nature of the movements.
- Attachments
-
- SIDEWAYS_2.oxtstack.zip
- (83.69 KiB) Downloaded 126 times
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
In both "SIDEWAYS.oxtstack" and "SIDEWAYS_2.oxtstack" the movements of the "wolf" and the background images is extremely coarse:
- -
The "wolf" moving 56 pixels per animation frame.
By reducing the movements a slightly better effect is reached:
- -
You should see that the code has been modified BOTH to provide a lap counter for the backGroundPatterns that is distinct from the movement counter, and the movement has been changed from 56 to 4 pixels per time.
The effect is STILL clunky, but less so.
- -
The "wolf" moving 56 pixels per animation frame.
By reducing the movements a slightly better effect is reached:
- -
You should see that the code has been modified BOTH to provide a lap counter for the backGroundPatterns that is distinct from the movement counter, and the movement has been changed from 56 to 4 pixels per time.
The effect is STILL clunky, but less so.
- Attachments
-
- SIDEWAYS_3.oxtstack.zip
- (83.72 KiB) Downloaded 117 times
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Bumping up the moveSpeed reduces the clunkiness:
- -
- -
- Attachments
-
- SIDEWAYS_4.oxtstack.zip
- (83.73 KiB) Downloaded 116 times
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
I think I'll just take a break to make one of my famous abusive remarks.
- -
Just to really "rub things in", here's a snapshot from 'somewhere else':
-
data:image/s3,"s3://crabby-images/fbe06/fbe0628b4030d891d34c70c67a8eda56f7b68aa7" alt="Cool 8-)"
- -
Just to really "rub things in", here's a snapshot from 'somewhere else':
-
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Using an image rather than a graphic as an animation container results in far less clunkiness:
-
-
Code: Select all
put image ("WR" & VULK & ".gif") into image "LOUP"
- Attachments
-
- SIDEWAYS_5.oxtstack.zip
- (85.11 KiB) Downloaded 119 times
https://richmondmathewson.owlstown.net/
- tperry2x
- Posts: 3211
- Joined: Tue Dec 21, 2021 9:10 pm
- Location: Somewhere in deepest darkest Norfolk, England
- Contact:
Re: Animation, Image Format, Containers
Yeah, the dictionary I had built upon has some issues reading the edited sqlite database.
If you put the original one in from the LC community version, it functions just fine.
I did mention this back here
https://www.openxtalk.org/forum/viewtop ... 6160#p6160
I assume there's something it doesn't like with the edited sqlite database, but not sure. With the original LC one, I had no issues - but that might be as to how this stack is referencing the database.
If you put the original one in from the LC community version, it functions just fine.
I did mention this back here
https://www.openxtalk.org/forum/viewtop ... 6160#p6160
I assume there's something it doesn't like with the edited sqlite database, but not sure. With the original LC one, I had no issues - but that might be as to how this stack is referencing the database.
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Yeah: but that was at the full moon and I was more concerned with the hairs growing on the palms of my hands.I did mention this back here
data:image/s3,"s3://crabby-images/6753f/6753fd47d4d5d1a4a5e0b1225b4c653c4c26f91f" alt="Very Happy :D"
-
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Using set the location as opposed to move seems to make no obvious difference.
Code: Select all
set the location of image "LOUP" to HORIZONTAL_POSITION_WOLF, VERTICAL_POSITION_WOLF
- Attachments
-
- SIDEWAYS_6.oxtstack.zip
- (85.02 KiB) Downloaded 119 times
https://richmondmathewson.owlstown.net/
- tperry2x
- Posts: 3211
- Joined: Tue Dec 21, 2021 9:10 pm
- Location: Somewhere in deepest darkest Norfolk, England
- Contact:
Re: Animation, Image Format, Containers
I think you've found the limits of OXT regarding smooth animation (or lack of).
If you have a look at the help menu > guides > Working with media section > "Working with Vector Graphics" - I've included the animation engine v6, so perhaps that would give you smoother results?
Although OXT & LC is fine at crunching a few numbers, and producing prototypes for a button interface, I don't see it ever being able to achieve something like this, this smoothly. We just have to have realistic expectations I suppose on what OXT / LC is capable of, and what it isn't.
If you have a look at the help menu > guides > Working with media section > "Working with Vector Graphics" - I've included the animation engine v6, so perhaps that would give you smoother results?
Although OXT & LC is fine at crunching a few numbers, and producing prototypes for a button interface, I don't see it ever being able to achieve something like this, this smoothly. We just have to have realistic expectations I suppose on what OXT / LC is capable of, and what it isn't.
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Not completely, as I have yet to get into move to the points here.
Of course that can be a pain-in-the-bum as it involves manipulating multi-point vector graphics as paths for whatever you are proposing to animate.
WATCH THIS SPACE.
Of course that can be a pain-in-the-bum as it involves manipulating multi-point vector graphics as paths for whatever you are proposing to animate.
WATCH THIS SPACE.
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Well: pretty silly really: but it does illustrate how this works:
- -
The button "GENERATE A PATH", oddly enough generates a 'random' path (i.e. a multi-point graphic) between some fairly strict constraints:
Of course these points could go into a variable, an array, or a custom property: I put them into a scrolling list field so that people can see that something is going on.
The button "ANIMATE BLOB", err, animates the image "BLOB" by sending it along the path:
- -
The button "GENERATE A PATH", oddly enough generates a 'random' path (i.e. a multi-point graphic) between some fairly strict constraints:
Code: Select all
on mouseUp
put empty into fld "POYNTS"
put 400 into UPDOWN
put 10 into LRIGHT
repeat until LRIGHT > 1390
put LRIGHT/10 into LYNE
put random(50) into VERT
put random(2) into UD
if UD = 2 then
put (VERT + 390) into VERT
else
put (VERT + 340) into VERT
end if
put LRIGHT & "," & VERT into line LYNE of fld "POYNTS"
add 10 to LRIGHT
end repeat
set the points of graphic "PATEKA" to field "POYNTS"
end mouseUp
data:image/s3,"s3://crabby-images/fbe06/fbe0628b4030d891d34c70c67a8eda56f7b68aa7" alt="Cool 8-)"
The button "ANIMATE BLOB", err, animates the image "BLOB" by sending it along the path:
Code: Select all
on mouseUp
move image "BLOB" to the points of graphic "PATEKA"
wait 10 ticks
set the location of image "BLOB" to 10, 400
end mouseUp
- Attachments
-
- POINTY.oxtstack.zip
- (2.84 KiB) Downloaded 120 times
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
It is perfectly possible to send an animated GIF along a multi-point graphic . . .
https://richmondmathewson.owlstown.net/
- tperry2x
- Posts: 3211
- Joined: Tue Dec 21, 2021 9:10 pm
- Location: Somewhere in deepest darkest Norfolk, England
- Contact:
Re: Animation, Image Format, Containers
That moves and everything, but can you have that happening smoothly at the same time you have another object moving?
That's what animation engine does:
(demo of animating multiple objects without blocking)
Code is quite simple too:
That's what animation engine does:
(demo of animating multiple objects without blocking)
Code is quite simple too:
Code: Select all
on mouseUp
aeMoveTo the long ID grc "center", 200,200,1000,"overShoot"
aeMoveTo the long ID grc 1 of grp "rotateMe",160,145,1000,"overShoot"
aeMoveTo the long ID grc 2 of grp "rotateMe",150,250,1000,"overShoot"
aeMoveTo the long ID grc 3 of grp "rotateMe",250,250,1000,"overShoot"
end mouseUp
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
It is perfectly possible to send an animated GIF along a multi-point graphic . . .
This might go down in history as the worst bit of crap I have ever made
-
This might go down in history as the worst bit of crap I have ever made
data:image/s3,"s3://crabby-images/c2cb6/c2cb67b505490515f656dc305bbbf5ae42f910ea" alt="Laughing :lol:"
-
- Attachments
-
- WOLFY.oxtstack.zip
- (21.71 KiB) Downloaded 117 times
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
A word of warning to the wise: do not touch those online animated GIF makers with a ten foot pole. data:image/s3,"s3://crabby-images/fbe06/fbe0628b4030d891d34c70c67a8eda56f7b68aa7" alt="Cool 8-)"
data:image/s3,"s3://crabby-images/fbe06/fbe0628b4030d891d34c70c67a8eda56f7b68aa7" alt="Cool 8-)"
https://richmondmathewson.owlstown.net/
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Let's start our Sunday by mentioning a blasphemous word:
multithreading
Here are some canonical phrases:
without waiting
with messages
Were xTalk to have m*lt*thr**ding (censored), animations and so forth would be a much simpler affair.
https://forums.livecode.com/viewtopic.p ... ng#p222985
multithreading
data:image/s3,"s3://crabby-images/fbe06/fbe0628b4030d891d34c70c67a8eda56f7b68aa7" alt="Cool 8-)"
Here are some canonical phrases:
without waiting
with messages
Were xTalk to have m*lt*thr**ding (censored), animations and so forth would be a much simpler affair.
https://forums.livecode.com/viewtopic.p ... ng#p222985
https://richmondmathewson.owlstown.net/
- OpenXTalkPaul
- Posts: 2633
- Joined: Sat Sep 11, 2021 4:19 pm
- Contact:
Re: Animation, Image Format, Containers
Oh yes, I'd forgotten Animation Engine was open source licensed a few years back, I've personally never used it, but I should take a look at it, perhaps we can include it and expand on it.tperry2x wrote: ↑Sat Feb 24, 2024 7:52 pm I think you've found the limits of OXT regarding smooth animation (or lack of).
If you have a look at the help menu > guides > Working with media section > "Working with Vector Graphics" - I've included the animation engine v6, so perhaps that would give you smoother results?
Although OXT & LC is fine at crunching a few numbers, and producing prototypes for a button interface, I don't see it ever being able to achieve something like this, this smoothly. We just have to have realistic expectations I suppose on what OXT / LC is capable of, and what it isn't.
If you look at the side scrolling game demo here https://livecodeshare.runrev.com/stack/ ... -Game-Test
Which is an attempt to recreate a Super Mario Bros. Level, for the background it uses an image in a scrolling group and then sets the horizontal scroll of the group. It works well enough in LC CE 9.5.1, but for some reason it is significantly glitchy and slower in 9.6.3. Something effecting timing has changed between those two versions.
The other thing about that demo is that is polls the keysDown() instead of doing animation on KepUp pKey messages (which floods the message queue if your Key Repeat Rate is not set to 0 / off ) Polling and update rendering at regular on a timer intervals is the way to go.
- OpenXTalkPaul
- Posts: 2633
- Joined: Sat Sep 11, 2021 4:19 pm
- Contact:
Re: Animation, Image Format, Containers
Your scripts can do other things while its moving an object on a path
move image "WOLFY" to the points of graphic "MyPath" in 6666 millisecs without waiting
Part of the problem here is syncing frames for an animated sequence, you can not just move the image box while it's changing frames of an animation without syncing to the movement of the animation, otherwise it will always look awkward.
When you made your wolfy animated GIF you must have set a long delay time set between the frames between.
The online GIF Makers that I've used have this set to a default of 20 which is too much for a sequence that only has 9 frames, it makes the run slow, so your move points must be further apart for it to look correct but then it looks unnatural, more like it's floating. You want it to be lower for this fast running sequence.
move image "WOLFY" to the points of graphic "MyPath" in 6666 millisecs without waiting
Part of the problem here is syncing frames for an animated sequence, you can not just move the image box while it's changing frames of an animation without syncing to the movement of the animation, otherwise it will always look awkward.
When you made your wolfy animated GIF you must have set a long delay time set between the frames between.
The online GIF Makers that I've used have this set to a default of 20 which is too much for a sequence that only has 9 frames, it makes the run slow, so your move points must be further apart for it to look correct but then it looks unnatural, more like it's floating. You want it to be lower for this fast running sequence.
- OpenXTalkPaul
- Posts: 2633
- Joined: Sat Sep 11, 2021 4:19 pm
- Contact:
Re: Animation, Image Format, Containers
This is why I've become interested in a making a library that can do things with the GIF data, things like change the time between individual frames without remaking the GIF in an external editor, and changing the color table would be cool too, then you can get animated effects like 'electrify' a sprite by changing the table. For example you could have a character get more red colored as their energy level gets low, just by changing the color table in the data and then setting the image data of the image control again. And most of all I want to be able to merge single frame GIFs to animated GIFs, and also split ani-GIF frames to individual GIFs.
https://en.wikipedia.org/wiki/GIF#Animated_GIF
https://en.wikipedia.org/wiki/GIF#Animated_GIF
- richmond62
- Posts: 4833
- Joined: Sun Sep 12, 2021 11:03 am
- Location: Bulgaria
- Contact:
Re: Animation, Image Format, Containers
Sounds like a super idea,making a library that can do things with the GIF data
https://richmondmathewson.owlstown.net/
Who is online
Users browsing this forum: No registered users and 0 guests