本文转自网络。
vc中位图伸缩函数StretchBlt在对图片进行缩放时会造成严重的图片失真,在了解解决方法前先巩固下StretchBlt的用法:
StretchBlt
函数功能: 函数从源DC中复制一个位图到目标DC,必要时按目前目标设备设置的模式进行图像的拉伸或压缩。
参数:
hdcDest: 指向目标设备环境的句柄。
nXOriginDest:指定目标矩形左上角的X轴坐标,按逻辑单位表示坐标。
nYOriginDest:指定目标矩形左上角的Y轴坐标,按逻辑单位表示坐标。
nWidthDest: 指定目标矩形的宽度,按逻辑单位表示宽度。
nHeightDest:指定目标矩形的高度,按逻辑单位表示高度。
hdcSrc: 指向源设备环境的句柄。
nXOriginSrc:指向源矩形区域左上角的X轴坐标,按逻辑单位表示坐标。
nYOriginSrc:指向源矩形区域左上角的Y轴坐标,按逻辑单位表示坐标。
nWidthSrc: 指定源矩形的宽度,按逻辑单位表示宽度。
nHeightSrc: 指定源矩形的高度,按逻辑单位表示高度。
dwRop: 指定要进行的光栅操作。光栅操作码定义了系统如何在输出操作中组合颜色,这些操作包括刷子、源位图和目标位图等对象。参考BitBlt可了解常 用的光栅操作码列表。
dc.SetStretchBltMode(COLORONCOLOR);
或者:
SetStretchBltMode(dc,COLORONCOLOR);
深层了解:
函数原型:int SetSTretchBltMode(HDC hdc, int iStretchMode)
参数:
hdc: 设备环境句柄。
LStretchMode: 指定拉伸模式。它可以取下列值,这些值的含义如下:
BLACKONWHITE:使用消除和现在的像素颜色值进行逻辑AND(与)操作运算。如果该位图是单色位图,那么该模式以牺牲白色像素为代 价,保留黑色像素点。
COLORONCOLOR:删除像素。该模式删除所有消除的像素行,不保留其信息。
HALFTONE:将源矩形区中的像素映射到目标矩形区的像素块中,覆盖目标像素块的一般颜色与源像素的颜色接近。在设置完 HALFTONE拉伸模之后,应用程序必须调用SetBrushOrgEx函数来设置刷子的起始点。如果没有成功,那么会出现刷子 没对准的情况。
WHITEONBLACK:使用颜色值进行逻辑OR(或)操作,如果该位图为单色位图,那么该模式以牺牲黑色像素为代价,保留白色像素点。
返回值:如果函数执行成功,那么返回值就是先前的拉伸模式,如果函数执行失败,那么返回值为0。
备注:
该函数在应用程序调用StretchBit函数时定义系统如何将位图的行或列与显示设备上的现有像素点进行组合:
BLACKONWHITE和WHITEONBLACK模式用来保留单色位图中的前景像素。
COLORONCOLOR(STRETCH_DELETESCANS)模式则用于保留彩色位图中的颜色。
HALFTONE模式比上述三种模式需要对源图像进行更多的处理,也比其他模式慢,但它能产生高质量图像。也应注意在设置HALFTONE模式之后,应调用 SetBrushOrgEx函数以避免出现刷子没对准现象。