Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

248 lines
7.3 KiB

//+-------------------------------------------------------------------------
//
// Microsoft Windows
//
// Copyright (C) Microsoft Corporation, 1999
//
// File: eventprompt.h
//
//--------------------------------------------------------------------------
#ifndef _EVENTPROMPT_H_
#define _EVENTPROMPT_H_
#include <windows.h>
#include "wiaacmgr.h"
#include "acqmgrcw.h"
#include "evntparm.h"
#include "resource.h"
#include <commctrl.h>
// CHandlerList does all our comboboxex operations for the list of event handlers
class CHandlerList
{
private:
HWND m_hwnd;
public:
CHandlerList (HWND hwnd)
: m_hwnd(hwnd)
{
}
~CHandlerList ()
{
}
UINT FillList (const CSimpleStringWide &strDeviceId, GUID &guidEvent);
WIA_EVENT_HANDLER *GetSelectedHandler ();
};
// CEventPromptDlg does the work of asking the user which handler to run
// and invoking the specified handler
class CEventPromptDlg
{
private:
CHandlerList *m_pList;
HWND m_hwnd;
CSharedMemorySection<HWND> *m_PromptData;
CEventParameters *m_pEventParameters;
CEventPromptDlg (CEventParameters *pEventParameters)
: m_pEventParameters (pEventParameters), m_hwnd(NULL), m_PromptData(NULL),
m_pList(NULL)
{
}
~CEventPromptDlg ()
{
if (m_PromptData)
{
delete m_PromptData;
}
if (m_pList)
{
delete m_pList;
}
}
static INT_PTR CALLBACK DlgProc(HWND hwnd, UINT msg, WPARAM wp, LPARAM lp);
void OnInit ();
INT_PTR OnCommand (WORD wCode, WORD widItem);
INT_PTR OnOK ();
void SetDefaultHandler (WIA_EVENT_HANDLER *pHandler);
bool InvokeHandler (WIA_EVENT_HANDLER *pHandler);
public:
static HRESULT Invoke (HINSTANCE hInst, CEventParameters *pEventParameters)
{
WIA_PUSHFUNCTION(TEXT("CEventPromptDlg::Invoke"));
HRESULT hr = S_OK;
// Register common controls
INITCOMMONCONTROLSEX icce;
icce.dwSize = sizeof(icce);
icce.dwICC = ICC_USEREX_CLASSES ;
InitCommonControlsEx( &icce );
CEventPromptDlg *pDlg = new CEventPromptDlg (pEventParameters);
if (!pDlg)
{
hr = E_OUTOFMEMORY;
}
else if (-1 == DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_EVENTPROMPT), NULL, DlgProc,reinterpret_cast<LPARAM>(pDlg)))
{
DWORD dw = GetLastError();
hr = HRESULT_FROM_WIN32(dw);
}
if (pDlg)
{
delete pDlg;
}
return hr;
}
}; //CEventPromptDlg
// CPromptThread invokes the event handler prompt dialog
class CPromptThread
{
private:
CEventParameters m_EventParameters;
CPromptThread (const CEventParameters &EventParameters)
: m_EventParameters (EventParameters)
{
}
~CPromptThread ()
{
}
HRESULT Run(void)
{
WIA_PUSHFUNCTION(TEXT("CPromptThread::Run"));
HRESULT hr = CoInitialize (NULL);
if (SUCCEEDED(hr))
{
hr = CEventPromptDlg::Invoke (g_hInstance, &m_EventParameters);
CoUninitialize();
}
return hr;
}
static DWORD ThreadProc( LPVOID pvParam )
{
WIA_PUSHFUNCTION(TEXT("CPromptThread::ThreadProc"));
#if !defined(DBG_GENERATE_PRETEND_EVENT)
_Module.Lock();
#endif
DWORD dwResult = static_cast<DWORD>(E_FAIL);
CPromptThread *pThread = reinterpret_cast<CPromptThread*>(pvParam);
if (pThread)
{
dwResult = static_cast<DWORD>(pThread->Run());
delete pThread;
}
#if !defined(DBG_GENERATE_PRETEND_EVENT)
_Module.Unlock();
#endif
return dwResult;
}
public:
static HANDLE Create( const CEventParameters &EventParameters )
{
WIA_PUSHFUNCTION(TEXT("CPromptThread::Create"));
HANDLE hThreadResult = NULL;
CPromptThread *pThread = new CPromptThread(EventParameters);
if (pThread)
{
DWORD dwThreadId;
hThreadResult = CreateThread( NULL, 0, ThreadProc, pThread, 0, &dwThreadId );
if (!hThreadResult)
{
delete pThread;
}
}
return hThreadResult;
}
}; // CPromptThread
// CEventPrompt responds to the event by asking the user which event handler
// to run
class ATL_NO_VTABLE CEventPrompt :
public CComObjectRootEx<CComSingleThreadModel>,
public CComCoClass<CEventPrompt, &CLSID_EventPrompter>,
public IWiaEventCallback
{
public:
CEventPrompt()
{
}
~CEventPrompt()
{
}
DECLARE_REGISTRY_RESOURCEID(IDR_EVENTPROMPT)
DECLARE_PROTECT_FINAL_CONSTRUCT()
BEGIN_COM_MAP(CEventPrompt)
COM_INTERFACE_ENTRY(IWiaEventCallback)
END_COM_MAP()
public:
// IWiaEventCallback
STDMETHODIMP ImageEventCallback (const GUID __RPC_FAR *pEventGUID,
BSTR bstrEventDescription,
BSTR bstrDeviceID,
BSTR bstrDeviceDescription,
DWORD dwDeviceType,
BSTR bstrFullItemName,
ULONG *pulEventType,
ULONG ulReserved)
{
WIA_PUSHFUNCTION(TEXT("CEventPrompt::ImageEventCallback"));
bool bRun = true;
// Find out if we already have a prompt for this event open.
// If the user just keeps pressing the same button we ignore
// successive presses until the choice is made.
CSharedMemorySection<HWND> PromptSharedMemory;
LPWSTR wszGuid;
StringFromCLSID (*pEventGUID, &wszGuid);
// use a unique name for the shared memory
CSimpleStringWide strSection(wszGuid);
strSection.Concat (CSimpleStringWide(bstrDeviceID));
CoTaskMemFree (wszGuid);
if (CSharedMemorySection<HWND>::SmsOpened == PromptSharedMemory.Open(CSimpleStringConvert::NaturalString(strSection), false))
{
HWND *pHwnd = PromptSharedMemory.Lock();
if (pHwnd)
{
bRun = false;
if (*pHwnd && IsWindow(*pHwnd))
{
SetForegroundWindow(*pHwnd);
}
PromptSharedMemory.Release();
}
}
if (bRun)
{
CEventParameters EventParameters;
EventParameters.EventGUID = *pEventGUID;
EventParameters.strEventDescription = static_cast<LPCWSTR>(bstrEventDescription);
EventParameters.strDeviceID = static_cast<LPCWSTR>(bstrDeviceID);
EventParameters.strDeviceDescription = static_cast<LPCWSTR>(bstrDeviceDescription);
EventParameters.ulEventType = *pulEventType;
EventParameters.ulReserved = ulReserved;
EventParameters.strFullItemName = bstrFullItemName;
HANDLE hThread = CPromptThread::Create (EventParameters);
if (hThread)
{
CloseHandle(hThread);
}
}
return S_OK;
}
}; // CEventPrompt
#endif