Making a countdown digital display in PHP

The project came up to email some sort of countdown clock by email through lyris to potential donors. The challenge is to produce in the email box of the prospect an accurate representation of how much time is left to help Middlebury acheive 60% participation that results in Middlebury College receiving a $1mm additional donation.

Countdown timers are very effective in instilling a sense of urgency in a challenge. The problem is email clients can not perform any scripts or complex animations other than GIFs. So the solution is to pull a series of images that reflect the current difference in time from when the images are pulled and the deadline. Adding an animated gif will help the illustration.

With this solution in mind I remember being able to produce a graphic from data in a MySQL table. This was done this way:

CODE*

//—

<?
require(‘dbconnect.php3’);

$uniqid = $_GET[‘u’];
$SQL = “SELECT bin_datab,filetypesb from prod WHERE uniqid = $uniqid”;
$result = mysql_db_query($db, $SQL, $connection) or die(mysql_error());

$data = mysql_result($result,0,”bin_datab”);
$type = mysql_result($result,0,”filetypesb”);

Header (“Content-type: $type”);//headertype very important
echo $data;
?>

–//

This PHP file is called from another page with <img src=”image.php?u=92938″>

I also know how to display time in php
<?php
$today = date(d);
print “today is “.$time;
?>

I know how to set a day in the future:
<?php
$target = mktime(12, 0, 0, 7, 01, 2009);
?>

I know how to make a time differential:
$target = mktime(12, 0, 0, 7, 01, 2009);//what time to which to countdown
$today = time ();
$difference =($target-$today);//howmuch time is left

So, I’m almost there.
I need to have a series of images 0-9 that will help represent the time left in my digital clock.
Created in illustrator

Now I need to grab the time difference and pull out the days, hours, minutes, seconds numerically then separate the 10’s and 1’s columns of the return. I also don’t want to make more than 10 graphics or more than one image.php.

I know I can pass variables to image.php by adding ?variablename=definition to the url and use $_GET[] to pull it into the php page. so I define the unit of I want to return by sending ?t=d (for day in numbers). This will return. 01-12 That’s good but I would have to make 12 graphics to represent this ( and 48 more to represent the minutes).

I need to grab a column(10’s or 1’s) in the returned number. PHP can handle this but I need to tell the parsing program what column I want returned: image.php?t=d0 and image.php?t=d1.

My client-side page looks like this:

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml” style=”height:100%;”>
<head>
<title>Test Countdown</title>
</head>

<body style=”margin: 0; height:100%;”>
<div style=”margin: 0 auto; width: 790px”>

<table cellspacing=”0″ cellpadding=”0″ bgcolor=”#003366″ style=”font: 11px courier; font-style: italic; color:#ddd; border: 4px #003366 ridge; padding: 10px 10px 5px 10px;”>
<tr>
<td valign=”bottom”>
<img src=”image.php?t=d0″ width=”52″ height=”70″ />
<img src=”image.php?t=d1″ width=”52″ height=”70″ />
</td>
<td valign=”bottom”><img src=”images/col.gif” />
</td>
<td valign=”bottom”>
<img src=”image.php?t=H0″ width=”52″ height=”70″ />
<img src=”image.php?t=H1″ width=”52″ height=”70″ />
</td>
<td valign=”bottom”>
<img src=”images/col.gif” />
</td>
<td valign=”bottom”>
<img src=”image.php?t=i0″ width=”52″ height=”70″ />
<img src=”image.php?t=i1″ width=”52″ height=”70″ />
</td>
<td valign=”bottom”>
<img src=”images/col.gif” />
</td>
<td valign=”bottom”>
<img src=”image.php?t=s0″ width=”52″ height=”70″ />
<img src=”image.php?t=s1″ width=”52″ height=”70″ />
</td>
</tr>
<tr>
<td>Days</td>
<td></td>
<td>Hours</td>
<td></td>
<td>Minutes</td>
<td></td>
<td>Seconds</td>
</tr>
<table>
</div>
</body>
</html>

—-

My Parsing page looks like:

<?php
if (isset($_GET[‘t’]))
{
$timeDefinition = $_GET[‘t’]; //what time to display from the refering url d0, d1 …
$displayTime = $timeDefinition[0];//Grab the first character from the url
$column = $timeDefinition[1];//Grab the second character from the url
//time differential
$target = mktime(12, 0, 0, 7, 01, 2009);//what time to which to countdown
$today = time ();
$difference =($target-$today);//howmuch time is left

$ref = date($displayTime, $difference);
$image = $ref[$column];

header(“Location: images/$image.gif”);
}
else
{
header(“Location: images/0.gif”);
}
?>

Result days to my BDAY:

Months Days Hours Minutes Seconds
Depending how your browser cashes the images you may be able to reload the page and see the seconds go. I imagine this could be handled in the browser with Javascript or the like but remember this is being emailed out to prospects nothing but plain images would work. Comments welcome.

Let’s Make a Slide Show HTML Primer

Web Introduction to web production
Let’s make a slide show

I want to set up a time to do an introduction to web production. Most of us learn best went project based. I have a slide show that I have to make and I thought you could all come along for the ride.

This project will result in a click through of images. This introduction will cover Basic HTML code and grooming images for the web using photoshop.

Class materials
A computer
8+ photos or images
Access to Photoshop to resize the images
Illustrator but not necessary.
Notepad for PCs and SimpleTextTextWrangler for Macs (no WISYWIGs yet)
A web browser.

First things first:
Make a thumbnail sketch of the layout for your slideshow. Consistency in where your navigation buttons (in this case next and previous buttons) and display areas are located is critical in good site design.


I then like to use Illustrator to layout my grid it allows me to make numeric widths and heights in pixels so I can make sure I can fit the elements in comfortably. (whitespace is the mantra)

Using Illustrator also allows me to get an idea of the tonality for the UI (User Interface). The images will draw the viewers attention the copy has to be next and the navigation as to be third in most cases. Other tweaks can me made using color and stroke in the final tests.

I also now know the image display area needs to be 720px wide and I can now calculate the margin to the description text.

Photoshop.

Open each image and make it 720px wide it would be excellent for each image to be the same Height and Width. This sometimes won’t happen but if it is possible crop each image to 720x480px 72dpi(screen resolution).

Save the images using PShop’s export to web feature as a JPG with Medium compression. A folder labeled “images” in a folder label “slideshow.”

We are now ready to “Web it Up!”

Basic elements to HTML

All web site have these tags in common:


<html>
<head>
<title>
</title>
</head>
<body>

</body>
</html>


It’s important to understand that HTML “tags” have open tags <body> and close tags </body>

When you get to a web site by typing in its URL you are presented with webpage. The Web Server is configured to display a Home Page or landing page. The most widely used name of this Home Page is index. Some Windows servers use default. Some Servers are configured to recognize either.

The extension we will be using today is .html. You have probably seen extensions of .php, .asp, .aspx,, .htm. These just indicate that the page can use some web services provided by the server that allow server site scripting. We’ll cover that in the next tutorial.

Open TextEdit TextWrangler (PCs use NotePad)
Type this

<html>
<head>
<title> Middlebury SlideShow </title>

</head>
<body>
<h1 id="title">Title</h1>

</body>
</html>

Save the file as index.html in a folder you created called slideshow.

Go to the finder and drag that file into your web browser

Lets add an image:
Add
<img src="images/(THE NAME OF the FILE)" />
Under “Title”

Go to your web browser and refresh the page. you should see you image and text on the same line. if the browser window width is less than the image and the text the image will appear under “Title.”

To a very basic level this demonstrates the fundamental difficulty of formatting websites for the myriad of browsers and user settings. “well it looks correct on my machine,” is the mantra of a poor web programmer.

Formatting the document.
Add a line brake after by typing “<br>” after “Title”.
Save the file, switch to the web browser and refresh the page. The Layout will be consistant reguardless of your browser’s window width.

HTML needs to know when to add line breaks. There will only ever be one space between rendered elements unless you tell the web browser what to do. Adding spaces(with the space bar) or Returns in HTML won’t do it.

Tables
Tables are similar to the columns and rows of excel:

An example of a table’s row

a table’s column:

One rudimentary and reliable way to format your layout is to use tables.
Create a table by typing:

<table>
</table>

Our table will have 2 table rows signified by <tr></tr>

<table>
<tr>
</tr>

<tr>
</tr>
</table>

Our table had 2 columns. Columns are create when you add table data signified by <td></td>

<table>
<tr>
<td>
</td>
<td>
</td>
</tr>

<tr>
<td>
</td>
<td>
</td>
</tr>
</table>

Now add the content:

<table>
<tr>
<td>
NEXT »
</td>
<td>
</td>
</tr>

<tr>
<td>
<img src="images/TheNameOfTheFILE.jpg" />
</td>
<td>
<h1>Title</h1>
<p>Duis vitae sem sit amet mauris posuere laoreet. Sed et enim et ligula congue commodo. Vivamus molestie tellus nec augue. Suspendisse sit amet magna. Phasellus pellentesque ipsum.</p>
</td>
</tr>
</table>

Styling the Table Cells

We’re now going to add style elements to the table Cells to make it look more like our Photoshop Composition.

<html>
<head>
<title> Middlebury SlideShow </title>

</head>
<body background="#b0b2b4">
<table>
<tr>
<td>
NEXT >>
</td>
<td>
</td>
</tr>

<tr>
<td bgcolor="#000000">
<img src="images/TheNameOfTheFILE.jpg" />
</td>
<td bgcolor="#ebecec">
<h1>Title</h1>
<p>Duis vitae sem sit amet mauris posuere laoreet. Sed et enim et ligula congue commodo. Vivamus molestie tellus nec augue. Suspendisse sit amet magna. Phasellus pellentesque ipsum.</p>
</td>
</tr>
</table>
</body>
</html>

Refresh your browser and see how the layout is looking

Refining the Table

We Know the overall width of the table is to be 950px, and that the image view panel is 720px wide. so we will set these as well as the text alignment of the different cells:

<html>
<head>
<title> Middlebury SlideShow </title>

</head>
<body background="#b0b2b4">

<table width="950">
<tr>
<td align="right" width="720">
NEXT >>
</td>
<td>
</td>
</tr>

<tr>
<td bgcolor="#000000" align="center">
<img src="images/1.jpg" />
</td>
<td bgcolor="#ebecec" valign="top" style="padding:20px;">
<h2>Title</h2>
<p>Duis vitae sem sit amet mauris posuere laoreet. Sed et enim et ligula congue commodo. Vivamus molestie tellus nec augue. Suspendisse sit amet magna. Phasellus pellentesque ipsum.</p>
</td>
</tr>
</table>
</body>
</html>

Making links and adding pages

Please copy your document and name the new html file index2.html. Open index.html and change the NEXT >> to read: <a href="index2.html">NEXT >></a>

The “href” tag is followed by the document to be linked in quotes.

Go to your browser and refresh the page. You will see Next >> in blue. Click on the link. Since index2.html is a duplicate of index.html nothing will appear different except for the URL.

Open index2.html in Text Wrangler.

Change the image source reference and change the navigation from:
<a href="index2.html">NEXT >></a>
to
<a href="index.html"><< PREV</a> <a href="index3.html">NEXT >></a>

The HTML for index2.html should look like this:

<html>
<head>
<title> Middlebury SlideShow </title>

</head>
<body background="#b0b2b4">

<table width="950">
<tr>
<td align="right" width="720">
<a href="index.html"><< PREV</a> <a href="index3.html">NEXT >></a>
</td>
<td>
</td>
</tr>

<tr>
<td bgcolor="#000000" align="center">
<img src="images/2.jpg" />
</td>
<td bgcolor="#ebecec" valign="top" style="padding:20px;">
<h2>Title</h2>
<p>Duis vitae sem sit amet mauris posuere laoreet. Sed et enim et ligula congue commodo. Vivamus molestie tellus nec augue. Suspendisse sit amet magna. Phasellus pellentesque ipsum.</p>
</td>
</tr>
</table>
</body>
</html>