The Web has increasingly become a medium for showing off art. From candid snapshots
taken by an amateur photographer to professional art galleries, Web pages are primary vehicles
for displaying images. But a beautiful image is hindered—or
aided—by its frame. Using a
simple JavaScript library, you can "frame" your online images beautifully and provide an
intuitive user interface along the way.
Everyone's a photographer these days
Five years ago, it seemed like everyone was blogging. Mothers, grandmothers, uncles, soldiers, and athletes were all going online to share the latest minutiae from their lives. Lately, the trend has been to display your photos online.With a few hundred bucks, even high school students can purchase a nice digital camera and begin building their photography skills. But most photos are meant to be shared, not admired only by their taker. That's where the Web comes in: The Web provides a bigger platform than any art gallery (although perhaps with less distinguished tastes). But a beautiful photo slapped into an HTML page amidst some text can quickly lose its appeal. And potential in a novice photographer can be overshadowed by a horrible Web design.
Enter Lightbox (and now its successor, Lightbox 2). Lightbox is a JavaScript library that provides a full-featured image viewer. Images are displayed in a slick "overlay" that sits atop the main Web page. Navigation, image descriptions, and even custom buttons are all a possibility. At its simplest, a lightbox looks something like Figure 1.
Figure 1. The default Lightbox viewer
Before digging deeper into the specifics, there are a few good reasons to use Lightbox, and you should know each of them. Even if you're personally convinced, you may want to get a coworker, boss, or friend to agree with using Lightbox on a site. Besides, understanding why you choose a particular technology or tool is often as important as the tool itself.
Lightbox is JavaScript
First, Lightbox is JavaScript. With every modern browser (and several very un-modern browsers) supporting JavaScript "out of the box," you can be sure your pages will work easily on most users' browsers. While there are certainly other great plugin-based technologies, like Flash or the Microsoft® suite of controls, JavaScript is part of every browser. So, you don't need your users to download special components or worry about updating their browsers (within reason). Almost every computer user with a browser will be able to view your lightboxes just as you designed them.Lightbox is browser-neutral
Not only is Lightbox built with JavaScript, it's built with cross-browser JavaScript. In other words, Lightbox will work on any modern browser, and work the same way across those browsers. Internet Explorer, Safari, Firefox, Opera—they'll all handle the Lightbox code in the same way. That means that when you use Lightbox, you're building code and pages that aren't requiring your users to choose a particular browser (or operating system). And that, in turn, means more users, more people seeing your photos, and less irritated calls from your mother-in-law who wants to see your latest photos of the grandkids. That's a good thing, right?Lightbox builds on existing libraries
Finally, Lightbox actually builds on two well-established JavaScript libraries, Prototype and Scriptaculous. Prototype provides some utility functions for working with a page and its objects, and Scriptaculous adds a ton of display effects. Both are well-tested, have been around for a few years, and are also standard JavaScript, built to work across all modern browsers. The end result is that Lightbox is building on solid code, rather than reinventing the wheel (and introducing its own bugs).Download and "install" Lightbox
As with any JavaScript library, getting Lightbox set up is quick and painless. Here's exactly what you need to do.Download Lightbox
Visit the Lightbox Web site (actually, the Lightbox 2 site) by clicking the "Lightbox 2 Web site" link in the Resources section of this article. On the left-side navigation, find and click the "Download" link. Your browser should look something like Figure 2.Figure 2. The Lightbox download section
Figure 3. The Lightbox download contents
Make the Lightbox files accessible to your site
Now you need to make all the Lightbox files—including the images and CSS it uses—available for your Web site. Fortunately, the Lightbox download is already primed for this. It uses standard directory names like images/, css/, and js/. So you can copy those three directories and their contents directly into your Web site's root and probably be ready to go.One thing you should be cautious about: The default Lightbox download includes an index.html file. You do not want to copy that into your Web root, as you'll almost certainly blow away your own site's index page. That page in the installation is a set of instructions, but you've got this article, so you may just want to delete index.html to avoid confusion.
Reference the three Lightbox-related files
Once you've got the right files in the right places, you can reference those files. Here are the three lines of JavaScript you'll want to add to all your pages in which you intend to use Lightbox:<script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script>
<link rel="stylesheet" href="css/lightbox.css" type="text/css" media="screen" />
Build a simple example app
To get started, we need a page with some images. Listing 1 shows the HTML for a gallery page. Go ahead and type this HTML into your own editor, or copy and paste it, or download the code from the examples (available in the Resources section).Listing 1. HTML for example image gallery
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> </head> <body> <h1>Image Gallery</h1> <div id="page"> <div id="images"> <ul class="gallery"> <li><img src="img/photo01.jpg" alt="description" /></li> <li><img src="img/photo02.jpg" alt="description" /></li> <li><img src="img/photo03.jpg" alt="description" /></li> <li><img src="img/photo04.jpg" alt="description" /></li> <li><img src="img/photo05.jpg" alt="description" /></li> <li><img src="img/photo06.jpg" alt="description" /></li> <li><img src="img/photo07.jpg" alt="description" /></li> <li><img src="img/photo08.jpg" alt="description" /></li> <li><img src="img/photo09.jpg" alt="description" /></li> <li><img src="img/photo10.jpg" alt="description" /></li> <li><img src="img/photo11.jpg" alt="description" /></li> <li><img src="img/photo12.jpg" alt="description" /></li> <li><img src="img/photo13.jpg" alt="description" /></li> <li><img src="img/photo14.jpg" alt="description" /></li> <li><img src="img/photo15.jpg" alt="description" /></li> <li><img src="img/photo16.jpg" alt="description" /></li> <li><img src="img/photo17.jpg" alt="description" /></li> <li><img src="img/photo18.jpg" alt="description" /></li> <li><img src="img/photo19.jpg" alt="description" /></li> <li><img src="img/photo20.jpg" alt="description" /></li> </ul> </div> </div> </body> </html>
Listing 2. CSS for example image gallery
* { border: 0; margin: 0; padding: 0; } body { background: #fff; color: #777; padding: 50px; } #page { position: relative; } #images { float: left; width: 600px; } #details { color: #000; } h1 { background: inherit; border-bottom: 1px dashed #ccc; color: #933; font: 32px Georgia, serif; font-weight: bold; margin: 0 0 20px; padding: 0 0 15px; text-align: center; } .gallery { width: 700px; cursor: default; list-style: none; } .gallery img { background: #fff; border-color: #aaa #ccc #ddd #bbb; border-style: solid; border-width: 1px; color: inherit; padding: 2px; vertical-align: top; width: 100px; height: 75px; } .gallery li { background: #eee; border-color: #ddd #bbb #aaa #ccc; border-style: solid; border-width: 1px; color: inherit; display: inline; float: left; margin: 3px; padding: 5px; position: relative; }
Figure 4. An image gallery in need of a Lightbox
Add Lightbox to the gallery page
With an actual page to work on, you're ready to put those script references mentioned above into place. Then, a few more simple steps, and you're ready to see Lightbox in action on a working site that you created.Reference the correct scripts
First, open up index.html (or whatever you've called the example gallery page). In thehead
section, add the lines shown in Listing
3.Listing 3. References to Lightbox scripts (in context)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> <script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script> </head> <-- Rest of HTML ... -->
script
references must be in this particular order. Each
successive script references functions in the previous scripts, so ordering is crucial. If you
mix the order, you'll get errors on your page, so take particular note that you reference
Prototype, then Scriptaculous, and then Lightbox.Reference the correct CSS
Next, add in a CSS reference, as shown in Listing 4.Listing 4. Reference to Lightbox CSS (in context)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> <script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script> <link rel="stylesheet" href="css/lightbox.css" type="text/css" media="screen" /> </head> <-- Rest of HTML ... -->
As a bonus, you can always update the Lightbox CSS to match your own visual preferences. We'll talk a bit more about this later, but it's important to realize that even with a toolkit like Lightbox, separating content (XHTML) from presentation (CSS) from behavior (JavaScript) offers you a ton of flexibility.
Copy over the Lightbox files to your example directory
Here's another step that's often overlooked: Make sure you've got the Lightbox scripts and CSS in the same directory as your example image gallery. If you've downloaded the gallery and dropped it onto an existing site, just upload the Lightbox files as well. If you're working locally, just make sure you copy the Lightbox scripts/, css/, and images/ directories alongside your image gallery files.Add links to each image in your gallery
Lightbox works usinga
elements. So before you can go any further, you'll want to wrap
each image on your page that you want shown in a Lightbox in an a
tag. Generally, the target of the link—the value of the href
attribute—should be the image itself, often displayed at full size.Listing 5 shows the HTML for the gallery, updated with
a
tags.Listing 5. Add links around each image
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> <script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script> <link rel="stylesheet" href="css/lightbox.css" type="text/css" media="screen" /> </head> <body> <h1>Image Gallery</h1> <div id="page"> <div id="images"> <ul class="gallery"> <a href="img/photo01.jpg"> <li><img src="img/photo01.jpg" alt="description" /></li> </a> <a href="img/photo02.jpg"> <li><img src="img/photo02.jpg" alt="description" /></li> </a> <a href="img/photo03.jpg"> <li><img src="img/photo03.jpg" alt="description" /></li> </a> <a href="img/photo04.jpg"> <li><img src="img/photo04.jpg" alt="description" /></li> </a> <a href="img/photo05.jpg"> <li><img src="img/photo05.jpg" alt="description" /></li> </a> <a href="img/photo06.jpg"> <li><img src="img/photo06.jpg" alt="description" /></li> </a> <a href="img/photo07.jpg"> <li><img src="img/photo07.jpg" alt="description" /></li> </a> <a href="img/photo08.jpg"> <li><img src="img/photo08.jpg" alt="description" /></li> </a> <a href="img/photo09.jpg"> <li><img src="img/photo09.jpg" alt="description" /></li> </a> <a href="img/photo10.jpg"> <li><img src="img/photo10.jpg" alt="description" /></li> </a> <a href="img/photo11.jpg"> <li><img src="img/photo11.jpg" alt="description" /></li> </a> <a href="img/photo12.jpg"> <li><img src="img/photo12.jpg" alt="description" /></li> </a> <a href="img/photo13.jpg"> <li><img src="img/photo13.jpg" alt="description" /></li> </a> <a href="img/photo14.jpg"> <li><img src="img/photo14.jpg" alt="description" /></li> </a> <a href="img/photo15.jpg"> <li><img src="img/photo15.jpg" alt="description" /></li> </a> <a href="img/photo16.jpg"> <li><img src="img/photo16.jpg" alt="description" /></li> </a> <a href="img/photo17.jpg"> <li><img src="img/photo17.jpg" alt="description" /></li> </a> <a href="img/photo18.jpg"> <li><img src="img/photo18.jpg" alt="description" /></li> </a> <a href="img/photo19.jpg"> <li><img src="img/photo19.jpg" alt="description" /></li> </a> <a href="img/photo20.jpg"> <li><img src="img/photo20.jpg" alt="description" /></li> </a> </ul> </div> </div> </body> </html>
Connect Lightbox to each image
The last step is a simple one: Eacha
element needs a new attribute, rel
, with a value of "lightbox". Just add that attribute into each link that surrounds
an image that you want displayed in a Lightbox. Listing 6 shows this change in
place.Listing 6. Add links around each image
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> <script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script> <link rel="stylesheet" href="css/lightbox.css" type="text/css" media="screen" /> </head> <body> <h1>Image Gallery</h1> <div id="page"> <div id="images"> <ul class="gallery"> <a href="img/photo01.jpg" rel="lightbox"> <li><img src="img/photo01.jpg" alt="description" /></li> </a> <a href="img/photo02.jpg" rel="lightbox"> <li><img src="img/photo02.jpg" alt="description" /></li> </a> <a href="img/photo03.jpg" rel="lightbox"> <li><img src="img/photo03.jpg" alt="description" /></li> </a> <a href="img/photo04.jpg" rel="lightbox"> <li><img src="img/photo04.jpg" alt="description" /></li> </a> <a href="img/photo05.jpg" rel="lightbox"> <li><img src="img/photo05.jpg" alt="description" /></li> </a> <a href="img/photo06.jpg" rel="lightbox"> <li><img src="img/photo06.jpg" alt="description" /></li> </a> <a href="img/photo07.jpg" rel="lightbox"> <li><img src="img/photo07.jpg" alt="description" /></li> </a> <a href="img/photo08.jpg" rel="lightbox"> <li><img src="img/photo08.jpg" alt="description" /></li> </a> <a href="img/photo09.jpg" rel="lightbox"> <li><img src="img/photo09.jpg" alt="description" /></li> </a> <a href="img/photo10.jpg" rel="lightbox"> <li><img src="img/photo10.jpg" alt="description" /></li> </a> <a href="img/photo11.jpg" rel="lightbox"> <li><img src="img/photo11.jpg" alt="description" /></li> </a> <a href="img/photo12.jpg" rel="lightbox"> <li><img src="img/photo12.jpg" alt="description" /></li> </a> <a href="img/photo13.jpg" rel="lightbox"> <li><img src="img/photo13.jpg" alt="description" /></li> </a> <a href="img/photo14.jpg" rel="lightbox"> <li><img src="img/photo14.jpg" alt="description" /></li> </a> <a href="img/photo15.jpg" rel="lightbox"> <li><img src="img/photo15.jpg" alt="description" /></li> </a> <a href="img/photo16.jpg" rel="lightbox"> <li><img src="img/photo16.jpg" alt="description" /></li> </a> <a href="img/photo17.jpg" rel="lightbox"> <li><img src="img/photo17.jpg" alt="description" /></li> </a> <a href="img/photo18.jpg" rel="lightbox"> <li><img src="img/photo18.jpg" alt="description" /></li> </a> <a href="img/photo19.jpg" rel="lightbox"> <li><img src="img/photo19.jpg" alt="description" /></li> </a> <a href="img/photo20.jpg" rel="lightbox"> <li><img src="img/photo20.jpg" alt="description" /></li> </a> </ul> </div> </div> </body> </html>
Check out Lightbox in action
All that's left is to save the changes to your HTML and load (or reload) the image gallery. Click on any image and you should see a nice animation as the image opens, full size, in a Lightbox. Check out Figure 5 to see what the results look like on Firefox.Figure 5. Lightbox-enabled image gallery
Group images into collections
While the initial, "default" Lightbox is pretty cool, there's a lot more Lightbox can do. The most useful is to group a set of your photos into a ... well ... group. Take the example gallery, for instance. To view the next photo, you've got to close the current one, and then click the next one. But that's not very gallery-like. In a real gallery, you'd just browse to the next photo. Fortunately, Lightbox lets you do something very similar.Set a group for your photos
For photos you want in a group, you just have to add a group name after therel="lightbox"
. You add the group name within brackets ([
and ]
), all within the quotation marks. So
let's put all the images in the example with a set called "gallery". Listing 7 shows the changes
you'd need to
make.Listing 7. Group together all the photos on the page
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>Image Gallery</title> <link rel="stylesheet" href='css/gallery.css' type="text/css" media="screen, projection" /> <script type="text/javascript" src="js/prototype.js"></script> <script type="text/javascript" src="js/scriptaculous.js?load=effects,builder"></script> <script type="text/javascript" src="js/lightbox.js"></script> <link rel="stylesheet" href="css/lightbox.css" type="text/css" media="screen" /> </head> <body> <h1>Image Gallery</h1> <div id="page"> <div id="images"> <ul class="gallery"> <a href="img/photo01.jpg" rel="lightbox[gallery]"> <li><img src="img/photo01.jpg" alt="description" /></li> </a> <a href="img/photo02.jpg" rel="lightbox[gallery]"> <li><img src="img/photo02.jpg" alt="description" /></li> </a> <a href="img/photo03.jpg" rel="lightbox[gallery]"> <li><img src="img/photo03.jpg" alt="description" /></li> </a> <a href="img/photo04.jpg" rel="lightbox[gallery]"> <li><img src="img/photo04.jpg" alt="description" /></li> </a> <a href="img/photo05.jpg" rel="lightbox[gallery]"> <li><img src="img/photo05.jpg" alt="description" /></li> </a> <a href="img/photo06.jpg" rel="lightbox[gallery]"> <li><img src="img/photo06.jpg" alt="description" /></li> </a> <a href="img/photo07.jpg" rel="lightbox[gallery]"> <li><img src="img/photo07.jpg" alt="description" /></li> </a> <a href="img/photo08.jpg" rel="lightbox[gallery]"> <li><img src="img/photo08.jpg" alt="description" /></li> </a> <a href="img/photo09.jpg" rel="lightbox[gallery]"> <li><img src="img/photo09.jpg" alt="description" /></li> </a> <a href="img/photo10.jpg" rel="lightbox[gallery]"> <li><img src="img/photo10.jpg" alt="description" /></li> </a> <a href="img/photo11.jpg" rel="lightbox[gallery]"> <li><img src="img/photo11.jpg" alt="description" /></li> </a> <a href="img/photo12.jpg" rel="lightbox[gallery]"> <li><img src="img/photo12.jpg" alt="description" /></li> </a> <a href="img/photo13.jpg" rel="lightbox[gallery]"> <li><img src="img/photo13.jpg" alt="description" /></li> </a> <a href="img/photo14.jpg" rel="lightbox[gallery]"> <li><img src="img/photo14.jpg" alt="description" /></li> </a> <a href="img/photo15.jpg" rel="lightbox[gallery]"> <li><img src="img/photo15.jpg" alt="description" /></li> </a> <a href="img/photo16.jpg" rel="lightbox[gallery]"> <li><img src="img/photo16.jpg" alt="description" /></li> </a> <a href="img/photo17.jpg" rel="lightbox[gallery]"> <li><img src="img/photo17.jpg" alt="description" /></li> </a> <a href="img/photo18.jpg" rel="lightbox[gallery]"> <li><img src="img/photo18.jpg" alt="description" /></li> </a> <a href="img/photo19.jpg" rel="lightbox[gallery]"> <li><img src="img/photo19.jpg" alt="description" /></li> </a> <a href="img/photo20.jpg" rel="lightbox[gallery]"> <li><img src="img/photo20.jpg" alt="description" /></li> </a> </ul> </div> </div> </body> </html>
View your Lightbox gallery
Reload your gallery page with these changes. Figure 6 shows a photo chosen.Figure 6. Photo 1 of a 20-set grouping
Now, mouse over the current photo, and you'll see a "NEXT" button show up. If this weren't the first photo in a set, you could also get a "PREV" button. These buttons take you to the next photo in the group, and the previous photo, respectively. Figure 7 shows the NEXT button displayed.
Figure 7. You can move directly forward and backward within a group
Create multiple galleries on a page
You can create as many different galleries or groups on a single page as you want, just by using different group names within the square brackets used after "lightbox" as the value of therel
attribute. So you might have one gallery of water-related images, and
another with faces of actual people.Be careful about abusing—or even just overusing—multiple galleries, though. For you, the photographer (or designer), it might be apparent why certain photos are in one gallery and not another. You may even design your page to highlight those differences. For the average Web user, though, those differences might be vague, if not completely unapparent. In that case, multiple galleries can cause confusion. Why aren't all the photos displayed? Why can I click NEXT on this photo, but not on another?
When in doubt, sticking with a single gallery containing all of a single page's images is intuitive and has the least chance of confusing your users.
Describe your pictures (it's important!)
Another nice feature of Lightbox is its ability to display some extra information about your images. Just as a gallery can add little plaques beneath pictures, you can add titles to your images.Add title attributes to your "a" elements
You've already surrounded each image with ana
element. It's that a
element that's actually the primary way of supplying information to
Lightbox. You've used it to indicate that an image should be shown in a Lightbox, as well as to
indicate the grouping of a photo. Now, you can use the same a
element
to add titles to your images.Add a
title
attribute, and then
as the attribute's value, supply an image title. Listing 8 shows this for several
images.Listing 8. Title your images (using the a element)
<div id="page"> <div id="images"> <ul class="gallery"> <a href="img/photo01.jpg" rel="lightbox[gallery]" title="Sunrise over the bay"> <li><img src="img/photo01.jpg" alt="description" /></li> </a> <a href="img/photo02.jpg" rel="lightbox[gallery]" title="Birds scattering at dusk"> <li><img src="img/photo02.jpg" alt="description" /></li> </a> <a href="img/photo03.jpg" rel="lightbox[gallery]" title="Rock balanced precariously on rock"> <li><img src="img/photo03.jpg" alt="description" /></li> </a> <a href="img/photo04.jpg" rel="lightbox[gallery]" title="I saw men as trees walking..."> <li><img src="img/photo04.jpg" alt="description" /></li> </a> <-- etc... --> </ul> </div> </div>
View your image titles
Now reload your page. Click on an image, and you'll see the image's title, bolded, just above the group information about an image. Figure 8 shows the title of the example gallery's fourth image.Figure 8. Titles show up in the lightbox
The Lightbox title is additional image information
Keep in mind that the title you add for an image's Lightbox is specific to the Lightbox. In fact, you're not adding a title to the image itself at all; that would require a change to theimg
element. This leads to a common mistake:
The alt
attribute of an image has nothing to do with what's
displayed in an image's Lightbox. It's arguable whether that's a good or bad thing, but it's
certainly a factual thing.The idea is to make Lightbox as unobtrusive as possible. So if you've given your image an alt description, or even a long description (using
longdesc
), those attributes don't have to be affected or changed to add a
title for use by Lightbox. In fact, you're encouraged to add alt
attributes to your images, anyway, as XHTML requires that attribute for every image on a
page.Changing basic Lightbox UI properties
Everything you've seen so far is "standard" Lightbox fare. But there's a lot more available, especially if you're willing to play around a bit with the Lightbox CSS and images.Change the Lightbox CSS
Remember, all of the display properties for Lightbox are included in the CSS file lightbox.css. Since CSS is just plain text, there's nothing preventing you from opening that file up and changing whatever you like. In fact, as seen in Listing 9, the CSS isn't even that complex.Listing 9. CSS for Lightbox
#lightbox{ position: absolute; left: 0; width: 100%; z-index: 100; text-align: center; line-height: 0;} #lightbox img{ width: auto; height: auto;} #lightbox a img{ border: none; } #outerImageContainer{ position: relative; background-color: #fff; width: 250px; height: 250px; margin: 0 auto; } #imageContainer{ padding: 10px; } #loading{ position: absolute; top: 40%; left: 0%; height: 25%; width: 100%; text-align: center; line-height: 0; } #hoverNav{ position: absolute; top: 0; left: 0; height: 100%; width: 100%; z-index: 10; } #imageContainer>#hoverNav{ left: 0;} #hoverNav a{ outline: none;} #prevLink, #nextLink{ width: 49%; height: 100%; background-image: url(); /* Trick IE into showing hover */ display: block; } #prevLink { left: 0; float: left;} #nextLink { right: 0; float: right;} #prevLink:hover, #prevLink:visited:hover { background: url(../images/prevlabel.gif) left 15% no-repeat; } #nextLink:hover, #nextLink:visited:hover { background: url(../images/nextlabel.gif) right 15% no-repeat; } #imageDataContainer{ font: 10px Verdana, Helvetica, sans-serif; background-color: #fff; margin: 0 auto; line-height: 1.4em; overflow: auto; width: 100%; } #imageData{ padding:0 10px; color: #666; } #imageData #imageDetails{ width: 70%; float: left; text-align: left; } #imageData #caption{ font-weight: bold; } #imageData #numberDisplay{ display: block; clear: left; padding-bottom: 1.0em; } #imageData #bottomNavClose{ width: 66px; float: right; padding-bottom: 0.7em; outline: none;} #overlay{ position: absolute; top: 0; left: 0; z-index: 90; width: 100%; height: 500px; background-color: #000; }
- A black background for each picture
- A black background for the details about each image, with white text
- Times New Roman font in 12 point for the image description
- A gray fade on the rest of the page, instead of the darker fade currently used
Listing 10. Updated CSS for Lightbox
#lightbox{ position: absolute; left: 0; width: 100%; z-index: 100; text-align: center; line-height: 0;} #lightbox img{ width: auto; height: auto;} #lightbox a img{ border: none; } #outerImageContainer{ position: relative; background-color: #000; width: 250px; height: 250px; margin: 0 auto; } #imageContainer{ padding: 10px; } #loading{ position: absolute; top: 40%; left: 0%; height: 25%; width: 100%; text-align: center; line-height: 0; } #hoverNav{ position: absolute; top: 0; left: 0; height: 100%; width: 100%; z-index: 10; } #imageContainer>#hoverNav{ left: 0;} #hoverNav a{ outline: none;} #prevLink, #nextLink{ width: 49%; height: 100%; background-image: url(); /* Trick IE into showing hover */ display: block; } #prevLink { left: 0; float: left;} #nextLink { right: 0; float: right;} #prevLink:hover, #prevLink:visited:hover { background: url(../images/prevlabel.gif) left 15% no-repeat; } #nextLink:hover, #nextLink:visited:hover { background: url(../images/nextlabel.gif) right 15% no-repeat; } #imageDataContainer{ font: 12px Times New Roman; background-color: #000; margin: 0 auto; line-height: 1.4em; overflow: auto; width: 100%; } #imageData{ padding:0 10px; color: #fff; } #imageData #imageDetails{ width: 70%; float: left; text-align: left; } #imageData #caption{ font-weight: bold; } #imageData #numberDisplay{ display: block; clear: left; padding-bottom: 1.0em; } #imageData #bottomNavClose{ width: 66px; float: right; padding-bottom: 0.7em; outline: none;} #overlay{ position: absolute; top: 0; left: 0; z-index: 90; width: 100%; height: 500px; background-color: #666; }
Figure 9. A darker, modified Lightbox
Change the Lightbox images
There is one rather glaring problem with the changes in this Lightbox: The CLOSE button is oddly black-on-white, as are the NEXT and PREV buttons. That's in contrast to the otherwise white-on-black color scheme. Thankfully, though, here's another opportunity for you to customize Lightbox. With a tool like Photoshop, Photoshop Elements, or even the open-source G.I.M.P., you can change buttons to look like whatever you want.Figure 10 shows a very simple, modified version of the CLOSE button; Figure 11 is the PREV button, and Figure 12 is the NEXT button.
Figure 10. Updated CLOSE button
Figure 11. Updated PREV button
Figure 12. Updated NEXT button
The buttons shown here are pretty simple, but you can get as flashy as you like. (But you should avoid actually flashing the buttons. That's way too close to the dreaded
<BLINK />
tag.) Still, once you've got new images, drop them into
your Lightbox image directory, overwriting the existing button images.Now reload your gallery and click on an image. You should get something like Figure 13.
Figure 13. Modified Lightbox with custom buttons
Conclusion
It's easy to write Lightbox off as just one more Web widget, or a JavaScript library that only does one really simple thing. However, the focus in any Web design work has to be on the user. For a user, Lightbox is an innovative, simple, easy approach to viewing photos. The simple opening animation as the image loads is slick, there's a progress indicator as the image loads, and navigation is both intuitive and unobtrusive. All that adds up to an engaging user experience. And, we all know by now that users will spend hours checking out photos on the Web.Even better, and particularly important to you, the developer or designer, is the fact that Lightbox is cross-browser. You're not stuck asking a user to download a Flash plugin, and you certainly won't spend hours trying to remember if it's margin or padding that Internet Explorer chokes on. The end-result: better Web pages, better image displays, and happy users.
Finally, the sky's the limit when it comes to Lightbox customization. You can change the color scheme, the framing of an image, and its position. You can use your own custom buttons, or a variation of the default buttons. You can even change the fade on the background screen when the Lightbox shows. Add this to custom groupings and the ability to title images, and you've got a pretty robust tool to add to your Web toolkit.
Downloads
Description | Name | Size |
---|---|---|
The initial version of the image gallery | examples-initial.zip | 284KB |
The completed version of the image gallery | examples-final.zip | 391KB |
0 comments: