Skip to content
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

getTotalDuration returns 0 for a 117 frame GIF? #7

Open
lukeify opened this issue Apr 25, 2015 · 4 comments
Open

getTotalDuration returns 0 for a 117 frame GIF? #7

lukeify opened this issue Apr 25, 2015 · 4 comments

Comments

@lukeify
Copy link

lukeify commented Apr 25, 2015

I'm not even sure this repo is maintained anymore. I sure hope it is, since it could be very useful.

Can anyone please explain why this GIF returns a getTotalDuration() of 0? GifFrameExtractor recognizes it has frames, 117 of them, but it returns a frameDuration of 0 for each, which adds up to 0. -_-

This isn't exactly helpful. I suspect it has something to do with 'Delay Time' vs. 'Unclamped Delay Time', as inspecting it with Preview on Mac shows the former to have a value of 0.1, and the latter to be 0.

Help, ideas?

@yang-jandro
Copy link

Hey LukeNZ, depending how long it takes @Sybio to merge in my pull request, I might end up taking over the project and working on my forked copy. With that said, here's a useful link that may lead you to your answer:

http://humpy77.deviantart.com/journal/Frame-Delay-Times-for-Animated-GIFs-240992090

@yang-jandro
Copy link

@LukeNZ Forgot to mention a solution. Something I've used before is:

$gfe = new GifFrameExtractor\GifFrameExtractor();
$gfe->extract($Image);
$total_single_loop_duration = $total_duration = 0;
foreach ($gfe->getFrameDurations() as $duration) {
    // if 0/100s add 10/100s, otherwise add original
    $total_single_loop_duration += $duration == 0 ? 10 : $duration;
}

$total_duration = $total_single_loop_duration * $gfe->getLoopCount();

// Note: all these times are in hundredths of a second, to get in seconds just divide by 100
// Note: to use getLoopCount you'll have to use my pull request, otherwise you're only
// able to get timing for a single loop

@lukeify
Copy link
Author

lukeify commented Apr 28, 2015

Hey @gpv-dev. Thanks for the quick reply, I honestly wasn't expecting anything to come of this! If you were able to fork and maintain the repo, that'd be great. I'd be willing to help out if you needed it.

That solution makes sense, and I had actually read that article, but didn't consider the implications of simply bumping it up from 0 to 10 hundredths.

For what it's worth, you may find this interesting. It seems to take a mix of both clamped and unclamped duration of each frame, which could be a nice addition to this repo: http://justinsomnia.org/2006/10/gif-animation-duration-calculation/

@yang-jandro
Copy link

@LukeNZ Nice article. I don't think I understand what you mean by clamped and un-clamped duration.

Looks like for their solution on handling 0 delay frames, they opted for 1 hundredths of a second per 0 delay frame. I prefer the upper limit at 10 hundredths of a second when setting constraints of gif duration for an application. Seems safer to me.

Nonetheless, everything done in that article should be supported by the current repo + my pull request update adding getLoopCount() (their getGIFIterations()).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants