このトピックでは、センサーが特定のデータ フィールドセットを提供できることを確認する方法について説明します。
センサー オブジェクトを取得したら、 ISensor::GetSupportedDataFields を呼び出して、センサーが必要なデータを提供できるかどうかを判断できます。
次のコード例では、センサーが 3 つのサンプル データ フィールドすべてを提供できるかどうかをテストするヘルパー関数を作成します。 関数は、センサーへのポインターを入力として受け取り、ブール値を返します。 TRUE は 、センサーが必要なすべてのデータ フィールドを提供できることを示します。
BOOL CheckForSupportedDataFields(ISensor* pSensor)
{
assert(pSensor);
HRESULT hr = S_OK;
DWORD cKeys = 0; // Key count.
BOOL bRet = FALSE;
IPortableDeviceKeyCollection* pKeys = NULL; // Output
// CoCreate a key collection to store property keys.
hr = CoCreateInstance(CLSID_PortableDeviceKeyCollection,
NULL,
CLSCTX_INPROC_SERVER,
IID_PPV_ARGS(&pKeys));
if(SUCCEEDED(hr))
{
hr = pSensor->GetSupportedDataFields(&pKeys);
}
if(SUCCEEDED(hr))
{
hr = pKeys->GetCount(&cKeys);
}
if(SUCCEEDED(hr))
{
PROPERTYKEY pk;
BOOL bHour, bMinute, bSecond = FALSE;
for (DWORD i = 0; i < cKeys; i++)
{
hr = pKeys->GetAt(i, &pk);
if(SUCCEEDED(hr))
{
// Test for the data fields.
if(IsEqualPropertyKey(pk, SAMPLE_SENSOR_DATA_TYPE_HOUR))
{
bHour = TRUE;
}
else if(IsEqualPropertyKey(pk, SAMPLE_SENSOR_DATA_TYPE_MINUTE))
{
bMinute = TRUE;
}
else if(IsEqualPropertyKey(pk, SAMPLE_SENSOR_DATA_TYPE_SECOND))
{
bSecond = TRUE;
}
}
}
// Compute the return value.
// If all three properties were found,
// bRet will resolve to TRUE.
bRet = bHour && bMinute && bSecond;
}
SafeRelease(&pKeys);
return bRet;
}
関連トピック