我正试图让我在这里找到的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'必须声明一个正文,因为它没有标记为abstract或extern
以下是此类实现的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中复制此功能?
感谢您的时间。
答案 0 :(得分:0)
可能需要一个事件,但作为委托属性:
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;
}
答案 1 :(得分:0)
填写财产声明中的空白 - 没有任何魔法发生:
private FilterMessage _filterMessageCallback;
public FilterMessage FilterMessageCallback
{
get { return _filterMessageCallback; }
set { _filterMessageCallback = value; }
}
答案 2 :(得分:0)
只需使用支持字段:
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的正常接口定义。