一、实验目的

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

https://github.com/shenxiaolinZERO/Resources/tree/master/Resources/Computer-Graphics/CoordinateSystem

MFC图形绘制——绘制直尺和坐标系的更多相关文章

  1. 如何在 Matlab 中绘制带箭头的坐标系

    如何在 Matlab 中绘制带箭头的坐标系 如何在 Matlab 中绘制带箭头的坐标系 实现原理 演示效果 完整代码 实现原理 使用 matlab 的绘制函数时,默认设置为一个方框形的坐标系, 图1 ...

  2. MFC 用gdi绘制填充多边形区域

    MFC 用gdi绘制填充多边形区域 这里的代码是实现一个三角形的绘制,并用刷子填充颜色 在OnPaint()函数里面 运用的是给定的三角形的三个点,很多个点可以绘制多边形 CBrush br(RGB( ...

  3. HTML5 Canvas ( 填充图形的绘制 ) closePath, fillStyle, fill

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. Quartz2D常见图形的绘制:线条、多边形、圆

    UI高级 Quartz2D http://ios.itcast.cn  iOS学院 掌握 drawRect:方法的使用 常见图形的绘制:线条.多边形.圆 绘图状态的设置:文字颜色.线宽等 图形上下文状 ...

  5. 利用XtraDiagram.DiagramControl进行流程图形的绘制和控制

    DevExpress提供了一个比较强大的图形绘制工具,可以用于绘制各种图形,如流程图.组织机构图等等,本篇随笔介绍XtraDiagram.DiagramControl的使用,以及利用代码对其属性进行控 ...

  6. MFC图形编辑器

    前言 vs2015竟然可以完美打开工程,哈哈可以直接生成类图了.由于内容较多,所以根据内容的重要性会安排详略. https://github.com/bajdcc/GraphEditor/releas ...

  7. MFC-创建MFC图形界面dll

    创建MFC图形界面dll 概述: 利用MFC的DLL框架,制作带有图形界面的dll,可以实现很多功能. 流程: 选择静态链接MFC DLL:以免有的库没有. 采用该框架创建的MFC,会自动生产一个MF ...

  8. 利用Microsoft VC++6.0 的MFC 的绘图工具实现简单图形的绘制

          MFC运算功能强大,拥有完备的绘图功能.       在Windows平台上,应用程序的图形设备接口(graphics device interface,GDI)被抽象为设备上下文(Dev ...

  9. MFC+OpenGL基础绘制<转>

    转载地址:https://blog.csdn.net/u013232740/article/details/47904115 ------------------------------------- ...

随机推荐

  1. Informatica 常用组件Source Qualifier之八 Distinct

    如果希望 PowerCenter 从源选择唯一值,您可以使用"选择相异"选项.例如,您可以使用此功能从列出总销售额的表中提取唯一客户标识.使用"选择相异"过滤器 ...

  2. go语言基础之切片的创建和截取

    1.切片的创建 示例: package main //必须有个main包 import "fmt" func main() { //切片和数组的区别 //数组[]里面的长度时固定的 ...

  3. [leetcode]Construct Binary Tree from Inorder and Postorder Traversal @ Python

    原题地址:http://oj.leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/ 题意: ...

  4. 30条技巧提高Web程序执行效率

    尽量避免使用DOM.当需要反复使用DOM时,先把对DOM的引用存到JavaScript本地变量里再使用.使用设置innerHTML的方法来替换document.createElement/append ...

  5. Java基础(十一):接口

    一.接口: 接口(英文:Interface),在JAVA编程语言中是一个抽象类型,是抽象方法的集合,接口通常以interface来声明.一个类通过继承接口的方式,从而来继承接口的抽象方法. 接口并不是 ...

  6. jquery获取元素各种宽高及页面宽高总结

    window.onload=function(){ var a = $("#div").width(),//width()返回元素的宽高,不包括padding/border/mar ...

  7. Android之PowerManager&BatteryManager

    PowerManager是Android平台中用于管理控制设备电源状态.重启.休眠状态.唤醒等,使用该API会影响到电池的待机时间,所以无非必要,一般不要使用. 在PowerManager中有几个比较 ...

  8. 编译和使用 MySQL C++ Connector

    记录编译 mysql C and C++ connector 和简单访问数据库. 环境: vs2012,  mysql 5.6.13, 基于x64 0. 软件包 mysql http://dev.my ...

  9. IT运维流程 — ITIL

    导读 在IT运维中,最有名也是最实用的流程就是ITIL.说到这里,我想大家都有过实施ITIL痛苦的经历,一定会有人说:我们没有办法实施ITIL. 问:ITIL是什么? 答:ITIL即IT基础架构库(I ...

  10. RAID5工作原理介绍

    RAID 5是一种存储性能.数据安全和存储成本兼顾的存储解决方案.以四个硬盘组成的RAID 5为例,其数据存储方式如图4所示:图中,P0为D0,D1和D2的奇偶校验信息,P1为D3,D4,D5的奇偶校 ...