• Feed RSS

Build a Pure CSS Slideshow With Webkit Keyframes

Build a Pure CSS Slideshow With Webkit Keyframes: "
While playing around with Webkit Keyframe Animations I figured out a way to create an awesome little image slider using only CSS. It’s definitely a bit unconventional but it’s a great way to learn to think outside of the box with what you can do with CSS3.

Keep in mind that since we’re using Webkit Keyframes, this is purely an educational experiment and will only work in Safari or Chrome. As more browsers begin to support keyframe animations in the future, this method should become perfectly usable in your own web projects.



Like the article? Be sure to subscribe to our RSS feed and follow us on Twitter to stay up on recent content.

What We’re Building


Slideshow Live Demo: Click here

screenshot

Porthole Live Demo: Click here

screenshot

Why Pure CSS?


Before anyone gets too excited, I want to recognize that, at this point in time, this is a job for JavaScript. Though some rare and confused souls browse with JavaScript turned off, that will leave out a much lower percentage of your audience than today’s method.

That said, I think it’s important and even fun to experiment with upcoming technologies to see how we’ll be coding in the near future. As we saw in our recent article on creating Colorful Pulsing Backgrounds, Webkit Keyframe Animations really stretch what’s possible with CSS and are actually quite easy to work with.

Getting Started: Basic HTML


To begin, let’s create the page as if it contained only static elements. We’re not going to worry too much about creating a complex page design this time around, just a simple container with the slideshow and a headline.

With that in mind, the markup for this project is super simple:

<div id='container'> <div id='headline'> <h1>Webkit Slideshow</h1> <p>An image slider made with pure CSS.</p> </div>
<div id='slideshow'> </div>
</div>

</ br>

After this, you shouldn’t have anything more than a white page with some text on it:

screenshot

Basic CSS


Now that we have our markup all laid out, it’s time to start styling the page to make it look presentable. The first thing I’m going to do is throw in a basic margin/padding reset, apply a background to the body and center the container.

The reset simply helps clear any browser presets and centering the div is as easy as applying a width and setting the left and right margins to auto.

* { margin: 0; padding: 0;
}

body { background: url(black_denim.jpg); /* source: http://subtlepatterns.com/ */
}

#container { width: 960px; margin: 0 auto;
}

</ br>

Styling the Text


Now that our background and container are set up, let’s make the headline look a little better. Our markup created three sections to work with: the headline div, the h1 and the paragraph.

I started by applying some margins to the entire div along with centering any text within and setting the default color to white. After this I applied some basic font styling (using shorthand) to the h1 and paragraph tags.

#headline { margin: 50px 0 30px 0; text-align: center; color: #fff;
}

#headline h1 { font: 60px/55px 'Josefin Sans', Helvetica, sans-serif; font-weight: normal; color: #37c5fb;
}

#headline p { font: 20px/25px 'Josefin Sans', Helvetica, sans-serif;
}

</ br>

Note that I’ve used ‘Josefin Sans’ for the font. This is from the Google Font Library so to make it work make sure you have this snippet in the head section of your HTML.

<link href='http://fonts.googleapis.com/css?family=Josefin+Sans' rel='stylesheet' type='text/css'>

</ br>

And with that, our page is starting to look a lot nicer!

screenshot

Styling the Image


Now we need to apply a background to the slideshow div. In the next step we’ll do a lot more with this but for now you basically just want to choose a placeholder image and apply a width and height to the div.

#slideshow { width: 465px; height: 300px; background: url(slideshow-1.jpg); margin: 0 auto;
}

</ br>

Our page is looking great at this point. Now that we’ve got it how we want, we can proceed with bringing it to life!

screenshot

Setting Up the Slideshow Image


The way that we’ll be setting up this slideshow is basically through the use of a modified version of CSS sprites. The idea is to create one big image containing all of our slides then to use keyframe animations to reveal specific portions of the image at certain points in the animation.

If that doesn’t quite make sense yet, don’t worry, it’s a lot easier than you think! To start off, we’ll need to go into Photoshop and build our image. Now, given that the size we set up above for the slideshow is 465px wide by 300px tall, we’ll need to make our Photoshop document 930px by 600px (double both the width and the height). This will give us enough area for four images, if you want more, simply make it bigger!

From here, you want to drop in four images, each of which is 465px by 300px. Set them up in a grid with no gaps and save out a JPG at full size. Your result should look something like the image below.

screenshot

Slideshow CSS


Webkit Keyframe Animations are really simple to work with. All you have to so is choose something to animate and then set the state of that item at various points in the animation, defined by percentages. So if you set the width of a div to 100px at 0%, 50px at 50% and 10px at 100%, the div will shrink over the course of the animation.

Today, we’re going to animate the background-position property. Our slideshow is set up to show only the top left quadrant of our image by default and we can use background-position to move that around to show the others.

To visualize this, picture our webpage as a dark background with a rectangle hole cut in it. The image we just created is then set under that hole and we’re going to move it around.

First, we want to go from the top left picture to the top right picture, so we’re going to set the “right” value (the first number) to the negative width of one image (465px). Next, we set the “up” value (the second value) to the negative height of one image (300px). Finally, we stay at -300 on the height but bring the right value back to zero. The effect of this will be to show the top left image, the top right image, the bottom right image and then the bottom left image.

@-webkit-keyframes slider { 0% {background-position: 0px 0px} 10% {background-position: 0px 0px} 33% {background-position: -465px 0px} 66% {background-position: -465px -300px} 100% {background-position: 0px -300px}
}

</ br>

Notice that I threw a bit of a curve ball in here and set everything to 0 at 10%. This is because I didn’t like the slideshow starting right away without giving you a chance to look at the first image. This simply builds in a brief pause.

Also, one of the most important elements here is the syntax at the beginning: “@-webkit-keyframes slider”. The “@-webkit-keyframes” part tells the browser what you’re defining with the code below but the “slider” part is a customizable title that you give the animation. It can be anything you want, just remember to use it again in the next step when we activate this animation.

Activating the Slideshow


Throwing in the CSS above defines the behavior of the slideshow, but it doesn’t activate it. To do that, you need to add a new line into your slideshow div.

#slideshow { width: 465px; height: 300px; background: url(slideshow-1.jpg); margin: 0 auto;
/*Animation*/ -webkit-animation: slider 20s infinite alternate;
}

</ br>

Here I called the “slider” animation that we just defined, then set the length to 20 seconds, the iterations to infinite and the direction to alternate (once the animation is finished, it will go backwards to the beginning).

Demo


With that, we’re all finished! Check out the live demo to see it in action. Again, make sure you’re using Safari or Chrome.

screenshot

Alternative Execution: Porthole Effect


Notice that this technique isn’t really using multiple images but is instead just panning around a single image. Because of this, you can achieve a really cool effect by simply utilizing one large photo.

To see how this works, I grabbed an underwater image and modified the page above to have a sort of ocean porthole feel. The code is shown below. Notice that this time, instead of making the animation start automatically, it only takes place when the user hovers over the image.

For the styling, I simply rounded the corners of the div so that it’s a circle and applied a box shadow set to inset to give it that cut out look.

<div id='container'> <div id='headline'> <h1>Webkit Porthole</h1> <p>Hover over the image below to look around.</p> </div>
<div id='slideshow'> </div>
</div>

</ br>

* { margin: 0; padding: 0;
}

body { /*background: url(http://griddle.it/960-12-30) repeat-y center top;*/ background: url(black_denim.jpg);
}

#container { width: 960px; margin: 0 auto;
}

#headline { margin: 50px 0 30px 0; text-align: center; color: #fff;
}

#headline h1 { font: 60px/55px 'Josefin Sans', Helvetica, sans-serif; font-weight: normal; color: #37c5fb;
}

#headline p { font: 20px/25px 'Josefin Sans', Helvetica, sans-serif;
}

#slideshow { width: 300px; height: 300px; background: url(fish.jpg); margin: 0 auto; -webkit-border-radius: 150px; -webkit-box-shadow: inset 0 0 10px rgba(0,0,0,0.9);

}

@-webkit-keyframes slider { 0% {background-position:0px 0px} 33% {background-position:0px -300px} 66% {background-position:-300px -300px} 100% {background-position:-300px 0px}
}


#slideshow:hover { -webkit-animation: slider 20s infinite alternate ease;
}

</ br>

Demo


To see the Porthole Demo, click on the image below.

screenshot

Conclusion


In summary, Webkit Keyframe Animations hold tons of potential for making web pages impressively dynamic without a shred of JavaScript. Typically this kind of effect would take a pretty decent chunk of code but with CSS it’s incredibly easy.

Leave a comment below and let us know what you think of the effect. Are you excited that CSS is expanding to include these types of behaviors or do you think that this should always be the job of JavaScript? Let us know!
"