有这样的代表:
public delegate void GraphInit(ref DataMedia media);
public delegate void GraphStop(ref DataMedia media);
我想像那样使用smth:
void VideoRenderProcess(object sender, VideoRenderingArgs r_args)
{
DataMedia obj_mdata = sender as DataMedia;
switch (obj_mdata.state)
{
case GraphState.Running:
this.Dispatcher.Invoke(new GraphStop(ref obj_mdata));
break;
......
}
}
VideoRenderingArgs
是自行设计的课程:
public class VideoRenderingArgs
{
public string uri { get; set; }
}
// it's just one string, of course I'm planning to add many other details
// which relate to video, but it's other story
GraphStop()
方法是:
void GraphStop(ref DataMedia media)
{
if (media.mre_demux_conf != null) media.mre_demux_conf.WaitOne(2000);
lock (this)
{
if (media.i_main_control != null)
{
media.i_main_control.Stop();
media.state = GraphState.Stopped;
}
}
GraphClean();
}
我收到错误:
'obj_mdata'是一个'变量'但是像''方法'一样使用
ref
而不使用。
如何在C#中做我想做的事情?
答案 0 :(得分:0)
不要使用new来创建委托。只需为委托变量分配所需的方法即可。
如果您尝试这样做会发生什么:
this.Dispatcher.Invoke(() => GraphStop(ref obj_mdata))
此外,如果您的委托与同一范围内的方法具有相同的名称,您将遇到麻烦!
[编辑]不幸的是,上述仅适用于.Net 4.5或更高版本。
答案 1 :(得分:0)
找到了解决方案:
public delegate void DGraphInit(ref DataMedia media);
...
if (obj_mdata.state == GraphState.Running)
{
object[] data = { obj_mdata };
DGraphInit delegate2call = new DGraphInit(GraphInit);
this.Dispatcher.Invoke(delegate2call, data);
}