
三、认识任务管理器
1
正在运行的程序
“应用程序”选项卡显示计算机上正在运行的程序的状态。在此选项卡中,您能够结束、切换、最小化或最大化程序。不过在此选项中,只会显示当前已打开窗口的应用程序,而QQ、Flash
Get等最小化至系统托盘区的应用程序则不会显示。
如果需要同时结束多个任务,可以按住Ctrl或SHIFT键复选,然后点击“结束任务”;
点击“新任务”按钮,可以直接打开相应的程序、文件夹、文档或Internet资源,类似于开始菜单中的“运行”应用:打开了一大堆的窗口,如何关闭一个个点,太累了吧。。。通过任务管理器来实现吧。通过CTRL和SHIFT,用鼠标选中想关闭的任务,点“结束任务”,嘿嘿!当然我们也可以实现多个程序的最大化、最小化等 *** 作。2
正在运行的进程
“进程”选项卡显示计算机上正在运行的进程的相关信息。例如,您可以显示关于
CPU
和内存使用情况、PID、页面错误、句柄计数以及其他一些参数的信息。
你可以看到所有当前正在运行的进程,包括应用程序、后台服务等。找到需要结束的进程名,然后执行右键菜单中的“结束进程”命令,就可以强行终止,不过这种方式将丢失未保存的数据,而且如果结束的是系统服务,则系统的某些功能可能无法正常使用。
这个是不可能的,易语言可以获取程序的信息,却只能更改程序的一些保存数据,无法对程序直接影响,而且QQ也自带了保护程序。就算你再怎么厉害,你也只能查看程序的结构,很多软件一旦更改,程序就打不开了!所以,不要说易语言了就是c++一类的也不大可能!而且,楼主你学过汇编吗?没汇编基础去做查看软件结构等根本不可能!
托盘区域这个TTBButton结构的dwData实际上是指向用于接收对应图标的通知消息的窗口句柄(即NOTIFYICONDATA结构的hWnd)的指针,根据此句柄就可以得到PID了!
在Windows *** 作系统中 任务栏的右边(托盘)会常驻几个图标 如输入法切换图标 音量控制图标等 此外我们还经常遇到具有托盘图标的软件 如金山词霸 实时监测功能的杀毒软件等 这些软件在后台运行 通常不占用太多的屏幕资源 只在通知栏上放一个小小的标志 必要时我们可以通过用鼠标点击图标对其进行选单 *** 作或激活其主窗口 有时我们自己编写的程序也希望有类似的效果 本文将详细地介绍用VC设计托盘图标程序的方法 一 NOTIFYICONDATA结构 NOTIFYICONDATA结构包含了系统用来处理托盘图标的信息 它包括选择的图标 回调消息 提示消息和图标对应的窗口等内容 其定义为 typedef struct—NOTIFYICONDATA { DWORD cbSize; //以字节为单位的这个结构的大小 HWND hWnd; //接收托盘图标通知消息的窗口句柄 UINT uID; //应用程序定义的该图标的ID号 UINT uFlags; //设置该图标的属性 UINT uCallbackMessage; //应用程序定义的消息ID号 此消息传递给hWnd HICON hIcon; //图标的句柄 char szTip[ ]; //鼠标停留在图标上显示的提示信息 } NOTIFYICONDATA PNOTIFYICONDATA; 该结构中 成员uFlags可以是下列的组合或其中之一 NIF_ICON 设置成员hIcon有效 NIF_MESSAGE 设置成员uCallbackMessage有效 NIF_TIP 设置成员szTip有效 二 Shell_NotifyIcon函数 全局函数Shell_NotifyIcon()用于在托盘上增加 删除或修改图标 其原型为 WINSHELLAPI BOOL WINAPI Shell_NotifyIcon( DWORD dwMessage PNOTIFYICONDATA pnid); Pnid是上面的NOTIFYICONDATA结构的指针 dwMessage是被传递的消息 可以是以下消息之一 NIM_ADD 增加图标 NIM_DELETE 删除图标 NIM_MODIFY 修改图标 三 托盘图标程序设计示例 首先我们用AppWizard创建一个不基于文档和视图结构的应用程序Tray 我们并不想在应用程序启动时显示主窗口 所以需要删除应用程序类CTrayApp中成员函数InitInstance()的以下两句代码 pFrame 〉ActivateFrame(); pFrame 〉ShowWindow(SW_SHOW); 在CMainFrame类中加入NOTIFYICONDATA结构的保护成员变量m_tnid 并在其OnCreate函数中return语句前加入生成托盘图标的代码 m_tnid cbSize=sizeof(NOTIFYICONDATA); m_tnid hWnd=this 〉m_hWnd; m_tnid uFlags=NIF_MESSAGE|NIF_ICON|NIF_TIP; m_tnid uCallbackMessage=MYWM_NOTIFYICON;
//用户定义的回调消息 CString szToolTip; szToolTip=_T( 托盘图标实例 ); _tcscpy(m_tnid szTip szToolTip); m_tnid uID=IDR_MAINFRAME; HICON hIcon; hIcon=AfxGetApp() 〉LoadIcon(IDR_MAINFRAME); m_tnid hIcon=hIcon; ::Shell_NotifyIcon(NIM_ADD &&m_tnid); if(hIcon)::DestroyIcon(hIcon); 返回消息的ID应在主框架类的头函数中定义 #define MYWM_NOTIFYICON WM_USER+ 为了处理图标返回消息 如鼠标左键双击 鼠标右键单击消息 我们重载WindowProc()函数 此外 我们还希望在主框架窗口最小化时图标不在任务栏的空白区出现 在此函数中同时作相应处理 LRESULT CMainFrame::WindowProc(UINT message WPARAM wParam LPARAM lParam) { switch(message){ case MYWM_NOTIFYICON: //如果是用户定义的消息 if(lParam==WM_LBUTTONDBLCLK){ //鼠标双击时主窗口出现 AfxGetApp() 〉m_pMainWnd 〉ShowWindow(SW_SHOW); } else if(lParam==WM_RBUTTONDOWN){ //鼠标右键单击d出选单 CMenu menu; menu LoadMenu(IDR_RIGHT_MENU); //载入事先定义的选单 CMenupMenu=menu GetSubMenu( ); CPoint pos; GetCursorPos(&&pos); pMenu 〉TrackPopupMenu(TPM_LEFTALIGN|TPM_RIGHTBUTTON pos x pos y AfxGetMainWnd()); } break; case WM_SYSMAND: //如果是系统消息 if(wParam= =SC_MINIMIZE){ //接收到最小化消息时主窗口隐藏 AfxGetApp() 〉m_pMainWnd 〉ShowWindow(SW_HIDE); return ; } break; } return CFrameWnd::WindowProc(message wParam lParam); } 为使应用程序退出时图标消失 映射WM_DESTROY消息 在OnDestroy()函数中加入 ::Shell_NotifyIcon(NIM_DELETE &&m_tnid); 至此 托盘图标程序的常规功能我们均已实现 我们还可以通过Shell_NotifyIcon()函数的调用实现不同状态下图标的改变 本程序在VC++ Windows / Professional下调试通过 lishixinzhi/Article/program/net/201311/11634
Windows 95以及后来的Windows版本允许你将程序图标放入系统托盘。所谓系统托盘,通常指的是屏幕右下方显示时间,音量等图标的那个区域。这个区域主要用于显示状态信息或者当你运行的程序不可见时,允许你方便地访问程序的主要特性。这个区域还可以用于显示小程序的图标,以便用户容易访问主程序,或者在预定的时间加载主程序。
有些系统托盘图标可以变化用以指示程序状态,例如,浏览器的系统托盘图标当modem接收和发送数据时显示的是不同的图标。把鼠标移到托盘图标上停留一下常常会显示一个提示,根据程序的状态,它可能也会变化。在托盘图标上单击鼠标右键常常显示一个程序菜单,而双击鼠标左键常常可以启动主窗口或应用程序。
访问系统托盘的方法是通过Shell_NotifyIcon函数和NOTIFYICONDATA结构实现的。
typedef struct _NOTIFYICONDATA {
DWORD cbSize;
HWND hWnd;
UINT uID;
UINT uFlags;
UINT uCallbackMessage;
HICON hIcon;
TCHAR szTip[64];
DWORD dwState; //Version 50
DWORD dwStateMask; //Version 50
TCHAR szInfo[256]; //Version 50
UINT uTimeout; //Version 50
TCHAR szInfoTitle[64]; //Version 50
DWORD dwInfoFlags; //Version 50
} NOTIFYICONDATA, PNOTIFYICONDATA;
为了要在系统托盘中显示图标,用NIM_ADD标志调用Shell_NotifyIcon函数。
#define ID_TASKBARICON 100
#define WM_ICONNOTIFY (WM_USER + 101)
NOTIFYICONDATA nid;
// 初始化系统托盘图标
m_tnidcbSize=sizeof(NOTIFYICONDATA);
m_tnidhWnd=this->m_hWnd;
m_tniduFlags=NIF_MESSAGE|NIF_ICON|NIF_TIP;
m_tniduCallbackMessage=MYWM_NOTIFYICON;
CString szToolTip;
szToolTip=_T("托盘实例");
_tcscpy(m_tnidszTip,szToolTip);
m_tniduID=IDR_MAINFRAME;
m_tnidhIcon=AfxGetApp()->LoadIcon(IDR_MAINFRAME);
::Shell_NotifyIcon(NIM_ADD,&m_tnid);
cbSize成员是结构的大小(使用它主要是为了支持将来这个结构大小增加)。
hWnd是窗口句柄。当图标发生某事件时(如单击、双击等),Windows将向窗口发送uCallbackMessage成员指定的消息。uID成员指定与图标关联的ID。它不是很重要,除非你需要显示并跟踪几个图标。
uFlag成员告诉Windows应该读取哪个成员。当添加一个图标时,应该包含这个结构的大多数成员。当更新图标时,如只是需要改变图标时,你只要设置相应
的标志就可以了。
hIcon成员是你想显示的图标。 最后,szTip成员是提示文本。设置好这些结构成员后,调用Shell_NotifyIcon函数。
当与图标关联的事件发生时,Windows将发送uCallbackMessage成员指定的消息。IParam包含发送的消息。当获得WM_LBUTTONDBLCLK消息时显示主窗口 在这里我们可以定义一个WM_MYNOTIFYICON
#define WM_MYNOTIFYICON WM_USER+101或者启动主程序。当获得WM_RBUTTONUP消息时显示菜单。
注意:如果在系统托盘中单击鼠标右键,有时会有一个d出式(上下文菜单)菜单显示/消失的怪现象,可以参考下列代码加以解决。
switch(message)
{
case MYWM_NOTIFYICON:
if(lParam==WM_LBUTTONDBLCLK)
{
AfxGetApp()->m_pMainWnd->ShowWindow(SW_SHOW);
CenterWindow();
}
else if(lParam==WM_RBUTTONDOWN)
{
CMenu menu;
menuLoadMenuW(IDM_RIGHT_MENU);
CMenu pMenu;
pMenu=menuGetSubMenu(0);
POINT point;
GetCursorPos(&point);
pMenu->TrackPopupMenu(TPM_LEFTALIGN|TPM_RIGHTBUTTON,pointx,pointy,AfxGetMainWnd());
}
break;
case WM_SYSCOMMAND:
if(wParam==SC_MINIMIZE||wParam==SC_CLOSE)
{
AfxGetApp()->m_pMainWnd->ShowWindow(SW_HIDE);
return 0; //请问这里为什么要加个return 0 呢???
}
break;
} 不论什么时候,你都可以用 NIM_MODIFY 调用 Shell_NotifyIcon。程序终止之前,用 NIM_DELETE 调用 Shell_NotifyIcon从托盘中清除图标。
Shell_NotifyIcon(NIM_DELETE, &nid);
另外打开程序时直接最小托盘
CMyEyeProtectApp::InitInstance()函数中
m_pMainWnd->ShowWindow(SW_HIDE);
这样就可以在开始的时候直接进入托盘
另外在程序开始之前出现一个几秒钟的启动画面
CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)函数中
CSplashDlg dlg=new CSplashDlg(this);
dlg->Create(CSplashDlg::IDD,this);
dlg->ShowWindow(SW_SHOW);
dlg->CenterWindow(this);
dlg->UpdateWindow();
Sleep(2000);
dlg->DestroyWindow();
把那对话框的属性贴上你想显示的,然后去掉边框,再按上面方法处理就可以了
我在基于对话框的程序初始化里建立了一个模态对话框(作为登录使用),此时如果单击最小化后它会最小化到屏幕左下角(开始上方),我觉得这样不好看,所以就把在最小化的时候添加了ShowWindow(SW_HIDE),隐藏起来了,在创建模态对话框之前我把主对话框的任务栏去掉了并添加了托盘图标,现在我把登陆框隐藏了之后,想通过单击托盘图标重新显示登陆框,但是在处理函数里出了用FindWindow以外是否还有办法显示它
这是处理双击托盘响应的事件:
case WM_LBUTTONDBLCLK: //双击图标的处理{CWnd pWnd=CWnd::FindWindow(NULL,_T(XXXX));
------解决方案--------------------------------------------------------
创建的时候获得,然后把它保存,备用
------解决方案--------------------------------------------------------
囧,你的主窗口类定义个你登陆对话框类的对象不就好了对 正确 大侠就是不一样
以上就是关于VBS能不能用进程最小化窗口或根据进程获取句柄全部的内容,包括:VBS能不能用进程最小化窗口或根据进程获取句柄、易语言能通过获取句柄的方式把某个软件的右上角的关闭按钮隐藏掉或禁止掉么还有就是托盘后鼠标右键的d、delphi 如何通过托盘图标,获取进程PID等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)