博客
关于我
VC++绘制铁路道岔
阅读量:108 次
发布时间:2019-02-26

本文共 2760 字,大约阅读时间需要 9 分钟。

绘制代码;

void CDaocaView::OnDraw(CDC* pDC){    CDaocaDoc* pDoc = GetDocument();    ASSERT_VALID(pDoc);    // 画法待完成    COLORREF DaoChaColor= RGB(0,0,0);    int width = m_rect.Width() ;    int height = m_rect.Height() ;    CPen newpen(PS_SOLID,60,DaoChaColor);    CPen newpen1(PS_SOLID,60,RGB(0,255,255));    CPen *pOldPen = pDC->SelectObject(&newpen);    pDC->MoveTo(m_rect.left,(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width*0.33),(int)(m_rect.top + height*0.5));    pDC->MoveTo((int)(m_rect.left +width*0.33),(int)(m_rect.top+height*0.5));    pDC->LineTo((int)(m_rect.left +width*0.5),(int)(m_rect.top+(height*0.5+width*(sqrt(3))/6)));    pDC->MoveTo((int)(m_rect.left +width*0.67),(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width),m_rect.top+height*0.5);    m_rect.left=240;    m_rect.right=440;    pDC->MoveTo(m_rect.left,(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width/3),(int)(m_rect.top + height*0.5));    pOldPen = pDC->SelectObject(&newpen1);    pDC->MoveTo((int)(m_rect.left +width/3),(int)(m_rect.top+height*0.5));    pDC->LineTo((int)(m_rect.left +width*2/3),(int)(m_rect.top+height*0.5));    pOldPen = pDC->SelectObject(&newpen);    pDC->MoveTo((int)(m_rect.left +width*2/3),(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width),m_rect.top+height*0.5);    m_rect.left=470;    m_rect.right=670;    pDC->MoveTo(m_rect.left,(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width/3),(int)(m_rect.top + height*0.5));    pDC->MoveTo((int)(m_rect.left +width/3),(int)(m_rect.top+height*0.5));    pDC->LineTo((int)(m_rect.left +width*0.5),(int)(m_rect.top+(height*0.5 - width*(sqrt(3))/6)));    pDC->MoveTo((int)(m_rect.left +width*2/3),(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width),m_rect.top+height*0.5);    m_rect.left=700;    m_rect.right=900;    pDC->MoveTo(m_rect.left,(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width/3),(int)(m_rect.top + height*0.5));    pDC->MoveTo((int)(m_rect.left +width/3),(int)(m_rect.top+height*0.5));    pDC->LineTo((int)(m_rect.left +width/2),(int)(m_rect.top+(height*0.5 + width*(sqrt(3))/6)));    pDC->MoveTo((int)(m_rect.left +width*2/3),(int)(m_rect.top + height*0.5));    pDC->LineTo((int)(m_rect.left +width),m_rect.top+height*0.5);    pDC->SetBkMode(TRANSPARENT);    pDC->SelectObject(pOldPen);}

头文件添加一个成员变量:CRect m_rect;

初始化;

CDaocaView::CDaocaView(){    // 初始化成员变量    m_rect.left=10;    m_rect.top=10;    m_rect.right=210;    m_rect.bottom=210;}

包含<math.h>;

绘制效果如下;

代码采用了几何计算方法绘制图形,主要包括菱形和直线的绘制。通过调整坐标点的位置,画出了具有特定角度的交叉图形。图形绘制采用了透明笔触模式,并通过改变颜色进行区分。绘制完成后,重设了窗口的位置和大小。

关于道岔的问题,这里指的是铁路交叉处的道岔结构。通过代码实现的绘制效果,展示了道岔的基本构造方式及其在不同位置的几何特性。

转载地址:http://kpyy.baihongyu.com/

你可能感兴趣的文章
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO基于UDP协议的网络编程
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>