Click here to Skip to main content
Click here to Skip to main content

Webcam Web Service

By , 23 Apr 2002
 

Contents

Introduction

Webcam is a Simple Object Access Protocol (SOAP) project that will permit client's software to get, from a Web Service, JPEG pictures captured by a Webcam. It is my first step experiment in the world of SOAP after several projects using COM/DCOM and ATL.

The project is split in three parts:

  • Server: Active Template Library Server capturing a picture from the Webcam.
  • Web Service: Generated with WSDL Generator from Microsoft®.
  • Client: ActiveX client connecting to Webcam SOAP Server getting pictures and displaying them.

Server

We use Visual C++ and the Active Template Library (ATL) object Wizard to create a Simple COM object, called Camera. It handles the grabbing of the picture and the JPEG compression.

The jpeg compression is achieved with Intel® JPEG Library v1.5. Get it here. You may use other libraries, like IJG JPEG LIBRARY, by using the abstract base class CPicturePacker.

Camera handling is done using Microsoft® Video for Windows® (VFW). Get more information on MSDN / Platform SDK Documentation / Graphics and Multimedia Services / Windows Multimedia / Video Capture.

Trick: VFW needs a handler on a window to attach the camera driver to. As we chose to create a Simple COM object we do not have access to any window handler. Calling GetDesktopWindow() got us one.

    // Don't have access to the container's window so just use the desktop.
    // RMK: If the desktop is not at least 24bits colors, then the grab will
    //      fail
    HWND hWnd = ::GetDesktopWindow();

    if ( hWnd )
    { ...
All functionalities needed to grab a picture on a Webcam are done in the class CWebCam. For example the method GrabFrame:
    bool CWebCam::GrabFrame( CPicturePacker * pPacker,
                             unsigned char  ** ppPackedPicture,
                             unsigned long  * pnPackedPictureBytes )
Use a reference to a CPicturePacker base class to pack the original picture's bits, permitting to extend the packing to whatever format you want, as mentioned before. In this sample I have written the class CIntelJpegPacker inheriting from CPicturePacker and using the Intel® JPEG Library v1.5 to pack the picture grabbed. You may consider using GDI+ for example to do the same.

The rest of the source is dealing with COM and is nothing special.

Server Interface

Our server needs to achieve two simple operations: grabbing a picture from a Webcam and compressing it as a JPEG picture according to a compression ratio defined by the caller. This is achieved in the GrabFrame method.

HRESULT GrabFrame( [in] short nQuality, 
                   [out, retval] SAFEARRAY(unsigned char) * ppGrabbedPicture );
The input parameter 'nQuality' represents the jpeg compression ratio, from 1 to 99. A value of one meaning lowest quality (highest compression) and a value of ninety-nine meaning highest quality (lowest compression).

As an output return value the client get the jpeg picture in a SAFEARRAY of unsigned char. We use this data type because it is fully supported by SOAP (See faced problem 1 and 2).

Our COM object supports the interface IErrorInfo as indicated by the ISupportErrorInfo interface. It permits sending back to the client information about possible issues encountered by the server. The good point is that it is fully automatic for us. Read more about that point in Microsoft SOAP User Guide: "Understanding the SOAP Fault <detail> Contents".

Before writing your interfaces check out the different types supported by SOAP in "Data Type Mappings" and there equivalence in programming languages. You find them in the Microsoft SOAP User Guide.

Web Service

We simply use Microsoft WSDL Generator to wrap our COM object, Camera, into a SOAP Web Service.

On the welcome page click Next.

On the dialog "Select the COM .dll to analyze":

Enter the name of your Web Service, i.e. webcam. 

Browse to select your dll.

Click Next.

On the dialog "Select the services you would like to expose":

Expand the list and check the GrabFrame method.

Click Next.

 

On the dialog "SOAP listener information":

In the URI text box, type the url of your webservice, i.e. http://localhost/webservices/webcam.

Choose ISAPI Listener type.

Then select 2001 as XSD Schema Namespace.

Click Next.

On the dialog "Specify the location for the new WSDL and WSML files":

Select UTF-8 as character set.

Then select the place you want to store the new files, i.e. c:\inetpub\WebServices\webcam.

Click Next.

Click Finish.

 


Now we have our Web Service! You must also define a Virtual Directory called WebServices in IIS.
In the case you want to change the location of the Web Service you need to change the WSDL file generated by Microsoft WSDL Generator.

Client

We use Visual C++ and Active Template Library (ATL) object Wizard to create an ActiveX, called Webcam. This ActiveX is the client part of the Web Service Webcam. It is connecting to the Webcam Web Service, receiving back a jpeg picture and displaying it.

To be able to compile the project you must have installed SOAP Toolkit on your computer. Find it here. For the client you must also have WTL installed. If It is not the case donwload it here.

Client Interface

To be able to grab a picture on the Webcam Web Service, we need to specify the location of the Web Service and a compression ratio. We define this interface:

    HRESULT GrabFrame([in] BSTR strWeb ServiceURL, [in] short nQuality);
  • Input parameter 'strWeb ServiceURL' represents Web Service's URL.
  • Input parameter 'nQuality' represents the jpeg compression ratio, from 1 to 99. A value of one meaning lowest quality (highest compression) and a value of ninety-nine meaning highest quality (lowest compression).

If we get an error, we display it in a tooltip. To create and display the tooltip we use Windows Template Library (WTL).

Test

You may test this Web Service after installing client ActiveX on this page.

Problems Faced

  • When adding the "GrabFrame" method to Webcam Server using the ATL "Add Method to Interface", the method was created correctly in .idl and .h files but the not in the .cpp. We can find a kind of explanation on MSDN: Q198017.
  • Before SOAP SDK SP2, SAFEARRAY(unsigned char) was not correctly handled. You need the SP2 to get a correct wrapping from SAFEARRAY(unisgned char) to base64Binary.

History

Version 1.00 December 4, 2001
First release.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Laurent Kempé
Architect
France France
Member

Laurent Kempé is the editor, founder, and primary contributor of Tech Head Brothers, a French portal about Microsoft .NET technologies.

He is currently employed by Innoveo Solutions since 10/2007 as a Senior Solution Architect and certified Scrum Master.

Founder, owner and Managing Partner of Jobping, which provides a unique and efficient platform for connecting Microsoft skilled job seekers with employers using Microsoft technologies.

Laurent is awarded by Microsoft since Avril 2002: Most Valuable Professional (MVP).


Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
Questionmy vote of 5membermuhamad yousef4 Jun '12 - 19:45 
GeneralIt's about time to leave the VFW and move to DirectShowmemberuvik30 Sep '10 - 11:20 
GeneralRe: It's about time to leave the VFW and move to DirectShowmemberLaurent Kempé30 Sep '10 - 20:23 
GeneralA thank youmemberuvik30 Sep '10 - 23:54 
QuestionHow to creat the ".DLL" file??member8200151830 Jul '09 - 21:57 
Generalit helps me!member7916711529 Jul '09 - 19:40 
QuestionSOAP SDK v2.0 required?memberDan Thurman13 Jul '06 - 16:04 
I tried to build this program but apparently
it appears that the soap dll is missing?
 
StdAfx.cpp
C:\Documents and Settings\dant.CDKKT\Desktop\Code Project\WebCam Service\WebCam\ActiveX Client\stdafx.h(30) : fatal error C1083: Cannot open type library file: 'C:\Program Files\Common Files\MSSoap\Binaries\mssoap1.dll': No such file or directory
Error executing cl.exe.
 
Ok, so I tried to find the SOAP Toolkit SDK v2.0 to download and
install it but M$ appears to have removed it and replaced this
with SOAP ToolKit SDK with v3.0?
 
I tried changing the code from mssoap1.dll to mssoap30.dll but them
the next line of code appears missing:
 
StdAfx.cpp
==========
...
#import "C:\Program Files\Common Files\MSSoap\Binaries\mssoap1.dll" exclude("IStream", "ISequentialStream", "_LARGE_INTEGER", "_ULARGE_INTEGER", "tagSTATSTG", "_FILETIME")
using namespace MSSOAPLib; <=== missing
...
 
So, can anyone get this to build anymore?

AnswerRe: SOAP SDK v2.0 required?memberDan Thurman14 Jul '06 - 10:02 
Questionhow to caopture images in C++ using webcammemberrichytany12 Jul '06 - 3:10 
QuestionHow to get array of int, or byte without the safearraymemberguocang11 Jul '06 - 11:59 
Questionusing camera example for a printer filememberdavid barnwell16 May '06 - 10:13 
Questionvirtual WebCammemberolariuadrian17 Feb '06 - 1:00 
GeneralMicrosoft WSDL GeneratorsussAnonymous14 Jul '05 - 10:54 
GeneralYahoo ProtocolmemberManpreet Chadha25 Oct '04 - 19:01 
GeneralRe: Yahoo Protocolmemberpengdingfu24 Dec '04 - 17:01 
GeneralHelp -- Compile Error for ClientmemberZhijie Wang27 Aug '04 - 11:34 
GeneralWeb ServicesussAnonymous11 Aug '04 - 23:11 
Questionis .NET framework required ?memberhspc30 Jul '04 - 19:18 
GeneralWebcammemberhungrau28 Apr '04 - 17:33 
QuestionCamera pilotable via interface web et ActiveX de la carte de capture video ?memberALIBAS26 Apr '04 - 20:25 
QuestionCamera pilotable via interface web et pour l'ActiveX de la carte de capture video ?memberALIBAS26 Apr '04 - 4:46 
Questionweb page sample doesn't exist ?memberorenboskila19 Feb '04 - 13:37 
AnswerRe: web page sample doesn't exist ?memberLaurent Kempé19 Feb '04 - 21:20 
Questionhow to save a flash file created with a object as a gif/jpg/bmp file?memberzhongxunyang24 Sep '03 - 16:49 
AnswerRe: how to save a flash file created with a object as a gif/jpg/bmp file?editorNishant S24 Sep '03 - 17:26 
GeneralClient side questionmemberDee San26 Aug '03 - 9:29 
GeneralRe: Client side questionmemberLaurent Kempé26 Aug '03 - 18:52 
GeneralCool Example!memberNikolai Teofilov2 Jul '03 - 5:04 
GeneralRe: Cool Example!memberLaurent Kempé3 Aug '03 - 3:15 
GeneralNot a .NET code example actuallymemberJason Orphanidis10 Jun '03 - 3:36 
GeneralRe: Not a .NET code example actuallymemberLaurent Kempé14 Jun '03 - 21:17 
GeneralI need your helpmemberzero_code8 Jun '03 - 20:56 
GeneralRe: I need your helpmemberLaurent Kempé9 Jun '03 - 8:19 
GeneralRe: thanks very muchmemberzero_code14 Jun '03 - 14:37 
GeneralSOAP ToolkitsussAnonymous15 May '03 - 0:30 
GeneralRe: SOAP ToolkitmemberLaurent Kempé15 May '03 - 1:31 
QuestionCan you give me Intel@ jpeg Library?memberjjsxq29 Apr '03 - 14:42 
AnswerRe: Can you give me Intel@ jpeg Library?memberJon Sagara29 Apr '03 - 16:08 
GeneralRe: Can you give me Intel@ jpeg Library?memberLaurent Kempé29 Apr '03 - 22:38 
GeneralRe: Can you give me Intel@ jpeg Library?memberbialalbi12 Apr '12 - 22:21 
AnswerRe: Can you give me Intel@ jpeg Library?memberLaurent Kempé29 Apr '03 - 22:29 
GeneralRe: Can you give me Intel@ jpeg Library?memberjjsxq5 May '03 - 22:51 
GeneralRe: Can you give me Intel@ jpeg Library?memberLaurent Kempé5 May '03 - 23:54 
QuestionMarshelling of SAFEARRAY ??membertyounsi13 Mar '03 - 5:32 
AnswerRe: Marshelling of SAFEARRAY ??memberLaurent Kempé29 Apr '03 - 22:41 
GeneralSoap tookit 3.0membercoeus12 Jan '03 - 19:10 
GeneralRe: Soap tookit 3.0memberLaurent Kempé13 Jan '03 - 9:52 
GeneralRe: Soap tookit 3.0memberLaurent Kempé28 Feb '03 - 8:53 
GeneralRe: Soap tookit 3.0membertyounsi12 Mar '03 - 5:45 
GeneralRe: Soap tookit 3.0memberLaurent Kempé12 Mar '03 - 8:38 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web02 | 2.6.130516.1 | Last Updated 24 Apr 2002
Article Copyright 2002 by Laurent Kempé
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid