Condividi tramite


Metodo ISensorDriver::OnClientDisconnect (sensorclassextension.h)

Il metodo ISensorDriver::OnClientDisconnect notifica al driver del sensore che un'applicazione client è disconnessa.

Sintassi

HRESULT OnClientDisconnect(
  [in] IWDFFile *pClientFile,
  [in] LPWSTR   pwszSensorID
);

Parametri

[in] pClientFile

Puntatore a un'interfaccia IWDFFile che rappresenta l'oggetto file per il client disconnesso.

[in] pwszSensorID

LPWSTR che contiene l'ID per il sensore da cui l'applicazione client si disconnette.

Valore restituito

Se l'operazione ha esito positivo, questo metodo restituisce S_OK. In caso contrario, questo metodo restituisce uno dei codici di errore definiti in Winerror.h.

Commenti

L'estensione della classe sensore chiama questo metodo nelle istanze seguenti:

  • Un'applicazione chiude normalmente.
  • L'utente revoca l'autorizzazione per un'applicazione per accedere al dispositivo che contiene il sensore specificato.
  • Il lavoro di pulizia da una chiamata a ISensorClassExtension::CleanupFile è stato completato.
È possibile usare questa chiamata come segnale per aggiornare elenchi e conteggi di riferimento delle applicazioni connesse.

Per altre informazioni su come usare questo metodo, vedere Filtro dei dati.

Esempio

Il codice di esempio seguente illustra un'implementazione di ISensorDriver::OnClientDisconnect. Questa funzione usa una semplice mappa ATL, denominata Client, per tenere traccia dei client connessi. Vedere ISensorDriver::OnClientConnect per un esempio di modalità di aggiunta dei client connessi alla mappa.

La struttura ClientData è definita come indicato di seguito.

// Struct to keep track of connected client status.
struct ClientData
{
    BOOL bListening;  // Client is listening to events.
    ULONG ulInterval;  // Interval requested by client.
};

La definizione della funzione segue.

HRESULT CSensorDdi:: OnClientDisconnect(
        __in IWDFFile* pClientFile,
        __in LPWSTR pwszSensorID
        )
{
    if(NULL == pClientFile ||
       NULL == pwszSensorID)
    {
        return E_POINTER;
    }

    HRESULT hr = S_OK;
    ClientData* pCD = NULL;
    BOOL bRet = FALSE;

    // Find this client in the map.
    pCD = Clients.Lookup(pClientFile);
    if(pCD == NULL)
    {
        hr = E_UNEXPECTED;
    }

    if(SUCCEEDED(hr))
    {
        // Free the client data memory.
        delete pCD;
        pCD = NULL;

        // Remove this client from the array.
        bRet = Clients.Remove(pClientFile);
        if(FALSE == bRet)
        {
            hr = E_UNEXPECTED;
        }
    }

    return hr;
}

Requisiti

Requisito Valore
Client minimo supportato Windows 7,Disponibile in Windows 7.
Server minimo supportato Nessuno supportato
Piattaforma di destinazione Desktop
Intestazione sensorclassextension.h
Libreria SensorsClassExtension.lib

Vedi anche

ISensorDriver

ISensorDriver::OnClientConnect