Revision: 20070726_195421 | All Revisions
My wife and I just had a newborn. Traditionally, the Chinese newborn mothers get a full month of rest. They do nothing, except eat, feed the baby, sleep, and minor exercise when they feel up to it. They start on a low-sodium, low-sugar, and low-spice diet. This practice eliminates stress and helps The mother recover quickly. In Asian countries, it is relatively easy to find an "expert" to help at home. In the U.S., finding that Kind of help is virtually impossible.
On the other hand, there are many home nursing centers in large, Asian-populated U.S. cities. These nursing centers have one or more after birth "experts" to take care of the mother and the newborn. They will cook for the mother, change diapers, do laundry, and bring the baby to the mother for feedings. Most, if not all, of these nursing centers have WiFi access for the guests.
My wife checked into one of these nursing homes soon after giving birth. I, on the other hand, have to catch up on chores at home and at work. Nevertheless, I wanted to be with our baby and my wife all the time. Plus, my wife would feel better if I check in on her often. So I decided to set up a remote web cam for me to see them while I am away.
In this article, I will explain how to set up a remote web cam on a Windows XP computer with a basic web cam. The same procedure works for a desktop or a notebook computer. I choose a basic web cam over a stand-alone network web cam because 1) I already have one; and 2) I don't have administration access to the remote router to allow outside viewing of the remote web cam.
It you are familiar with Linux, you can substitute a Linux computer. I chose Windows XP because that is what my wife is running on her notebook computer; I didn't want to set up another computer in her room.
The idea is to have the remote web cam computer capture and transmit images over the WiFi link to a web server. The remote web cam computer can't serve the image itself because it is behind a firewall/router that you don't have permission to re-configure.
The web server can be one you set up at home or at a web hosting service. You may already have one that can be used for this purpose. Setting up a web server or a web hosting service is beyond the scope of this article.
You can use any imaging device that your operating system recognizes. I've use the IBM PC Camera (USB web cam) and the Sony DCR-TRV350 Handycam (Firewire); they both work. See these articles to set-up these devices:
Fwink is a free, open source web cam software for Microsoft Windows 98, ME, 2000, and XP. I choose this software because my wife's computer runs windows XP. It being free, open source, and small are also big pluses. It also serves my need because it can transfer images over the network to my web server. You can get a copy of Fwink from "Related links" below.
Its only shortcome is that it only supports the FTP for network transfer. It's less secure than some other transfer portocols. I can live with this insecurity for a month. Most web hosting services support FTP uploads, so you probably already have access to FTP. If not, you can set-up a FTP daemon on your own Linux web server quite easily. Check out the "Installing Telnet Daemon on Ubuntu" and "Installing FTP Daemon on Ubuntu" articles in "Related Links" below for more details.
So far, Fwink and Windows XP has ran continuously for about a week or so without crashing.
As of this writing, Fwink is at version 0.9.95. There are three different distributions for Windows:
You'll have to download the one for the Windows you are running. After downloading the software, installation is as easy as double-clicking on the executable and clicking "Next >" a few times.
After installing Fwink, run it from the "Start" menu. You might not see anything at first. You'll need to configure it. Click on "Settings..." to configure Fwink.
The first configuration page you'll see is the "File Transfer" page (see photo below). Enter the FTP information in the field provided. If you have a web hosting service, you can get the FTP information from your host provider. You can also disable FTP if you don't want to send the image remotely. In that case, you'd probably want to enable "Save images to a file".
I kept my capture interval at 1 minute; you can change it to as often as you like. Just keep your network bandwidth and traffic in mind.
After configuring the "File Transfer" page, click on the "Video Capture" tab. You'll end up at the "Video Capture" settings page (see photo below).
If you only have one video capturing device attached, then that's the default video device. If you have multiple imaging devices, you can click the "Change Device..." button to pick the one you want to use. But if no devices show up, then it means you haven't installed a video capturing device. In that case, to back to installing the video device before continuing.
You can also change the standard size for your images. Just keep in mind that the larger the image, the longer it take to transfer over the network. You will also eat up a lot more bandwidth, depending on your capturing interval.
When you are done with the settings, click "Apply" and then "OK". You'll need to restart Fwink for some settings to become effective.
Once Fwink is running, and is successfully uploading images to the web server, it's time to build a web page to display the image and automatically refresh. To teach you how to write web pages would take a whole book and is out of the scope for this article. So in this article, I will present a simple web page that only displays the image and includes the code to automatically refresh. You can customize it to your liking. The following is a simple "index.html" file for you to place in your web cam image directory.
<html> <head> <title>WebCam</title> <META HTTP-EQUIV="REFRESH" CONTENT="60; URL=index.html"> </head> <body bgcolor="black" text="white" link="yellow" vlink="red"> <center> <h1>WebCam</h1> <img src="webcam.jpg"> </center> </body> </html>
The web page above refresh the browser every minute (60 seconds). You can change that value by changing the "META" line. You can also change the color scheme anyway you like.