The Beatles are on iTunes! Or, if you are like me and don’t care that much about it, you’ve probably noticed the awesome splash screen that Apple used to promote the event. Risking to start a trend, in this tutorial we are going to create a simple jQuery plugin that will display fancy Apple-style splash screens for us.
The HTML
Encapsulating the splash screen functionality into a jQuery plugin makes it portable and easy to incorporate into an existing website. But before starting work on the plugin files, we first need to lay down the HTML markup of a simple demonstration page, where the plugin is going to be used.
index.html
04 | < meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" /> |
05 | < title >Apple-style Splash Screen | Tutorialzine Demo</ title > |
07 | < link rel = "stylesheet" type = "text/css" href = "css/styles.css" /> |
08 | < link rel = "stylesheet" type = "text/css" href = "css/splashscreen.css" /> |
11 | < script src = "js/jquery.splashscreen.js" ></ script > |
12 | < script src = "js/script.js" ></ script > |
18 | < div id = "topBar" ></ div > |
21 | < img src = "img/available_now.png" alt = "Available Now" /> |
24 | < div id = "contentArea" > |
25 | < p >... The textual content ...</ p > |
Notice that I’ve placed the script tags in the head section. Usually it is best to include them in the body, after all the other content, as otherwise the page rendering blocks while the js files are being downloaded and our visitor is left staring at a blank screen. This time, however, this is a necessary evil, as we need to be sure that nothing of the page is going to be shown to the user before we show the splash screen.
The code of the splash screen plugin is contained in jquery.splashscreen.js, which we will be discussing in the last section. The plugin depends on splashcreen.css, which defines some useful styles. You can see the stylesheet in the next section of the tutorial.
The #promoIMG div has the MacBook illustration set as its background. This is what our plugin is going to be looking for, when we call it. It will then create a splash screen div and set the illustration as its background, offsetting it so it aligns with the #promoIMG div below it. Finally, when the splash screen is hidden, we are left with the impression that the page around it slowly fades in.
The CSS
We have two distinct stylesheets – styles.css and splashscreen.css. The first one is pretty straightforward, and as it is only used to style the underlying page, is of no interest to us and will not be discussed here. The styles that define the looks of the splash screen are separated in their own file – splashcreen.css, which you can see below.
splashscreen.css
11 | background-color : #252525 ; |
12 | background-repeat : no-repeat ; |
In the fragment above, we are basically saying that the stylesheet div is positioned absolutely with relation to the document window and that it should take the full width and height of the page. The background color is the same as the one of the MacBook illustration, which we are using as a background image, as you will see in a moment.
Making an Apple-style Splash Screen with jQuery & CSS
The jQuery
All of the plugin code resides in jquery.splashscreen.js. As I mentioned in the first section of the tutorial, it is important that the script is loaded before any content is shown to the user, otherwise they will witness a somewhat unpleasant flicker when the splashscreen is shown.
jquery.splashscreen.js
06 | $.fn.splashScreen = function (settings){ |
21 | var splashScreen = $( '<div>' ,{ |
24 | backgroundImage : promoIMG.css( 'backgroundImage' ), |
25 | backgroundPosition : 'center ' +promoIMG.offset().top+ 'px' , |
26 | height : $(document).height() |
30 | $( 'body' ).append(splashScreen); |
32 | splashScreen.click( function (){ |
33 | splashScreen.fadeOut( 'slow' ); |
39 | splashScreen.bind( 'changeText' , function (e,newID){ |
44 | if (settings.textLayers[newID]){ |
52 | splashScreen.trigger( 'changeText' ,0); |
57 | function showText(id){ |
58 | var text = $( '<img>' ,{ |
59 | src:settings.textLayers[id], |
61 | marginTop : promoIMG.offset().top+settings.textTopOffset |
66 | text.fadeIn( 'slow' ).delay(settings.textShowTime).fadeOut( 'slow' , function (){ |
68 | splashScreen.trigger( 'changeText' ,[id+1]); |
72 | splashScreen.append(text); |
The plugin is passed a settings object. The only property of this object that is required is textLayer. This property should be an array with the URLs of all the images with promo phrases that fade in and out above the MacBook illustration. You can make this array arbitrary long, and even put any kind of images there, not just containing text. You could even turn it into a stylish slideshow.
The this of the function corresponds to the promoIMG div. Notice how we take the offset of the image from the top of the page with the offset() method on line 25, and set it as the offset of the background image on the splash screen. This gives us perfect alignment and in the same time frees us from having to pass the offset as a parameter, making the plugin more robust.
You can see how the plugin is used in the fragment below:
script.js
01 | $(document).ready( function (){ |
06 | $( '#promoIMG' ).splashScreen({ |
09 | 'img/more_elegant.png' , |
What is left is to only call the splash screen plugin. The document ready event is perfect for the task, as it is called before the page is visible to the user and we can safely display the screen straight away.
With this our Apple-like Splash Screen Plugin is complete!
Parting words
You can use the plugin to easily create your own stylish intro splash screens. You only need to remember to limit it only to one of your pages, as it will become annoying to the user if they have to sit through a 30 second intro on every page view. Also, using the textLayers parameter, you can turn it into a slide show with different product screenshots, which would be an interesting effect to see.
No comments:
Post a Comment