creatediscardablebitmap

本文介绍了一个用于创建与指定设备兼容的弃用位图的函数,详细解释了其功能、参数及返回值等内容。此函数允许应用程序选择位图作为指定设备的内存设备上的当前位图。
  name="google_ads_frame" marginwidth="0" marginheight="0" src="http://pagead2.googlesyndication.com/pagead/ads?client=ca-pub-5572165936844014&dt=1193665761703&lmt=1193665780&format=336x280_as&output=html&correlator=1193665761687&url=http%3A%2F%2Fwww.codeguru.cn%2Fpublic%2Fiframe%2Fwinapiiframe.htm&color_bg=FFFFFF&color_text=000000&color_link=000000&color_url=FFFFFF&color_border=FFFFFF&ad_type=text&ga_vid=1285758818.1193665762&ga_sid=1193665762&ga_hid=111695597&flash=9&u_h=768&u_w=1024&u_ah=740&u_aw=1024&u_cd=32&u_tz=480&u_his=8&u_java=true" frameborder="0" width="336" scrolling="no" height="280" allowtransparency="allowtransparency">     函数功能:该函数创建与指定设备兼容的位图,这种位图是已淘汰的,它具有与设备一样的位/像素格式和颜色调色板。应用程序可以选择这种位图作为与指定设备兼容的内存设备的当前位图。

    函数原型:HBITMAP CreateDiscardableBitmap(HDC hdc, int nWidth, int nHeight);

    参数:

    hdc:设备环境句柄。

    nWidth:按位来指定位图的宽度。

    nHeight:按位来指定位图的高度。

    返回值:如果函数执行成功,返回值是指向位图的句柄;如果函数执行失败,那么返回值为NULL。Windows NT:若想获取更多错误信息,请调用GetLastError函数。

void ControlNet::DrawFrame(CDC*pDC,CRect&rect, double& orgx, double& orgy, double& scalex,double&scaley) { double lowx, lowy, highx, highy; MAX_(lowx, lowy, highx, highy);//求得测图区的范围 rect.DeflateRect(rect.Width()*0.1, rect.Height()*0.1); int num = 5; int dx = rect.Width() / (num); int dy = rect.Height() / (num); int tx = (highx - lowx) / num; int ty = (highy - lowy) / num; scalex = double(dy) / tx;//x方向的比例系数 scaley = double(dx) / ty;//y方向的比例系数 CRect grideRect(rect.left, rect.top, rect.left + dx * num, rect.top + dy * num);//调整矩形大小,以便于格网的绘制 orgx = grideRect.bottom; orgy = grideRect.left; CPen gridpen(PS_DASH, 0, RGB(0, 100, 200));//创建格网画笔 CPen* pOldPen = pDC->SelectObject(&gridpen); //绘制垂直线 for (int i = 0; i <= num; i++) { pDC->MoveTo(grideRect.left + i * dx, grideRect.bottom); pDC->LineTo(grideRect.left + i * dx, grideRect.top); CString str; str.Format(_T("%d"), int(lowy)+i*ty); pDC->TextOutW(grideRect.left + i * dx-10, grideRect.bottom + 10, str); if (i == 0) { pDC->MoveTo(grideRect.left, grideRect.top); pDC->LineTo(grideRect.left, grideRect.top - 30); pDC->MoveTo(grideRect.left-10, grideRect.top - 20); pDC->LineTo(grideRect.left, grideRect.top - 30); pDC->LineTo(grideRect.left + 10, grideRect.top - 20); } } //绘制水平线 for (int i = 0; i <= num; i++) { pDC->MoveTo(grideRect.left, grideRect.top+i*dy); pDC->LineTo(grideRect.right , grideRect.top + i * dy); CString str; str.Format(_T("%d"), int(lowx) + i * tx); pDC->TextOutW(grideRect.left-60, grideRect.bottom-i*dy-5, str); if (i == 0) { pDC->MoveTo(grideRect.right, grideRect.bottom); pDC->LineTo(grideRect.right+30, grideRect.bottom); pDC->MoveTo(grideRect.right+20, grideRect.bottom- 10); pDC->LineTo(grideRect.right+30, grideRect.bottom); pDC->LineTo(grideRect.right+20, grideRect.bottom+10); } } //绘制比例尺 pDC->SelectObject(pOldPen); pDC->MoveTo(grideRect.left + grideRect.Width() / 2, grideRect.bottom + 40); pDC->LineTo(grideRect.left + grideRect.Width() / 2 + 30, grideRect.bottom + 40); CString sca; sca.Format(_T("1:%d"), tx / dx); pDC->TextOutW(grideRect.left + grideRect.Width() / 2 + 40, grideRect.bottom + 30, sca); pDC->TextOutW(grideRect.right+45, grideRect.bottom-5, _T("Y")); pDC->TextOutW(grideRect.left-5, grideRect.top-45, _T("X"));
最新发布
06-26
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值