2023年12月22日发(作者:)

图形画板2008设计文档

目录

1. 图形后台框架

1.1. 基本图形类框架如下:

2. 界面框架

2.1. 快捷菜单

2.2. 主菜单

2.3. 工具栏

3. 如何创建OFFICE风格的MFC工程

4. 如何在工具栏上面添加按钮

4.1. 添加菜单主项

4.2. 为菜单项添加事件

4.3. 添加Ribbon字符

4.4. 将按钮添加到工具栏

4.4.1. 创建主类别(CMFCRibbonCategory)

4.4.2. 创建面板(CMFCRibbonPanel)

4.4.3. 添加按钮(CMFCRibbonButton)到面板

1. 图形后台框架

1.1. 基本图形类框架如下:

2. 界面框架

主用应用了Visual Studio 2008 SP1添加的新增强包,可以方面的创建出像OFFCIE2007的Ribbon界面。

Ribbon工具栏是在中的void CMainFrame::InitializeRibbon()生成的

整个工具栏CMFCRibbonBar分为

2.1. 快捷菜单

2.2. 主菜单

主菜单按钮CMFCRibbonApplicationButton

主菜单CMFCRibbonMainPanel

2.3. 工具栏

主要分成3层结构:

第一层:分类(容器) CMFCRibbonCategory,如图中红色部分所示。

第二层:面板(容器) CMFCRibbonPanel ,如图中红色部分所示。

第三层:元素 CMFCRibbonBaseElem,如图中红色部分所示。

先有一个整体的概念~

3. 如何创建OFFICE风格的MFC工程

以下是创建Visual C++ 2008 SP1创建Office风格的MFC的步骤:

首先,新建项目,选择Visual C++ 中的MFC应用程序,输入名称,点击确定

接着选择Office的项目类型,MFC的使用选择“在静态库中使用MFC”(这样可以保证在任何Windows系统中都能正确运行,如果选择共享DLL,则只能在有MFC7.0库的机子上正确运行,所以推荐选“在静态库中使用MFC”)

接下来的几个步骤都直接按默认即可

这里我们先将“导航窗格”的勾去掉(由于本程序没有用到它,所以再此不详细介绍)

这里将视图类的基类选为CScrollView,点击完成

然后运行一下,基本的雏形就出来啦,简单吧~

4. 如何在工具栏上面添加按钮

4.1. 添加菜单主项

接着继续添加菜单子项,并在属性栏中设置相应的属性,注意Prompt要按照“解释n标题”这种格式,例如:Prompt绘制一个圆n画圆做完要记得保存哦

4.2. 为菜单项添加事件

右键点击需要添加事件的选项,选择添加“事件处理程序”

点击“添加编辑”,然后就到视图类的结尾找到这个事件的函数,开始编写事件,可以注意到“函数处理程序名称”是根据“命令名”自动生成的,虽然自己也可以修改,不过还是按默认的比较好,所以也说明上面提到的加入ID时候要根据这样的命名规则来命名。

4.3. 添加Ribbon字符

如下图所示在String Table中添加所有需要放到工具栏中按钮的ID及其标题,别忘了保存哦

4.4. 将按钮添加到工具栏

通过上面的准备,接下来,我们可以通过类视图定位到Ribbon初始化的位置

然后按照上1.2.3章节介绍的层次,来将按钮添加到菜单栏

4.4.1. 创建主类别(CMFCRibbonCategory)

// 为“剪贴板”面板添加“主”类别:

bNameValid = ring(IDS_RIBBON_HOME);//添加“主页"分类面板

ASSERT(bNameValid);

CMFCRibbonCategory* pCategoryHome = m_egory(strTemp,

IDB_WRITESMALL, IDB_WRITELARGE2);//创建分类页

bNameValid = ring(IDS_RIBBON_DIY);添加“自定义基本图形”主分类面板,应现在String Table中添加IDS_RIBBON_DIY及其标题

ASSERT(bNameValid);

CMFCRibbonCategory* pCategoryDIY =

m_egory(strTemp,IDB_WRITESMALL,IDB_WRITELARGE2);//创建分类IDB_WRITESMALL是小图标,IDB_WRITELARGE2是大图标,它们都是在资源里面创建的

4.4.2. 创建面板(CMFCRibbonPanel)

//创建“绘图”面板

bNameValid = ring(IDS_RIBBON_SHAPE);

ASSERT(bNameValid);

CMFCRibbonPanel* pPanelDraw = pCategoryHome->AddPanel(strTemp,

m_tIcon (7));

4.4.3. 添加按钮(CMFCRibbonButton)到面板

//添加VC直线按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_VCLINE);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_DRAW_VCLINE,strTemp,11,2));

//添加BEZIER曲线按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_BEZIER);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_DRAW_BEZIER,strTemp,12,3));

//添加矩形按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_RECTANGEL);

ASSERT(bNameValid);

pPanelDraw->Add(new

CMFCRibbonButton(ID_DRAW_RECTANGLE,strTemp,13,4));

//添加VC圆按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_VCCIRCLE);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_DRAW_VCCIRCLE,strTemp,14,5));

//添加VC椭圆按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_VCELLIPSE);

ASSERT(bNameValid);

pPanelDraw->Add(new

CMFCRibbonButton(ID_DRAW_VCELLIPSE,strTemp,15,6));

//添加多边形按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_POLYGON);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_DRAW_POLYGON,strTemp,16,7));

//添加画笔对话框按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_PENDIALOG);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_OPTIONS_PEN,strTemp));

//添加线颜色按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_COLOR);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_OPTIONS_COLOR,strTemp));

//添加填充色按钮到“绘图”面板

bNameValid=ring(IDS_RIBBON_HATCHCOLOR);

ASSERT(bNameValid);

pPanelDraw->Add(new CMFCRibbonButton(ID_OPTIONS_FILLCOLOR,strTemp));

这样,按钮就添加到工具栏中了,具体可以查看源代码