次の方法で共有


CTaskDialog::AddCommandControl

CTaskDialog に新しいコマンド ボタン コントロールを追加します。

void AddCommandControl(
   int nCommandControlID,
   const CString& strCaption,
   BOOL bEnabled = TRUE,
   BOOL bRequiresElevation = FALSE
);

パラメーター

  • [入力] nCommandControlID
    コマンド コントロールの識別番号。

  • [入力] strCaption
    CTaskDialog でユーザーに対して表示される文字列。この文字列でコマンドの目的を説明します。

  • [入力] bEnabled
    新しいボタンが有効か無効かを示すブール値パラメーター。

  • [入力] bRequiresElevation
    コマンドの昇格が必要かどうかを示すブール値パラメーター。

解説

CTaskDialog クラスで表示できるコマンド ボタン コントロールの数に制限はありません。ただし、CTaskDialog にコマンド ボタン コントロールを表示する場合は、表示できるボタンは 6 個までになります。CTaskDialog にコマンド ボタン コントロールを表示しない場合は、表示できるボタンの数は無制限です。

ユーザーがコマンド ボタン コントロールを選択すると、CTaskDialog が閉じます。アプリケーションが CTaskDialog::DoModal を使用してダイアログ ボックスを表示する場合、DoModal は、クリックされたコマンド ボタン コントロールの nCommandControlID を返します。

使用例

// TODO: Replace the strings below with the appropriate message, 
// main instruction, and dialog title.
CString message("This is an important message to the user.");
CString mainInstruction("Important!\nPlease read!");
CString title("Alert Dialog");

CTaskDialog taskDialog(message, mainInstruction, title, 
    TDCBF_YES_BUTTON | TDCBF_NO_BUTTON | TDCBF_CANCEL_BUTTON );

taskDialog.AddCommandControl(201, L"First command button control");
taskDialog.AddCommandControl(202, L"Second command button control");
taskDialog.AddCommandControl(203, L"Third command button control");

// Show the CTaskDialog and remember how the user closed it.
int selection = taskDialog.DoModal();

switch(selection)
{
case 201:
    // TODO: Place processing here for the first 
    // command button control.
    break;

case 202:
    // TODO: Place processing here for the second 
    // command button control.
    break;

case 203:
    // TODO: Place processing here for the third 
    // command button control.
    break;

default:
    break;
}

// Remove all the command controls so that we can use the same task
// dialog with new command button controls.
taskDialog.RemoveAllCommandControls();

taskDialog.AddCommandControl(301, 
    L"New first command button control");
taskDialog.AddCommandControl(302, 
    L"New second command button control should require elevation",
    TRUE, TRUE);
taskDialog.AddCommandControl(303, 
    L"New third command button control should be disabled");

// Change the default command button control
taskDialog.SetDefaultCommandControl(302);

// Make sure the third option is disabled.
if (taskDialog.IsCommandControlEnabled(303))
{
    taskDialog.SetCommandControlOptions(303, FALSE);
}

taskDialog.DoModal();

switch(taskDialog.GetSelectedCommandControlID())
{
case 301:
    // TODO: Place processing here for new first 
    // command button control.
    break;

case 302:
    // TODO: Place processing here for new second 
    // command button control.
    break;

case 303:
    // TODO: Place processing here for the new third 
    // command button control.
    break;

default:
    break;
}

// Remove all the command button controls and add new ones from
// the string table resource.
taskDialog.RemoveAllCommandControls();
taskDialog.LoadCommandControls(1001, 1005);

必要条件

ヘッダー: afxtaskdialog.h

参照

関連項目

CTaskDialog クラス

階層図

CTaskDialog::ClickCommandControl

CTaskDialog::GetSelectedCommandControlID

CTaskDialog::IsCommandControlEnabled

CTaskDialog::RemoveAllCommandControls

CTaskDialog::SetCommandControlOptions

CTaskDialog::SetDefaultCommandControl