我有一个数据库表,其中包含两个文本字段:methodname和methodparameters.表中的值存储在字典中.
每个methodname值对应于c#类中的图像过滤器方法,每个方法参数是以逗号分隔的数值列表.
我想使用反射来调用methodname及其相应的方法参数列表.
以下是图像过滤器类的一部分:
namespace ImageFilters { public class Filters { private static Bitmap mBMP; public Bitmap BMP { get { return mBMP; } set { mBMP = value; } } public static void FilterColors(string[] paramlist) { mBMP = FilterColors(mBMP,Convert.ToInt16(paramlist[0].ToString()),Convert.ToInt16(paramlist[1].ToString()),Convert.ToInt16(paramlist[2].ToString()),Convert.ToInt16(paramlist[3].ToString()),Convert.ToInt16(paramlist[4].ToString()),Convert.ToInt16(paramlist[5].ToString()) ); } public static Bitmap FilterColors(Bitmap bmp,int RedFrom,int RedTo,int GreenFrom,int GreenTo,int BlueFrom,int Blueto,byte RedFill = 255,byte GreenFill = 255,byte BlueFill = 255,bool FillOutside = true) { AForge.Imaging.Filters.ColorFiltering f = new AForge.Imaging.Filters.ColorFiltering(); f.FillOutsideRange = FillOutside; f.FillColor = new AForge.Imaging.RGB(RedFill,GreenFill,BlueFill); f.Red = new AForge.IntRange(RedFrom,RedTo); f.Green = new AForge.IntRange(GreenFrom,GreenTo); f.Blue = new AForge.IntRange(BlueFrom,Blueto); return f.Apply(bmp); }
这是我使用的代码使用Reflection:
private static void ApplyFilters(ref Bitmap bmp,dictionaries.FilterFields pFilters) { for(int i = 0; i < pFilters.Detail.Length; i++) { Type t = typeof(ImageFilters.Filters); MethodInfo mi = t.getmethod(pFilters.Detail[i].MethodName); ImageFilters.Filters f = new ImageFilters.Filters(); f.BMP = bmp; string[] parameters = pFilters.Detail[i].MethodParameters.Split(','); mi.Invoke(f,parameters); } }
每个图像都不使用过滤器处理,并使用两组不同的过滤器(来自数据库).以下循环处理过滤器:
foreach (keyvaluePair<string,dictionaries.FilterFields> item in dictionaries.Filters) { bmp = OriginalBMP; ApplyFilters(ref bmp,item.Value); }
我的问题是,当它在循环中遇到ApplyFilters时,它会给我以下错误:
“找不到方法:’Void ImageFilters.Filters.set_BMP(System.Drawing.Bitmap)’.它甚至不允许我进入ApplyFilters方法.
我绝对没有在我的数据库表中有一个名为“set_BMP”的方法.
有任何想法吗?
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。