判斷作業的進度
BITS 會維護每個作業的進度資訊。 使用進度信息來判斷已傳輸的位元組和檔案數目。
若要擷取作業的進度資訊,請呼叫 IBackgroundCopyJob::GetProgress 方法,如下列範例所示。 此範例假設 IBackgroundCopyJob 介面指標有效。
#define PROGRESS_COMPLETE_LEN 50
HRESULT hr;
IBackgroundCopyJob* pJob;
WCHAR szProgressComplete[PROGRESS_COMPLETE_LEN+1];
BG_JOB_PROGRESS Progress;
hr = pJob->GetProgress(&Progress);
if (FAILED(hr))
{
//Handle error
}
//Because the BytesTotal member can be 0 or BG_SIZE_UNKNOWN, you may not be able
//to determine a percentage value to display, such as 57%. It is best to display a
//string that shows the number of bytes transferred. For example, "123456 of
//999999" or "123456 of Unknown".
if (BG_SIZE_UNKNOWN == Progress.BytesTotal)
{
StringCchPrintf(szProgressComplete, PROGRESS_COMPLETE_LEN+1, L"%I64d of Unknown",
Progress.BytesTransferred);
}
else
{
StringCchPrintf(szProgressComplete, PROGRESS_COMPLETE_LEN+1, L"%I64d of %I64d",
Progress.BytesTransferred, Progress.BytesTotal);
}
若要擷取上傳回復作業之回復部分的進度資訊,請呼叫 IBackgroundCopyJob2::GetReplyProgress 方法,如下列範例所示。 此範例假設 IBackgroundCopyJob 介面指標有效。
#define REPLY_COMPLETE_LEN 4
HRESULT hr;
IBackgroundCopyJob* pJob;
IBackgroundCopyJob2* pJob2 = NULL;
WCHAR szReplyComplete[REPLY_COMPLETE_LEN+1];
BG_JOB_REPLY_PROGRESS Progress;
pJob->QueryInterface(__uuidof(IBackgroundCopyJob2), (void**)&pJob2);
hr = pJob2->GetReplyProgress(&Progress);
if (SUCCEEDED(hr))
{
if (0 == Progress.BytesTotal) //The job type is not BG_JOB_TYPE_UPLOAD_REPLY
{
//Logic to deal with this case
}
else if (BG_SIZE_UNKNOWN == Progress.BytesTotal) //The reply has not begun
{
StringCchPrintf(szReplyComplete, REPLY_COMPLETE_LEN+1, L"0%%");
}
else
{
StringCchPrintf(szReplyComplete, REPLY_COMPLETE_LEN+1 L"%I64d%%",
100*Progress.BytesTransferred/Progress.BytesTotal);
}
}
檔案也包含進度資訊。 若要擷取進度資訊,請使用 IBackgroundCopyFile::GetProgress 方法。 如需如何擷取作業檔案的資訊,請參閱 列舉作業中的檔案。