+ =委托{}是将自定义eventarg附加到UI控件事件的正确方法吗?

斯蒂芬·路易斯

我一直在修改Events,以更好地了解它们在一般情况下的用法。我很惊讶地发现以下内容,所以我可能朝着错误的方向前进...我要做的本质是在单击按钮时将按钮更改为随机颜色:

Windows表格

public Form1()       
{ 

ColorChanges KK = new ColorChanges();

KK.ColorEventHandler += handle_ColorChanges;

button1.Click += delegate { KK.ChangeColor(button1); };

}

活动类

class ColorChanges
{

   *... properties & constructor*

   public void ChangeColor(object sender)
   {
   *... randomly assign color to ColorEventArgs*
   }

   protected virtual void onColorEvent(object sender, ColorEventArgs e)
   {
      EventHandler<ColorEventArgs> ceh = ColorEventHandler;
      {   
      if (ceh != null)
         {
         ceh(sender, e)             
         }
     }
   }

   public event EventHandler<ColorEventArgs> ColorEventHandler;
}

自定义事件Args

public class ColorEventArgs : EventArgs
{
  public Color xColor { get; set; }
}

事件处理程序

public void handle_ColorChanges(object sender, ColorEventArgs e)
{
   if (sender is Button)
      {
       var ButtonSender = (Button)sender;

       ButtonSender.BackColor = e.xColor;
       }
}

因此,编辑后的问题是:

使用EventHandler(TEventArgs)委托有用吗?MS文档表明语法类似于

  button1.Click += new EventHandler<AutoRndColorEventArgs>(handle_ColorChanges);

是正确的,但是无法达到我的代码来随机选择颜色和错误

“'handle_ColorChanges'没有重载匹配委托>'System.EventHandler'”

所以像

button1.Click += new EventHandler<AutoRndColorEventArgs>(KK.ChangeColor(button1));

要么

button1.Click += new EventHandler(KK.ChangeColor(button1));

错误说需要一种方法,如果我使用

“'handle_ColorChanges'没有重载匹配委托'System.EventHandler'”

Lambda表达式有助于您的支持

button1.Click += (sender,args) => KK.ChangeColor(s); 

但这不允许取消分配,以后将需要...

匿名委托也有同样的问题

button1.Click += delegate(object sender, EventArgs e)
            { KK.ChangeColor(sender); };

问题的症结在于我的颜色方法或其委托与按钮委托签名(对象,事件)不匹配。我不在乎按钮args,并且想使用自己的操作方法

詹姆士

委托的使用正确吗?

是的,您正在做的是分配一个匿名委托作为您的事件处理程序。这是完全有效的,但是这里的要点是您不能取消分配事件处理程序,因为您没有对其进行引用。您可以保留对它的引用并以这种方式进行(如果需要)

var clickHandler = delegate { ... };
button1.Click += clickHandler;
...
button1.Click -= clickHandler

如果您需要访问事件处理程序的参数,则需要将其添加到签名中,例如

button1.Click += delegate (object sender, EventArgs args) { ... }

new EventHandler(SomeHandlerMethod)结构是做事很长的路要走,它的同义词+= SomeHandlerMethod您的代码当前无法正常工作,因为当构造函数期望对该方法引用时,您试图在构造函数内部实际调用该处理函数

+= new EventHandler<ColorEventArgs>(KK.ChangeColor);

有没有更好的结构呢?

是的,您可以使用更少的代码来实现

button1.Click += (s, args) => KK.ChangeColor(button1);

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章