- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
读取csv文件数据内容进行图形绘制(vc描述)
读取csv文件数据内容进行图形绘制(vc++描述)根据csv文件数据内容绘图。csv文件内容包括:图形类型(横线,竖线,横半圆弧,竖半圆弧),长度(线长度,半圆半径)。根据csv文件中提供的数据,在dialog中绘制出相应的图形。如果要绘制的图形超出dialog的 x轴边界,则从x=0,y不变的坐标开始绘制该图形;如果超出了y轴边界,则从x不变,y=0坐标开始绘制。(编码要求:从csv文件读取的内容和操作使用链表类保持)。例如:csv文件内容为:(假设:a:横线,b:竖线,c:横半圆,d:竖半圆)style,length a, 50b, 50c, 25d, 25
首先要定义头文件:#include string#include iostream#include fstream#include stdlib.h#include vector#include stdio.h
using namespace std;vectorstring str_iterator ; //to deposit the data
在初始化里也可以加上如下语句:m_fileName=d:\\recordset.csv;UpdateData(FALSE);
然后在dialog中添加一个读取文件的按钮,并添加如下代码:
UpdateWindow();str_iterator.clear();
fstream istrm; //define a I/O streamstring s;int pos,i;char *store;
string name;name=m_fileName; UpdateData(TRUE);
store=(char *)name.c_str();
istrm.open(store,ios::in); //open the file by only-readif(!istrm){MessageBox(Cant open file!\n); }else{ while(!istrm.eof()){istrms; i=0;int log=1;while(log){pos = s.find(,,i); if(pos == string::npos){ //if cant findstr_iterator .push_back(s.substr(i));log=0;}else //if find the character of ,str_iterator .push_back(s.substr(i,pos-i));
i = pos+1;} }
str_iterator.pop_back(); istrm.close();UpdateWindow(); //引用OnPaint()
}
最后在OnPaint()里面添加如下的处理代码:
UpdateWindow();
CClientDC dc(this); CPen pen(PS_SOLID,1,RGB(0,0,255));CRect rect;GetClientRect(rect); dc.MoveTo(5,46); CPoint p; int var;char *ch;CWnd *pWnd = GetDlgItem(IDC_STATIC); CPen *pOldPen= dc.SelectObject(pen);int x=0;
while (x str_iterator .size()){ ch = (char*)str_iterator [x].c_str();var = atoi((char*)str_iterator [x+1].c_str()); switch(*ch){case a: // draw the horizontal line{ p=dc.GetCurrentPosition();if((p.x+var) rect.right) // 判断是否越界{ dc.MoveTo(5,p.y);}
p=dc.GetCurrentPosition();dc.LineTo(p.x+var,p.y); break;}case b: // draw the vertical line{p=dc.GetCurrentPosition();if((p.y+var) rect.bottom) // 判断是否越界{dc.MoveTo(p.x,46);}
p=dc.GetCurrentPosition();dc.LineTo(p.x,p.y+var);break;}case c: // draw the semic
您可能关注的文档
- 加工厂质量报告.ppt
- 技术讲座(第六讲).ppt
- 沅江市全面作好备汛工作确保安全度汛.doc
- 概率选择题.ppt
- 中学排球垫球教学设计.doc
- 2011年高考湖北英语试卷及答案.doc
- 人才举荐办法.doc
- 公路运输枢纽.doc
- 如何在关机时执行程序.doc
- 队列带队技巧.doc
- 2025年辽宁省抚顺市新宾满族自治县中考四模道德与法治试题(含答案).pdf
- 广东省江门市新会区江门市新会区名冠实验学校2024-2025学年高二下学期5月月考英语试题(含答案).pdf
- 江西省丰城中学2025届九年级下学期4月期中考试英语试卷(含音频).pdf
- 四川省成都市成华区某校2024-2025学年高二下学期5月期中考试英语试卷(含答案,无听力i音频及听力原文).pdf
- 山东省潍坊市2025年5月高三三模英语试卷(含答案,含听力原文无音频).pdf
- 人教版高一英语期末考试复习试题原卷版2.pdf
- 2024-2025学年七年级下学期道德与法治统编版(2024)期末达标测试卷(B卷,含解析).pdf
- 2025年山东省济宁市任城区中考二模道德与法治试题(含答案).pdf
- 广东省广州市执信中学2024-2025学年高三下学期第三次测试英语试题(含解析).pdf
- 2025年安徽省池州市中考三模道德与法治试题(含答案).pdf
文档评论(0)