C/C++ 绘制初等函数曲线图形

初等函数曲线图形的简易绘制:设屏幕显示文本是25行,80列,可以用“+”和“——〉”号画坐标系,用“*”号画曲线上的点,给出初等函数,例如cos(x),ex,x3-3x+... 初等函数曲线图形的简易绘制:设屏幕显示文本是25行,80列,可以用“+”和“——〉”号画坐标系,用“*”号画曲线上的点,给出初等函数,例如cos(x),ex, x3-3x+1,等等,还要给出x的一个估计的范围,程序就画出这个初等函数的简易图形。
这个就是原题了 一个字没少 其实要求也不是很高
平台最好是VC++6.0 语言用C或者C++
展开
 我来答
匿名用户
2011-04-20
展开全部
可以 CDC * pDC = pWnd->GetDC();
然后直接调用 CDC的成员函数实现曲线的绘制,具体看看msdn,上面有详细的说明,对于你所说的函数曲线直线片段来实现,使用for循环,递增t的值得到y的值。
打开位图BMP,使用 LoadImage 函数,MSDN上有说明,指定相应的参数即可,注意指定 LR_LOADFROMFILE 参数,返回值是图形的句柄,然后通过CDC的函数BitBlt来在设备描述符上绘制图象,
CBitmap bmp;
if (bmp.LoadBitmap(IDB_BITMAP1))
{
// Get the size of the bitmap
BITMAP bmpInfo;
bmp.GetBitmap(&bmpInfo);

// Create an in-memory DC compatible with the
// display DC we're using to paint
CDC dcMemory;
dcMemory.CreateCompatibleDC(pDC);

// Select the bitmap into the in-memory DC
CBitmap* pOldBitmap = dcMemory.SelectObject(&bmp);

// Find a centerpoint for the bitmap in the client area
CRect rect;
GetClientRect(&rect);
int nX = rect.left + (rect.Width() - bmpInfo.bmWidth) / 2;
int nY = rect.top + (rect.Height() - bmpInfo.bmHeight) / 2;

// Copy the bits from the in-memory DC into the on-
// screen DC to actually do the painting. Use the centerpoint
// we computed for the target offset.
pDC->BitBlt(nX, nY, bmpInfo.bmWidth, bmpInfo.bmHeight, &dcMemory,
0, 0, SRCCOPY);

dcMemory.SelectObject(pOldBitmap);
}
}
这段MSDN上的代码你参考一下
另外,虚机团上产品团购,超级便宜
dexahh
2011-04-19 · TA获得超过354个赞
知道答主
回答量:216
采纳率:100%
帮助的人:290万
展开全部
这个不好做,画这些的数据类型最少都要float的数据,给你的条件精度不够,画不出来
更多追问追答
追问
不是要求精确的 不然也不能用*了。。。
简易绘制~
追答
#include "math.h"
#define row 50
#define col 162
class CTGDraw
{
public:
enum ct
{
ct_bk = int(char(' ')),
ct_org = int(char('+')),
ct_x = int(char('-')),
ct_y = int(char('|')),
ct_1 = int(char('*'))
};
CTGDraw();
virtual ~CTGDraw();

BOOL SaveToFile(LPCTSTR lpzPath);
BOOL DrawCosLine();
void ClearBk();

private:
char** m_pData;
};
CTGDraw::CTGDraw()
{
m_pData = new char*[row];
int len = sizeof(char) * col;
int i;
for (i = 0; i ';
for (i = 1; i < len; ++i)
{
m_pData[w][i] = ct_x;
}
}

BOOL CTGDraw::SaveToFile(LPCTSTR lpzPath)
{
CFile file;
if(!file.Open(lpzPath,CFile::modeCreate|CFile::modeReadWrite))
return FALSE;

for (int i = 0; i < row; ++i)
{
file.Write(m_pData[i],col);
}
file.Close();
return TRUE;
}

BOOL CTGDraw::DrawCosLine()
{
int orgx = (col -2)/2;
int orgy = row/2;
double s = 0.05;
int i = 0;
double v;
int x,y;
for (;i < col-2; ++i)
{
x = i - orgx;
v = cos(x*s);
y = (int)((v/s)+0.5);
y = abs(y- orgy);
m_pData[y][i] = ct_1;
}
return TRUE;
}
///////////////////////////////////////
//只做了画Cos的方法
//调用。
CTGDraw tgd;
tgd.ClearBk();
tgd.DrawCosLine();
tgd.SaveToFile("C:\\Documents and Settings\\Administrator.PC-20101126LEDB\\桌面\\aass.txt");
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式