程序A如何知道程序B里的CheckBox被选中呢?(200分)

  • 主题发起人 主题发起人 mayi
  • 开始时间 开始时间
M

mayi

Unregistered / Unconfirmed
GUEST, unregistred user!
我做了一个小程序,但遇到一个问题,就是如何才能让程序A知道程序B里的某个CheckBox是否是打勾呢?A和B是两个独立的程序,我想了很久,还是不能判断,各位帮一下。
 
主要要用到 WINDOWS的消息 但具体哪里一个 我也没时间看(太多了)抱歉!<br><br>WINDOWS消息大全(一)<br>消息,就是指Windows发出的一个通知,告诉应用程序某个事情发生了。例如,单击鼠标、改变窗口尺寸、按下键盘上的一个键都会使Windows发送一个消息给应用程序。消息本身是作为一个记录传递给应用程序的,这个记录中包含了消息的类型以及其他信息。例如,对于单击鼠标所产生的消息来说,这个记录中包含了单击鼠标时的坐标。这个记录类型叫做TMsg, &nbsp;<br><br>它在Windows单元中是这样声明的: <br>type <br>  TMsg = packed record <br>  hwnd: HWND; / /窗口句柄 <br>  message: UINT; / /消息常量标识符 <br>  wParam: WPARAM ; // 32位消息的特定附加信息 <br>  lParam: LPARAM ; // 32位消息的特定附加信息 <br>  time: DWORD; / /消息创建时的时间 <br>  pt: TPoint; / /消息创建时的鼠标位置 <br>  end;<br>  消息中有什么? <br>  是否觉得一个消息记录中的信息像希腊语一样?如果是这样,那么看一看下面的解释: <br>hwnd 32位的窗口句柄。窗口可以是任何类型的屏幕对象,因为Win32能够维护大多数可视对象的句柄(窗口、对话框、按钮、编辑框等)。 <br><br>  message 用于区别其他消息的常量值,这些常量可以是Windows单元中预定义的常量,也可以是自定义的常量。 <br>  wParam 通常是一个与消息有关的常量值,也可能是窗口或控件的句柄。 <br>  lParam 通常是一个指向内存中数据的指针。由于W P a r a m、l P a r a m和P o i n t e r都是3 2位的, 因此,它们之间可以相互转换。 <br>  WM_NULL = $0000; <br>  WM_CREATE = $0001; <br>  应用程序创建一个窗口 <br>  WM_DESTROY = $0002; <br>  一个窗口被销毁 <br>  WM_MOVE = $0003; <br>  移动一个窗口 <br>  WM_SIZE = $0005; <br>  改变一个窗口的大小 <br>  WM_ACTIVATE = $0006;<br>一个窗口被激活或失去激活状态; <br>  WM_SETFOCUS = $0007; <br>  获得焦点后 <br>  WM_KILLFOCUS = $0008; <br>  失去焦点 <br>  WM_ENABLE = $000A; <br>  改变enable状态 <br>  WM_SETREDRAW = $000B; <br>  设置窗口是否能重画 <br>  WM_SETTEXT = $000C; <br>  应用程序发送此消息来设置一个窗口的文本 <br>  WM_GETTEXT = $000D; <br>  应用程序发送此消息来复制对应窗口的文本到缓冲区 <br>  WM_GETTEXTLENGTH = $000E; <br>  得到与一个窗口有关的文本的长度(不包含空字符) <br>  WM_PAINT = $000F; <br>  要求一个窗口重画自己 <br>  WM_CLOSE = $0010; 当一个窗口或应用程序要关闭时发送一个信号 <br>  WM_QUERYENDSESSION = $0011; <br>  当用户选择结束对话框或程序自己调用ExitWindows函数 <br>  WM_QUIT = $0012; <br>  用来结束程序运行或当程序调用postquitmessage函数 <br>  WM_QUERYOPEN = $0013; <br>  当用户窗口恢复以前的大小位置时,把此消息发送给某个图标 <br>  WM_ERASEBKGND = $0014; <br>  当窗口背景必须被擦除时(例在窗口改变大小时) <br>  WM_SYSCOLORCHANGE = $0015; <br>  当系统颜色改变时,发送此消息给所有顶级窗口 <br>  WM_ENDSESSION = $0016; <br>  当系统进程发出WM_QUERYENDSESSION消息后,此消息发送给应用程序, <br>  通知它对话是否结束 <br>  WM_SYSTEMERROR = $0017; <br>  WM_SHOWWINDOW = $0018; <br>  当隐藏或显示窗口是发送此消息给这个窗口 <br>  WM_ACTIVATEAPP = $001C; <br>  发此消息给应用程序哪个窗口是激活的,哪个是非激活的;<br>WM_FONTCHANGE = $001D; <br>  当系统的字体资源库变化时发送此消息给所有顶级窗口 <br>  WM_TIMECHANGE = $001E; <br>  当系统的时间变化时发送此消息给所有顶级窗口 <br>  WM_CANCELMODE = $001F; <br>  发送此消息来取消某种正在进行的摸态(操作) <br>  WM_SETCURSOR = $0020; <br>  如果鼠标引起光标在某个窗口中移动且鼠标输入没有被捕获时,就发消息给某个窗口 <br>  WM_MOUSEACTIVATE = $0021; <br>  当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给当前窗口 <br>  WM_CHILDACTIVATE = $0022; <br>  发送此消息给MDI子窗口当用户点击此窗口的标题栏,或当窗口被激活,移动,改变大小 <br>  WM_QUEUESYNC = $0023; <br>  此消息由基于计算机的训练程序发送,通过WH_JOURNALPALYBACK的hook程序 <br>  分离出用户输入消息 <br>  WM_GETMINMAXINFO = $0024; <br>  此消息发送给窗口当它将要改变大小或位置;<br>WM_PAINTICON = $0026; <br>  发送给最小化窗口当它图标将要被重画 <br>  WM_ICONERASEBKGND = $0027; <br>  此消息发送给某个最小化窗口,仅当它在画图标前它的背景必须被重画 <br>  WM_NEXTDLGCTL = $0028; <br>  发送此消息给一个对话框程序去更改焦点位置 <br>  WM_SPOOLERSTATUS = $002A; <br>  每当打印管理列队增加或减少一条作业时发出此消息 <br>  WM_DRAWITEM = $002B; <br>  当button,combobox,listbox,menu的可视外观改变时发送 <br>  此消息给这些空件的所有者 <br>  WM_MEASUREITEM = $002C; <br>  当button, combo box, list box, list view control, or menu item 被创建时 <br>  发送此消息给控件的所有者 <br>  WM_DELETEITEM = $002D; <br>  当the list box 或 combo box 被销毁 或 当 某些项被删除通过LB_DELETESTRING, LB_RESETCONTENT, CB_DELETESTRING, or CB_RESETCONTENT 消息 <br>  WM_VKEYTOITEM = $002E; <br>  此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应 &nbsp;WM_KEYDOWN消息 <br>&nbsp; &nbsp; WM_CHARTOITEM = $002F; <br>  此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息 <br>  WM_SETFONT = $0030; <br>  当绘制文本时程序发送此消息得到控件要用的颜色 <br>  WM_GETFONT = $0031; <br>  应用程序发送此消息得到当前控件绘制文本的字体 <br>  WM_SETHOTKEY = $0032; <br>  应用程序发送此消息让一个窗口与一个热键相关连 <br>  WM_GETHOTKEY = $0033; <br>  应用程序发送此消息来判断热键与某个窗口是否有关联 <br>  WM_QUERYDRAGICON = $0037; <br>  此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回<br>一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标 <br>  WM_COMPAREITEM = $0039; <br>  发送此消息来判定combobox或listbox新增加的项的相对位置 <br>&nbsp; &nbsp; WM_GETOBJECT = $003D; <br>  WM_COMPACTING = $0041; <br>  显示内存已经很少了 <br>  WM_WINDOWPOSCHANGING = $0046; <br>  发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数 <br>  WM_WINDOWPOSCHANGED = $0047; <br>  发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数 <br>  WM_POWER = $0048;(适用于16位的windows) <br>  当系统将要进入暂停状态时发送此消息 <br>  WM_COPYDATA = $004A; <br>  当一个应用程序传递数据给另一个应用程序时发送此消息 <br>  WM_CANCELJOURNAL = $004B; <br>  当某个用户取消程序日志激活状态,提交此消息给程序 <br>  WM_NOTIFY = $004E; <br>  当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口 <br>  WM_INPUTLANGCHANGEREQUEST = $0050;<br>当用户选择某种输入语言,或输入语言的热键改变 <br>  WM_INPUTLANGCHANGE = $0051; <br>  当平台现场已经被改变后发送此消息给受影响的最顶级窗口 <br>  WM_TCARD = $0052; <br>  当程序已经初始化windows帮助例程时发送此消息给应用程序 <br>  WM_HELP = $0053; <br>  此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果当前都没有焦点,就把此消息发送给当前激活的窗口 <br>  WM_USERCHANGED = $0054; <br>  当用户已经登入或退出后发送此消息给所有的窗口,当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息; <br>  WM_NOTIFYFORMAT = $0055; <br>  公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构 <br>在WM_NOTIFY消息,使用此控件能使某个控件与它的父控件之间进行相互通信 <br>  WM_CONTEXTMENU = $007B; <br>  当用户某个窗口中点击了一下右键就发送此消息给这个窗口 <br>  WM_STYLECHANGING = $007C; <br>  当调用SETWINDOWLONG函数将要改变一个或多个 窗口的风格时发送此消息给那个窗口 <br>  WM_STYLECHANGED = $007D; <br>  当调用SETWINDOWLONG函数一个或多个 窗口的风格后发送此消息给那个窗口 <br>  WM_DISPLAYCHANGE = $007E; <br>  当显示器的分辨率改变后发送此消息给所有的窗口 <br><br>
 
WINDOWS消息大全(二)<br>WM_GETICON = $007F; <br>  此消息发送给某个窗口来返回与某个窗口有关连的大图标或小图标的句柄; <br>&nbsp; &nbsp;WM_SETICON = $0080; <br>  程序发送此消息让一个新的大图标或小图标与某个窗口关联; <br>  WM_NCCREATE = $0081; <br>  当某个窗口第一次被创建时,此消息在WM_CREATE消息发送前发送; <br>  WM_NCDESTROY = $0082; <br>  此消息通知某个窗口,非客户区正在销毁 <br>  WM_NCCALCSIZE = $0083; <br>  当某个窗口的客户区域必须被核算时发送此消息 <br>  WM_NCHITTEST = $0084;//移动鼠标,按住或释放鼠标时发生 <br>  WM_NCPAINT = $0085; <br>  程序发送此消息给某个窗口当它(窗口)的框架必须被绘制时; <br>  WM_NCACTIVATE = $0086; <br>  此消息发送给某个窗口 仅当它的非客户区需要被改变来显示是激活还是非激活状态; <br>  WM_GETDLGCODE = $0087; <br>  发送此消息给某个与对话框程序关联的控件,widdows控制方位键和TAB键使输入进入此控件 <br>通过响应WM_GETDLGCODE消息,应用程序可以把他当成一个特殊的输入控件并能处理它 <br>  WM_NCMOUSEMOVE = $00A0; <br>  当光标在一个窗口的非客户区内移动时发送此消息给这个窗口 //非客户区为:窗体的标题栏及窗的边框体 <br>WM_NCLBUTTONDOWN = $00A1; <br>  当光标在一个窗口的非客户区同时按下鼠标左键时提交此消息 <br>  WM_NCLBUTTONUP = $00A2; <br>  当用户释放鼠标左键同时光标某个窗口在非客户区十发送此消息; <br>  WM_NCLBUTTONDBLCLK = $00A3; <br>  当用户双击鼠标左键同时光标某个窗口在非客户区十发送此消息 <br>  WM_NCRBUTTONDOWN = $00A4; <br>  当用户按下鼠标右键同时光标又在窗口的非客户区时发送此消息 <br>  WM_NCRBUTTONUP = $00A5; <br>  当用户释放鼠标右键同时光标又在窗口的非客户区时发送此消息 <br>  WM_NCRBUTTONDBLCLK = $00A6; <br>  当用户双击鼠标右键同时光标某个窗口在非客户区十发送此消息 <br>  WM_NCMBUTTONDOWN = $00A7; <br>  当用户按下鼠标中键同时光标又在窗口的非客户区时发送此消息 <br>  WM_NCMBUTTONUP = $00A8; <br>  当用户释放鼠标中键同时光标又在窗口的非客户区时发送此消息 <br>  WM_NCMBUTTONDBLCLK = $00A9; <br>  当用户双击鼠标中键同时光标又在窗口的非客户区时发送此消息 <br>  WM_KEYFIRST = $0100; <br>  WM_KEYDOWN = $0100; <br>  //按下一个键 <br>  WM_KEYUP = $0101;<br>//释放一个键 <br>  WM_CHAR = $0102; <br>  //按下某键,并已发出WM_KEYDOWN, WM_KEYUP消息 <br>  WM_DEADCHAR = $0103; <br>  当用translatemessage函数翻译WM_KEYUP消息时发送此消息给拥有焦点的窗口 <br>  WM_SYSKEYDOWN = $0104; <br>  当用户按住ALT键同时按下其它键时提交此消息给拥有焦点的窗口; <br>  WM_SYSKEYUP = $0105; <br>  当用户释放一个键同时ALT 键还按着时提交此消息给拥有焦点的窗口 <br>  WM_SYSCHAR = $0106; <br>  当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后提交此消息给拥有焦点的窗口 <br>  WM_SYSDEADCHAR = $0107; <br>  当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后发送此消息给拥有焦点的窗口 <br>  WM_KEYLAST = $0108; <br>  WM_INITDIALOG = $0110; <br>  在一个对话框程序被显示前发送此消息给它,通常用此消息初始化控件和执行其它任务 <br>  WM_COMMAND = $0111; <br>  当用户选择一条菜单命令项或当某个控件发送一条消息给它的父窗口,一个快捷键被翻译 <br>  WM_SYSCOMMAND = $0112; <br>当用户选择窗口菜单的一条命令或当用户选择最大化或最小化时那个窗口会收到此消息 <br>  WM_TIMER = $0113; //发生了定时器事件 <br>  WM_HSCROLL = $0114; <br>  当一个窗口标准水平滚动条产生一个滚动事件时发送此消息给那个窗口,也发送给拥有它的控件 <br>  WM_VSCROLL = $0115; <br>  当一个窗口标准垂直滚动条产生一个滚动事件时发送此消息给那个窗口也,发送给拥有它的控件WM_INITMENU = $0116; <br>  当一个菜单将要被激活时发送此消息,它发生在用户菜单条中的某项或按下某个菜单键,它允许程序在显示前更改菜单 <br>  WM_INITMENUPOPUP = $0117; <br>  当一个下拉菜单或子菜单将要被激活时发送此消息,它允许程序在它显示前更改菜单,而不要改变全部 <br>  WM_MENUSELECT = $011F; <br>  当用户选择一条菜单项时发送此消息给菜单的所有者(一般是窗口) <br>  WM_MENUCHAR = $0120; <br>  当菜单已被激活用户按下了某个键(不同于加速键),发送此消息给菜单的所有者; <br>  WM_ENTERIDLE = $0121; <br>  当一个模态对话框或菜单进入空载状态时发送此消息给它的所有者,一个模态对话框或菜单进入空载状态就是在处理完一条或几条先前的消息后没有消息它的列队中等待 <br>  WM_MENURBUTTONUP = $0122; <br>  WM_MENUDRAG = $0123; <br>  WM_MENUGETOBJECT = $0124; <br>  &nbsp;WM_UNINITMENUPOPUP = $0125; <br>  WM_MENUCOMMAND = $0126; <br>  WM_CHANGEUISTATE = $0127; <br>  WM_UPDATEUISTATE = $0128; <br>  WM_QUERYUISTATE = $0129; <br>  WM_CTLCOLORMSGBOX = $0132;<br>在windows绘制消息框前发送此消息给消息框的所有者窗口,通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置消息框的文本和背景颜色 <br>  WM_CTLCOLOREDIT = $0133; <br>  当一个编辑型控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口<br>可以通过使用给定的相关显示设备的句柄来设置编辑框的文本和背景颜色 <br>  WM_CTLCOLORLISTBOX = $0134; <br>  当一个列表框控件将要被绘制前发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置列表框的文本和背景颜色 <br>  WM_CTLCOLORBTN = $0135; <br>  当一个按钮控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置按纽的文本和背景颜色 <br>  WM_CTLCOLORDLG = $0136; <br>  当一个对话框控件将要被绘制前发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置对话框的文本背景颜色 <br>  WM_CTLCOLORSCROLLBAR= $0137; <br>  当一个滚动条控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置滚动条的背景颜色 <br>  WM_CTLCOLORSTATIC = $0138; <br>  当一个静态控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置静态控件的文本和背景颜色 <br>  WM_MOUSEFIRST = $0200; <br>  WM_MOUSEMOVE = $0200; <br>  // 移动鼠标 <br>  WM_LBUTTONDOWN = $0201;<br>//按下鼠标左键 <br>  WM_LBUTTONUP = $0202; <br>  //释放鼠标左键 <br>  WM_LBUTTONDBLCLK = $0203; <br>  //双击鼠标左键 <br>  WM_RBUTTONDOWN = $0204; <br>  //按下鼠标右键 <br>  WM_RBUTTONUP = $0205; <br>  //释放鼠标右键 <br>  WM_RBUTTONDBLCLK = $0206; <br>  //双击鼠标右键 <br>  WM_MBUTTONDOWN = $0207; <br>  //按下鼠标中键 <br>  WM_MBUTTONUP = $0208; <br>  //释放鼠标中键 <br>  WM_MBUTTONDBLCLK = $0209; <br>  //双击鼠标中键 <br>  WM_MOUSEWHEEL = $020A; <br>  当鼠标轮子转动时发送此消息个当前有焦点的控件 <br>&nbsp; &nbsp; WM_MOUSELAST = $020A; <br>  WM_PARENTNOTIFY = $0210; <br>  当MDI子窗口被创建或被销毁,或用户按了一下鼠标键而光标在子窗口上时发送此消息给它的父窗口 <br>  WM_ENTERMENULOOP = $0211; <br>  发送此消息通知应用程序的主窗口that已经进入了菜单循环模式 <br>  WM_EXITMENULOOP = $0212; <br>  发送此消息通知应用程序的主窗口that已退出了菜单循环模式 <br>  WM_NEXTMENU = $0213; <br>  WM_SIZING = 532; <br>  当用户正在调整窗口大小时发送此消息给窗口;通过此消息应用程序可以监视窗口大小和位<br>置也可以修改他们 <br>  WM_CAPTURECHANGED = 533; <br>  发送此消息 给窗口当它失去捕获的鼠标时; <br>  WM_MOVING = 534; <br>  当用户在移动窗口时发送此消息,通过此消息应用程序可以监视窗口大小和位置也可以修改他们; <br>  WM_POWERBROADCAST = 536; <br>  此消息发送给应用程序来通知它有关电源管理事件; <br>  WM_DEVICECHANGE = 537; <br>  当设备的硬件配置改变时发送此消息给应用程序或设备驱动程序 <br>  WM_IME_STARTCOMPOSITION = $010D; <br>  WM_IME_ENDCOMPOSITION = $010E; <br>  WM_IME_COMPOSITION = $010F; <br>  WM_IME_KEYLAST = $010F; <br>  WM_IME_SETCONTEXT = $0281; <br>  WM_IME_NOTIFY = $0282; <br>  WM_IME_CONTROL = $0283; <br>  WM_IME_COMPOSITIONFULL = $0284; <br>  WM_IME_SELECT = $0285; <br>&nbsp;  WM_IME_CHAR = $0286; <br>  WM_IME_REQUEST = $0288; <br>  WM_IME_KEYDOWN = $0290; <br>  WM_IME_KEYUP = $0291; <br>  WM_MDICREATE = $0220;<br>应用程序发送此消息给多文档的客户窗口来创建一个MDI 子窗口 <br>  WM_MDIDESTROY = $0221; <br>  应用程序发送此消息给多文档的客户窗口来关闭一个MDI 子窗口 <br>  WM_MDIACTIVATE = $0222; <br>  应用程序发送此消息给多文档的客户窗口通知客户窗口激活另一个MDI子窗口,当客户窗口收到此消息后,它发出WM_MDIACTIVE消息给MDI子窗口(未激活)激活它; <br>  WM_MDIRESTORE = $0223; <br>  程序发送此消息给MDI客户窗口让子窗口从最大最小化恢复到原来大小 <br>  WM_MDINEXT = $0224; <br>  程序发送此消息给MDI客户窗口激活下一个或前一个窗口 <br>  WM_MDIMAXIMIZE = $0225; <br>  程序发送此消息给MDI客户窗口来最大化一个MDI子窗口; <br>  WM_MDITILE = $0226; <br>  程序发送此消息给MDI客户窗口以平铺方式重新排列所有MDI子窗口 <br>  WM_MDICASCADE = $0227; <br>  程序发送此消息给MDI客户窗口以层叠方式重新排列所有MDI子窗口 <br>  WM_MDIICONARRANGE = $0228; <br>  程序发送此消息给MDI客户窗口重新排列所有最小化的MDI子窗口 <br>  WM_MDIGETACTIVE = $0229; <br>&nbsp; &nbsp; 程序发送此消息给MDI客户窗口来找到激活的子窗口的句柄 <br>  WM_MDISETMENU = $0230; <br>  程序发送此消息给MDI客户窗口用MDI菜单代替子窗口的菜单 <br>  WM_ENTERSIZEMOVE = $0231; <br>  WM_EXITSIZEMOVE = $0232; <br>  WM_DROPFILES = $0233; <br>  WM_MDIREFRESHMENU = $0234; <br>  WM_MOUSEHOVER = $02A1; <br>  WM_MOUSELEAVE = $02A3; <br>  WM_CUT = $0300; <br>  程序发送此消息给一个编辑框或combobox来删除当前选择的文本 <br>  WM_COPY = $0301; <br>  程序发送此消息给一个编辑框或combobox来复制当前选择的文本到剪贴板 <br>  WM_PASTE = $0302; <br>  程序发送此消息给editcontrol或combobox从剪贴板中得到数据 <br>  WM_CLEAR = $0303; <br>  程序发送此消息给editcontrol或combobox清除当前选择的内容; <br>  WM_UNDO = $0304; <br>  程序发送此消息给editcontrol或combobox撤消最后一次操作 <br>  WM_RENDERFORMAT = $0305; <br>  WM_RENDERALLFORMATS = $0306; <br>  WM_DESTROYCLIPBOARD = $0307;<br>当调用ENPTYCLIPBOARD函数时 发送此消息给剪贴板的所有者 <br>  WM_DRAWCLIPBOARD = $0308; <br>  当剪贴板的内容变化时发送此消息给剪贴板观察链的第一个窗口;它允许用剪贴板观察窗口来显示剪贴板的新内容; <br>  WM_PAINTCLIPBOARD = $0309; <br>  当剪贴板包含CF_OWNERDIPLAY格式的数据并且剪贴板观察窗口的客户区需要重画; <br>  WM_VSCROLLCLIPBOARD = $030A; <br>  WM_SIZECLIPBOARD = $030B; <br>  当剪贴板包含CF_OWNERDIPLAY格式的数据并且剪贴板观察窗口的客户区域的大小已经改变是<br>此消息通过剪贴板观察窗口发送给剪贴板的所有者; <br>  WM_ASKCBFORMATNAME = $030C; <br>  通过剪贴板观察窗口发送此消息给剪贴板的所有者来请求一个 &nbsp; &nbsp; &nbsp; &nbsp; CF_OWNERDISPLAY格式的剪贴板的名字 <br>  WM_CHANGECBCHAIN = $030D; <br>  当一个窗口从剪贴板观察链中移去时发送此消息给剪贴板观察链的第一个窗口; <br>  WM_HSCROLLCLIPBOARD = $030E; <br>  此消息通过一个剪贴板观察窗口发送给剪贴板的所有者 ;它发生在当剪贴板包含CFOWNERDISPALY格式的数据并且有个事件在剪贴板观察窗的水平滚动条上;所有者应滚动剪贴板图象并更新滚动条的值; <br>  WM_QUERYNEWPALETTE = $030F; <br>  此消息发送给将要收到焦点的窗口,此消息能使窗口在收到焦点时同时有机会实现他的逻辑调色板 <br>  WM_PALETTEISCHANGING= $0310; <br>  当一个应用程序正要实现它的逻辑调色板时发此消息通知所有的应用程序 <br>  WM_PALETTECHANGED = $0311;<br>此消息在一个拥有焦点的窗口实现它的逻辑调色板后发送此消息给所有顶级并重叠的窗口,以此来改变系统调色板 <br>  WM_HOTKEY = $0312; <br>  当用户按下由REGISTERHOTKEY函数注册的热键时提交此消息 <br>  WM_PRINT = 791; <br>  应用程序发送此消息仅当WINDOWS或其它应用程序发出一个请求要求绘制一个应用程序的一部分; <br>  WM_PRINTCLIENT = 792; <br>  WM_HANDHELDFIRST = 856; <br>  WM_HANDHELDLAST = 863; <br>  WM_PENWINFIRST = $0380; <br>  WM_PENWINLAST = $038F; <br>  WM_COALESCE_FIRST = $0390; <br>  WM_COALESCE_LAST = $039F; <br>  WM_DDE_FIRST = $03E0; <br>  WM_DDE_INITIATE = WM_DDE_FIRST + 0; <br>  一个DDE客户程序提交此消息开始一个与服务器程序的会话来响应那个指定的程序和主题名; <br>  WM_DDE_TERMINATE = WM_DDE_FIRST + 1; <br>  一个DDE应用程序(无论是客户还是服务器)提交此消息来终止一个会话; <br>  WM_DDE_ADVISE = WM_DDE_FIRST + 2; <br>  一个DDE客户程序提交此消息给一个DDE服务程序来请求服务器每当数据项改变时更新它 <br>  WM_DDE_UNADVISE = WM_DDE_FIRST + 3; <br>  一个DDE客户程序通过此消息通知一个DDE服务程序不更新指定的项或一个特殊的剪贴板格式<br>的项 <br>  WM_DDE_ACK = WM_DDE_FIRST + 4; <br>  此消息通知一个DDE(动态数据交换)程序已收到并正在处理WM_DDE_POKE, WM_DDE_EXECUTE, WM_DDE_DATA, WM_DDE_ADVISE,WM_DDE_UNADVISE,or WM_DDE_INITIAT消息 <br>WM_DDE_DATA = WM_DDE_FIRST + 5;
 
晕 这么复杂啊 :D
 
give &nbsp;an example pls
 
呵呵,我以前的一个程序也是这样的,但是我们的应用是在网络OA上面<br>所以我的实现是用了SOCKET来实现,在本机开一个server和client<br>然后发数据报就是了,很简单就实现了要求<br>但是有个前提是我们的是在网络OA上的,默认的是PC机上面都有TCP/IP的东东
 
由三种方法可进行程序间参数传递(我所知)<br>我找不到了,你查查吧,dfw上有,我以前发的
 
在同一台机器上,<br>一种:利用系统的公共资源进行传递可以
 
to:tty_xiaotao,<br>weichao9999,能不能给小弟们一些原代码感受一下,我也很想学习啊!
 
其实也不麻烦,只要找到checkbox的据柄(用FindWindow,EnumWindows等api函数,就可以找到,以前有好多这样的贴子),然后发一个BM_GETCHECK消息就可以了。<br>var<br>&nbsp; icheck:integer;<br>&nbsp; hcheckbox:hwnd;<br><br>hcheckbox:=。。。//b程序的checkbox得句柄 <br>isCheck:=SendMessage(hcheckbox, BM_GETCHECK, 0, 0) ;<br>if icheck=0 then<br>&nbsp; showmessage('not check')<br>else<br>&nbsp; showmessage('check');
 
to 迷糊:<br>你的提示很好,让我找到解决的方法,我先试一下,解决后立即送上分数。
 
解决问题,谢谢迷糊的有效提示,也谢谢bottom的资料。
 
to :mayi,迷糊:<br>嘿你是怎么解决的?<br>我的意思是:如果另一个程序上有checkbox1 和 checkbox2 如何<br>通过 EnumchildWindows 知道我所获得的一堆 句柄是哪个对应checkbox1 <br>哪个对应checkbox2 ,谢谢!<br><br>
 
这是我的软件里的一段代码,判断另外一个软件里的“记住密码”复选框是否已选中。<br>function EnumChildWindowsProc(hwnd: Integer; lparam: Longint):Boolean; <br>stdcall;<br>&nbsp; var<br>&nbsp; &nbsp; buffer: array[0..255] of Char;<br>&nbsp; &nbsp; &nbsp;buffer1: array[0..255] of Char;<br>&nbsp; begin<br>&nbsp; &nbsp; Result := True;<br>&nbsp; &nbsp; //得到目标窗口的控件<br>&nbsp; &nbsp; GetClassName(hwnd,buffer,256);<br>&nbsp; &nbsp; //找到发消息的目标窗口的目标控件<br>&nbsp; &nbsp; if StrPas(Buffer)='Button' then<br>&nbsp; &nbsp; begin<br>&nbsp; &nbsp; GetWindowText(hwnd,buffer1,100);<br>&nbsp; &nbsp; &nbsp; if buffer1='记住密码' then<br>&nbsp; &nbsp; &nbsp; begin<br>&nbsp; &nbsp; &nbsp; PInteger(lparam)^ := hwnd;// 得到目标控件的Hwnd(句柄)<br>&nbsp; &nbsp; &nbsp; Result:=False; &nbsp;//终止循环<br>&nbsp; &nbsp; &nbsp; end;<br>&nbsp; &nbsp; end;<br>&nbsp; end;<br><br>procedure TForm1.Button1Click(Sender: TObject);<br>var<br>&nbsp;ischeck:integer;<br>&nbsp;hcheckbox:hwnd;<br>begin<br>hcheckbox:=findwindow('#3321',nil);//b程序的checkbox得句柄<br>EnumChildWindows(findwindow('#3321',nil),@EnumChildWindowsProc,Integer(@hcheckbox));<br><br>isCheck:=SendMessage(hcheckbox, BM_GETCHECK, 0, 0) ;<br>if isCheck=0 then<br>&nbsp;showmessage('not check')<br>else<br>&nbsp;showmessage('check');<br>end;
 
后退
顶部