Ever wanted to turn an app interface PSD into a fully animated demo for your clients or site? Turns out, you can use Photoshop for that, too.
In this tutorial, we will design a simple news iPhone app, and then animate it for client presentation and export it as a GIF file. You’ll learn everything you need to go from idea to animated demo, all inside any recent version of Photoshop.
We’ve used Photoshop CC in this tutorial, but CS5 or 6 would work as well to follow along. You will also need the following stock photo to complete this tutorial. Please download them before you begin, or substitute with a similar picture and adjust the steps accordingly:
1. Design an iPhone App GUI
First, we will start designing the app’s interface. Make a new file (Control-N) with canvas size 640 px by 1136 px, then click OK.
If instead you already have an app interface designed, you can open it in Photoshop and then jump to the Tap section of this tutorial.
Click View > New Guide to make new guide, which will help us in placing GUI elements accurately. Set it to Vertical with position 15 px.
Add another vertical guide at each side of the canvas with 15 px distance between each guide.
Draw another guide, this time horizontally at 40 px, 128 px, and 220 px.
Add a status bar on the upper most section of your canvas. If you need detailed directions on that, check out the status bar section of our earlier tutorial How to Design an iOS 7 Email App in Photoshop.
Then, make a new layer and then select second section and then fill it a gray color,
Add the app’s title text on the top part of the interface.
Add a logo to the title. I just drew some simple rectangles for the logo, but if you have an existing app icon, you can just import it into a new layer.
Draw a magnifier icon using a combination of two circle shapes and a rounded rectangle, using the same color as the app logo. Place it on the right side of the app.
On the other side, draw four rounded rectangles for the option icon.
Make a new layer with a rectangle section that fits under the titlebar. Fill the next section with a gray color, just as the previous section.
Add a layer mask onto the layer, and then add a black to white gradient until the bottom is faded.
Add a menu using the Type Tool, containing the news categories. Set the first menu—in this case, the All option—to be bold, to indicate that the category is active. Duplicate it (Control-J) and then set other menu—in this case, Sport—to be bold, once again to indicate which category is selected.
Now, from the Layers panel, set the Sport menu Opacity to 0% to hide it, as we want the All category to be bold first.
Add a thin arrow for menu navigation, made of rounded rectangles.
Add another arrow onto the other side.
Fill the rest of the interface with the gray color. Make sure to put this background underneath all the GUI elements.
Draw a light gray rectangle for the individual news section background.
Apply Stroke, Inner Glow, and Outer Glow to add more contrast to the news area. Double click the layer and then use the following settings from the screenshots below:
Draw a white rounded rectangle on the top part of the previous shape. We will put news image here.
Apply Inner Glow into the white shape with the following settings:
Select a photo from the Tuts+ Stock Photo set you previously downloaded, or any other photos you’d like to use, and place it covering the white rounded rectangle shape.
Hit Control-Alt-G to convert selected photo layer into a Clipping Mask. The photo will automatically go inside layer behind it. And, here’s what you see:A perfectly placed photo on top of the individual news area.
Add text for the news content. Make sure to add contrast to the news text for a better reading experience by varying font type, color, and size.
Let’s add icons into the news element design. Draw two small rounded rectangles without Fill and 1 pt white stroke.
Double click the layer and then add layer style Color Overlay. Use
#708196 for its color.
Repeat previous process, but this time uses a combination of a rounded rectangle and a rectangle.
Add a small circle shape. Now, we have a tag icon. Sweet!
So far, this is our app design at 100% magnification.
Add other individual news articles into the app by duplicating the news element layers, customizing them appropriately.
Add bigger news area. This will be shown when an individual news is selected.
Put all the individual news elements and big news stories in separate layer groups. You want to assure every layer is carefully placed into a layer group according to its element.
For example, you want each layer that made the first individual news section placed together in a layer group, and the elements for full-screen news articles in other groups. This will help you to work easier while making the animation.
For now, we will not use this big news section. So, set its Opacity to 0%.
2. Tap Indicator
We now need to design the tap indicator. Make a new layer group and name it
tap. Next, draw a white circle shape. Set its Opacity to 50%.
Duplicate the circle shape by pressing Control-J. Make it larger, set stroke to 3 ptwith a white color, and remove the Fill color.
Add another circle shape, this time thinner. Set its stroke size to 2 pt.
Hide all the layers inside tap layer group we have just made, as you won’t want the taps to show up when the UI is first loaded, but instead will only display them when the animation is fixing to transition to a selected element.
3. Scroll App
Now, we’re finally ready to start building our UI animation. Open the Timeline panel and then make a new frame.
Make another new frame.
Now it’s time to reveal the tap layer group. When showing a scrolling scene, hide the two stroked circles, and we are going to use this condition to indicate scroll gesture. It will appear more as a continuous stroke, whereas the outer stroked circles give a ripple appearance more consistent with a single tap to select an item.
Change the duration to 1 second for first frame and 0.2 seconds for second frame.
Add another frame.
Activate the Tap layer group and all the news grid layers. Use Move Tool to move them up in your list of layers.
To automatically make a smooth animation between current and previous frame, click Tween from Timeline panel menu.
Set the tween to 5 for the added frame.
Now, we have an animation of the news grid moving upward on each frame.
If you think that the animation is too fast, you can make it slower by selecting all the frames and setting the duration to 0.2 seconds.
Test the animation by clicking the play icon in the Timeline panel. Don’t forget to set the animation to Forever; this way the animation is looped.
Our current animation contains the news grid moving upward. In next frame, we need to put it back to previous condition so it will continue seamlessly with the first frame. To do this, copy the second frame and then paste it at the last position by choosing Paste After Selection in the dialogue box.
Apply the Tween command again to make a new animation between last and next-to-last frames.
Add a new frame and hide the tap indicator.
So far, this is the animation we get, which gives us a basic scrolling UI.
4. Tap Link
Now it’s time to animate the selection of a link in the menu. First, make a new frame. In this frame, set the Opacity text menu with the selected bold variant of All from the menu set to 0% and Sport‘s selected variant’s transparency set to 100%.
Activate the Tap layer group and reveal all its layers. Change frame duration to 0.2 seconds.
Make a new frame with a duration of 0.1 seconds. This time hides the thinnest stroked circle.
Add another frame and hide next stroked circle.
Add a new frame and hide the tap layer group.
Make a new frame and then set the Opacity of every news story in the grid without the sport tag to 0%.
Still in this frame, drag the individual sports news stories upward in the grid, filling empty spaces above them.
Tween between current frame and the previous. For faster animation, set added frames to 3.
Set duration in the last frame to 2 seconds.
For this tap, this is the animation we have.
6. Tap News
Next, we are going to select one of the news articles and reveal it in full screen. First, make new frame with duration 0.2 seconds and then reveal all layers inside the Tap layer group.
Add new frame and then set its duration to 0.1 seconds. Hide thinnest circle stroke.
Add another frame and then hide next stroked circle.
Add another frame with duration 0.1 seconds. Hide the Tap layer group, and make a new frame. Reveal the big news section we made earlier in Section 1 Step 28 by setting its Opacity to 100%. Hide the small news grid by setting its Opacity to 0%.
Add tween animation between the current frame and the previous ones.
This is what we have for this animation.
7. Convert Layers Animation to Frames
From Timeline panel, click Flatten Frames Into Layers.
Each frame will be converted into a flat layer. If you have 33 frames, you will also get 33 flat layers: layer Frame 1 taken from content of frame 1, layer Frame 2 taken from frame 2, and so on.
Select all frame layers in Layers panel.
Drag the layers onto the iPhone photo that you downloaded previously.
In Timeline panel, select Create Frame Animation and then click New Framebutton.
Make sure all layers are still selected. Hit Control-T to perform a transformation. Hold Control and then drag each corner and place them onto the screen corner.
Make a new frame for each layer. Put layer Frame 1 in the first frame, layer Frame 2in second frame, layer Frame 3 in third frame, and so on. You also want to match the duration for each of the frame. Make sure to set the loop to Forever, so the animation will keep on looping.
Look at picture below for an example. Layer Frame 23 is revealed on frame 23. Layer Frame 25 is revealed on frame 25, and so on. Continue this for each frame.
It’s time to export the result as animated GIF file. Select Save for Web in the File menu, and select GIF as file type. Play around with available settings to get the optimum file size. Test the animation result by clicking on the play button. Make sure to set its Looping Options to Forever.
And that’s it: you’ve designed a demo app UI, animated it, and put the animation inside an iPhone picture to make the animation look like it’s running on a real device.