系统之家 - 系统光盘下载网站!

当前位置:系统之家 > 系统教程 > XP系统如何屏蔽键盘某个按键

XP系统中如何屏蔽Ctrl+Esc键序列(4)

时间:2011-08-24 09:44:46 作者:不后悔 来源:系统之家 1. 扫描二维码随时看资讯 2. 请使用手机浏览器访问: https://m.xitongzhijia.net/xtjc/20110823/1072.html 手机查看 评论

  LRESULT CALLBACK MyTaskKeyHookLL(...)

  {

  if (/* 任务键*)

  return 1; // 立即返回

  return CallNextHookEx(...);

  }

  TaskKeyHook的大部分实现都很简单。只有一个地方用到了一点小技巧:既使用#pragma data_seg 命名包含全程数据的数据段,并且用#pragma comment (linker...)告诉链接器让这个数据段为共享段。实现细节请参考源代码。本文附带的例子程序(TrapKeys.exe)汇集了上述几个有关屏蔽键盘按键序列的功能,除此之外,它还有一个功能就是禁用任务栏。因为既然禁用了任务转换键,那么一般来说,也必然要禁用任务栏,否则禁用任务转换键就没有意义了。禁用任务栏的具体方法如下:

  HWND hwnd = FindWindow("Shell_traywnd", NULL);//找到任务栏

  EnableWindow(hwnd, FALSE); // 禁用任务栏

  如图四是例子程序运行画面:

  图四 TrapKeys程序运行画面

  以下是TrapKeys程序的实现代码:

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

  // TrapKeys.cpp

  //

  #include "stdafx.h"

  #include "resource.h"

  #include "StatLink.h"

  #include "TaskKeyMgr.h"

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

  // 主对话框

  //

  class CMyDialog : public CDialog {

  public:

  CMyDialog(CWnd* pParent = NULL) : CDialog(IDD_MYDIALOG, pParent) { }

  protected:

  HICON m_hIcon;

  CStaticLink m_wndLink1;

  CStaticLink m_wndLink2;

  CStaticLink m_wndLink3;

  virtual BOOL OnInitDialog();

  // 命令/UI 的更新处理

  afx_msg void OnDisableTaskMgr();

  afx_msg void OnDisableTaskKeys();

  afx_msg void OnDisableTaskbar();

  afx_msg void OnUpdateDisableTaskMgr(CCmdUI* pCmdUI);

  afx_msg void OnUpdateDisableTaskKeys(CCmdUI* pCmdUI);

  afx_msg void OnUpdateDisableTaskbar(CCmdUI* pCmdUI);

  afx_msg LRESULT OnKickIdle(WPARAM,LPARAM);

  DECLARE_MESSAGE_MAP()

  };

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

  // 标准的MFC 对话框应用类代码。

  //

  class CMyApp : public CWinApp {

  public:

  virtual BOOL InitInstance() {

  // 初始化app:运行对话框

  CMyDialog dlg;

  m_pMainWnd = &dlg;

  dlg.DoModal();

  return FALSE;

  }

  virtual int ExitInstance() {

  // 为了按全起见,在退出程序的时候,将所有禁用的项目复原

  CTaskKeyMgr::Disable(CTaskKeyMgr::ALL, FALSE);

  return 0;

  }

  } theApp;

  BEGIN_MESSAGE_MAP(CMyDialog, CDialog)

  ON_COMMAND(IDC_DISABLE_TASKKEYS,OnDisableTaskKeys)

  ON_COMMAND(IDC_DISABLE_TASKBAR, OnDisableTaskbar)

  ON_COMMAND(IDC_DISABLE_TASKMGR, OnDisableTaskMgr)

  ON_UPDATE_COMMAND_UI(IDC_DISABLE_TASKKEYS, OnUpdateDisableTaskKeys)

  ON_UPDATE_COMMAND_UI(IDC_DISABLE_TASKBAR, OnUpdateDisableTaskbar)

  ON_UPDATE_COMMAND_UI(IDC_DISABLE_TASKMGR, OnUpdateDisableTaskMgr)

  ON_MESSAGE(WM_KICKIDLE,OnKickIdle)

  END_MESSAGE_MAP()

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

  // 初始化对话框:子类化超链接柄加栽图标

  //

  BOOL CMyDialog::OnInitDialog()

  {

  CDialog::OnInitDialog();

  // 初始化超链接

  m_wndLink1.SubclassDlgItem(IDC_EMAIL,this);

  m_wndLink2.SubclassDlgItem(IDC_VCKBASEURL,this);

  m_wndLink3.SubclassDlgItem(IDC_VCKBASELINK,this);

  // 自己设置对话框图标。MFC不会为对话框应用程序设置它

  m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);

  SetIcon(m_hIcon, TRUE); // 打图标

  SetIcon(m_hIcon, FALSE); // 小图标

  return TRUE;

  }

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

  // 命令/UI 更新处理:写这些东西应该很轻松。

  void CMyDialog::OnDisableTaskKeys()

  {

  CTaskKeyMgr::Disable(CTaskKeyMgr::TASKKEYS,

  !CTaskKeyMgr::AreTaskKeysDisabled(), TRUE); // 蜂鸣

  }

  void CMyDialog::OnUpdateDisableTaskKeys(CCmdUI* pCmdUI)

  {

  pCmdUI->SetCheck(CTaskKeyMgr::AreTaskKeysDisabled());

  }

  void CMyDialog::OnDisableTaskbar()

  {

  CTaskKeyMgr::Disable(CTaskKeyMgr::TASKBAR,

  !CTaskKeyMgr::IsTaskBarDisabled());

  }

  void CMyDialog::OnUpdateDisableTaskbar(CCmdUI* pCmdUI)

  {

  pCmdUI->SetCheck(CTaskKeyMgr::IsTaskBarDisabled());

  }

  void CMyDialog::OnDisableTaskMgr()

  {

  CTaskKeyMgr::Disable(CTaskKeyMgr::TASKMGR,

  !CTaskKeyMgr::IsTaskMgrDisabled());

  }

  void CMyDialog::OnUpdateDisableTaskMgr(CCmdUI* pCmdUI)

  {

  pCmdUI->SetCheck(CTaskKeyMgr::IsTaskMgrDisabled());

  }

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

  // 要想让ON_UPDATE_COMMAND_UI正常工作,这是必需的。

  //

  LRESULT CMyDialog::OnKickIdle(WPARAM wp, LPARAM lCount)

  {

  UpdateDialogControls(this, TRUE);

  return 0;

  }

  按上述方法尽管禁用了任务栏,但是还有一个机关没有处理,那就是按下Windows键仍然可以弹出“开始”菜单。显然在处理VK_LWIN之前,任务栏不会检查是否被启用。一般来讲,如果某个窗口被屏蔽掉,那么它就不再会处理用户在这个窗口的输入——这就是所谓的禁用(Disable)的含义。通常调用EnableWindow(FALSE)后自然就达到了这个目的。但是处理VK_LWIN/VK_RWIN按键的代码决不会去检查任务栏启用/禁用状态。对此,本文的处理办法仍然是利用键盘钩子。修改一下TaskKeyHook实现,增加对Windows键的捕获。这样按下“开始”菜单键之后什么也不会发生。希望没有漏掉其它的按键。如果哪位读者发现漏掉了什么键,请和我联系,以便把它加到键盘钩子中去。为了简单起见,我在类CTaskKeyMgr中封装了所有禁用的函数。下面是这个类的定义击实现文件:

发表评论

0

没有更多评论了

评论就这些咯,让大家也知道你的独特见解

立即评论

以上留言仅代表用户个人观点,不代表系统之家立场

其他版本软件

人气教程排行

XP系统推荐

扫码关注
扫码关注

扫码关注 官方交流群 软件收录