简单实现向导式应用程序

类别:Delphi 点击:0 评论:0 推荐:

其实方法也很简单,主要使用了Delphi的PageControl控件。而“上一步”,“下一步”则是按顺序显示不同的Page。

具体实现如下:

(1)首先在form上放置一个PageControl控件,并且添加若干个Page。程序需要几个步骤,就添加相应数目的Page。然后將PageControl的Style的属性值设为tsFlatButtons,这样PageControl控件就没有变框了。

(2)在form上放置btnBack,btnNext,btnConfirm,btnCancel等按钮,分别执行“上一步”,“下一步”,“确认”以及“取消”等操作。并且将btnBack的Enable属性设为False;btnConfirm的Visible属性设为False。为了方便编写代码,暂时将btnNext和btnConfirm两个按钮分开放置。而最后编译的时候是要将两个按钮重叠在一起的。

(3)将每一个步骤需要用到的控件分别放在相应的各个Page上。完成如下图的用户界面:

 

 

 

(4)定义一个form的私有变量OperationSeq,类型为整型。用这个变量记录当前的操作步骤顺序号,并且控制显示相应的Page。

(5)在btnNext按钮的OnClick事件中写入如下的处理:

  case OperationSeq of

  1:  //Step1

    begin

      btnBack.Enabled := True;

      {第1个步骤的处理模块}

    end;

  2:  //Step2

    begin

      btnNext.Visible := False;

      btnConfirm.Visible := True;

      {第2个步骤的处理模块}

    end;

  end;

  OperationSeq := OperationSeq + 1;  //每次按btnNext都会将OperationSeq的计数加一。

  pgcSteps.TabIndex := OperationSeq - 1;  //根据OperationSeq的计数,跳到下一个Page。

(6) 在btnBack按钮的OnClick事件中写入如下的处理:

  case OperationSeq of

  2:  //Step2

    begin

      btnBack.Enabled := False;

      {第2个步骤的处理模块}

    end;

  3:  //Step3

    begin

      btnNext.Visible := True;

      btnConfirm.Visible := False;

      {第3个步骤的处理模块}

    end;

  end;

  OperationSeq := OperationSeq - 1; //每次按btnBack都会将OperationSeq的计数减一。

  pgcSteps.TabIndex := OperationSeq - 1;  //根据OperationSeq的计数,跳到上一个Page。

(7)将btnNext和btnConfirm重叠然后编译执行。效果如下图:

 

 

 

(8)一般这种向导型的应用程序都必须让用户按一定步骤执行。因此,还需要将PageControl的本身的按钮隐藏掉。很简单,只要用一个Panel控件把这些按钮盖住就行了。这样,用户就不能用这些按钮转换不同的Page。效果如下图所示:

 

但是,还有一点需要注意,一定要将PageControl的TabStop属性设值为True。这样用户也就不能用tab键,将焦点转换到PageControl自身的按钮上。

现在,用户已经完全不能控制PageControl了,必须按照既定的步骤执行。

为了美观,可以将Panel控件的BevelInner和BevelOuter的属性都设为bvNone,这样用户就完全看不出有这么一个控件以及下面被覆盖的按钮。或者给Panel加个边框,动态显示提示信息,也是一个不错的选择。

至此,一个向导式应用程序就很快做好了。要增加减少处理步骤,只需要在btnNext和btnBack的事件中修改OperationSeq的case项目就可以了。

用同样的方法,也可以在C#和VB.NET中实现,只是换成TabControl控件罢了。这里也就不再敷述了。

本文地址:http://com.8s8s.com/it/it4394.htm