-
Notifications
You must be signed in to change notification settings - Fork 40
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
Support animated GIFs with transparency as RGBA frames with frame delay #32
Comments
As you noticed, this library does in fact support the loading of animated images since all frames are accessible. Furthermore it also allows to output animated images (with delay) as it is illustrated in the example code in the readme file. Unfortunately the support is quite rough as it did not have any users. I'm very interested to get input for this topic. What exactly are you missing, what should be added? Imho storing information about the current frames' timely offset doesn't make much sense because this information is deeply tied to the implementation of the presenter. If you would imagine an implementation which just sleeps for |
Does #33 cover your intention? |
Right, it does support it but people who don't know about the specifics of the GIF format (e. g. that frames can have different sizes) and just want to load animated GIFs as an image sequence will take a long time to figure out how to load them like this. re: frame delay, I meant that the output shouldn't just contain a Vec of image buffers but also each frame's relative delay to the frame before (so the user code can choose to integrate the frame delays or sleep etc.) Also to be able to save a sequence of image buffers (with associated frame delays) as animated GIF would be useful. (The inverse operation of the loading, where each frame is cropped to the bounding box of its non transparent pixels). |
I totally agree to you on the image buffer thing. I’m currently reworking the existing image buffer from Since the delay specifies the time until the next image is displayed I do not see how storing the time to the previous image would help. I am still not convinced how equally sized buffers would always help, you could for example just blit the next frame onto the existing image/background color and you’re fine. On the other hand, the fact that your code ignores the disposal method convinces me that there should be a convenience method in addition to the "low level" interface. Unfortunately it is not beneficial to implement the iterator trait such that a |
I think this issue can simply be solve by expanding the documentation.
Unfortunately, the doc does not give an example on how to make a multi frame gif with delays and disposal set for each frame. Maybe this is where the confusion of users stem from. The from_rgba/from_rgb APIs are already good high level APIs for creating animated GIF with custom delays for each frame. It just needs an example code. |
Thanks, I didn't even know I have to care about the disposal method. @kosinix: Yeah, maybe an example that takes the disposal method into account would be sufficient. |
@Boscop Unfortunately nobody gets animated gifs right. Frames with a delay of zero are rendered incorrect in all browsers I know of. |
I'm writing GIF converter and for it I need both raw frames with palettes, as well as RGBA rendering of all of it together. Some sort of abstraction for gif's concept of "screen" would be very useful: while let Some(frame) = reader.read_next_frame()? {
screen.blit(frame);
screen.rgba(); // -> &[RGBA]
} |
In case anybody needs it, I've implemented it: edit: now it's a crate! https://lib.rs/crates/gif-dispose |
Thank you, but the third to last line is the reason why it is still is as it is. It is really not trivial to create an ergonomic but safe (i.e. do not use unsafe for such “trivial” things) abstraction. |
Oh, that unsafe line was just a microoptimization. It was quite unnecessary, so I've removed it. Now it's 100% safe pure Rust. |
That is not what I meant. It get’s quite tricky if you only want to define a shim over the underlying slice of primitives. Meaning not copying the data, which is what your code did before. Something like color_model/mod.rs#L54 is really difficult to avoid, because you cannot write generic code that abstracts over ownership, mutability or integer numbers. |
Sorry, I completely don't understand what you're saying.
|
All I'm saying is, that I'm completely with you but it takes time to implement because I it is harder to create a wrapper than i thought. |
Is there something I can help with? I think the disposal code should live in the gif crate. What are your requirements for including it? |
Any updates on this? |
For a project of mine I was looking for a crate that could load animated GIFs which I wanted to render with glium. Since this crate didn't have support for loading animated GIFs (I was surprised, because animation is the main reason why GIFs are used) I wrote my own loader based on this crate. It would be great to integrate animated GIF support into this crate, so that other projects can benefit from it as well.
This is my animated GIF loader / renderer code:
It iterates over all the frames and expands them to the same size, then concatenates them into one vertical texture atlas. cur_frame_offset is used to index that texture during rendering to get the current frame of the animation.
As you can see it assumes that the frame delay is always 10 because I was only dealing with those kind of GIFs but it could easily be generalized. The frame delay would have to be stored for each frame, and accumulated and then used for the cur_frame_offset uniform during rendering.
Also there are potentials for optimizations/preallocations..
But this is just a start to get the discussion going.
The animated GIF support in this crate shouldn't be specific to glium / opengl but should be designed with that in mind, so that rendering the animated GIFs as textures is easy.
Also it would be useful to be able to save an image sequence as an animated GIF with given frame delay.
What do you think?
The text was updated successfully, but these errors were encountered: