• <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>

            李錦俊(mybios)的blog

            游戲開發(fā) C++ Cocos2d-x OpenGL DirectX 數(shù)學(xué) 計算機圖形學(xué) SQL Server

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              86 Posts :: 0 Stories :: 370 Comments :: 0 Trackbacks

            公告

            QQ:30743734
            EMain:mybios@qq.com

            常用鏈接

            留言簿(16)

            我參與的團隊

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 371288
            • 排名 - 67

            最新評論

            閱讀排行榜

            評論排行榜

            好好的一個程序,在我的電腦(ELSA X800 256M顯卡)上運行一切正常,拿到別的電腦(845G內(nèi)置顯卡)上。啊。花屏~~趕快調(diào)試,幸好公司的電腦也有這種內(nèi)置顯卡的電腦。趕快用遠(yuǎn)程調(diào)試。誰知這一調(diào)試,就花了我整整一個上午。。。趕快寫下來。。。

            最終排差的原因是DrawIndexedPrimitiveUP最后一個參數(shù)VertexStreamZeroStride ,這個參數(shù)是用來指定頂點所占的字節(jié)數(shù)。我自作聰明的把頂點結(jié)構(gòu)后增加了一個自己用的數(shù)據(jù),如:正常的頂點結(jié)構(gòu)
            struct CUSTOMVERTEX
            {
            ?FLOAT x, y, z,rhw;
            ?DWORD color;
            ?float u,v;
            };

            我改了之后的頂點結(jié)構(gòu):
            struct CUSTOMVERTEX
            {
            ?FLOAT x, y, z,rhw;
            ?DWORD color;
            ?float u,v;
            DWORD dwMyData; // 用來保存我自己用的數(shù)據(jù)
            };

            結(jié)果,在我的顯卡上一切正常,這個數(shù)據(jù)也有用,然后DrawIndexedPrimitiveUP的時候,也會根據(jù)最后的參數(shù)sizeof(CUSTOMVERTEX)順利的讀取相應(yīng)的頂點。但是,拿到845G的內(nèi)置顯卡上就死活花屏。后來終于知道是這個原因,于是解決辦法就是把dwMyData去掉,放到頂點結(jié)構(gòu)外面去。

            順便說說DrawIndexedPrimitiveUP的用法:
            HRESULT DrawIndexedPrimitiveUP(
            ? D3DPRIMITIVETYPEPrimitiveType, // 圖原的類型
            ? UINTMinVertexIndex,? //?指定0
            ? UINTNumVertices,? // 指定需要渲染的頂點的數(shù)量(如一個矩形可以由4個頂點組成,然后通過頂點索引來達(dá)到渲染2個三角形的效果,那么這里就應(yīng)該填寫4,而不是6)
            ? UINTPrimitiveCount, // 要渲染的圖原的數(shù)量(如一個矩形,由兩個三角形組成,就應(yīng)該填寫2)
            ? CONST void *pIndexData, // 索引數(shù)據(jù)指針
            ? D3DFORMATIndexDataFormat, // 索引數(shù)據(jù)格式,一般為D3DFMT_INDEX16或D3DFMT_INDEX32?
            ? CONST void*pVertexStreamZeroData, // 頂點數(shù)據(jù)指針
            ? UINTVertexStreamZeroStride // 頂點大小一般為sizeof(頂點結(jié)構(gòu))
            );

            記得默認(rèn)情況下渲染三角形的順序是逆時針的(初學(xué)者經(jīng)常范這個錯誤,本來想渲染一個矩形,結(jié)果一個三角形順時間、另一個三角形逆時針,結(jié)果渲染出來只看到一個三角形了,被背面剔除掉了)。
            posted on 2006-12-25 15:11 李錦俊(mybios) 閱讀(4876) 評論(2)  編輯 收藏 引用 所屬分類: Direct3D

            Feedback

            # re: 硬件兼容性的陷阱,DrawIndexedPrimitiveUP的用法 2006-12-26 16:52 Konami
            老李,你好厲害啊。。。。I got it.  回復(fù)  更多評論
              

            # re: 硬件兼容性的陷阱,DrawIndexedPrimitiveUP的用法 2008-09-27 11:03 sunraiing
            我也出了和你一樣的問題

            我是6600LE,寫得東西拿去6600GT上跑就花了,也和你一樣的方法解決了一下,但是拿去intel的機器上跑,又出問題了,仍然花屏

            還得繼續(xù)解決 汗阿  回復(fù)  更多評論
              

            国产精品成人无码久久久久久| 久久中文精品无码中文字幕| 久久精品国产一区二区| 精品久久久久久久无码| 欧洲成人午夜精品无码区久久| 7777精品伊人久久久大香线蕉| 久久成人永久免费播放| 久久国产高清一区二区三区| 精品久久久久久无码中文字幕 | 久久国产精品久久国产精品| 2021久久精品国产99国产精品| 久久久久久亚洲AV无码专区| 精品国产一区二区三区久久久狼 | 97精品国产97久久久久久免费| 午夜精品久久久内射近拍高清| 久久久久18| 婷婷久久精品国产| 久久人人爽人人爽人人片av麻烦| 亚洲国产精品一区二区久久hs | 久久男人Av资源网站无码软件 | 丁香五月综合久久激情| 国产精品久久亚洲不卡动漫| 91精品国产高清91久久久久久| 97久久超碰国产精品旧版| 狠狠色伊人久久精品综合网| 奇米影视7777久久精品人人爽| 国产精品99久久久精品无码| 久久国产精品一国产精品金尊 | 亚洲国产精品无码久久九九| 国产毛片欧美毛片久久久| 欧美综合天天夜夜久久| 久久经典免费视频| 久久久精品免费国产四虎| 亚洲国产视频久久| 亚洲精品高清久久| 亚洲国产精品无码久久一线| 精品国产91久久久久久久a| 人妻精品久久久久中文字幕一冢本| 久久精品国产精品亚洲精品| 久久久久人妻一区二区三区 | 日本久久中文字幕|