我试图让我在这里找到的TwainDotNet解决方案(C# TWAIN interaction)进行编译,而且我已经束手无策了。
这个解决方案显然是在VS 2008开发的,我在2005年工作(目前别无选择)。我可能花了很长时间在2005年把这些都编译好,我把我的错误减少到两个,这两个错误都是同一个问题。
using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;
namespace TwainDotNet.WinFroms
{
/// <summary>
/// A windows message hook for WinForms applications.
/// </summary>
public class WinFormsWindowMessageHook : IWindowsMessageHook, IMessageFilter
{
IntPtr _windowHandle;
bool _usingFilter;
public WinFormsWindowMessageHook(Form window)
{
_windowHandle = window.Handle;
}
public bool PreFilterMessage(ref Message m)
{
if (FilterMessageCallback != null)
{
bool handled = false;
FilterMessageCallback(m.HWnd, m.Msg, m.WParam, m.LParam, ref handled);
return handled;
}
return false;
}
public IntPtr WindowHandle { get { return _windowHandle; } }
public bool UseFilter
{
get
{
return _usingFilter;
}
set
{
if (!_usingFilter && value == true)
{
Application.AddMessageFilter(this);
_usingFilter = true;
}
if (_usingFilter && value == false)
{
Application.RemoveMessageFilter(this);
_usingFilter = false;
}
}
}
public FilterMessage FilterMessageCallback
{
get;
set;
}
}
}在访问委托实例的属性上编译失败。
'TwainDotNet.WinFroms.WinFormsWindowMessageHook.FilterMessageCallback.get‘必须声明一个主体,因为它没有标记为抽象或导出
下面是这个类实现的接口IWindowsMessageHook:
using System;
using System.Collections.Generic;
using System.Text;
namespace TwainDotNet
{
public interface IWindowsMessageHook
{
/// <summary>
/// Gets or sets if the message filter is in use.
/// </summary>
bool UseFilter { get; set; }
/// <summary>
/// The delegate to call back when the filter is in place and a message arrives.
/// </summary>
FilterMessage FilterMessageCallback { get; set; }
/// <summary>
/// The handle to the window that is performing the scanning.
/// </summary>
IntPtr WindowHandle { get; }
}
public delegate IntPtr FilterMessage(IntPtr hwnd, int msg, IntPtr wParam, IntPtr lParam, ref bool handled);
}我承认我是一个代表新手,我在这里很困惑。如何在VS 2005中复制此功能?
谢谢你抽出时间。
发布于 2009-12-02 17:30:32
只需使用支持字段:
private FilterMessage m_FilterMessageCallback;
public FilterMessage FilterMessageCallback
{
get { return m_FilterMessageCallback; }
set { m_FilterMessageCallback = value; }
}界面中的代码
FilterMessage FilterMessageCallback { get; set; }顺便说一下。与C#2.0/3.0无关,这是一个与setter和getter有关的普通整数定义。
发布于 2009-12-02 17:29:24
事件可能是可取的,但作为委托属性:
private FilterMessage filterMessageCallback;
public FilterMessage FilterMessageCallback
{
get {return filterMessageCallback;}
set { filterMessageCallback = value;}
}为了避免边缘大小写(线程-争用/ null),您可能还需要:
public bool PreFilterMessage(ref Message m)
{
FilterMessage callback = FilterMessageCallback;
if (callback != null)
{
bool handled = false;
callback(m.HWnd, m.Msg, m.WParam, m.LParam, ref handled);
return handled;
}
return false;
}发布于 2009-12-02 17:30:32
填补财产声明中的空白--什么都没有发生:
private FilterMessage _filterMessageCallback;
public FilterMessage FilterMessageCallback
{
get { return _filterMessageCallback; }
set { _filterMessageCallback = value; }
}https://stackoverflow.com/questions/1834469
复制相似问题