delphi中SendMessage使用说明

SendMessage基础知识
函数功能:该函数将指定的消息发送到一个或多个窗口。此函数为指定的窗口调用窗口程序,直到窗口程序处理完消息再返回。而函数PostMessage不同,将一个消息寄送到一个线程的消息队列后立即返回。<wbr><br><wbr> 函数原型:LRESULT<wbr><wbr> SendMessage(HWND<wbr><wbr> hWnd,UINT<wbr><wbr> Msg,WPARAM<wbr><wbr> wParam,LPARAM<wbr><wbr> IParam);<wbr><br><wbr> 参数:<wbr><br><wbr> hWnd:其窗口程序将接收消息的窗口的句柄。如果此参数为HWND_BROADCAST,则消息将被发送到系统中所有顶层窗口,包括无效或不可见的非自身拥有的窗口、被覆盖的窗口和弹出式窗口,但消息不被发送到子窗口。<wbr><br><wbr> Msg:指定被发送的消息。<wbr><br><wbr> wParam:指定附加的消息指定信息。<wbr><br><wbr> IParam:指定附加的消息指定信息。<wbr><br><wbr> 返回值:返回值指定消息处理的结果,依赖于所发送的消息。<wbr><br><wbr> 备注:需要用HWND_BROADCAST通信的应用程序应当使用函数RegisterWindowMessage来为应用程序间的通信取得一个唯一的消息。<wbr><br><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> 如果指定的窗口是由调用线程创建的,则窗口程序立即作为子程序调用。如果指定的窗口是由不同线程创建的,则系统切换到该线程并调用恰当的窗口程序。线程间的消息只有在线程执行消息检索代码时才被处理。发送线程被阻塞直到接收线程处理完消息为止。<wbr><br><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> Windows<wbr><wbr> CE:Windows<wbr><wbr> CE不支持Windows桌面平台支持的所有消息。使用SendMesssge之前,要检查发送的消息是否被支持。<br><br> 附:Delphi中SendMessage使用技巧<br><br> Windows系统是由消息机制驱动的,每个线程如果建立了一个窗口,则由系统分配一个消息队列用于窗口消息的处理。另外,消息也可以不经过消息队<br> 列而利用SendMessage函数直接发送给窗口,窗口过程将处理这个消息,但只有当消息被处理之后,SendMessage才能返回到调用程序。下面<br> 结合两个Delphi程序,讨论如何利用SendMessage向控件发送消息和控件对这种消息的响应。<br> 用SendMessage向控件发送消息<br> 在编程中,有时需要控件以特殊的风格显示,而这种要求又无法通过设置控件属性实现。例如,读取客户列表并显示在下拉框供用户选择,如果下拉框宽度太<br> 窄,则不能全部显示;如果将宽度定得太宽,界面又有不紧凑之感。因此希望能在运行期动态地确定下拉框显示区域的宽度,这种要求如果不用<br> SendMessage函数就很难实现。<br> 解决办法是,在读数据库时计算字符串的显示宽度,用显示宽度的最大值确定下拉框显示区域的宽度。再用SendMessage函数向下拉框发送CB_SETDROPPEDWIDTH消息和宽度值,下拉框根据消息中传来的信息,就可以进行正确显示。<br>   部分源程序代码如下:<br>   i:=0; //计数<br>   MaxWidth:=0;<br>   Query1.SQL.Clear;<br>   Query1.SQL.Add(‘select Company from Customer’);<br>   Query1.Open;<br> //读客户列表到下拉框<br>   while not Query1.Eof do begin<br>   ComboBox1.Items.add(Query1.FieldByName<br> (‘Company’).AsString);<br>    Width:=ComboBox1.Font.Size * Length<br> (ComboBox1.Items);<br>    if Width&gt;MaxWidth then<br>    MaxWidth:=Width; //找出最大值<br>    Query1.Next;<br>    i:=i+1;<br>   end;<br>   Query1.Close;<br>   ComboBox1.Text:=ComboBox1.Items[0];<br>   //发送消息以确定显示区域的宽度<br>   SendMessage(ComboBox1.Handle,<br> CB_SETDROPPEDWIDTH,MaxWidth,0);<br> 利用SendMessage函数还可以实现一些有趣的效果,例如在按钮的Click事件中加入如下语句:<br> SendMessage(Button.Handle,BM_SETSTYLE,<br> BS_RADIOBUTTON,1);<br> 运行后点击按钮,就可以把按钮变成一个收音机按钮。<br> 控件接收SendMessage消息<br> 上面讨论了用SendMessage向控件发送消息的过程。但凡事有利就有弊,用SendMessage发送的消息在处理上存在着一定困难。因为该<br> 消息不经过消息队列,所以无法用OnMessage方式来指定对消息的响应,甚至用HookMainWindow也不行,因为消息直接发送到控件,绕过了<br> 主窗体。要对这种类型的消息作出响应,需要重载控件的WndProc方法。<br> 例如,对于一个列表框,滚动条的滚动消息就是用SendMessage方式发送的,因此该消息不在TlistBox的事件列表中。下面是处理控件响应该滚动消息的具体步骤。<br> 1.首先从TlistBox继承一个TmyListBox类,并重载WndProc方法。在程序中加入下列定义:<br> type<br> TMyListBox=class(TListBox)<br> private<br> procedure WndProc(var Msg: TMessage);<br> override;<br> //重载WndProc,处理发送到控件的消息<br> public<br> end;<br> 其中WndProc方法指定控件对消息的响应,输入参数是TMessage类型,该数据类型是一个记录,包含了消息代码和消息的参数,消息参数可以用Longint或Word方式获得。<br> 2.对滚动事件做出响应,在WndProc方法中加入如下处理代码:<br>   if (Msg.Msg=WM_VSCROLL) and<br> (Msg.WParamLo=SB_ENDSCROLL) then<br>    begin<br> //获得鼠标位置对应的列<br>     ItemIndex:=ItemAtPos(Point,true);<br>   Form1.Edit1.Text:=inttostr(ItemIndex);<br>   inherited;<br>    end<br>   else<br>    inherited;<br> 当程序接收到WM_VSCROLL消息,且WParamLo参数为SB_ENDSCROLL时,表示竖直滚动条停止滚动,就可以用<br> ItemAtPos方法确定与鼠标位置对应的ItemIndex。ItemAtPos方法的Point参数是一个TPoint类型的变量,用来保存鼠标的<br> 位置。<br> 3.定义方法ListBoxMouseMove,在鼠标移动时,将当前位置保存在Point中:<br> procedure TForm1.ListBoxMouseMove(Sender:<br> TObject; Shift: TShiftState; X,Y: Integer);<br>    begin<br>     Point.X:=X;<br>     Point.Y:=Y;<br>    end;<br> 4.在运行期创建和初始化列表框,并指定列表框的MouseMove事件对应上一步定义的ListBoxMouseMove方法。在主窗体的Create事件中输入下面的代码:begin<br> Point.X:=0;<br> Point.Y:=0;<br> //创建自定义列表框<br> List:=TMyListBox.Create(Form1);<br> List.Parent:=Form1;<br> List.Left:=5;<br> List.Top:=30;<br> List.Width:=150;<br> List.Height:=200;<br> for i:=0 to 300 do<br> begin<br> List.Items.Add(inttostr(i)); //初始化<br> end;<br> //指定处理MouseMove事件的方法<br> List.OnMouseMove := ListBoxMouseMove; end;<br><wbr><wbr><br> SendMessage参数<br> TTreeView:<br> (引用CommCtrl)<br> SendMessage(TreeView.Handle,TVM_SETBKCOLOR,0,RGB(255,0,0)); 设置TV背景颜色<br> SendMessage(Button.Handle,WM_LBUTTONDOWN,0,0);  鼠标左键按下<br> SendMessage(Button.Handle,WM_LBUTTONUP,0,0);   鼠标左键抬起<br> SendMessage(Edit.Handle,WM_SETTEXT,255,Integer(PChar('abc'))); 传递文本<br> SendMessage(Edit.Handle,WM_Char,Wparam('Q'),2);  传递字符<br> SendMessage(Button.Handle,BM_SETSTYLE,BS_RADIOBUTTON,1);  改变Button风格<br> SendMessage(ComboBox.Handle,CB_SETDROPPEDWIDTH,300,0);  改变CBDownWidth<br> WM_CUT、WM_COPY和WM_PASTE  剪切,复制,粘帖<br> 实现任意组合键<br> keybd_event(VK_Control, MapVirtualKey(VK_Control, 0), 0, 0);<br> keybd_event(ord('V'), MapVirtualKey(ord('V'), 0), 0, 0);<br> keybd_event(ord('V'), MapVirtualKey(ord('V'), 0), KEYEVENTF_KEYUP, 0);<br> keybd_event(VK_Control, MapVirtualKey(VK_Control, 0), KEYEVENTF_KEYUP, 0);<br><br>  Windows是一个消息驱动式系统,SendMessage是应用程序和应用程序之间进行消息传递的主要手段之一,这里我搜集整理了SendMessage函数的详细参数介绍,以备自用。<br>   VFP声明:<br>   DECLARE INTEGER SendMessage IN user32;<br>   INTEGER hWnd,;<br>   INTEGER wMsg,;<br>   INTEGER wParam,;<br>   INTEGER lParam<br>   参数1:hWnd-窗口句柄。窗口可以是任何类型的屏幕对象。<br>   参数2:wMsg-用于区别其他消息的常量值.<br>   参数3:wParam-通常是一个与消息有关的常量值,也可能是窗口或控件的句柄.<br>   参数4: lParam-通常是一个指向内存中数据的指针。<br>   wMsg参数常量值:<br>   #DeFine WM_CREATE 0x01<br>   创建一个窗口<br>   #DeFine WM_DESTROY 0x02<br>   当一个窗口被破坏时发送<br>   #DeFine WM_MOVE 0x03<br>   移动一个窗口<br>   #DeFine WM_SIZE 0x05<br>   改变一个窗口的大小<br>   #DeFine WM_ACTIVATE 0x06<br>   一个窗口被激活或失去激活状态<br>   #DeFine WM_SETFOCUS 0x07<br>   一个窗口获得焦点<br>   #DeFine WM_KILLFOCUS 0x08<br>   一个窗口失去焦点<br>   #DeFine WM_ENABLE 0x0A<br>   一个窗口改变成Enable状态<br>   #DeFine WM_SETREDRAW 0x0B<br>   设置窗口是否能重画<br>   #DeFine WM_SETTEXT 0x0C<br>   应用程序发送此消息来设置一个窗口的文本<br>   #DeFine WM_GETTEXT 0x0D<br>   应用程序发送此消息来复制对应窗口的文本到缓冲区<br>   #DeFine WM_GETTEXTLENGTH 0x0E<br>   得到与一个窗口有关的文本的长度(不包含空字符)<br>   #DeFine WM_PAINT 0x0F<br>   要求一个窗口重画自己<br>   #DeFine WM_CLOSE 0x10<br>   当一个窗口或应用程序要关闭时发送一个信号<br>   #DeFine WM_QUERYENDSESSION 0x11<br>   当用户选择结束对话框或程序自己调用ExitWindows函数<br>   #DeFine WM_QUIT 0x12<br>   用来结束程序运行<br>   #DeFine WM_QUERYOPEN 0x13<br>   当用户窗口恢复以前的大小位置时,把此消息发送给某个图标<br>   #DeFine WM_ERASEBKGND 0x14<br>   当窗口背景必须被擦除时(例在窗口改变大小时)<br>   #DeFine WM_SYSCOLORCHANGE 0x15<br>   当系统颜色改变时,发送此消息给所有顶级窗口<br>   #DeFine WM_ENDSESSION 0x16<br>   当系统进程发出WM_QUERYENDSESSION消息后,此消息发送给应用程序,通知它对话是否结束<br>   #DeFine WM_SHOWWINDOW 0x18<br>   当隐藏或显示窗口是发送此消息给这个窗口<br>   #DeFine WM_ACTIVATEAPP 0x1C<br>   发此消息给应用程序哪个窗口是激活的,哪个是非激活的<br>   #DeFine WM_FONTCHANGE 0x1D<br>   当系统的字体资源库变化时发送此消息给所有顶级窗口<br>   #DeFine WM_TIMECHANGE 0x1E<br>   当系统的时间变化时发送此消息给所有顶级窗口<br>   #DeFine WM_CANCELMODE 0x1F<br>   发送此消息来取消某种正在进行的摸态(操作)<br>   #DeFine WM_SETCURSOR 0x20<br>   如果鼠标引起光标在某个窗口中移动且鼠标输入没有被捕获时,就发消息给某个窗口<br>   #DeFine WM_MOUSEACTIVATE 0x21<br>   当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给当前窗口<br>   #DeFine WM_CHILDACTIVATE 0x22<br>   发送此消息给MDI子窗口当用户点击此窗口的标题栏,或当窗口被激活,移动,改变大小<br>   #DeFine WM_QUEUESYNC 0x23<br>   此消息由基于计算机的训练程序发送,通过WH_JOURNALPALYBACK的hook程序分离出用户输入消息<br>   #DeFine WM_GETMINMAXINFO 0x24<br>   此消息发送给窗口当它将要改变大小或位置<br>   #DeFine WM_PAINTICON 0x26<br>   发送给最小化窗口当它图标将要被重画<br>   #DeFine WM_ICONERASEBKGND 0x27<br>   此消息发送给某个最小化窗口,仅当它在画图标前它的背景必须被重画<br>   #DeFine WM_NEXTDLGCTL 0x28<br>   发送此消息给一个对话框程序去更改焦点位置<br>   #DeFine WM_SPOOLERSTATUS 0x2A<br>   每当打印管理列队增加或减少一条作业时发出此消息<br>   #DeFine WM_DRAWITEM 0x2B<br>   当button,combobox,listbox,menu的可视外观改变时发送<br>   #DeFine WM_MEASUREITEM 0x2C<br>   当button, combo box, list box, list view control, or menu item 被创建时<br>   #DeFine WM_VKEYTOITEM 0x2E<br>   此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应WM_KEYDOWN消息<br>   #DeFine WM_CHARTOITEM 0x2F<br>   此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息<br>   #DeFine WM_SETFONT 0x30<br>   当绘制文本时程序发送此消息得到控件要用的颜色<br>   #DeFine WM_GETFONT 0x31<br>   应用程序发送此消息得到当前控件绘制文本的字体<br>   #DeFine WM_SETHOTKEY 0x32<br>   应用程序发送此消息让一个窗口与一个热键相关连<br>   #DeFine WM_GETHOTKEY 0x33<br>   应用程序发送此消息来判断热键与某个窗口是否有关联<br>   #DeFine WM_QUERYDRAGICON 0x37<br>   此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标<br>   #DeFine WM_COMPAREITEM 0x39<br>   发送此消息来判定combobox或listbox新增加的项的相对位置<br>   #DeFine WM_COMPACTING 0x41<br>   显示内存已经很少了<br>   #DeFine WM_WINDOWPOSCHANGING 0x46<br>   发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数<br>   #DeFine WM_WINDOWPOSCHANGED 0x47<br>   发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数<br>   #DeFine WM_POWER 0x48<br>   当系统将要进入暂停状态时发送此消息<br>   #DeFine WM_COPYDATA 0x4A<br>   当一个应用程序传递数据给另一个应用程序时发送此消息<br>   #DeFine WM_CANCELJOURNA 0x4B<br>   当某个用户取消程序日志激活状态,提交此消息给程序<br>   #DeFine WM_NOTIFY 0x4E<br>   当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口<br>   #DeFine WM_INPUTLANGCHANGEREQUEST 0x50<br>   当用户选择某种输入语言,或输入语言的热键改变<br>   #DeFine WM_INPUTLANGCHANGE 0x51<br>   当平台现场已经被改变后发送此消息给受影响的最顶级窗口<br>   #DeFine WM_TCARD 0x52<br>   当程序已经初始化windows帮助例程时发送此消息给应用程序<br>   #DeFine WM_HELP 0x53<br>   此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果当前都没有焦点,就把此消息发送给当前激活的窗口<br>   #DeFine WM_USERCHANGED 0x54<br>   当用户已经登入或退出后发送此消息给所有的窗口,当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息<br>   #DeFine WM_NOTIFYFORMAT 0x55<br>   公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构<br>   #DeFine WM_CONTEXTMENU ??<br>   当用户某个窗口中点击了一下右键就发送此消息给这个窗口<br>   #DeFine WM_STYLECHANGING 0x7C<br>   当调用SETWINDOWLONG函数将要改变一个或多个 窗口的风格时发送此消息给那个窗口<br>   #DeFine WM_STYLECHANGED 0x7D<br>   当调用SETWINDOWLONG函数一个或多个 窗口的风格后发送此消息给那个窗口<br>   #DeFine WM_DISPLAYCHANGE 0x7E<br>   当显示器的分辨率改变后发送此消息给所有的窗口<br>   #DeFine WM_GETICON 0x7F<br>   此消息发送给某个窗口来返回与某个窗口有关连的大图标或小图标的句柄<br>   #DeFine WM_SETICON 0x80<br>   程序发送此消息让一个新的大图标或小图标与某个窗口关联<br>   #DeFine WM_NCCREATE 0x81<br>   当某个窗口第一次被创建时,此消息在WM_CREATE消息发送前发送<br>   #DeFine WM_NCDESTROY 0x82<br>   此消息通知某个窗口,非客户区正在销毁<br>   #DeFine WM_NCCALCSIZE 0x83<br>   当某个窗口的客户区域必须被核算时发送此消息<br>   #DeFine WM_NCHITTEST 0x84<br>   移动鼠标,按住或释放鼠标时发生<br>   #DeFine WM_NCPAINT 0x85<br>   程序发送此消息给某个窗口当它(窗口)的框架必须被绘制时<br>   #DeFine WM_NCACTIVATE 0x86<br>   此消息发送给某个窗口仅当它的非客户区需要被改变来显示是激活还是非激活状态<br>   #DeFine WM_GETDLGCODE 0x87<br>   发送此消息给某个与对话框程序关联的控件,widdows控制方位键和TAB键使输入进入此控件通过应<br>   #DeFine WM_NCMOUSEMOVE 0xA0<br>   当光标在一个窗口的非客户区内移动时发送此消息给这个窗口 非客户区为:窗体的标题栏及窗 的边框体<br>   #DeFine WM_NCLBUTTONDOWN 0xA1<br>   当光标在一个窗口的非客户区同时按下鼠标左键时提交此消息<br>   #DeFine WM_NCLBUTTONUP 0xA2<br>   当用户释放鼠标左键同时光标某个窗口在非客户区十发送此消息<br>   #DeFine WM_NCLBUTTONDBLCLK 0xA3<br>   当用户双击鼠标左键同时光标某个窗口在非客户区十发送此消息<br>   #DeFine WM_NCRBUTTONDOWN 0xA4<br>   当用户按下鼠标右键同时光标又在窗口的非客户区时发送此消息<br>   #DeFine WM_NCRBUTTONUP 0xA5<br>   当用户释放鼠标右键同时光标又在窗口的非客户区时发送此消息<br>   #DeFine WM_NCRBUTTONDBLCLK 0xA6<br>   当用户双击鼠标右键同时光标某个窗口在非客户区十发送此消息<br>   #DeFine WM_NCMBUTTONDOWN 0xA7<br>   当用户按下鼠标中键同时光标又在窗口的非客户区时发送此消息<br>   #DeFine WM_NCMBUTTONUP 0xA8<br>   当用户释放鼠标中键同时光标又在窗口的非客户区时发送此消息<br>   #DeFine WM_NCMBUTTONDBLCLK 0xA9<br>   当用户双击鼠标中键同时光标又在窗口的非客户区时发送此消息#DeFine WM_KEYFIRST 0x100<br>   WM_KEYDOWN 按下一个键<br>   #DeFine WM_KEYUP 0x101<br>   释放一个键<br>   #DeFine WM_CHAR 0x102<br>   按下某键,并已发出WM_KEYDOWN, WM_KEYUP消息<br>   #DeFine WM_DEADCHAR 0x103<br>   当用translatemessage函数翻译WM_KEYUP消息时发送此消息给拥有焦点的窗口<br>   #DeFine WM_SYSKEYDOWN 0x104<br>   当用户按住ALT键同时按下其它键时提交此消息给拥有焦点的窗口<br>   #DeFine WM_SYSKEYUP 0x105<br>   当用户释放一个键同时ALT 键还按着时提交此消息给拥有焦点的窗口<br>   #DeFine WM_SYSCHAR 0x106<br>   当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后提交此消息给拥有焦点的窗口<br>   #DeFine WM_SYSDEADCHAR 0x107<br>   当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后发送此消息给拥有焦点的窗口<br>   #DeFine WM_INITDIALOG 0x110<br>   在一个对话框程序被显示前发送此消息给它,通常用此消息初始化控件和执行其它任务<br>   #DeFine WM_COMMAND 0x111<br>   当用户选择一条菜单命令项或当某个控件发送一条消息给它的父窗口,一个快捷键被翻译<br>   #DeFine WM_SYSCOMMAND 0x112<br>   当用户选择窗口菜单的一条命令或当用户选择最大化或最小化时那个窗口会收到此消息<br>   #DeFine WM_TIMER 0x113<br>   发生了定时器事件<br>   #DeFine WM_HSCROLL 0x114<br>   当一个窗口标准水平滚动条产生一个滚动事件时发送此消息给那个窗口,也发送给拥有它的控件<br>   #DeFine WM_VSCROLL 0x115<br>   当一个窗口标准垂直滚动条产生一个滚动事件时发送此消息给那个窗口也,发送给拥有它的控件<br>   #DeFine WM_INITMENU 0x116<br>   当一个菜单将要被激活时发送此消息,它发生在用户菜单条中的某项或按下某个菜单键,它允许程序在显示前更改菜单<br>   #DeFine WM_INITMENUPOPUP 0x117<br>   当一个下拉菜单或子菜单将要被激活时发送此消息,它允许程序在它显示前更改菜单,而不要改变全部<br>   #DeFine WM_MENUSELECT 0x11F<br>   当用户选择一条菜单项时发送此消息给菜单的所有者(一般是窗口)<br>   #DeFine WM_MENUCHAR 0x120<br>   当菜单已被激活用户按下了某个键(不同于加速键),发送此消息给菜单的所有者<br>   #DeFine WM_ENTERIDLE 0x121<br>   当一个模态对话框或菜单进入空载状态时发送此消息给它的所有者,一个模态对话框或菜单进入空载状态就是在处理完一条或几条先前的消息后没有消息它的列队中等待<br>   #DeFine WM_CTLCOLORMSGBOX 0x132<br>   在windows绘制消息框前发送此消息给消息框的所有者窗口,通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置消息框的文本和背景颜色<br>   #DeFine WM_CTLCOLOREDIT 0x133<br>   当一个编辑型控件将要被绘制时发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置编辑框的文本和背景颜色<br>   #DeFine WM_CTLCOLORLISTBOX 0x134<br>   当一个列表框控件将要被绘制前发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置列表框的文本和背景颜色<br>   #DeFine WM_CTLCOLORBTN 0x135<br>   当一个按钮控件将要被绘制时发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置按纽的文本和背景颜色<br>   #DeFine WM_CTLCOLORDLG 0x136<br>   当一个对话框控件将要被绘制前发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置对话框的文本背景颜色<br>   #DeFine WM_CTLCOLORSCROLLBAR 0x137<br>   当一个滚动条控件将要被绘制时发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置滚动条的背景颜色<br>   #DeFine WM_CTLCOLORSTATIC 0x138<br>   当一个静态控件将要被绘制时发送此消息给它的父窗口 通过响应这条消息,所有者窗口可以 通过使用给定的相关显示设备的句柄来设置静态控件的文本和背景颜色<br>   #DeFine WM_MOUSEFIRST 0x200<br>   移动鼠标时发生<br>   #DeFine WM_MOUSEMOVE 0x200<br>   移动鼠标时发生,同WM_MOUSEFIRST<br>   #DeFine WM_LBUTTONDOWN 0x201<br>   按下鼠标左键<br>   #DeFine WM_LBUTTONUP 0x202<br>   释放鼠标左键<br>   #DeFine WM_LBUTTONDBLCLK 0x203<br>   双击鼠标左键<br>   #DeFine WM_RBUTTONDOWN 0x204<br>   按下鼠标右键<br>   #DeFine WM_RBUTTONUP 0x205<br>   释放鼠标右键<br>   #DeFine WM_RBUTTONDBLCLK 0x206<br>   双击鼠标右键<br>   #DeFine WM_MBUTTONDOWN 0x207<br>   按下鼠标中键<br>   #DeFine WM_MBUTTONUP 0x208<br>   释放鼠标中键<br>   #DeFine WM_MBUTTONDBLCLK 0x209<br>   双击鼠标中键<br>   #DeFine WM_MOUSEWHEEL 0x20A<br>   当鼠标轮子转动时发送此消息个当前有焦点的控件 Buttons<br>   <br>   BM_CLICK button被点击 消息<br>   BM_GETCHECK 用于check boxes 或radio boxes 。查看 是否 checked 了。<br>   <br>   BM_GETSTATE 发送此消息,可返回 button 的状态,如 是否被 checked;是否 可用(不可用就 变灰了)<br>   <br>   BM_SETCHECK 如果 已经 checked 了,发送此消息后,变为 unchecked,就是 那个钩钩 没被 选上。ok?<br>   <br>   BM_SETSTATE 设置 button被 点击 状态。<br> ====================<br>   Combo Boxes<br>   <br>   CB_ADDSTRING 添加 字符串到 Combo Boxes 。<br>   CB_DELETESTRING 删除 Combo Boxes 中的 条目,既 item<br>   CB_GETCOUNT 得到 Combo Boxes 条目 item 的 数目<br>   CB_GETCURSEL 返回 Combo Boxes 中被选 条目 在 Combo Boxes 中 的位置,第一条为0 。<br>   如果 没有 条目或出错,则返回 -1<br>   <br>   CB_GETDROPPEDSTATE 发送此消息,可判断 Combo Boxes 的list box 是否被 放下,如果 是,返回 非零值,不是,则 返回 0<br>   <br>   CB_GETLBTEXT 得到 combo box 的 条目 的text。 返回值 是 这个text 的长度。<br>   CB_GETLBTEXTLEN 返回值 是 条目的 text 的长度。<br>   CB_INSERTSTRING 插入 字符串 条目到 combo box 中<br>   CB_RESETCONTENT 清空 combo box 所有条目<br>   CB_SETCURSEL 设置 combo box 被选 条目。<br>   CB_SHOWDROPDOWN 让 combo box 的listbox 下拉。 既 显出 所有 条目<br>   ===================<br>   Edit Controls<br>   <br>   EM_CANUNDO 决定 上一次操作 是否可以 undo (撤消操作)。如果可以,则可发送 EM_undo<br>   <br>   EM_GETFIRSTVISIBLELINE 在 multi-line 控件中,找到 最上层的 可见的 行号。次行号是相对于 所有行的。<br>   <br>   EM_GETPASSWORDCHAR 返回 密码框的 字符集。既 是查看密码。<br>   EM_GETSEL 返回在 可编辑 控件中 ,被选择(HIGHLIGHT高量选择)的字符集 的 起点 和终点的 位置。<br>   用 sendmessage 的wParam 参数 返回 起点位置,lParam 返回 终点位置<br>   EM_REPLACESEL 用不同的字符串 替换 可编辑 控件 中的 字符串,如果 可编辑 控件中 没有 字符串,则 此消息变为 添加 字符串<br>   EM_SETPASSWORDCHAR 在可编辑 控件中 设置 密码字符集 ,既 用* 代替<br>   EM_UNDO 发送 操作 撤消 消息。<br>   ======================<br>   IP Address Control<br>   ===================<br>   <br>   IPM_CLEARADDRESS 清除 IP 地址控件(IP Address control)的内容<br>   IPM_GETADDRESS 从IP 地址控件 获得 存储在 它中的 IP 地址 信息/<br>   IPM_ISBLANK 决定 IP 地址控件 是否可以为 空值。既 127.0.0.1 之类的地址 为 空。<br>   IPM_SETADDRESS 在 IP 地址控件中设置 IP 地址。<br>   IPM_SETFOCUS 在 IP 地址控件中,当需要输入 IP 地址时, 使之获得 键盘输入 焦点<br>   IPM_SETRANGE 设置 输入IP 地址的有效范围<br>   =====================<br>   Media Control Interface (MCI)<br>   =============================<br>   MM_MCINOTIFY 告诉 窗体 MCI 命令 完成的状态. 这个 状态包括 success, failure, 或 其它事件<br>   <br>   Menus<br>   =============================<br>   WM_COMMAND 当 用户 选择 菜单中的 项目后,将向 窗体 发送此消息. 窗体 受到 此消息后,再 决定 下一个 行为<br>   <br>   WM_INITMENU 当 菜单 准备 显示 前,向 窗体发送 此消息, 窗体 将 初始化 菜单 项.<br>   <br>   WM_SYSCOMMAND 向 窗体 发送 用户点击 系统菜单 消息. 窗体将 响应 这个消息 ,决定 下个 行为.<br>   ================<br>   Windows<br>   =====================<br>   <br>   WM_CLOSE 发送 让窗体关闭的消息,有些窗体会 在此时 弹出个 关闭对话框。<br>   <br>   WM_GETTEXT 返回 窗体 标题栏 (caption 属性)。 需要先 用WM_GETTEXTLENGTH 获得 字符串长度<br>   <br>   WM_GETTEXTLENGTH 见上!<br>   <br>   WM_HELP 发送此 消息后,将 显示 指定的 HELP 文件<br>   WM_SETTEXT 设置 窗体 标题栏 。<br>   ==============================<br>   List Boxes<br>   ===============<br>   <br>   LB_ADDSTRING 在条目中添加 字符串<br>   <br>   LB_DELETESTRING 删除一个 条目. 条目 序号是从 0 开始的.<br>   <br>   LB_GETCOUNT 得到 条目总数.<br>   <br>   LB_GETCURSEL 得到 单选 的list box 的 选项条目的 序号<br>   <br>   LB_GETSEL 判断 list 的 条目 是否被选上, 如果 选上了,则返回 &gt;0 的值.否则 返回 0 ,表示 用户没选择条目<br>   <br>   LB_GETSELCOUNT 获得 可多选 的list , 被用户选择的条目的个数.<br>   <br>   LB_GETSELITEMS 返回 可多选的list 的 被选条目的 序号. 可返回 数组.<br>   <br>   LB_GETTEXT 得到 list中的 一个 条目的 text 值<br>   LB_GETTEXTLEN 得到 list中的 一个 条目的 text 值的长度<br>   LB_INSERTSTRING 在list 中,插入 一个条目。如果成功,将返回 插入后,此条目的序号。<br>   LB_RESETCONTENT 清空 所有的 list 中的 条目。<br>   LB_SETCURSEL 对单选 的list box, 设定 用户 选择条目的 具体值<br>   LB_SETSEL 对多选 的list box, 设定 用户 选择条目的 具体值<br>   =======================================================<br>   Mouse<br>   ==================<br>   WM_LBUTTONDBLCLK 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已双击 。返回值 0<br>   <br>   WM_LBUTTONDOWN 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已点击,返回值 0<br>   WM_LBUTTONUP 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已释放,返回值 0<br>   <br>   WM_MBUTTONDBLCLK 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已双击 。返回值 0<br>   WM_MBUTTONDOWN 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已点击,返回值 0<br>   WM_MBUTTONUP 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已释放,返回值 0<br>   最近越来越觉得,windows果然是很不安全啊,,,想要学windows平台的编程,就要学mfc,在win上,mfc简直无所不能。。。<br>   <br>  <br>  Trackback:<br> http://tb.blog.csdn.net/TrackBack.aspx?PostId=2185728<br> SendMessageA<br> 说明:<wbr><wbr><wbr><wbr><wbr><wbr> 调用一个窗口的窗口函数,将一条消息发给那个窗口。除非消息处理完毕,否则该函数不会返回SendMessage所包含4个参数:<wbr><wbr><wbr><br> 1.<wbr><wbr><wbr><wbr><wbr><wbr> hwnd<wbr><wbr><wbr><wbr><wbr><wbr> 32位的窗口句柄窗口可以是任何类型的屏幕对象,因为Win32能够维护大多数可视对象的句柄<br> 2.<wbr><wbr><wbr><wbr><wbr><wbr> wMsg<wbr><wbr><wbr><wbr><wbr><wbr> 用于区别其他消息的常量值,这些常量可以是Windows单元中预定义的常量,也可以是自定义的常量<br> 3.<wbr><wbr><wbr><wbr><wbr><wbr> wParam<wbr><wbr><wbr><wbr><wbr><wbr> 通常是一个与消息有关的常量值,也可能是窗口或控件的句柄<br> 4.<wbr><wbr><wbr><wbr><wbr><wbr> lParam<wbr><wbr><wbr><wbr><wbr><wbr> 通常是一个指向内存中数据的指针。由于WParm、lParam和Pointer都是32位的,因此,它们之间可以相互转换<br> wMsg函数<wbr><wbr><wbr><br> ★WM_Create<wbr><wbr><wbr><wbr><wbr><wbr> 创建一个窗口<br> ★WM_DESTROY<wbr><wbr><wbr><wbr><wbr><wbr> 当一个窗口被破坏时发送<br> ★WM_MOVE<wbr><wbr><wbr><wbr><wbr><wbr> 移动一个窗口<br> ★WM_SIZE<wbr><wbr><wbr><wbr><wbr><wbr> 改变一个窗口的大小<br> ★WM_ACTIVATE<wbr><wbr><wbr><wbr><wbr><wbr> 一个窗口被激活或失去激活状态<br> ★WM_SETFOCUS<wbr><wbr><wbr><wbr><wbr><wbr> 一个窗口获得焦点<br> ★WM_KILLFOCUS<wbr><wbr><wbr><wbr><wbr><wbr> 一个窗口失去焦点<br> ★WM_ENABLE<wbr><wbr><wbr><wbr><wbr><wbr> 一个窗口改变成Enable状态<br> ★WM_SETREDRAW<wbr><wbr><wbr><wbr><wbr><wbr> 设置窗口是否能重画<br> ★WM_SETTEXT<wbr><wbr><wbr><wbr><wbr><wbr> 应用程序发送此消息来设置一个窗口的文本<br> ★WM_GETTEXT<wbr><wbr><wbr><wbr><wbr><wbr> 应用程序发送此消息来复制对应窗口的文本到缓冲区<br> ★WM_GETTEXTLENGTH<wbr><wbr><wbr><wbr><wbr><wbr> 得到与一个窗口有关的文本的长度(不包含空字符)<br> ★WM_PAINT<wbr><wbr><wbr><wbr><wbr><wbr> 要求一个窗口重画自己<br> ★WM_CLOSE<wbr><wbr><wbr><wbr><wbr><wbr> 当一个窗口或应用程序要关闭时发送一个信号<br> ★WM_QUERYENDSESSION<wbr><wbr><wbr><wbr><wbr><wbr> 用户选择结束对话框或程序自己调用ExitWindows函数<br> ★WM_QUIT<wbr><wbr><wbr><wbr><wbr><wbr> 用来结束程序运行<br> ★WM_QUERYOPEN<wbr><wbr><wbr><wbr><wbr><wbr> 用户窗口恢复以前的大小位置时,把此消息发送给某个图标<br> ★WM_ERASEBKGND<wbr><wbr><wbr><wbr><wbr><wbr> 当窗口背景必须被擦除时(例在窗口改变大小时)<br> ★WM_SYSCOLORCHANGE<wbr><wbr><wbr><wbr><wbr><wbr> 当系统颜色改变时,发送此消息给所有顶级窗口<br> ★WM_QUERYENDSESSION<wbr><wbr><wbr><wbr><wbr><wbr> 消息后,此消息发送给应用程序,通知它对话是否结束<br> ★WM_SHOWWINDOW<wbr><wbr><wbr><wbr><wbr><wbr> 当隐藏或显示窗口是发送此消息给这个窗口<br> ★WM_ACTIVATEAPP<wbr><wbr><wbr><wbr><wbr><wbr> 发此消息给应用程序哪个窗口是激活的,哪个是非激活的<wbr><wbr><wbr><br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值