List Control

// List Control初始化,下面代码需要放在OnInitDialog()函数里面
// 设置扩展风格:正行选中
m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT | LVS_EX_GRIDLINES);
// 添加标题
m_list.InsertColumn(, _T("名称"), LVCFMT_CENTER, );
m_list.InsertColumn(, _T("PID"), LVCFMT_CENTER, );
m_list.InsertColumn(, _T("文件所在位置"), LVCFMT_CENTER, );
// ------------------------------
// 先插入一个item到列表
m_list.InsertItem(dwIndex, L"");
// 将进程名插入到item第0列
m_list.SetItemText(dwIndex, 0, pe.szExeFile);
// 将进程PID插入到item第1列
str.Format(_T("%d"), pe.th32ProcessID);
m_list.SetItemText(dwIndex, 1, str);

 // 需要用到列表里面的内容的时候,会用到下面的代码

 if (m_list.GetSelectedCount() == 1)
 {
  POSITION pos_s;
  pos_s = m_list.GetFirstSelectedItemPosition();
  int item = m_list.GetNextSelectedItem(pos_s);

  CString m_exeName;
  m_exeName = m_list.GetItemText(item, 1);
 }

如何让MFC窗口的Esc键和Enter键失效?

// 重写PreTranslateMessage函数,让程序主窗口的Enter键和Esc键失效
BOOL CFileDlg::PreTranslateMessage(MSG* pMsg)
{
// TODO: 在此添加专用代码和/或调用基类
if (pMsg->message == WM_KEYDOWN)
{
int nKey = (int)pMsg->wParam;
if (nKey == VK_RETURN || nKey == VK_ESCAPE)
{
return true;
}
}
return CDialogEx::PreTranslateMessage(pMsg);
}

如何加载菜单

CMenu m_Menu; // 最好写为类的成员变量
m_Menu.LoadMenuW(IDR_MENU1);
SetMenu(&m_Menu);
// 实现主菜单的子菜单前面的图标
CBitmap m_Bmp[2]; // 最好写为类的成员变量
m_Bmp[0].LoadBitmap(IDB_EXIT);
m_Bmp[1].LoadBitmap(IDB_ABOUT);
GetMenu()->GetSubMenu(0)->SetMenuItemBitmaps(0, MF_BYPOSITION, &m_Bmp[0], &m_Bmp[0]);
GetMenu()->GetSubMenu(1)->SetMenuItemBitmaps(0, MF_BYPOSITION, &m_Bmp[1], &m_Bmp[1]);

列表右键弹出菜单

// 定义下面要用到的cmenu对象
CMenu menu, *pSubMenu;
// 装载自定义的右键菜单
menu.LoadMenu(IDR_MENU2);
// 获取子菜单项
pSubMenu = menu.GetSubMenu();
// 实现右键菜单前面的图标
pSubMenu->SetMenuItemBitmaps(, MF_BYPOSITION, &m_subBmp[], &m_subBmp[]);
pSubMenu->SetMenuItemBitmaps(, MF_BYPOSITION, &m_subBmp[], &m_subBmp[]);
// 代表没有列表项被选中,则禁用结束进程的功能
if (pNMItemActivate->iItem == -)
{
  pSubMenu->EnableMenuItem(ID_32774, MF_BYCOMMAND | MF_DISABLED | MF_GRAYED);
}
// 获取第一个弹出菜单,所以第一个菜单必须有子菜单
// 定义一个用于确定光标位置的位置
CPoint oPoint;
//获取当前光标的位置,以便使得菜单可以跟随光标
GetCursorPos(&oPoint);
// 弹出子菜单
pSubMenu->TrackPopupMenu(TPM_LEFTALIGN, oPoint.x, oPoint.y, this);

点击按钮弹出对话框

CAbout dlg(this);
dlg.DoModal();

点击按钮打开一个选择文件对话框

// 1、打开一个文件夹选择对话框
CFileDialog dlg(TRUE);
if (dlg.DoModal() == IDOK)
{
CString path = dlg.GetFolderPath();
// 2、获取选择的文件的后缀名,判断是否是DLL
CString path1 = dlg.GetFileName();
PCTSTR FileType = PathFindExtension(path1);
if (wcscmp(FileType, L".dll") != )
{
m_Edit2.SetWindowText(L"");
return;
}
// 3、将文件路径显示到编辑框
m_Edit2.SetWindowText(path + L"\\" + path1);
}

Tab Control 第一种方法

  CProcess* pDlg = new CProcess;
CMyPE* peDlg = new CMyPE;
CMyFunction* fDlg = new CMyFunction;
CMySCMManager* sDlg = new CMySCMManager;
m_tab.AddTab(L"进程", pDlg);
m_tab.AddTab(L"PE", peDlg);
m_tab.AddTab(L"功能", fDlg);
m_tab.AddTab(L"服务", sDlg); CRect rt;
GetClientRect(rt);
rt.top += ;
rt.left += ;
rt.right -= ;
rt.bottom -= ;
// 显示进程子窗口
pDlg->MoveWindow(rt);
pDlg->ShowWindow(SW_SHOW);
// 隐藏pe子窗口
peDlg->ShowWindow(SW_HIDE);
// 隐藏功能子窗口
fDlg->ShowWindow(SW_HIDE);
// 隐藏服务窗口
sDlg->ShowWindow(SW_HIDE) // 要自定义下面的类 和函数

class CMyTabCtrl :
public CTabCtrl
{
public:
CMyTabCtrl();
~CMyTabCtrl();
// 保存tab对应的子窗口
std::vector<CWnd*> m_SubWnd;
void AddTab(const CString& title, CWnd* pSubWnd);
DECLARE_MESSAGE_MAP()
afx_msg void OnTcnSelchange(NMHDR *pNMHDR, LRESULT *pResult);
};

// 添加控件处理函数
void CMyTabCtrl::AddTab(const CString& title, CWnd* pSubWnd)
{
// 调用父类的添加选项卡的函数
CTabCtrl::InsertItem(m_SubWnd.size(), title);
m_SubWnd.push_back(pSubWnd);
// 将子窗口的父窗口设置为本窗口(选项卡)
pSubWnd->ShowWindow(SW_SHOW);
pSubWnd->SetParent(this);

CRect rt;
GetClientRect(rt);
rt.top += 20;
rt.left += 1;
rt.right -= 1;
rt.bottom -= 1;
// 显示当前选项卡对应的子窗口
if (pSubWnd != NULL)
{
pSubWnd->MoveWindow(rt);
}
}

// 切换控件处理函数
void CMyTabCtrl::OnTcnSelchange(NMHDR *pNMHDR, LRESULT *pResult)
{
// TODO: 在此添加控件通知处理程序代码
*pResult = 0;
// 获取当前选中项
DWORD dwIndex = this->GetCurSel();
// 遍历所有窗口,将子窗口都隐藏起来
for (auto&i : m_SubWnd)
{
if (i != NULL)
{
i->ShowWindow(SW_HIDE);
}
}

CRect rt;
GetClientRect(rt);
rt.top += 20;
rt.left += 1;
rt.right -= 1;
rt.bottom -= 1;
// 显示当前选项卡对应的子窗口
if (m_SubWnd[dwIndex] != NULL)
{
m_SubWnd[dwIndex]->MoveWindow(rt);
m_SubWnd[dwIndex]->ShowWindow(SW_SHOW);
}
}

Tab Control 第二种方法

CTabCtrl m_tab;
CFileview *m_fileview;
CFiletrans *m_filetrans;
// 设置Tab控件前面的图标
m_imagetab.Create(, , ILC_COLOR24 | ILC_MASK, , );
// 文件查看
m_imagetab.Add(LoadIcon(AfxGetResourceHandle(),MAKEINTRESOURCE(IDI_ICON7)));
// 文件传输
m_imagetab.Add(LoadIcon(AfxGetResourceHandle(),MAKEINTRESOURCE(IDI_ICON6)));
m_tab.SetImageList(&m_imagetab); // Tab控件插入两个节点
m_tab.InsertItem(, _T("文件查看"), );
m_tab.InsertItem(, _T("文件传输"), ); // 显示文件查看对话框
m_fileview = new CFileview(this, m_sock);
m_fileview->Create(IDD_FILEVIEW, &m_tab);
CRect m_rect;
// 获取Tab控件客户区大小到m_rect
m_tab.GetClientRect(m_rect);
// 缩小m_rect的大小
m_rect.DeflateRect(, , , );
// 移动窗口
m_fileview->MoveWindow(m_rect); // 显示文件传输对话框
m_filetrans = new CFiletrans(this, m_sock);
m_filetrans->Create(IDD_FILETRANS, &m_tab);
m_tab.GetClientRect(m_rect);
m_rect.DeflateRect(, , , );
m_filetrans->MoveWindow(m_rect); // 默认显示文件查看对话框
m_fileview->ShowWindow(SW_SHOW);
// Tab控件切换处理函数
void CFileDlg::OnSelchangeTab1(NMHDR *pNMHDR, LRESULT *pResult)
{
// TODO: 在此添加控件通知处理程序代码 // 获取所选择的焦点ID
int sel = m_tab.GetCurFocus();
switch (sel)
{
case :
{
m_fileview->ShowWindow(SW_SHOW);
m_filetrans->ShowWindow(SW_HIDE);
}
break;
case :
{
m_fileview->ShowWindow(SW_HIDE);
m_filetrans->ShowWindow(SW_SHOW);
}
break;
}
*pResult = ;
}

状态栏

// 初始化状态栏
CStatusBar m_statusbar;
BOOL hbar = m_statusbar.Create(this);
UINT b[] = { , };
// 设置分栏的个数和每个分栏的ID
hbar = m_statusbar.SetIndicators(b, );
// 设置分栏的宽度
m_statusbar.SetPaneInfo(, b[], SBPS_NORMAL, );
m_statusbar.SetPaneInfo(, b[], SBPS_NORMAL, );
// 设置分栏的文本
m_statusbar.SetPaneText(, _T(""));
m_statusbar.SetPaneText(, _T(""));
// 显示状态栏
RepositionBars(AFX_IDW_CONTROLBAR_FIRST,

MFC基础笔记的更多相关文章

  1. MFC 学习笔记

    MFC 学习笔记 一.MFC编程基础: 概述: 常用头文件: MFC控制台程序: MFC库程序: 规则库可以被各种程序所调用,扩展库只能被MFC程序调用. MFC窗口程序: 示例: MFC库中类的简介 ...

  2. Java基础笔记 – Annotation注解的介绍和使用 自定义注解

    Java基础笔记 – Annotation注解的介绍和使用 自定义注解 本文由arthinking发表于5年前 | Java基础 | 评论数 7 |  被围观 25,969 views+ 1.Anno ...

  3. php代码审计基础笔记

    出处: 九零SEC连接:http://forum.90sec.org/forum.php?mod=viewthread&tid=8059 --------------------------- ...

  4. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  5. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  6. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  7. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  8. MYSQL基础笔记(二)-SQL基本操作

    SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...

  9. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

随机推荐

  1. C之指针

    什么是指针 * 指针变量:用来存储某种数据在内存中的地址.* 世面上书籍一般把指针和指针变量的概念混在一起了.市面上的书籍说的指针指的就是指针变量 Ø *号的三种含义1. 两个数相乘int i =5; ...

  2. NIO单一长连接——dubbo通信模型实现

    转: NIO单一长连接——dubbo通信模型实现 峡客 1.2 2018.07.15 19:04* 字数 2552 阅读 6001评论 30喜欢 17 前言 前一段时间看了下dubbo,原想将dubb ...

  3. 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_15-webpack研究-webpack-dev-server-程序调试

    webpack把我们的js文件都打包了.所以不能用chrome的调试工具. 打包生成的js文件比较乱无法跟踪. 配置好了以后就可以让浏览器查看到打包后的源代码 在源代码这里加一个debuuger 这里 ...

  4. git clone https://chromium.googlesource.com/失败

    一.现象     连接着vpn,网页上可以直接打开网站,但是使用terminal 执行git clone https://chromium.googlesource.com/xxxx时,     报错 ...

  5. ehcache快速入门

    前言 JAVA缓存实现方案有很多,最基本的自己使用Map去构建缓存,或者使用memcached或Redis,但是上述两种缓存框架都要搭建服务器,而Map自行构建的缓存可能没有很高的使用效率,那么我们可 ...

  6. leetcode 区间合并

    个区间若能合并,则第一个区间的右端点一定不小于第二个区间的左端点.所以先把区间集合按照左端点从小到大进行排序,接着从第一个区间开始遍历,对每个区间执行如下操作: 1.首先保存该区间的左端点start和 ...

  7. Linux nginx 会话保持(session)

    nginx 会话保持(session)有2种算法,一种是自带IP HASH 算法,一种是基于第三方模块sticky模块来实现会话保持 1)ip_hash 简单易用,但是有如下缺点 后端服务器宕机后,s ...

  8. 基于Keras 的VGG16神经网络模型的Mnist数据集识别并使用GPU加速

    这段话放在前面:之前一种用的Pytorch,用着还挺爽,感觉挺方便的,但是在最近文献的时候,很多实验都是基于Google 的Keras的,所以抽空学了下Keras,学了之后才发现Keras相比Pyto ...

  9. 用CapsNets做电能质量扰动分类(2019-08-05)

    当下最热神经网络为CNN,2017年10月,深度学习之父Hinton发表<胶囊间的动态路由>(Capsule Networks),最近谷歌正式开源了Hinton胶囊理论代码,提出的胶囊神经 ...

  10. FMZ发明者量化平台回测机制说明

    原文连接:https://www.fmz.com/digest-topic/4009 大部分策略在实盘之前都需要回测进行验证,FMZ支持部分品种数字货币现货.期货和永续合约,以及商品期货所有品种.但发 ...