StretchBlt

StretchBlt

StretchBlt是一個函式,函式從源矩形中複製一個點陣圖到目標矩形,必要時按目標設備設定的模式進行圖像的拉伸或壓縮。StretchBlt函式將pSrcDC源設備中的點陣圖移動到目標矩形,該矩形用成員函式正在調用的設備上下文來表示。PATPAINT:通過使用布爾OR(或)操作符將源矩形區域取反後的顏色值與特定模式的顏色合併。xSrc,ySrc,nSrcWidth和nSrcHeight 參數定義了源矩形的左上角和尺寸。StretchBlt函式在記憶體中對源點陣圖進行擴展或壓縮,然後將結果拷貝到目標矩形中。

參數

BOOL StretchBlt(HDC hdcDest, int nXOriginDest, int nYOriginDest, int nWidthDest, int nHeightDest, HDC hdcSrc, int nXOriginSrc, int nYOriginSrc, int nWidthSrc, int nHeightSrc, DWORD dwRop);

hdcDest:指向目標設備環境的句柄。

nXOriginDest:指定目標矩形左上角的X軸坐標,按邏輯單位表示坐標。

nYOriginDest:指定目標矩形左上角的Y軸坐標,按邏輯單位表示坐標。

nWidthDest:指定目標矩形的寬度,按邏輯單位表示寬度。

nHeightDest:指定目標矩形的高度,按邏輯單位表示高度。

hdcSrc:指向源設備環境的句柄。

nXOriginSrc:指向源矩形區域左上角的X軸坐標,按邏輯單位表示坐標。

nYOriginSrc:指向源矩形區域左上角的Y軸坐標,按邏輯單位表示坐標。

nWidthSrc:指定源矩形的寬度,按邏輯單位表示寬度。

nHeightSrc:指定源矩形的高度,按邏輯單位表示高度。

dwRop:指定要進行的光柵操作。光柵操作碼定義了系統如何在輸出操作中組合顏色,這些操作包括刷子、源點陣圖和目標點陣圖等對象。參考BitBlt可了解常用的光柵操作碼列表。

下面列出了一些常見的光柵操作代碼:

BLACKNESS:表示使用與物理調色板的索引0相關的色彩來填充目標矩形區域,(對預設的物理調色板而言,該顏色為黑色)。

DSTINVERT:表示使目標矩形區域顏色取反。

MERGECOPY:表示使用布爾型的AND(與)操作符將源矩形區域的顏色與特定模式組合一起。

MERGEPAINT:通過使用布爾型的OR(或)操作符將反向的源矩形區域的顏色與目標矩形區域的顏色合併。

NOTSRCCOPY:將源矩形區域顏色取反,再拷貝到目標矩形區域。

NOTSRCERASE:使用布爾類型的OR(或)操作符組合源和目標矩形區域的顏色值,然後將合成的顏色取反。

PATCOPY:將特定的模式拷貝到目標點陣圖上。

PATPAINT:通過使用布爾OR(或)操作符將源矩形區域取反後的顏色值與特定模式的顏色合併。然後使用OR(或)操作符將該操作的結果與目標矩形區域內的顏色合併。

PATINVERT:通過使用XOR(異或)操作符將源和目標矩形區域內的顏色合併。

SRCAND:通過使用AND(與)操作符來將源和目標矩形區域內的顏色合併。

SRCCOPY:將源矩形區域直接拷貝到目標矩形區域。

SRCERASE:通過使用AND(與)操作符將目標矩形區域顏色取反後與源矩形區域的顏色值合併。

SRCINVERT:通過使用布爾型的XOR(異或)操作符將源和目標矩形區域的顏色合併。

SRCPAINT:通過使用布爾型的OR(或)操作符將源和目標矩形區域的顏色合併。

WHITENESS:使用與物理調色板中索引1有關的顏色填充目標矩形區域。(對於預設物理調色板來說,這個顏色就是白色)。

BOOL StretchBlt( int x, int y, int nWidth, int nHeight, CDC* pSrcDC, int xSrc, int ySrc, int nSrcWidth, int nSrcHeight, DWORD dwRop );

x:邏輯單元x軸左上角坐標;

y:邏輯單元y軸左上角坐標;

nWidth: 設備矩形寬度;

nHeight:設備矩形高度;

pSrcDC: 源設備上下文;

xSrc :源矩形x軸左上角坐標;

ySrc: 源矩形y軸左上角坐標;

Specifies the x-coordinate (in logical units) of the upper-left corner of the source rectangle.

nSrcWidth:源矩形寬度;

nSrcHeight:源矩形高度

dwRop:指定要進行的光柵操作。(和第一個函式一樣標示)

返回值

如果函式執行成功,那么返回值為非零,如果函式執行失敗,那么返回值為零。Windows NT:若想獲得更多的 錯誤信息,請調用GetLastError函式。

速查:Windows NT:3.1及以上版本;Windows:95及以上版本;Windows CE:1.0及以上版本;頭檔案:wingdi.h:庫檔案:gdi32.lib。

說明

將源矩形中的點陣圖拷貝到目標矩形中,如果有必要,可以擴展或壓縮該點陣圖使其與目標矩形尺寸吻合。函式使用目標設備上下文(由SetStretchBltMode設定)的擴展模式來決定如何擴展或壓縮點陣圖。StretchBlt函式將pSrcDC源設備中的點陣圖移動到目標矩形,該矩形用成員函式正在調用的設備上下文來表示。xSrc,ySrc,nSrcWidth和nSrcHeight 參數定義了源矩形的左上角和尺寸。x,yc,nWidth和nHeight參數定義了目標矩形的左上角和尺寸。dwRop指定的光柵操作模式說明了源點陣圖與目標設備上已經存在的點陣圖是如何組合的。如果nSrcWidth和nWidth或nSrcHeight和nHeight的符號不同,StretchBlt將為點陣圖創建一個鏡像。如果nSrcWidth和nWidth符號不同,函式沿X軸創建鏡像。如果nSrcHeight和nHeight符號不同,函式沿Y軸創建鏡像。StretchBlt函式在記憶體中對源點陣圖進行擴展或壓縮,然後將結果拷貝到目標矩形中。如果模板要與結果組合,則在擴展後的點陣圖拷貝到目標矩形後才組合。如果用到畫刷,應使用目標設備上下文中選定的畫刷。目標坐標根據目標設備上下文來轉換,源坐標根據源設備上下文來轉換。如果目標點陣圖、源點陣圖和模板點陣圖的格式不一致,StretchBlt使模板與源點陣圖匹配模板點陣圖格式,轉換中會使用到目標設備上下文中的前景色和背景色。如果要將黑白點陣圖轉換為彩色點陣圖,它將背景色設定為白位(1),前景色設定為黑位(0)。如果要將彩色點陣圖轉換為黑白點陣圖,函式設定與背景色匹配的像素為白(1),其它像素為黑(0),用到了帶顏色的設備上下文中的前景色和背景色。不是所有的設備都支持StretchBlt函式。調用帶RASTERCAPS索引的GetDeviceCaps 函式來決定是否支持StretchBlt。並檢驗為返回給RC_STRETCHBLT標記的值。

相關詞條

相關搜尋

熱門詞條

聯絡我們