• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天行健 君子當(dāng)自強(qiáng)而不息

            頂點(diǎn)坐標(biāo)變換(6)

            視區(qū)變換

            視區(qū)(視口)變換是Direct3D頂點(diǎn)變換流水線的最后一步,它通過(guò)定義視區(qū)信息(屏幕顯示區(qū)域的實(shí)際寬和高等參數(shù)),完成頂點(diǎn)裁剪以及將頂點(diǎn)坐標(biāo)從投影坐標(biāo)變換為最終顯示的以像素為單位的屏幕坐標(biāo)等操作。裁剪過(guò)程保證不渲染完全在觀察平截面以外的對(duì)象,還確保對(duì)于與觀察平截面相交的對(duì)象,可以如下方式進(jìn)行渲染:即在視口指定范圍以外的部分不繪制像素。

             

            1、定義視區(qū)

            視區(qū)結(jié)構(gòu)D3DVIEWPORT9定義了Direct3D用以進(jìn)行視區(qū)變換的各項(xiàng)參數(shù):

            Defines the window dimensions of a render-target surface onto which a 3D volume projects.

            typedef struct D3DVIEWPORT9 {
            DWORD X;
            DWORD Y;
            DWORD Width;
            DWORD Height;
            float MinZ;
            float MaxZ;
            } D3DVIEWPORT9, *LPD3DVIEWPORT9;

            Members

            X
            Pixel coordinate of the upper-left corner of the viewport on the render-target surface. Unless you want to render to a subset of the surface, this member can be set to 0.
            Y
            Pixel coordinate of the upper-left corner of the viewport on the render-target surface. Unless you want to render to a subset of the surface, this member can be set to 0.
            Width
            Width dimension of the clip volume, in pixels. Unless you are rendering only to a subset of the surface, this member should be set to the width dimension of the render-target surface.
            Height
            Height dimension of the clip volume, in pixels. Unless you are rendering only to a subset of the surface, this member should be set to the height dimension of the render-target surface.
            MinZ
            Together with MaxZ, value describing the range of depth values into which a scene is to be rendered, the minimum and maximum values of the clip volume. Most applications set this value to 0.0. Clipping is performed after applying the projection matrix.
            MaxZ
            Together with MinZ, value describing the range of depth values into which a scene is to be rendered, the minimum and maximum values of the clip volume. Most applications set this value to 1.0. Clipping is performed after applying the projection matrix.

            Remarks

            The X, Y, Width, and Height members describe the position and dimensions of the viewport on the render-target surface. Usually, applications render to the entire target surface; when rendering on a 640 x 480 surface, these members should be 0, 0, 640, and 480, respectively. The MinZ and MaxZ are typically set to 0.0 and 1.0 but can be set to other values to achieve specific effects. For example, you might set them both to 0.0 to force the system to render objects to the foreground of a scene, or both to 1.0 to force the objects into the background.

            When the viewport parameters for a device change (because of a call to the IDirect3DDevice9::SetViewport method), the driver builds a new transformation matrix.

             

            2、視區(qū)設(shè)置

            使用函數(shù)IDirect3DDevice9::SetViewport()設(shè)置Direct3D的視區(qū),其聲明如下:

            HRESULT SetViewport(
            CONST D3DVIEWPORT9 * pViewport
            );

            SetViewport()的作用相當(dāng)于把投影空間的頂點(diǎn)P(x, y, z, 1)乘以下面的矩陣:

            因此,屏幕上的二維坐標(biāo)P'(x', y')的坐標(biāo)等于:

            x' = x * width/2 + startx + width/2

            y' = y * (-height/2) + starty + height/2

            z' = z * (maxz - minz) + minz

            這些坐標(biāo)被Direct3D用來(lái)進(jìn)行裁剪。

            與SetViewport()相對(duì)應(yīng),可以通過(guò)函數(shù)IDirect3DDevice9::GetViewport()獲得當(dāng)前視區(qū)的相關(guān)信息,該函數(shù)聲明如下:

            Retrieves the viewport parameters currently set for the device.

            HRESULT GetViewport(
            D3DVIEWPORT9 * pViewport
            );

            Parameters

            pViewport
            [out] Pointer to a D3DVIEWPORT9 structure, representing the returned viewport parameters.

            Return Values

            If the method succeeds, the return value is D3D_OK. D3DERR_INVALIDCALL is returned if the pViewport parameter is invalid.

            Remarks

            Typically, methods that return state will not work on a device that is created using D3DCREATE_PUREDEVICE. This method however, will work even on a pure device.

             

            3、清空視區(qū)

            一般情況下,在繪制每一幀圖形前都要先清空視區(qū),即清空渲染目標(biāo)表面上的視區(qū)矩形的內(nèi)容:顏色緩沖區(qū)、深度緩沖區(qū)或者模板緩沖區(qū)。使用函數(shù)IDirect3DDevice9::Clear()來(lái)清空視區(qū),該函數(shù)聲明如下:

            Clears one or more surfaces such as a render target, multiple render targets, a stencil buffer, and a depth buffer.

            HRESULT Clear(
            DWORD Count,
            CONST D3DRECT * pRects,
            DWORD Flags,
            D3DCOLOR Color,
            float Z,
            DWORD Stencil
            );

            Parameters

            Count
            [in] Number of rectangles in the array at pRects. Must be set to 0 if pRects is NULL. May not be 0 if pRects is a valid pointer.
            pRects
            [in] Pointer to an array of D3DRECT structures that describe the rectangles to clear. Set a rectangle to the dimensions of the rendering target to clear the entire surface. Each rectangle uses screen coordinates that correspond to points on the render target. Coordinates are clipped to the bounds of the viewport rectangle. To indicate that the entire viewport rectangle is to be cleared, set this parameter to NULL and Count to 0.
            Flags
            [in] Combination of one or more D3DCLEAR flags that specify the surface(s) that will be cleared.
            Color
            [in] Clear a render target to this ARGB color.
            Z
            [in] Clear the depth buffer to this new z value which ranges from 0 to 1. See remarks.
            Stencil
            [in] Clear the stencil buffer to this new value which ranges from 0 to 2n - 1 (n is the bit depth of the stencil buffer). See remarks.

            Return Values

            If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be: D3DERR_INVALIDCALL.

            Remarks

            Use this method to clear a surface including: a render target, all render targets in an MRT, a stencil buffer, or a depth buffer. Flags determines how many surfaces are cleared. Use pRects to clear a subset of a surface defined by an array of rectangles.

            IDirect3DDevice9::Clear will fail if you:

            • Try to clear either the depth buffer or the stencil buffer of a render target that does not have an attached depth buffer.
            • Try to clear the stencil buffer when the depth buffer does not contain stencil data.

            D3DCLEAR

            These flags identify a surface to reset when calling IDirect3DDevice9::Clear.

            #define Description
            D3DCLEAR_STENCIL Clear the stencil buffer.
            D3DCLEAR_TARGET Clear a render target, or all targets in a multiple render target. See Multiple Render Targets (Direct3D 9).
            D3DCLEAR_ZBUFFER Clear the depth buffer.

             

            獲取Direct3D坐標(biāo)變換矩陣

            在Direct3D中,可以通過(guò)IDirect3DDevice9::GetTransform()獲取當(dāng)前的世界變換矩陣、觀察變換矩陣以及投影變換矩陣,該函數(shù)聲明如下:

            Retrieves a matrix describing a transformation state.

            HRESULT GetTransform(
            D3DTRANSFORMSTATETYPE State,
            D3DMATRIX * pMatrix
            );

            Parameters

            State
            [in] Device state variable that is being modified. This parameter can be any member of the D3DTRANSFORMSTATETYPE enumerated type, or the D3DTS_WORLDMATRIX macro.
            pMatrix
            [out] Pointer to a D3DMATRIX structure, describing the returned transformation state.

            Return Values

            If the method succeeds, the return value is D3D_OK. D3DERR_INVALIDCALL if one of the arguments is invalid.

            Remarks

            This method will not return device state for a device that is created using D3DCREATE_PUREDEVICE. If you want to use this method, you must create your device with any of the other flag values in D3DCREATE.


            posted on 2008-05-02 13:54 lovedday 閱讀(1735) 評(píng)論(0)  編輯 收藏 引用

            公告

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            隨筆分類(lèi)(178)

            3D游戲編程相關(guān)鏈接

            搜索

            最新評(píng)論

            国产福利电影一区二区三区久久久久成人精品综合 | 久久精品国产只有精品2020| 人妻丰满?V无码久久不卡| 久久综合久久综合久久| 精品无码久久久久久午夜| 久久综合亚洲欧美成人| 久久婷婷五月综合成人D啪| 一本久久精品一区二区| 亚洲国产成人久久综合区| 无码8090精品久久一区| 中文字幕久久精品| 亚洲国产精品无码久久98| 一本久久知道综合久久| 亚洲成色www久久网站夜月| 欧美精品久久久久久久自慰| 国内精品久久久久影院日本| 国产精品久久久久久影院| 国产免费久久精品丫丫| 人妻无码久久精品| 久久香综合精品久久伊人| 久久久一本精品99久久精品88| 97久久国产亚洲精品超碰热| 狠狠狠色丁香婷婷综合久久俺| 久久综合狠狠色综合伊人| 免费精品久久久久久中文字幕| 久久丫忘忧草产品| 好久久免费视频高清| 欧美一级久久久久久久大| 久久久久久久91精品免费观看| 欧美一区二区三区久久综合| 亚洲国产成人久久综合一| 婷婷久久五月天| 久久成人精品视频| 国产69精品久久久久观看软件| 久久精品毛片免费观看| 久久无码人妻精品一区二区三区 | 色综合久久无码中文字幕| 久久中文字幕一区二区| 久久久亚洲裙底偷窥综合| 久久久91精品国产一区二区三区| 亚洲?V乱码久久精品蜜桃|