我很快把它放在一起,它起作用了。当回调的参数不正确时,它会给出编译错误。您需要创建一个委托并将其用作类型。
使用独立函数的示例
dwsUnit 是用于自定义 Delphi 方法的 TdwsUnit。
procedure TMainForm.FormCreate(Sender: TObject);
var
delegate: TdwsDelegate;
func: TdwsFunction;
parm: TdwsParameter;
begin
// Create a delegate
delegate := dwsUnit.Delegates.Add;
delegate.Name := 'TAppCheckProc';
parm := delegate.Parameters.Add;
parm.Name := 'Done';
parm.DataType := 'Boolean';
parm.IsVarParam := True;
// Create our function and link it to the event handler
func := dwsUnit.Functions.Add;
func.Name := 'Demo';
func.OnEval := dwsUnitFunctionsDemoEval;
parm := func.Parameters.Add;
parm.Name := 'CheckProc';
parm.DataType := 'TAppCheckProc';
end;
我用来测试的脚本如下:
procedure CheckProc(
var Done : Boolean);
begin
if Done then
SayHello('World');
end;
Demo(CheckProc);
如果我将参数从布尔值更改为整数,我会在脚本上收到编译错误。
我的完整性事件处理程序如下所示:
procedure TMainForm.dwsUnitFunctionsDemoEval(info: TProgramInfo);
begin
info.Vars['CheckProc'].Call([True]);
end;
使用类的示例
如果你想使用类,那么代码会略有不同。假设您正在使用 CustomClasses 演示并希望使用 TEarth 类,那么这将是创建方法和委托的代码。
procedure TMainForm.FormCreate(Sender: TObject);
var
delegate: TdwsDelegate;
method: TdwsMethod;
parm: TdwsParameter;
begin
// Create a delegate
delegate := dwsUnit.Delegates.Add;
delegate.Name := 'TAppCheckProc';
parm := delegate.Parameters.Add;
parm.Name := 'Done';
parm.DataType := 'Boolean';
parm.IsVarParam := True;
// Create our method and link it to the event handler
method := TdwsClass(dwsUnit.Classes.Symbols['TEarth']).Methods.Add;
method.Name := 'Demo';
method.OnEval := dwsUnitFunctionsDemoEval;
parm := method.Parameters.Add;
parm.Name := 'CheckProc';
parm.DataType := 'TAppCheckProc';
end;
使用它的脚本是:
procedure CheckProc(
var Done : Boolean);
begin
if Done then
PrintLn('Called with true')
else
PrintLn('Called with false');
end;
var earth: TEarth;
earth:=TEarth.Create;
earth.Demo(CheckProc);
事件处理程序如下:
procedure TMainForm.dwsUnitFunctionsDemoEval(info: TProgramInfo; ExtObject:
TObject);
begin
info.Vars['CheckProc'].Call([True]);
end;
与独立版本一样,更改脚本参数类型会产生“编译器”错误。
正如 SpeedFreak 在评论中指出的那样。您也可以通过 IDE 设计器而不是在代码中执行此操作。