Not sure where to start writing this topic, but it has been in my head for a while. I will jump around, but all will be related to animated GIF.
But basically when it comes to dealing with GIF (animated) using code or programmably, there seems to be no easy way. For example, there is no Python module that deals with Animated GIF elegantly. I found it really strange.
In my previous experience as graphic designer, I have used Photoshop to edit and create animated GIF. Editing GIF is simple enough in Photoshop via the interface and menu.
As many years pass by, I tried to challenge myself to try not to rely too much on Photoshop.
The truth is I want to be very flexible with my computing habits these days (it needs to be portable) and also I am becoming a little bit more comfortable in programming.
So, with open source languages like Python, Processing, or Wolfram Cloud, I supposed I should be able to produce animated GIF quite easily right? Well, not that simple apparently. Read on!
iPhone user should be familiar with concept of LIVE Photos (photo with embedded -1.5 and +1.5, for now a total 3 seconds of video with sound that can be viewed by pressing the screen).
And iPhone also can take Burst Shots natively. There is an app called BurstIO that deals with Burst Shots on iPhone and produces video based on that 7-10 fps of burst.
Each frame of burst shots can be viewed and selected easily.
Burst is not exactly GIF, but the idea of turning a sequential frames into a moving images that interest me, in a same way GIF loops beautifully.
Recent iPhone and iPad can actually deal with Animated GIF more elegantly. There are few apps already out there that can import and stitch sequence of images as GIF. Although most of them has limitation in size, sometimes the resulting GIF is too low res.
There is this Workflow app that enable user to "program" using stack to generate procedure to generate animated GIF. This is by far the most interesting one.
I supposed Pythonista app also can create animated GIF, but we will look into that at some point.
NOTE:
Remember that animated GIF needs to be 256 in colors, and with that limited color palette, I want the result that is good enough and will work when shared.
For all photos uploaded to Google Photos, apparently a sequential image will automagically turned into Animated GIF. And quite high resolution too. Around 1 MegaPixels of animated GIF. We can easily share the Animated GIF as GIF or download it as video.
In recent Google Photos update, they allow users to specify up to 50 frames of photos and it will stitch it into Animated GIF (Animation feature).
This is handy, but we need to upload the photos to Google Photos and need Internet.
I want to point out one cool thing, is that Mac OS Preview app can natively import and preview GIF frames and we can scroll and see the GIF moving frame by frame. We can actually extract GIF frames and output it as static sequential images.
But basically when it comes to dealing with GIF (animated) using code or programmably, there seems to be no easy way. For example, there is no Python module that deals with Animated GIF elegantly. I found it really strange.
In my previous experience as graphic designer, I have used Photoshop to edit and create animated GIF. Editing GIF is simple enough in Photoshop via the interface and menu.
As many years pass by, I tried to challenge myself to try not to rely too much on Photoshop.
The truth is I want to be very flexible with my computing habits these days (it needs to be portable) and also I am becoming a little bit more comfortable in programming.
So, with open source languages like Python, Processing, or Wolfram Cloud, I supposed I should be able to produce animated GIF quite easily right? Well, not that simple apparently. Read on!
iOS Environment for GIF
Now, I use the iPhone and iPad a lot nowadays. It introduces a new tricks and challenges.iPhone user should be familiar with concept of LIVE Photos (photo with embedded -1.5 and +1.5, for now a total 3 seconds of video with sound that can be viewed by pressing the screen).
And iPhone also can take Burst Shots natively. There is an app called BurstIO that deals with Burst Shots on iPhone and produces video based on that 7-10 fps of burst.
Each frame of burst shots can be viewed and selected easily.
Burst is not exactly GIF, but the idea of turning a sequential frames into a moving images that interest me, in a same way GIF loops beautifully.
Recent iPhone and iPad can actually deal with Animated GIF more elegantly. There are few apps already out there that can import and stitch sequence of images as GIF. Although most of them has limitation in size, sometimes the resulting GIF is too low res.
There is this Workflow app that enable user to "program" using stack to generate procedure to generate animated GIF. This is by far the most interesting one.
I supposed Pythonista app also can create animated GIF, but we will look into that at some point.
NOTE:
Remember that animated GIF needs to be 256 in colors, and with that limited color palette, I want the result that is good enough and will work when shared.
Google Photos App for GIF
Now, I gotta mention Google's way when dealing with GIF. Apparently Google Photos can do this quite elegantly and automatically.For all photos uploaded to Google Photos, apparently a sequential image will automagically turned into Animated GIF. And quite high resolution too. Around 1 MegaPixels of animated GIF. We can easily share the Animated GIF as GIF or download it as video.
In recent Google Photos update, they allow users to specify up to 50 frames of photos and it will stitch it into Animated GIF (Animation feature).
This is handy, but we need to upload the photos to Google Photos and need Internet.
Mac OS X for GIF
There must be OS X Apps that can make GIF, to capture screen and export it out as animated GIF like Giphy App. I am sure there are already a bunch of apps that this job. Maybe GIFBrew?I want to point out one cool thing, is that Mac OS Preview app can natively import and preview GIF frames and we can scroll and see the GIF moving frame by frame. We can actually extract GIF frames and output it as static sequential images.
MY TASK IS...
The tasks are simple, with available programming language of my choice (Wolfram or Python or Processing), I should be able to do belows :- Extracting animated GIF into sequential image frames, carefully named
- IMPORT bunch of images and EXPORT it as animated GIF
- IMPORT GIF and deal with each image frames contained in the GIF, perhaps EDIT the image selectively depending on the need
WOLFRAM WAY
I am using 2nd Trial version of the Wolfram Mathematica. I have 10 days left.
Now, Wolfram Mathematica has a FUN way when dealing with Images as Object or Symbol or what not they called it. Once we load something and import it as Image entity, we can apply all kind of Functions and Expressions to further process the Image and output all kind of cool stuffs as DATA.
Importing GIF to Wolfram Mathematica and we will get bunch of images automatically. This is very neat, I found:
Assigning those list of IMAGE into a VARIABLE, I can easily access any photo via INDEX:
Like in Python, I can also selectively deal with some elements of the list. I am using Take[] below:
NOTE: There is also Partition[] and ImagePartition[] but that is for different task.
Next, we can further process any part of the GIF. For example below I am using esoteric way Wolfram Mathematica can do "Edge Detect" whether it is as pure function, or function with argument. I am still familiarzing myself with this kind of way to make expression.
Another fun thing I figure out is how we can use Manipulate [] to view image and give user a bit of control to investigate animated GIF, frame by frame:
I like those ability of Mathematica. Once we undersand certain Expression, we can write a seriously concised "one liner" of code that can do interesting thing.
To import bunch of images and saving it as GIF, was not easy find, but apparently we can use Table[] and Export[].
Below code is a bit weird, but once understood, it's quite interesting.
Table[EdgeDetect[
Import[FileNames["*.png",
"/Users/jimmygunawan/bruce_gif_extracted"][[num]]]], {num, 25}]
Export["/Users/jimmygunawan/Desktop/bruce_edge4.gif", frames]
From the most inner to outer:
- FileNames check for file and generate List of Strings
- Import will import Images specified via path strings list Index
- Edge Detect will work on the List of Images Element
- Table helps Import to iterate over each element to import.
PYTHON AND JUPYTER NOTEBOOK WAY
Now, with Python, I really thought that PIL (Pillow) Module could handle GIF, and from quick research, apparently we need module called images2gif or something to do this.
There is one module I found that can extract GIF as sequence of images. But combining the images back as GIF was broken.
Maybe PIL can do it, but somewhat not very elegant.
Then I stumble into something like below:
I was surprised that apparently it is easier for Python to generate GIF from videos, rather than simply importing images and stitch them as GIF.
I don't know, I am probably wrong or missing information somewhere.
Although, my accidental finding of Python MoviePy module above that can convert videos into GIF was kind of nice.
I supposed, I really want Python to be my language to do stuff that Wolfram Mathematica can do. In order to do that sometimes, things are not as simple.
Python should be able to:
- Import Images as Images
- Process Image (maybe using SciKit module)
- Import and Export GIF elegantly
Sometimes I am still confused on: which module can best read and edit process image as pixel or in higher level?
OpenCV for example, can handle video frames in quite elegant way. I believe MoviePy is using OpenCV and ffmpeg.
The thing about Open Source, sometimes we can do something, but have to be so clever in using all the available modules.
As you may already notice, I use Python inside Jupyter Notebook. This is to emulate the Wolfram Mathematica style (there is a lot of things that I like from Wolfram, despite it is an expensive commercial and licensed sofware).
After a while of using Python inside Jupyter Notebook, I noticed that the experience can be pretty elegant, almost like Wolfram. Albeit Python is still Python and a bit wordy.
Below I am using yet another module to quickly download YouTube and receive video for conversion as GIF above.
Everything can be done in one go.
So...
I cannot give conclusion with this, in one way, we have Wolfram Mathematica (paid, commercial software) that seems to come with "all the tools" with some knowledge based of things. Wolfram itself has its own quirks and esoteric programming language.
On the other hand, we got Python (free open source) with all the availabe modules out there.
Myself, with self interest and motivation to learn programming for data visualization and analytic, still have to know both, I think.
IF one day Wolfram Mathematica comes pre-installed with Apple computer... just like NeXT computers, I think that would be awesome.
However, again Open Source and always available is always a bigger something.
Comments
Post a Comment