2 qq 28249373 qq_28249373 于 2016.08.03 12:03 提问

win32控制台程序获取windows消息 5C

在win32控制台程序中,如何获取windows消息?比如键盘和鼠标事件的消息。

5个回答

CSDNXIAON
CSDNXIAON   2016.08.03 12:15

Win32控制台程序,ListBox控件响应鼠标单击及双击消息
----------------------同志你好,我是CSDN问答机器人小N,奉组织之命为你提供参考答案,编程尚未成功,同志仍需努力!

oyljerry
oyljerry   Ds   Rxr 2016.08.03 13:24
hhv_01
hhv_01   2016.08.03 13:27

C#可以用Console.ReadKey();方法获取到ConsoleKeyInfo对象,然后判断ConsoleKeyInfo对象的Key属性的值

xmlate
xmlate   2016.08.03 13:49

看看这个或许对你有帮助:

// INCLUDES ///////////////////////////////////////////////
#define WIN32_LEAN_AND_MEAN // just say no to MFC

#include // include all the windows headers
#include // include useful macros
#include // very important and include WINMM.LIB too!
#include
#include
#include

// DEFINES ////////////////////////////////////////////////

// defines for windows
#define WINDOW_CLASS_NAME "WINCLASS1"

// GLOBALS ////////////////////////////////////////////////
HWND main_window_handle = NULL; // globally track main window
HINSTANCE hinstance_app = NULL; // globally track hinstance

// FUNCTIONS //////////////////////////////////////////////
LRESULT CALLBACK WindowProc(HWND hwnd,
UINT msg,
WPARAM wparam,
LPARAM lparam)
{
// this is the main message handler of the system
PAINTSTRUCT ps; // used in WM_PAINT
HDC hdc; // handle to a device context
char buffer[80]; // used to print strings

// what is the message
switch(msg)
{

case WM_CREATE:
{
// do initialization stuff here
// return success
return(0);
} break;

case WM_CHAR:
     {
     // get the character
     char ascii_code = wparam;
     int key_state = lparam;

     // get a graphics context
     hdc = GetDC(hwnd);

     // set the foreground color to green
     SetTextColor(hdc, RGB(0,255,0));

     // set the background color to black
     SetBkColor(hdc, RGB(0,0,0));

     // set the transparency mode to OPAQUE
     SetBkMode(hdc, OPAQUE);

     // print the ascii code and key state
     sprintf(buffer,"WM_CHAR: Character = %c   ",ascii_code);
     TextOut(hdc, 0,0, buffer, strlen(buffer));

     sprintf(buffer,"Key State = 0X%X  ",key_state);
     TextOut(hdc, 0,16, buffer, strlen(buffer));

     // release the dc back
     ReleaseDC(hwnd, hdc);

     } break;

case WM_PAINT: 
    {
    // simply validate the window 
       hdc = BeginPaint(hwnd,&ps);     

    // end painting
    EndPaint(hwnd,&ps);

    // return success
    return(0);
       } break;

case WM_DESTROY: 
    {

    // kill the application, this sends a WM_QUIT message 
    PostQuitMessage(0);

    // return success
    return(0);
    } break;

default:break;

} // end switch

// process any messages that we didn't take care of
return (DefWindowProc(hwnd, msg, wparam, lparam));

} // end WinProc

// WINMAIN ////////////////////////////////////////////////
int WINAPI WinMain( HINSTANCE hinstance,
HINSTANCE hprevinstance,
LPSTR lpcmdline,

int ncmdshow)
{

WNDCLASSEX winclass; // this will hold the class we create
HWND hwnd; // generic window handle
MSG msg; // generic message

// first fill in the window class stucture
winclass.cbSize = sizeof(WNDCLASSEX);
winclass.style = CS_DBLCLKS | CS_OWNDC |
CS_HREDRAW | CS_VREDRAW;
winclass.lpfnWndProc = WindowProc;
winclass.cbClsExtra = 0;
winclass.cbWndExtra = 0;
winclass.hInstance = hinstance;
winclass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
winclass.hCursor = LoadCursor(NULL, IDC_ARROW);
winclass.hbrBackground = (HBRUSH)GetStockObject(BLACK_BRUSH);
winclass.lpszMenuName = NULL;
winclass.lpszClassName = WINDOW_CLASS_NAME;
winclass.hIconSm = LoadIcon(NULL, IDI_APPLICATION);

// save hinstance in global
hinstance_app = hinstance;

// register the window class
if (!RegisterClassEx(&winclass))
return(0);

// create the window
if (!(hwnd = CreateWindowEx(NULL, // extended style
WINDOW_CLASS_NAME, // class
"WM_CHAR Demo", // title
WS_OVERLAPPEDWINDOW | WS_VISIBLE,
0,0, // initial x,y
400,300, // initial width, height
NULL, // handle to parent
NULL, // handle to menu
hinstance,// instance of this application
NULL))) // extra creation parms
return(0);

// save main window handle
main_window_handle = hwnd;

// enter main event loop, but this time we use PeekMessage()
// instead of GetMessage() to retrieve messages
while(TRUE)
{
// test if there is a message in queue, if so get it
if (PeekMessage(&msg,NULL,0,0,PM_REMOVE))
{
// test if this is a quit
if (msg.message == WM_QUIT)
break;

   // translate any accelerator keys
   TranslateMessage(&msg);

   // send the message to the window proc
   DispatchMessage(&msg);
   } // end if

// main game processing goes here
// Game_Main(); // or whatever your loop is called
} // end while

// return to Windows like this
return(msg.wParam);

} // end WinMain

///////////////////////////////////////////////////////////

weixin_34115450
weixin_34115450   2016.08.03 15:35

有一个结构体MSG,获取他就好

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
用消息在Win32控制台程序多线程间进行通讯
 #include #include //#include //#include #define UM_MSG1 (WM_USER + 1)#define UM_MSG2 (WM_USER + 2)DWORD WINAPI Thread1(LPVOID para){ DWORD dwThreadId = *(DWORD *)para; DWO
win32 c++控制台应用程序捕获ctrl+c程序关闭事件
#include #include bool ctrlhandler(DWORD fdwctrltype) { switch (fdwctrltype) { // handle the ctrl-c signal. case CTRL_C_EVENT: printf("ctrl-c event\n\n"); return(false); // ctrl-close: con
qt 获取windows 的消息(qt get message from win32 API )
<br />qt 给win32 发送消息很简单,但是要获取windows 消息却十分复杂,最后想了一个不是很完美 但是也是以现在本人能力所能实现的唯一途径了,基本原理是 利用vc编写一个mfc 的dll ,这个dll 中创建一个透明窗体,利用这个dll 获取win32 API 消息。<br /> <br /> <br />源码 已经在vs2010 vs6.0 qt 4.7 下试验通过<br /> <br />下面贴出 重要的实现源码: <br /> VC dll- ReceiveMessage.cpp<br
Win32控制台程序,忽略Ctrl+C
请看这片来自msdn的网页。 http://msdn.microsoft.com/en-us/library/windows/desktop/ms686016(v=vs.85).aspx 自己写的win32控制台串口程序,要输入Ctrl+C,原先使用了SetConsoleCtrlHandler函数,达不到预期,虽然没有退出,但已无法输入了。 于是上网搜索,文中提到有3种方法可以:
为控制台窗口建立消息队列
介绍Windows的窗口、消息、子类化和超类化 (2011-05-08 15:32:07) 转载▼ 标签: 杂谈 分类: windows程序设计 这篇文章本来只是想介绍一下子类化和超类化这两个比较“生僻”的名词。为了叙述的完整性而讨论了Windows的窗口和消息,也简要讨论了进程和线程。子类化(Subclassing)和超类化(Sup
Windows消息ID大全
WM_NULL=0x0000 e# A6 T0 E, S/ I) _6 W6 [8 wWM_CREATE=0x0001/ T- u( X* V1 @+ g! oWM_DESTROY=0x0002* O0 d* e2 v D8 [: A4 [- IWM_MOVE=0x0003, v; Y! S2 x! G* C  U+ QWM_SIZE=0x00053 }- g7 G/
win32 控制台 消息详解
Win32消息 一、消息概念 消息就是在事件驱动模式下,事件发布函数和具体功能执行函数(或者代码段)之间的调用协议,调用协议的执行表现为窗口事件发布函数跟具体功能执行函数(或者代码段)之间的选择关系。 在Windows系统下(下面所述均为Windows系统),对计算机外设的操作,例如当用户敲击键盘键、点击鼠标、热插拔USB盘等,系统都认为外设发生了事件,于是系统调用专职函数就
Windows消息大全(可查询)
function search(){ var txtSearch = document.getElementById(txtSearch); var txtSpan = document.getElementById(result); txtSpan.innerHTML = ""; if (txtSearch.value != "") { var list
Win32命令行参数的传入和获取
Win32控制台,如何传入和获取命令行参数的有关问题, 有几种解决办法, 总结出来,朋友们一起分享   // tt.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #include "afxinet.h" #include #include using namespace std; #define BUFS
在QT4中处理windows消息
为了能处理某些qt无法处理的事件,或者在Qt将消息封装之前能做某些操作等等,我们可以自己处理windows事件。 处理windows事件是重写QApplication::winEventFilter(MSG*,long)函数来实现的。假如我们想捕获所有在窗体上的鼠标中键按下的消息,我们可以继承一下QApplication类: class MyApplication:public QApplic