TaskManager
所属分类:进程与线程
开发工具:Visual C++
文件大小:60KB
下载次数:85
上传日期:2012-10-13 09:48:05
上 传 者:
bsaver
说明: VC6.0 制作的一个进程管理器,实现了当前进程的提取,新建进程,结束进程,内存、CPU利用率的动态图表显示
(VC6.0 produced by a process manager, the current process of extraction, the new process, the end of the process, memory, CPU utilization, dynamic charts show)
文件列表:
TaskManager\CPUInfo.h (1135, 2010-02-04)
TaskManager\MyCapad.cpp (9999, 2012-09-28)
TaskManager\MyCapad.h (1339, 2012-09-28)
TaskManager\MyOpen.cpp (1229, 2012-09-26)
TaskManager\MyOpen.h (1147, 2012-09-27)
TaskManager\MyProcess.cpp (5517, 2012-09-27)
TaskManager\MyProcess.h (1430, 2012-09-27)
TaskManager\MyProgram.cpp (3619, 2012-09-27)
TaskManager\MyProgram.h (1356, 2012-09-26)
TaskManager\psapi\PSAPI.DLL (18192, 2000-11-20)
TaskManager\psapi\PSAPI.H (4172, 1998-03-15)
TaskManager\psapi\Psapi.Lib (7458, 2012-09-27)
TaskManager\psapi (0, 2012-09-27)
TaskManager\res\Plasma1.ico (3774, 2012-09-26)
TaskManager\res\TaskManager.ico (4606, 2012-09-26)
TaskManager\res\TaskManager.rc2 (403, 2012-09-25)
TaskManager\res (0, 2012-09-26)
TaskManager\resource.h (1653, 2012-09-28)
TaskManager\StdAfx.cpp (213, 2012-09-25)
TaskManager\StdAfx.h (1120, 2012-09-27)
TaskManager\TaskManager.aps (41684, 2012-09-28)
TaskManager\TaskManager.clw (3251, 2012-10-08)
TaskManager\TaskManager.cpp (2133, 2012-09-25)
TaskManager\TaskManager.dsp (4890, 2012-09-28)
TaskManager\TaskManager.dsw (547, 2012-09-25)
TaskManager\TaskManager.h (1379, 2012-09-25)
TaskManager\TaskManager.ncb (82944, 2012-10-08)
TaskManager\TaskManager.opt (54784, 2012-10-08)
TaskManager\TaskManager.plg (1541, 2012-09-28)
TaskManager\TaskManager.rc (8049, 2012-09-28)
TaskManager\TaskManagerDlg.cpp (7439, 2012-09-26)
TaskManager\TaskManagerDlg.h (1778, 2012-09-26)
TaskManager (0, 2012-10-13)
//*****************************************************************************//
//获取应用程序信息
//*****************************************************************************//
1:获取任务栏窗体 Wnd 的指针
CWnd* pWnd = AfxWindowGetMainWnd()->GetWindow(GW_HWNDFIRST);
2:判断窗体是否可访问、是否有标题、是否为子窗体
if(pWnd->IsWindowCisible() && pWnd->GetWindowTextLength() && !pWnd->GetOwner())
{
}
3:获取任务栏窗体标题
pWnd->GetWindowText(strCaption);
4:利用循环遍历任务栏所有窗体
while(pWnd)
{
pWnd = pWnd->GetWindow(GW_HWNDNEXT);
}
//*****************************************************************************//
//获取系统进程信息
//*****************************************************************************//
1:定义 PROCESSENTRY32 的结构体变量 process 用来保存进程信息
2:调用 CreateToolhelp32Snapshot() 返回当前系统进程快照,并定义一个句柄指向这个快照
HANDLE hProcess = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
3:根据进程快照,用 Process32First() 函数访问快照中的第一个进程,将信息保存在 process 中,访问结果放在 bool bMore 中
bool bMore = Process32First(hProcess,&process);
4:提取 PROCESSENTRY32 结构体中的有用信息
strReFlx.Format("%s",process.szExeFile); //提取进程名字
strID.Format("%5u",process.th32ProcessID); //获取进程ID
strFID.Format("%u",process.th32ParentProcessID); //获取进程父ID
5:利用循环调用 Process32Next() 遍历进程
while(bMore)
{
bMore = Process32Next(hProcess,&process);
}
//*****************************************************************************//
//获取进程内存使用信息信息
//*****************************************************************************//
1:定义一个 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc,用于保存内存使用信息
2:根据进程 ID 号调用 OpenProcess() 的函数打开指定的进程,并将句柄保存
HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ,FALSE,process.rh32ProcessID);
3:根据打开的进程句柄获取进程使用内存的信息,并将获取的信息保存到 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc 中
GetProcessMemoryInfo(hProcessl,&pmc,sizeof(pmc));
4: 在 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc 中,提取有用的内存信息,一个是最大进程使用内存空间,一个是实际使用内存大小
CurMem = pmc.WorkingSetSize / 1024; //实际占用内存空间大小
MaxMem = pmc.PeakWorkingSetSize / 1024; //最大占用内存空间大小
//*****************************************************************************//
//如何启动、停止进程
//*****************************************************************************//
1:调用 ShellExecute() 函数来实现启动应用程序的进程,ShellExecute() 函数是运行一个外部程序(或是打开一个已经注册的文件、
打开一个目录、打印一个文件等),并对外部程序有一定的控制。原型如下:
ShellExecute(
HWND hwnd, //用于指定父窗口的句柄
LPCSTR lpOperation, //当函数调用过程中出现错误时,它将作为 Windows 消息窗口的父窗口
LPCSTR lpFile, //指定要打开的文件名或要执行程序的文件名,或是要浏览的文件夹名
LPCSTR lpParameters, //指定要进行的操作
LPCSTR lpDirectory, //用于指定默认目录
INT nShowCmd //指定程序窗口的初始化显示方式
)
example:
ShellExecute(NULL,_T("open"),dlg.m_file,NULL,NULL,SW_SHOW);
2:关闭进程
//*****************************************************************************//
//设置 ListCtrl 风格
//*****************************************************************************//
--------------------------------------------------------------------------------
1. CListCtrl 风格
LVS_ICON: 为每个item显示大图标
LVS_SMALLICON: 为每个item显示小图标
LVS_LIST: 显示一列带有小图标的item
LVS_REPORT: 显示item详细资料
直观的理解:windows资源管理器,“查看”标签下的“大图标,小图标,列表,详细资料”
--------------------------------------------------------------------------------
2. 设置listctrl 风格及扩展风格
LONG lStyle;
lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口style
lStyle &= ~LVS_TYPEMASK; //清除显示方式位
lStyle |= LVS_REPORT; //设置style
SetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置style
DWORD dwStyle = m_list.GetExtendedStyle();
dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)
dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)
dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件
m_list.SetExtendedStyle(dwStyle); //设置扩展风格
--------------------------------------------------------------------------------
3. 插入数据
m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列
m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );
int nRow = m_list.InsertItem(0, “11”);//插入行
m_list.SetItemText(nRow, 1, “jacky”);//设置数据
--------------------------------------------------------------------------------
4. 一直选中item
选中style中的Show selection always,或者在上面第2点中设置LVS_SHOWSELALWAYS
--------------------------------------------------------------------------------
5. 选中和取消选中一行
int nIndex = 0;
//选中
m_list.SetItemState(nIndex, LVIS_SELECTED|LVIS_FOCUSED, LVIS_SELECTED|LVIS_FOCUSED);
//取消选中
m_list.SetItemState(nIndex, 0, LVIS_SELECTED|LVIS_FOCUSED);
--------------------------------------------------------------------------------
6. 得到listctrl中所有行的checkbox的状态
m_list.SetExtendedStyle(LVS_EX_CHECKBOXES);
CString str;
for(int i=0; iGetItemCount();
--------------------------------------------------------------------------------
12. 删除所有列
方法一:
while ( m_list.DeleteColumn (0))
因为你删除了第一列后,后面的列会依次向上移动。
方法二:
int nColumns = 4;
for (int i=nColumns-1; i>=0; i--)
m_list.DeleteColumn (i);
--------------------------------------------------------------------------------
13. 得到单击的listctrl的行列号
添加listctrl控件的NM_CLICK消息相应函数
void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
// 方法一:
/*
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
m_list.ScreenToClient(&point);
LVHITTESTINFO lvinfo;
lvinfo.pt = point;
lvinfo.flags = LVHT_ABOVE;
int nItem = m_list.SubItemHitTest(&lvinfo);
if(nItem != -1)
{
CString strtemp;
strtemp.Format("单击的是第%d行第%d列", lvinfo.iItem, lvinfo.iSubItem);
AfxMessageBox(strtemp);
}
*/
// 方法二:
/*
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
if(pNMListView->iItem != -1)
{
CString strtemp;
strtemp.Format("单击的是第%d行第%d列",
pNMListView->iItem, pNMListView->iSubItem);
AfxMessageBox(strtemp);
}
*/
*pResult = 0;
}
--------------------------------------------------------------------------------
14. 判断是否点击在listctrl的checkbox上
添加listctrl控件的NM_CLICK消息相应函数
void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
m_list.ScreenToClient(&point);
LVHITTESTINFO lvinfo;
lvinfo.pt = point;
lvinfo.flags = LVHT_ABOVE;
UINT nFlag;
int nItem = m_list.HitTest(point, &nFlag);
//判断是否点在checkbox上
if(nFlag == LVHT_ONITEMSTATEICON)
{
AfxMessageBox("点在listctrl的checkbox上");
}
*pResult = 0;
}
--------------------------------------------------------------------------------
15. 右键点击listctrl的item弹出菜单
添加listctrl控件的NM_RCLICK消息相应函数
void CTest6Dlg::OnRclickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
if(pNMListView->iItem != -1)
{
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
CMenu menu;
VERIFY( menu.LoadMenu( IDR_MENU1 ) );
CMenu* popup = menu.GetSubMenu(0);
ASSERT( popup != NULL );
popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, point.x, point.y, this );
}
*pResult = 0;
}
--------------------------------------------------------------------------------
16. item切换焦点时(包括用键盘和鼠标切换item时),状态的一些变化顺序
添加listctrl控件的LVN_ITEMCHANGED消息相应函数
void CTest6Dlg::OnItemchangedList1(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
// TODO: Add your control notification handler code here
CString sTemp;
if((pNMListView->uOldState & LVIS_FOCUSED) == LVIS_FOCUSED &&
(pNMListView->uNewState & LVIS_FOCUSED) == 0)
{
sTemp.Format("%d losted focus",pNMListView->iItem);
}
else if((pNMListView->uOldState & LVIS_FOCUSED) == 0 &&
(pNMListView->uNewState & LVIS_FOCUSED) == LVIS_FOCUSED)
{
sTemp.Format("%d got focus",pNMListView->iItem);
}
if((pNMListView->uOldState & LVIS_SELECTED) == LVIS_SELECTED &&
(pNMListView->uNewState & LVIS_SELECTED) == 0)
{
sTemp.Format("%d losted selected",pNMListView->iItem);
}
else if((pNMListView->uOldState & LVIS_SELECTED) == 0 &&
(pNMListView->uNewState & LVIS_SELECTED) == LVIS_SELECTED)
{
sTemp.Format("%d got selected",pNMListView->iItem);
}
*pResult = 0;
}
--------------------------------------------------------------------------------
17. 得到另一个进程里的listctrl控件的item内容
http://www.codeproject.com/threads/int***_memsteal.asp
--------------------------------------------------------------------------------
18. 选中listview中的item
Q131284: How To Select a Listview Item Programmatically
http://support.microsoft.com/kb/131284/en-us
--------------------------------------------------------------------------------
19. 如何在CListView中使用CListCtrl的派生类
http://www.codeguru.com/cpp/controls/listview/introduction/article.php/c919/
--------------------------------------------------------------------------------
20. listctrl的subitem添加图标
m_list.SetExtendedStyle(LVS_EX_SUBITEMIMAGES);
m_list.SetItem(..); //具体参数请参考msdn
--------------------------------------------------------------------------------
21. 在CListCtrl显示文件,并根据文件类型来显示图标
网上找到的代码,share
BOOL CTest6Dlg::OnInitDialog()
{
CDialog::OnInitDialog();
HIMAGELIST himlSmall;
HIMAGELIST himlLarge;
SHFILEINFO sfi;
char cSysDir[MAX_PATH];
CString strBuf;
memset(cSysDir, 0, MAX_PATH);
GetWindowsDirectory(cSysDir, MAX_PATH);
strBuf = cSysDir;
sprintf(cSysDir, "%s", strBuf.Left(strBuf.Find("\\")+1));
himlSmall = (HIMAGELIST)SHGetFileInfo ((LPCSTR)cSysDir,
0,
&sfi,
sizeof(SHFILEINFO),
SHGFI_SYSICONINDEX | SHGFI_SMALLICON );
himlLarge = (HIMAGELIST)SHGetFileInfo((LPCSTR)cSysDir,
0,
&sfi,
sizeof(SHFILEINFO),
SHGFI_SYSICONINDEX | SHGFI_LARGEICON);
if (himlSmall && himlLarge)
{
::SendMessage(m_list.m_hWnd, LVM_SETIMAGELIST,
(WPARAM)LVSIL_SMALL, (LPARAM)himlSmall);
::SendMessage(m_list.m_hWnd, LVM_SETIMAGELIST,
(WPARAM)LVSIL_NORMAL, (LPARAM)himlLarge);
}
return TRUE; // return TRUE unless you set the focus to a control
}
void CTest6Dlg::AddFiles(LPCTSTR lpszFileName, BOOL bAddToDocument)
{
int nIcon = GetIconIndex(lpszFileName, FALSE, FALSE);
CString strSize;
CFileFind filefind;
// get file size
if (filefind.FindFile(lpszFileName))
{
filefind.FindNextFile();
strSize.Format("%d", filefind.GetLength());
}
else
strSize = "0";
// split path and filename
CString strFileName = lpszFileName;
CString strPath;
int nPos = strFileName.ReverseFind('\\');
if (nPos != -1)
{
strPath = strFileName.Left(nPos);
strFileName = strFileName.Mid(nPos + 1);
}
// insert to list
int nItem = m_list.GetItemCount();
m_list.InsertItem(nItem, strFileName, nIcon);
m_list.SetItemText(nItem, 1, strSize);
m_list.SetItemText(nItem, 2, strFileName.Right(3));
m_list.SetItemText(nItem, 3, strPath);
}
int CTest6Dlg::GetIconIndex(LPCTSTR lpszPath, BOOL bIsDir, BOOL bSelected)
{
SHFILEINFO sfi;
memset(&sfi, 0, sizeof(sfi));
if (bIsDir)
{
SHGetFileInfo(lpszPath,
FILE_ATTRIBUTE_DIRECTORY,
&sfi,
sizeof(sfi),
SHGFI_SMALLICON | SHGFI_SYSICONINDEX |
SHGFI_USEFILEATTRIBUTES |(bSelected ? SHGFI_OPENICON : 0));
return sfi.iIcon;
}
else
{
SHGetFileInfo (lpszPath,
FILE_ATTRIBUTE_NORMAL,
&sfi,
sizeof(sfi),
SHGFI_SMALLICON | SHGFI_SYSICONINDEX |
SHGFI_USEFILEATTRIBUTES | (bSelected ? SHGFI_OPENICON : 0));
return sfi.iIcon;
}
return -1;
}
--------------------------------------------------------------------------------
22. listctrl内容进行大数据量更新时,避免闪烁
m_list.SetRedraw(FALSE);
//更新内容
m_list.SetRedraw(TRUE);
m_list.Invalidate();
m_list.UpdateWindow();
或者参考
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vclib/html/_mfc_cwnd.3a3a.setredraw.asp
//*****************************************************************************//
//解决 list 闪烁
//*****************************************************************************//
设: 控件名称:m_List
1.先锁定窗口,不进行刷新
m_List.LockWindowUpdate();
2.设定列表不进行重画
m_List.SetRedraw(FALSE);
www.2cto.com
3.清空列表,删除历史数据
m_List.DeleteAllItems();
4.窗口解锁,允许刷新。否则系统的视图也会进行闪烁
m_List.UnlockWindowUpdate();
5.向列表中循环增加记录
m_List.InsertItems();
6.重画列表
m_List.SetRedraw(TRUE);
近期下载者:
相关文件:
收藏者: