MFC中如何对菜单栏进行操作

jokers_i 2011-07-21 02:43:44
刚开始学MFC,看到菜单栏操作,可是按照教程上的写法根本无法在VC++ 2010下运行,编译倒是可以,可是运行就出错。
代码如下:
GetMenu()->GetSubMenu(0)->GetMenuStringW(0,str,MF_BYPOSITION);
不只是这一个,所有有关CMenu类的操作都不行,我猜是因为新的MFC根本就没有采用CMenu类?在默认的单文档工程中我只找到了CMFCMenuBar 类,是不是这个原因呢?
不解中………………
...全文
606 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
兜兜很帅 2011-10-27
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 xxcc309 的回复:]

MFC是一种语言,和你用何编译器是无关的,而且好像MFC没有进行过升级之类的,所以没有新旧之分了,你应该在你代码中找一下原因,看看用法是否正确,或者将相关代码发上来让大家帮你看看。
[/Quote]

MFC是一种语言?? 哦买噶…… 第一次听说呀 哥你真强! MFC是微软的类库啊。一直在升级…… VC6.0 VS2005 VS2008 VS2010 都有自己的MFC版本,每个新的版本都会新增加很多东西!
辰岡墨竹 2011-07-29
  • 打赏
  • 举报
回复
嗯。MFC已经升级到7.0以上了,VS 2008 SP1对MFC进行了很大升级,引入了BGP的界面工具包。
你创建MFC工程时,要选择界面时选择“MFC标准”,才能是传统的代码。不支持换肤和Ribbon什么的。
因为是两年前的东西,比较新的,国外也没有出什么大部头的详细书籍。当时连MSDN的内容也不全。
现在已经完善了,不过国内书籍要跟上的话,得等两年。
你看WPS不也是到2012才转换进Ribbon界面了么?其实现在很多开发用VS 2003.NET/2005就足够了,像Ribbon、CMFCToolbar之类的引入了很多Manager来管理,很多地方文档都不全,需要一个过程吧。
jokers_i 2011-07-29
  • 打赏
  • 举报
回复
我看的就是孙鑫的教程,不过不是深入浅出MFC,还有我看过这个《深入浅出MFC》不过不是孙鑫的吧,是侯俊杰写的,也不错,不过没有视频教程。

[Quote=引用 9 楼 zhjl1200 的回复:]

看看孙鑫的深入浅出mfc吧!
[/Quote]


jokers_i 2011-07-29
  • 打赏
  • 举报
回复
说的很对啊

[Quote=引用 7 楼 ladingwen3 的回复:]

mfc是对win 32 api的封装,有兴趣自己都可以封装一个来使用,设计思路是自底而上,不是现在普遍采用的自顶而下,这点要注意。mfc有版本区别,vs2010的版本比vc6.0的新。

mfc的本质就win 32 api。

windows对窗口的调用,其实原理很简单,运行起程序a,然后程序进入消息循环,等待系统消息,系统随时监控用户的活动,当用户在程序a菜单所在坐标,点击了左键之后,……
[/Quote]
zhjl1200 2011-07-26
  • 打赏
  • 举报
回复
看看孙鑫的深入浅出mfc吧!
codetravel 2011-07-26
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 visualeleven 的回复:]
VS2010建出来的MDI、SDI和传统的VC6出来的SDI、MDI程序不一样,都是BCG类似的东西,所以不能想VC6中那么做。
[/Quote]

在创建项目的时候,第一页选择“经典菜单”,试试看。具体内在原因我不知道,但是这么做是可以的。
ladingwen3 2011-07-21
  • 打赏
  • 举报
回复
mfc是对win 32 api的封装,有兴趣自己都可以封装一个来使用,设计思路是自底而上,不是现在普遍采用的自顶而下,这点要注意。mfc有版本区别,vs2010的版本比vc6.0的新。

mfc的本质就win 32 api。

windows对窗口的调用,其实原理很简单,运行起程序a,然后程序进入消息循环,等待系统消息,系统随时监控用户的活动,当用户在程序a菜单所在坐标,点击了左键之后,系统捕捉到给这个用户的动作消息,接着经过判断发送给合适的程序,然后判断出应该发给程序a,就把这个消息,发送给程序a,程序a的消息处理程序接收到这个消息后,就选择相应的消息选项(一般是使用switch控制语句),然后执行相应消息选项下,设定的可执行代码。

其实只要将windows 程序的基本架构熟悉了,这些问题就很简单了。

国内的it教材没有什么可看的,属于食之无味,弃之可惜,就是传说中的鸡肋,而且还普遍基于vc 6.0这种古董级编译环境。

这么多年了,为什么不愿意改变呢?

那就要归功中国政府长期严格执行的应试教育了,或者直接说是愚民教育,更为贴切。把学生一只一只都驯化成了温顺的绵羊,只懂得在圈里“咩咩”温顺的叫着,用充满恐惧的眼神注视着外面的世界,心中虽然充满了疑惑,却也不敢去探寻了,因为他的探索精神早已被磨灭了,被严苛的学校教育和那精心营造的社会风气所磨灭了。

而这一切的一切,都是为了使绵羊能够永远置于他们的掌控之中,任他们鱼肉。

人为刀俎,我为鱼肉,奈何奈何。
jokers_i 2011-07-21
  • 打赏
  • 举报
回复
没有找到VC2010的MFC 教程,还得继续看VC6的。
好像教程里的都喜欢讲老的知识,而没有人愿意做一些新的教程出来,介绍一下新的东西啊。
jokers_i 2011-07-21
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 visualeleven 的回复:]

VS2010建出来的MDI、SDI和传统的VC6出来的SDI、MDI程序不一样,都是BCG类似的东西,所以不能想VC6中那么做。
[/Quote]
的确是这样啊.。.
jokers_i 2011-07-21
  • 打赏
  • 举报
回复
MFC不是升级到6.0了吗?原来VC6.0的时候不是5.0吗?我不太清楚,不过MFC也升级的吧。
MFC不是语言吧。
[Quote=引用 1 楼 xxcc309 的回复:]

MFC是一种语言,和你用何编译器是无关的,而且好像MFC没有进行过升级之类的,所以没有新旧之分了,你应该在你代码中找一下原因,看看用法是否正确,或者将相关代码发上来让大家帮你看看。
[/Quote]
我只是在默认的单文档程序中的CMainFrame类下的OnCreate函数最后添加了这么一句啊。

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CFrameWndEx::OnCreate(lpCreateStruct) == -1)
return -1;

BOOL bNameValid;
// 基于持久值设置视觉管理器和样式
OnApplicationLook(theApp.m_nAppLook);

if (!m_wndMenuBar.Create(this))
{
TRACE0("未能创建菜单栏\n");
return -1; // 未能创建
}

m_wndMenuBar.SetPaneStyle(m_wndMenuBar.GetPaneStyle() | CBRS_SIZE_DYNAMIC | CBRS_TOOLTIPS | CBRS_FLYBY);

// 防止菜单栏在激活时获得焦点
CMFCPopupMenu::SetForceMenuFocus(FALSE);

if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP | CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
!m_wndToolBar.LoadToolBar(theApp.m_bHiColorIcons ? IDR_MAINFRAME_256 : IDR_MAINFRAME))
{
TRACE0("未能创建工具栏\n");
return -1; // 未能创建
}

CString strToolBarName;
bNameValid = strToolBarName.LoadString(IDS_TOOLBAR_STANDARD);
ASSERT(bNameValid);
m_wndToolBar.SetWindowText(strToolBarName);

CString strCustomize;
bNameValid = strCustomize.LoadString(IDS_TOOLBAR_CUSTOMIZE);
ASSERT(bNameValid);
m_wndToolBar.EnableCustomizeButton(TRUE, ID_VIEW_CUSTOMIZE, strCustomize);

// 允许用户定义的工具栏操作:
InitUserToolbars(NULL, uiFirstUserToolBarId, uiLastUserToolBarId);

if (!m_wndStatusBar.Create(this))
{
TRACE0("未能创建状态栏\n");
return -1; // 未能创建
}
m_wndStatusBar.SetIndicators(indicators, sizeof(indicators)/sizeof(UINT));

// TODO: 如果您不希望工具栏和菜单栏可停靠,请删除这五行
m_wndMenuBar.EnableDocking(CBRS_ALIGN_ANY);
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockPane(&m_wndMenuBar);
DockPane(&m_wndToolBar);


// 启用 Visual Studio 2005 样式停靠窗口行为
CDockingManager::SetDockingMode(DT_SMART);
// 启用 Visual Studio 2005 样式停靠窗口自动隐藏行为
EnableAutoHidePanes(CBRS_ALIGN_ANY);

// 启用工具栏和停靠窗口菜单替换
EnablePaneMenu(TRUE, ID_VIEW_CUSTOMIZE, strCustomize, ID_VIEW_TOOLBAR);

// 启用快速(按住 Alt 拖动)工具栏自定义
CMFCToolBar::EnableQuickCustomization();

if (CMFCToolBar::GetUserImages() == NULL)
{
// 加载用户定义的工具栏图像
if (m_UserImages.Load(_T(".\\UserImages.bmp")))
{
CMFCToolBar::SetUserImages(&m_UserImages);
}
}

// 启用菜单个性化(最近使用的命令)
// TODO: 定义您自己的基本命令,确保每个下拉菜单至少有一个基本命令。
CList<UINT, UINT> lstBasicCommands;

lstBasicCommands.AddTail(ID_FILE_NEW);
lstBasicCommands.AddTail(ID_FILE_OPEN);
lstBasicCommands.AddTail(ID_FILE_SAVE);
lstBasicCommands.AddTail(ID_FILE_PRINT);
lstBasicCommands.AddTail(ID_APP_EXIT);
lstBasicCommands.AddTail(ID_EDIT_CUT);
lstBasicCommands.AddTail(ID_EDIT_PASTE);
lstBasicCommands.AddTail(ID_EDIT_UNDO);
lstBasicCommands.AddTail(ID_APP_ABOUT);
lstBasicCommands.AddTail(ID_VIEW_STATUS_BAR);
lstBasicCommands.AddTail(ID_VIEW_TOOLBAR);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_OFF_2003);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_VS_2005);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_OFF_2007_BLUE);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_OFF_2007_SILVER);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_OFF_2007_BLACK);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_OFF_2007_AQUA);
lstBasicCommands.AddTail(ID_VIEW_APPLOOK_WINDOWS_7);

CMFCToolBar::SetBasicCommands(lstBasicCommands);
/////////////////////////////////////////////////////
CString STA("");
pParentWnd->GetMenu()->GetSubMenu(0)->GetMenuStringW(0,STA,MF_BYPOSITION);
MessageBox(STA);
/////////////////////////////////////////////////////
return 0;
}

Eleven 2011-07-21
  • 打赏
  • 举报
回复
VS2010建出来的MDI、SDI和传统的VC6出来的SDI、MDI程序不一样,都是BCG类似的东西,所以不能想VC6中那么做。
jokers_i 2011-07-21
  • 打赏
  • 举报
回复
刚才看到一篇文章,说是需要在Initinstance虚函数中操作菜单栏,可是没有找到这个虚函数,于是在Create虚函数中试了试,竟然可以。
因为这个虚函数有个CWnd*的参数传递过来,估计是这个原因?
xxcc309 2011-07-21
  • 打赏
  • 举报
回复
MFC是一种语言,和你用何编译器是无关的,而且好像MFC没有进行过升级之类的,所以没有新旧之分了,你应该在你代码中找一下原因,看看用法是否正确,或者将相关代码发上来让大家帮你看看。

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧