Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Aplikacja może zarejestrować funkcje wywołania zwrotnego w oknie przechwytywania, aby powiadomić aplikację w następujących okolicznościach:
- Zmiany stanu
- Występują błędy
- Bufory ramki wideo i audio stają się dostępne
- Aplikacja powinna zwracać dane podczas przechwytywania przesyłania strumieniowego
Poniższy przykład tworzy okno przechwytywania oraz rejestruje funkcje statusu, błędu, strumienia wideo i wywołania zwrotnego ramki w pętli przetwarzania wiadomości aplikacji. Zawiera również przykładową instrukcję wyłączającą funkcję wywołania zwrotnego. Kolejne przykłady pokazują proste funkcje stanu, błędu i wywołania zwrotnego ramek.
case WM_CREATE:
{
char achDeviceName[80] ;
char achDeviceVersion[100] ;
char achBuffer[100] ;
WORD wDriverCount = 0 ;
WORD wIndex ;
WORD wError ;
HMENU hMenu ;
// Create a capture window using the capCreateCaptureWindow macro.
ghWndCap = capCreateCaptureWindow((LPSTR)"Capture Window",
WS_CHILD | WS_VISIBLE, 0, 0, 160, 120, (HWND) hWnd, (int) 0);
// Register the error callback function using the
// capSetCallbackOnError macro.
capSetCallbackOnError(ghWndCap, fpErrorCallback);
// Register the status callback function using the
// capSetCallbackOnStatus macro.
capSetCallbackOnStatus(ghWndCap, fpStatusCallback);
// Register the video-stream callback function using the
// capSetCallbackOnVideoStream macro.
capSetCallbackOnVideoStream(ghWndCap, fpVideoCallback);
// Register the frame callback function using the
// capSetCallbackOnFrame macro.
capSetCallbackOnFrame(ghWndCap, fpFrameCallback);
// Connect to a capture driver
break;
}
case WM_CLOSE:
{
// Use the capSetCallbackOnFrame macro to
// disable the frame callback. Similar calls exist for the other
// callback functions.
capSetCallbackOnFrame(ghWndCap, NULL);
break;
}
Tematy pokrewne