The following example shows how to enumerate and select ltmmCapture object devices.
// define helper macros for using interfaces under C
#ifndef COBJMACROS
#define COBJMACROS
#endif
#include "ltmm.h"
#include "resource.h"
#include "tchar.h"
#include "stdio.h"
HINSTANCE g_hInstance; // application instance handle
IltmmCapture* g_pCapture; // convert object's interface pointer
//
// BuildDeviceList
// fills a listbox to match the contents of the collection
//
// pDevices = device collection's interface pointer
// hwndListBox = listbox window handle
//
void BuildDeviceList(IltmmDevices* pDevices, HWND hwndListBox)
{
long i;
long count;
int selected = -1;
// reset the listbox contents
SendMessage(hwndListBox, LB_RESETCONTENT, 0, 0);
// get the collection's item count
IltmmDevices_get_Count(pDevices, &count);
for(i = 0; i < count; i++)
{
IltmmDevice* pDevice;
BSTR bstr;
TCHAR sz[256];
int index;
VARIANT_BOOL f;
// retrieve collection item
IltmmDevices_Item(pDevices, i, &pDevice);
// get displayable name
IltmmDevice_get_FriendlyName(pDevice, &bstr);
// convert from unicode
_stprintf(sz, _T("%ls"), bstr);
// free name
SysFreeString(bstr);
// add the name to the listbox
index = SendMessage(hwndListBox, LB_ADDSTRING, 0, (LPARAM) (LPCTSTR) sz);
// associate the listbox item with the collection item index
SendMessage(hwndListBox, LB_SETITEMDATA, index, i);
// remember this listbox item, if it is selected in the collection
IltmmDevice_get_Selected(pDevice, &f);
if(f)
selected = i;
// free the collection item
IUnknown_Release(pDevice);
}
// select the appropriate listbox item
for(i = 0; i < count; i++)
{
if(selected == (long) SendMessage(hwndListBox, LB_GETITEMDATA, i, 0))
{
SendMessage(hwndListBox, LB_SETCURSEL, i, 0);
break;
}
}
}
//
// DeviceSelectionChanged
// called to reflect changes in the listbox selection
//
// pDevices = device collection's interface pointer
// hwndListBox = listbox window handle
//
void DeviceSelectionChanged(IltmmDevices* pDevices, HWND hwndListBox)
{
int index;
long item;
int i;
int count;
HRESULT hr;
// get the index of current listbox selection
index = (int) SendMessage(hwndListBox, LB_GETCURSEL, 0, 0);
if(index < 0)
{
// clear selection
IltmmDevices_put_Selection(pDevices, -1);
}
else
{
// get the collection item index
item = (long) SendMessage(hwndListBox, LB_GETITEMDATA, index, 0);
// select the item
#ifdef _DEBUG
{
IltmmDevice* pDevice;
IltmmDevices_Item(pDevices, item, &pDevice);
hr = IltmmDevice_put_Selected(pDevice, VARIANT_TRUE);
IUnknown_Release(pDevice);
}
#else
hr = IltmmDevices_put_Selection(pDevices, item);
#endif
// if new selection failed, we need to force the listbox to match the actual selection
if(FAILED(hr))
{
// get the real selection
IltmmDevices_get_Selection(pDevices, &item);
// find the matching listbox item
count = (int) SendMessage(hwndListBox, LB_GETCOUNT, 0, 0);
for(i = 0; i < count; i++)
{
if(item == (long) SendMessage(hwndListBox, LB_GETITEMDATA, i, 0))
{
SendMessage(hwndListBox, LB_SETCURSEL, i, 0);
break;
}
}
}
}
}
//
// RefreshDeviceList
// called when to completely rebuild the collection
//
// pDevices = device collection's interface pointer
// hwndListBox = listbox window handle
//
void RefreshDeviceList(IltmmDevices* pDevices, HWND hwndListBox)
{
IltmmDevice* pDevice;
long item;
BSTR bstr;
// get the currently selected item
IltmmDevices_get_Selection(pDevices, &item);
if(item >= 0)
{
// get it's unique name
IltmmDevices_Item(pDevices, item, &pDevice);
IltmmDevice_get_Name(pDevice, &bstr);
IUnknown_Release(pDevice);
}
else
{
bstr = NULL;
}
// rebuild the collection
IltmmDevices_Refresh(pDevices);
if(bstr)
{
// find the previously selected item
IltmmDevices_Find (pDevices, bstr, &item);
// make it the current selection
if(item >= 0)
IltmmDevices_put_Selection (pDevices, item);
SysFreeString(bstr);
}
// rebuild the listbox
BuildDeviceList(pDevices, hwndListBox);
}
//
// DeviceDlgProc
// selects object devices
//
BOOL CALLBACK DeviceDlgProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
IltmmDevices* pDevices;
wParam = wParam ;
lParam = lParam ;
switch (msg)
{
case WM_INITDIALOG:
// initialize the audio device listbox
IltmmCapture_get_AudioDevices(g_pCapture, &pDevices);
BuildDeviceList(pDevices, GetDlgItem(hwnd, IDC_AUDIODEVICES));
IUnknown_Release(pDevices);
// initialize the video device listbox
IltmmCapture_get_VideoDevices(g_pCapture, &pDevices);
BuildDeviceList(pDevices, GetDlgItem(hwnd, IDC_VIDEODEVICES));
IUnknown_Release(pDevices);
return TRUE;
break;
case WM_COMMAND:
switch(LOWORD(wParam))
{
case IDC_REFRESHAUDIODEVICES:
// refresh the audio device listbox
IltmmCapture_get_AudioDevices(g_pCapture, &pDevices);
RefreshDeviceList(pDevices, GetDlgItem(hwnd, IDC_AUDIODEVICES));
IUnknown_Release(pDevices);
return TRUE;
break;
case IDC_AUDIODEVICES:
if(HIWORD(wParam) == LBN_SELCHANGE)
{
// select the audio device
IltmmCapture_get_AudioDevices(g_pCapture, &pDevices);
DeviceSelectionChanged(pDevices, GetDlgItem(hwnd, IDC_AUDIODEVICES));
IUnknown_Release(pDevices);
}
break;
case IDC_REFRESHVIDEODEVICES:
// initialize the video device listbox
IltmmCapture_get_VideoDevices(g_pCapture, &pDevices);
RefreshDeviceList(pDevices, GetDlgItem(hwnd, IDC_VIDEODEVICES));
IUnknown_Release(pDevices);
return TRUE;
break;
case IDC_VIDEODEVICES:
if(HIWORD(wParam) == LBN_SELCHANGE)
{
// select the video device
IltmmCapture_get_VideoDevices(g_pCapture, &pDevices);
DeviceSelectionChanged(pDevices, GetDlgItem(hwnd, IDC_VIDEODEVICES));
IUnknown_Release(pDevices);
}
break;
case IDOK:
EndDialog(hwnd, IDOK);
return TRUE;
break;
}
break;
}
return FALSE;
}
void SelectingltmmCaptureObjectDevices_Example ( HINSTANCE hInstance /*application instance handle*/ )
{
HRESULT hr;
g_hInstance = hInstance;
// initialize COM library
hr = CoInitialize(NULL);
if(FAILED(hr))
goto error;
// create the convert object
hr = CoCreateInstance(&CLSID_ltmmCapture, NULL, CLSCTX_INPROC_SERVER, &IID_IltmmCapture, (void**) &g_pCapture);
if(FAILED(hr))
goto error;
DialogBox(g_hInstance, (LPCTSTR)IDD_DEVICEDLG, NULL, DeviceDlgProc);
error:
// cleanup
if(g_pCapture)
IUnknown_Release(g_pCapture);
CoUninitialize();
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
Your email has been sent to support! Someone should be in touch! If your matter is urgent please come back into chat.
Chat Hours:
Monday - Friday, 8:30am to 6pm ET
Thank you for your feedback!
Please fill out the form again to start a new chat.
All agents are currently offline.
Chat Hours:
Monday - Friday
8:30AM - 6PM EST
To contact us please fill out this form and we will contact you via email.