似乎每个人都注意到CF无法控制。调用EventHandler类型以外的委托。我发现了几个方法来解决这个问题,并通过棘手的事件和属性来捕捉参数,但它仅适用于某些对象/原语。CF中的Control.Invoke委托3.5
问题是当我尝试发送一个控件时,程序在执行时抛出一个异常:“Control.Invoke必须用于与单独线程上创建的控件进行交互”无论我检查Control.IsInvokeRequired和由handler跟踪槽Invoke方法......到底是什么,还有就是snipet:
static class Program
{
[MTAThread]
static void Main()
{
Form1 frm = new Form1();
frm.modifier = new CModifier(ref frm);
Application.Run(frm);
}
}
class CModifier
{
internal event EventHandler Modify;
internal CModifier(ref Form1 _frm)
{ frm = _frm; }
private Form1 frm;
internal void Start()
{
Thread t = new Thread(new ThreadStart(TestMe));
t.Start();
}
private void TestMe()
{
frm._current = new Label() { Text = "Try Me" };
Modify(this, EventArgs.Empty);
}
}
public partial class Form1 : Form
{
internal Form1()
{
InitializeComponent();
}
internal CModifier modifier;
internal Control _current;
private void Form1_Load(object sender, EventArgs e)
{
modifier.Modify += new EventHandler(modifier_Modify);
modifier.Start();
}
void modifier_Modify(object sender, EventArgs e)
{
if (this.InvokeRequired)
{
this.Invoke(new EventHandler(modifier_Modify));
}
this.panel1.Controls.Add(_current);
}
}
我试图几乎每一个可能的方式做,我总是得到相同的结果。
我在做什么错? ---->有一个“回报”;在调用后丢失。
不管怎么说,在我的应用程序TE实际误差(以上只是一个例子),在此过程中:
internal void ManageControls(RSSDecisionMaking.InterfaceBehaviour _behaviour, Control _control)
{
if (this.InvokeRequired)
{
this.Invoke((Action)delegate { ManageControls(_behaviour, _control); });
return;
}
switch (_behaviour)
{
case RSSDecisionMaking.InterfaceBehaviour.Display:
this.pnDisplayContainer.Controls.Clear();
this.pnDisplayContainer.Controls.Add(_control);
break;
case RSSDecisionMaking.InterfaceBehaviour.Command:
this.pnDisplayContainer.Controls.Clear();
this.pnDisplayContainer.Controls.Add(_control);
this.pnDisplayContainer.Controls[0].Focus();
break;
}
}
的主要区别是在调用的东西,我要送从另一个线程控制。
可以告诉我它有什么不同吗?为什么这不起作用?
哦,伙计!我甚至意识到,你是对的。 –