MFC基础笔记
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基础笔记的更多相关文章
- MFC 学习笔记
MFC 学习笔记 一.MFC编程基础: 概述: 常用头文件: MFC控制台程序: MFC库程序: 规则库可以被各种程序所调用,扩展库只能被MFC程序调用. MFC窗口程序: 示例: MFC库中类的简介 ...
- Java基础笔记 – Annotation注解的介绍和使用 自定义注解
Java基础笔记 – Annotation注解的介绍和使用 自定义注解 本文由arthinking发表于5年前 | Java基础 | 评论数 7 | 被围观 25,969 views+ 1.Anno ...
- php代码审计基础笔记
出处: 九零SEC连接:http://forum.90sec.org/forum.php?mod=viewthread&tid=8059 --------------------------- ...
- MYSQL基础笔记(六)- 数据类型一
数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...
- MYSQL基础笔记(五)- 练习作业:站点统计练习
作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...
- MYSQL基础笔记(四)-数据基本操作
数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...
- MYSQL基础笔记(三)-表操作基础
数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...
- MYSQL基础笔记(二)-SQL基本操作
SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...
- MYSQL基础笔记(一)
关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...
随机推荐
- vue+七牛云 截图工具
1.安装:npm install vue-cropper 2.引入:import VueCropper from 'vue-cropper' Vue.use(VueCropper) <templ ...
- wm_concat()函数
转: Oracle wm_concat()函数 oracle wm_concat(column)函数使我们经常会使用到的,下面就教您如何使用oraclewm_concat(column)函数实现字段合 ...
- BUUCTF-writeup
Reverse RSA 使用openssl模块 rsa -pubin -text -modulus -in pub.key得到n值,在 factordb.com上分解大素数得到p,q值,脚本生成pri ...
- [转]Android 应用自动更新及6.0,7.0,8.0适配安装
原贴:https://www.jianshu.com/p/ea42040c7ace 原贴:https://www.jianshu.com/p/ea42040c7ace 原贴:https://www.j ...
- forge k8s/kubernetes ci/cd 最佳实践
forge的官网是: http://forge.sh forge工具是一个部署工具, 将你的应用自动更新到kubernets集群中, 只需要配置简洁的配置文件和模板即可. 其它的就交给forge, 它 ...
- 分布式开发之:id生成器
一般分布式系统开发中不建议使用数据库自带的自增ID做id. 理由: 1.不方便分库分表.(TIDB时代待商榷) 2.不利于多机房多活部署. 那么如果不使用数据库的id.那怎么生成id呢. 1. Twi ...
- springmvc项目 logback.xml配置 logstash日志收集
配置logback,需要一个转接的Appender,可以通过Maven依赖加到项目中: <dependency> <groupId>com.cwbase</groupId ...
- docker教程(1) - 快速使用
docker 笔记(1) --docker安装.获取镜像.启动容器.删除容器 一.安装 Docker 官方文档 根据官方文档整理简单流程 从Docker Hub下载mac包 运行磁盘镜像,将Docke ...
- kubernetes配置文件热更新细节
Secret与ConfigMap都是kubernetes用于文件配置的调用对象,细微的区在于Secret存储敏感信息,例如密码,OAuth token和SSH key等等,Secret更加安全和灵活. ...
- 经典卷积神经网络——AlexNet
一.网络结构 AlexNet由5层卷积层和3层全连接层组成. 论文中是把网络放在两个GPU上进行,为了方便我们仅考虑一个GPU的情况. 上图中的输入是224×224224×224,不过经过计算(224 ...