MFC图形绘制——绘制直尺和坐标系
一、实验目的
1.掌握建立MFC应用程序的方法;
2.掌握映射模式。
二、实验内容
1.在MFC中绘制直尺,直尺需要有刻度,类似于日常学生使用的透明塑料直尺,需要建立四个直尺,分别分布在屏幕客户区的上、下、左、右四个边界。尺子需要有刻度,那客户区上端的尺子距离,应该有厘米、5毫米、1毫米刻度,刻度用竖线显示,长度分别为7毫米、6毫米、5毫米,外观类似于学生直尺,右端留出一公分,防止4个尺子碰在一起。
2.画出一坐标系,给出x坐标变化范围、y坐标变化范围,画出坐标轴,并在坐标轴上标出刻度、原点,要求坐标轴充满客户区。
三、实验步骤
(一)在MFC中绘制直尺。
1.设计思路:
(1)声明客户区矩形
(2)获得客户区坐标
(3)设置映射模式
(4)分四个方向画尺子,并且通过循环画出尺子刻度
注意:
映射模式选用的是MM_LOMETRIC,其对应的坐标系特征是:每个逻辑坐标被转换为0.1 mm。正x向右,正y向上。
2.代码如下:
(1)声明客户区矩形并设置映射模式
void CRulerView::OnDraw(CDC* pDC)
{
CRulerDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: add draw code for native data here
CRect rect; //声明客户区矩形
GetClientRect(&rect); //获得客户区坐标
pDC->SetMapMode(MM_LOMETRIC); //设置映射模式为:MM_LOMETRIC,即每个逻辑坐标被转换为0.1 mm。正x向右,正y向上。
//设置实际的客户区窗口的长度和宽度范围
int height=rect.Height()*2.5;
int width=rect.Width()*2.5;
int i;
(2)画顶部的尺子
//top ruler 画顶部的尺子
//先在最上部画一条直线,作为尺子的度量边缘,从上(/左)往下(/右)画
pDC->MoveTo(,);
pDC->LineTo(width-,);
COLORREF c=RGB(,,);
//开始进行循环,画尺子的刻度
for( i=;i<width-;i+=)
{
//尺子距离为1厘米的,刻度竖线长度为7毫米
if(i%==)
{
pDC->MoveTo(i,);
pDC->LineTo(i,-);
}
//尺子距离为5毫米的,刻度竖线长度为6毫米
else if(i%==)
{
pDC->MoveTo(i,);
pDC->LineTo(i,-);
}
//尺子距离为1毫米的,刻度竖线长度为5毫米
else
{
pDC->MoveTo(i,);
pDC->LineTo(i,-);
}
}
(3)画底部的尺子
//bottom ruler 画底部的尺子
//先在底部画一条直线,作为尺子的度量边缘(从上/左往下/右画)
pDC->MoveTo(width,-height+);
pDC->LineTo(,-height+);
//开始进行循环,画尺子的刻度
for( i=;i<width-;i+=)
{ //尺子距离为1厘米的,刻度竖线长度为7毫米
if(i%==)
{
pDC->MoveTo(width-i,-height+);
pDC->LineTo(width-i,-height+);
}
//尺子距离为5毫米的,刻度竖线长度为6毫米
else if(i%==)
{
pDC->MoveTo(width-i,-height+);
pDC->LineTo(width-i,-height+);
}
//尺子距离为1毫米的,刻度竖线长度为5毫米
else
{
pDC->MoveTo(width-i,-height+);
pDC->LineTo(width-i,-height+);
}
}
(4)画左边的尺子
//left ruler 画左边的尺子
//先在最左部画一条直线,作为尺子的度量边缘(从上/左往下/右画)
pDC->MoveTo(,-height);
pDC->LineTo(,-);
//开始进行循环,画尺子的刻度
for( i=;i<height-;i+=)
{
//尺子距离为1厘米的,刻度竖线长度为7毫米
if(i%==)
{
pDC->MoveTo(,-height+i);
pDC->LineTo(,-height+i);
}
//尺子距离为5毫米的,刻度竖线长度为6毫米
else if(i%==)
{
pDC->MoveTo(,-height+i);
pDC->LineTo(,-height+i);
}
//尺子距离为1毫米的,刻度竖线长度为5毫米
else
{
pDC->MoveTo(,-height+i);
pDC->LineTo(,-height+i);
}
}
(5)画右边的尺子
//right ruler 画右边的尺子
//先在最右边画一条直线,作为尺子的度量边缘(从右往左画)
pDC->MoveTo(width,);
pDC->LineTo(width,-height+);
//开始进行循环,画尺子的刻度
for( i=;i<height-;i+=)
{
//尺子距离为1厘米的,刻度竖线长度为7毫米
if(i%==)
{
pDC->MoveTo(width,-i);
pDC->LineTo(width-,-i);
}
//尺子距离为5毫米的,刻度竖线长度为6毫米
else if(i%==)
{
pDC->MoveTo(width,-i);
pDC->LineTo(width-,-i);
}
//尺子距离为1毫米的,刻度竖线长度为5毫米
else
{
pDC->MoveTo(width,-i);
pDC->LineTo(width-,-i);
}
}
2.运行结果截图:
![]() |
(二)绘制坐标系。
1.设计思路:
(1)声明客户区矩形
(2)获得客户区坐标
(3)设置映射模式
(4)画出X轴、Y轴,并且通过循环画出坐标变化范围
注意:
映射模式选用的是MM_LOMETRIC,其对应的坐标系特征是:每个逻辑坐标被转换为0.1 mm。正x向右,正y向上。
2.代码如下:
(1)声明客户区矩形并设置映射模式
void CCoordinateSystemView::OnDraw(CDC* pDC)
{
CCoordinateSystemDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: add draw code for native data here
CRect rect;//声明客户区矩形
GetClientRect(&rect);//获得客户区坐标
int height=(int)rect.Height()*2.5;
int width=(int)rect.Width()*2.5;
int i;
pDC->SetMapMode(MM_LOMETRIC); //设置映射模式为:MM_LOMETRIC,即每个逻辑坐标被转换为0.1 mm。正x向右,正y向上。
pDC->SetWindowExt(width,height); //设置窗口
pDC->SetViewportExt(width,-height); //x轴水平向右,y轴垂直向上
//pDC->SetViewportOrg(width/2,height/2); //客户区中心为坐标系原点
(2)画X轴和Y轴
//画X轴
pDC->MoveTo(,-height/);
pDC->LineTo(width,-height/);
//画Y轴
pDC->MoveTo(width/,);
pDC->LineTo(width/,-height);
(3)画X轴和Y轴的坐标刻度
//画X轴负半轴刻度
for( i=;i<=width/;i+=)
{
pDC->MoveTo(i,-height/);
pDC->LineTo(i,-height/+);
}
//画X轴正半轴刻度
for( i=width/;i<=width;i+=)
{
pDC->MoveTo(i,-height/);
pDC->LineTo(i,-height/+);
}
//画y轴正半轴刻度
for( i=;i<=height/;i+=)
{
pDC->MoveTo(width/,i);
pDC->LineTo(width/+,i);
}
//画X轴负半轴刻度
for( i=-height/;i<=height;i+=)
{
pDC->MoveTo(width/,-i);
pDC->LineTo(width/+,-i);
}
2.运行结果截图:
![]() |
四、实验结果与讨论
(一)在MFC中绘制出的直尺如下图所示:
![]() |
(二)在MFC中绘制出的坐标系如下图所示:
![]() |
五、总结
(一)本次实验按时按量完成。
(二)通过本次实验,掌握了建立MFC应用程序的方法。
(三)通过本次实验,我掌握了映射模式及其使用。
(四)实验过程中遇到的问题及注意点:
1.客户区实际长度和宽度的设置范围应该为怎么样才能适配屏幕?
2.需要注意的是:映射模式选用的是MM_LOMETRIC,其对应的坐标系特征是:每个逻辑坐标被转换为0.1 mm。正x向右,正y向上。
参见源码:https://github.com/shenxiaolinZERO/Resources/tree/master/Resources/Computer-Graphics/ruler
MFC图形绘制——绘制直尺和坐标系的更多相关文章
- 如何在 Matlab 中绘制带箭头的坐标系
如何在 Matlab 中绘制带箭头的坐标系 如何在 Matlab 中绘制带箭头的坐标系 实现原理 演示效果 完整代码 实现原理 使用 matlab 的绘制函数时,默认设置为一个方框形的坐标系, 图1 ...
- MFC 用gdi绘制填充多边形区域
MFC 用gdi绘制填充多边形区域 这里的代码是实现一个三角形的绘制,并用刷子填充颜色 在OnPaint()函数里面 运用的是给定的三角形的三个点,很多个点可以绘制多边形 CBrush br(RGB( ...
- HTML5 Canvas ( 填充图形的绘制 ) closePath, fillStyle, fill
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Quartz2D常见图形的绘制:线条、多边形、圆
UI高级 Quartz2D http://ios.itcast.cn iOS学院 掌握 drawRect:方法的使用 常见图形的绘制:线条.多边形.圆 绘图状态的设置:文字颜色.线宽等 图形上下文状 ...
- 利用XtraDiagram.DiagramControl进行流程图形的绘制和控制
DevExpress提供了一个比较强大的图形绘制工具,可以用于绘制各种图形,如流程图.组织机构图等等,本篇随笔介绍XtraDiagram.DiagramControl的使用,以及利用代码对其属性进行控 ...
- MFC图形编辑器
前言 vs2015竟然可以完美打开工程,哈哈可以直接生成类图了.由于内容较多,所以根据内容的重要性会安排详略. https://github.com/bajdcc/GraphEditor/releas ...
- MFC-创建MFC图形界面dll
创建MFC图形界面dll 概述: 利用MFC的DLL框架,制作带有图形界面的dll,可以实现很多功能. 流程: 选择静态链接MFC DLL:以免有的库没有. 采用该框架创建的MFC,会自动生产一个MF ...
- 利用Microsoft VC++6.0 的MFC 的绘图工具实现简单图形的绘制
MFC运算功能强大,拥有完备的绘图功能. 在Windows平台上,应用程序的图形设备接口(graphics device interface,GDI)被抽象为设备上下文(Dev ...
- MFC+OpenGL基础绘制<转>
转载地址:https://blog.csdn.net/u013232740/article/details/47904115 ------------------------------------- ...
随机推荐
- Informatica 常用组件Source Qualifier之八 Distinct
如果希望 PowerCenter 从源选择唯一值,您可以使用"选择相异"选项.例如,您可以使用此功能从列出总销售额的表中提取唯一客户标识.使用"选择相异"过滤器 ...
- go语言基础之切片的创建和截取
1.切片的创建 示例: package main //必须有个main包 import "fmt" func main() { //切片和数组的区别 //数组[]里面的长度时固定的 ...
- [leetcode]Construct Binary Tree from Inorder and Postorder Traversal @ Python
原题地址:http://oj.leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/ 题意: ...
- 30条技巧提高Web程序执行效率
尽量避免使用DOM.当需要反复使用DOM时,先把对DOM的引用存到JavaScript本地变量里再使用.使用设置innerHTML的方法来替换document.createElement/append ...
- Java基础(十一):接口
一.接口: 接口(英文:Interface),在JAVA编程语言中是一个抽象类型,是抽象方法的集合,接口通常以interface来声明.一个类通过继承接口的方式,从而来继承接口的抽象方法. 接口并不是 ...
- jquery获取元素各种宽高及页面宽高总结
window.onload=function(){ var a = $("#div").width(),//width()返回元素的宽高,不包括padding/border/mar ...
- Android之PowerManager&BatteryManager
PowerManager是Android平台中用于管理控制设备电源状态.重启.休眠状态.唤醒等,使用该API会影响到电池的待机时间,所以无非必要,一般不要使用. 在PowerManager中有几个比较 ...
- 编译和使用 MySQL C++ Connector
记录编译 mysql C and C++ connector 和简单访问数据库. 环境: vs2012, mysql 5.6.13, 基于x64 0. 软件包 mysql http://dev.my ...
- IT运维流程 — ITIL
导读 在IT运维中,最有名也是最实用的流程就是ITIL.说到这里,我想大家都有过实施ITIL痛苦的经历,一定会有人说:我们没有办法实施ITIL. 问:ITIL是什么? 答:ITIL即IT基础架构库(I ...
- RAID5工作原理介绍
RAID 5是一种存储性能.数据安全和存储成本兼顾的存储解决方案.以四个硬盘组成的RAID 5为例,其数据存储方式如图4所示:图中,P0为D0,D1和D2的奇偶校验信息,P1为D3,D4,D5的奇偶校 ...



