C#中自定义消息,与MFc对比

在C#中采用的是事件驱动方式,但在我们使用的过程中,有时候通过调用系统原有的消息,处理起来会比较简单一些,特别是在处理与DLL文件的交互时,的确是非常的方便。
   在C#中使用自定义消息
     在C#中使用自定义消息非常简单,只需要下面几个简单的步骤就可以了:
1、  定义消息
定义消息的方法和VC中定义消息有一点点不同
比如在VC中申明一个自定义消息:
#define WM_TEST WM_USER + 101
而在c#中消息需要定义成windows系统中的原始的16进制数字,比如自定义消息
public const int USER = 0x0400;
那么我们在VC中申明的自定义消息,在C#中就可以做对应的声明:
         public const int WM_TEST = USER+101;
2、  发送消息
消息发送是通过windows提供的API函数SendMessage来实现的,它的原型定义:        [DllImport("User32.dll",EntryPoint="SendMessage")]
          private static extern int SendMessage(
            IntPtr hWnd,      // handle to destination window
            uint Msg,         // message
            uint wParam,      // first message parameter
            uint lParam       // second message parameter
       );
3、  消息接收
消息发出之后,在Form中如何接收呢?我们可以重载DefWinproc函数来接收消息。
protected override void DefWndProc ( ref System.Windows.Forms.Message m )
        {
            switch(m.Msg)
            {
                case Message.WM_TEST: //处理消息
                break;
                default:
                base.DefWndProc(ref m);//调用基类函数处理非自定义消息。
break;
            }
}
在C#中使用系统消息

们以WM_PAINT消息的处理为例,在C#中处理消息与MFC的消息处理是类似的,但更为简单。MFC中需要使用
DECLARE_MESSAGE_MAP来定义消息映射,在C#就不需要了。比如WM_PAINT消息,我们只要重载父类中的OnPaint虚拟方法即
可,方法如下:
在菜单View->Other Windows->Object Browser打开对象浏览窗口(或用CTRL+ALT+J打开),在我们的工程名下找到Form并选中,这时在右边的窗口列出所有Form类的成员函数,如图所示:


们选中OnPaint(System.WinForms.PaintEventArgs)此时在下面会显示完整的OnPaint函数protected
void OnPaint ( System.WinForms.PaintEventArgs e
)我们将这一行字符串Copy下来。打开Form1.cs进行代码编辑,我们把刚才拷贝下来的函数定义复制到Form1类里面,并加上override关
键字,此时我们便可以在里面添加我们的消息处理代码了,请参考如下代码段:
protected override void OnPaint (System.Windows.Forms.PaintEventArgs e  )
{
     Font font = new Font("黑体",28);///定义字体:黑体,大小:28
     SolidBrush bluepen = new SolidBrush(Color.Blue);///创建蓝色画笔
     SolidBrush blackpen = new SolidBrush(Color.FromARGB(0xa0,0xa0,0xb0));///创建黑色画笔
     e.Graphics.DrawString("VC知识库",font,blackpen,65,25);///写字符串
     e.Graphics.DrawString("VC知识库",font,bluepen,61,21);///偏移4个象素用不同的颜色再写一次,达到立体效果
}
示例应用
1、  定义消息

们在工程中添加一个Message类用来定义消息。然后添加了三个成员变量,其中USER为自定义消息的初始值,相当与MFC中的WM_USER。
WM_TEST为自定义的用来响应应用程序的消息,WM_MSG为自定义的用来响应DLL传递过来的消息。如何在DLL定义消息请参考文章:VC.Net
从DLL传递消息到DLL。
public class Message
    {
     public const int USER = 0x0400;
//as mfc Define WM_TEST WM_USER + 101
     public const int WM_TEST = USER+101;
     public const int WM_MSG = USER+102;
    }
2、  声明引用函数
在使用消息的地方,申明引用的函数,我们这里在MsgForm.cs文件中申明:
//申明发送消息函数
        [DllImport("User32.dll",EntryPoint="SendMessage")]
        private static extern int SendMessage(
            IntPtr hWnd,      // handle to destination window
            uint Msg,         // message
            uint wParam,      // first message parameter
            uint lParam       // second message parameter
            );

//申明DLL中启动消息函数
        [DllImport("MessageDLL.dll",EntryPoint="StartSendMessage")]
private extern static void StartSendMessage(IntPtr hWnd);

3、  处理系统消息
protected override void OnPaint (  System.Windows.Forms.PaintEventArgs e )
         {
///定义字体:黑体,大小:28
              Font font = new Font("黑体",28);
///创建蓝色画笔
              SolidBrush bluepen = new SolidBrush(Color.Blue);
///创建黑色画笔            
SolidBrush blackpen = new SolidBrush(Color.FromArgb(0xa0,0xa0,0xb0));
///写字符串
e.Graphics.DrawString("VC知识库",font,blackpen,65,25);
///偏移4个象素用不同的颜色再写一次,达到立体效果
             e.Graphics.DrawString("VC知识库",font,bluepen,61,21);       
}
4、   触发自定义消息

//测试应用程序消息
         private void TestAppbutton_Click(object sender, System.EventArgs e)
         {
            SendMessage(this.Handle,Message.WM_TEST,100,200);
         }
        //测试DLL消息
         private void TestDLLbutton_Click(object sender, System.EventArgs e)
         {
            StartSendMessage(this.Handle);
}

5、  响应和处理自定义消息
protected override void DefWndProc ( ref System.Windows.Forms.Message m )
          {
            string message;
            switch(m.Msg)
            {
                case Message.WM_TEST://处理消息
                        message = string.Format("收到从应用程序发出的消息!参数为:{0},{1}",m.WParam,m.LParam);
                    MessageBox.Show(message);///显示一个消息框
                    break;
                case Message.WM_MSG:
                    message = string.Format("收到从DLL发出的消息!参数
为:{0},{1}",m.WParam,m.LParam);
                    MessageBox.Show(message);///显示一个消息框
                    break;
                default:
                    base.DefWndProc(ref m);//调用基类函数处理非自定义消息。

break;
             }
         }
  程序运行结果:
当我们点击测试DLL消息时,弹出消息框显示收到消息的参数,窗口也会调用WM_PAIN函数对窗口进行重新绘制。

时间: 2024-08-05 07:07:11

C#中自定义消息,与MFc对比的相关文章

如何看TCO在虚拟化解决方案中的分析与对比

如何看TCO在虚拟化解决方案中的分析与对比 所谓TCO (Total cost of ownership) 即总体拥有成本,是一种经常采用的技术评价标准,它的目标是分析和对比在一定时间范围内所拥有的包括首次购置成本TCA (Total cost of acquisition) 和每年运维成本在内的总体成本.在某些情况下,这一总体成本是一个为获得可比较的现行开支而对3到5年生命周期范围内的成本进行平均的值. TCO的对比应该明确一个前提,就是IT系统的实现功能.性能.可靠性等方面基本相同,或者说满

WCF中自定义消息编码器:压缩编码器的使用

原文:WCF中自定义消息编码器:压缩编码器的使用 通过抓包知道WCF在提交.返回数据的时候大多使用XML进行数据交互,如果返回DataTable那么这些数据将变得很大,通过查询找到一个对数据压缩的方法: http://msdn.microsoft.com/zh-cn/library/ms751458(v=vs.110).aspx 新增项目GZipEncoder,GzipEncoder中增加三个文件 : GZipMessageEncoderFactory.cs using System; usin

控制台应用程序中添加对MFC的支持

在windows控制台应用程序中,肯能会想使用一些MFC中的类,如CStringArray等,通过下面两步简单的设置可以添加对MFC的支持: 1.右击工程名 -> References 选择 All Configuration ->Configuration Properties ->General->Use of MFC ->Use MFC in a Shared DLL 2.在stdafx.h头文件中添加一下内容: #define _ATL_CSTRING_EXPLICI

查看系统版本、32位与64位生产场景中的使用及对比

一.查看系统版本 [[email protected] ~]# uname -a #系统版本详细信息 Linux ysolin 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux [[email protected] ~]# uname -r   #内核版本 2.6.32-431.el6.x86_64 [[email protected] ~]# uname -m   #

老司机vps,来看中韩美vps对比

先来看看vps是什么:大白话讲就是它是从一台物理服务器上分割成多个'虚拟'服务器,有自己的独立公网IP,独立内存,独立CPU,独立操作系统配置,独立硬盘空间等等,可以方便单独重启服务器,自己安装程序,就像是物理服务器的缩小版,用它来做多个虚拟主机,企业邮箱,OA系统,访问量不是很大的论坛,私有云空间,代理服务器,搭建博客等等,它的用途最多了,很适合个人或站长们来使用! 然后再说各个vps服务器商对比,先说小编结论吧:美国vps服务器更好一些. 香港vps,美国vps,韩国vps都是免备案,香港v

VS2008中 ATL CLR MFC Win32 区别

ATL用于编写COM程序,CLR是.NET的公共语言运行库,MFC是指MFC类库,MFC程序是用这些类库做出的程序,WIN32常规就是不用MFC,使用API函数编的程序.MFC.ATL和CLR是VC2005内置的3大库,涵盖了windows的各种开发方法和开发应用.当然关于C++开发的库不止这3个,不过这3个是微软推荐.从编程所处层次而言,WIN32为最底层,其次是MFC.然后是CLR.WIN32 winAPI MFC MFC类库 CLR .net库 1. WIN32常规就是不用MFC,使用AP

Visual Studio中 ATL CLR MFC Win32 区别

ATL用于编写COM程序, CLR是.NET的公共语言运行库, MFC是指MFC类库,MFC程序是用这些类库做出的程序, WIN32常规就是不用MFC,使用API函数编的程序. MFC.ATL和CLR是VC2005内置的3大库,涵盖了windows的各种开发方法和开发应用.当然关于C++开发的库不止这3个,不过这3个是微软推荐.从编程所处层次而言,WIN32为最底层,其次是MFC.然后是CLR. WIN32 winAPI MFC MFC类库 CLR .net库 1. WIN32常规就是不用MFC

qt 与 mfc 对比

qt 风格 任何一个控件都是一个类.想在哪个窗口添加控件时声名一个控件变量就好.简单. 这里主要讲 mfcmfc 风格 第一步通过编辑器在主窗口中添加控件时没有用.像你搞个控件上去运行虽然显示但没用.没有绑定第二步要想父窗口操控这个控件.必须把这个控件声名成他的变量.id 就是你拖上去的控件 id 类型是控件继承的父类类型(clisetctrl)也就是控件类型确定之后会在 cpp 里有:这表示初始化(不要自己再 mylistctrl my; / mylistctrl* my =new mylis

mysql中select into 和sql中的select into 对比

现在有张表为student,我想将这个表里面的数据复制到一个为dust的新表中去. answer 01: create table dust select * from student;//用于复制前未创建新表dust的情况下 answer 02: insert into dust select * from student;//已经创建了新表dust的情况下 现在使用select..into..语句实现以上东东. MySQL不支持Select Into语句直接备份表结构和数据,一些种方法可以代