• <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ù)  更多評論
              

            国产91色综合久久免费分享| 久久精品夜色噜噜亚洲A∨| 久久综合精品国产二区无码| 日韩乱码人妻无码中文字幕久久 | 亚洲狠狠婷婷综合久久蜜芽 | 久久人妻少妇嫩草AV无码蜜桃| 日本高清无卡码一区二区久久 | 久久青青草原国产精品免费| 久久久综合香蕉尹人综合网| 人妻精品久久无码区| 久久久久亚洲AV综合波多野结衣 | 久久精品国产久精国产思思| 久久精品中文字幕一区| 久久丫精品国产亚洲av不卡 | 久久久久亚洲AV片无码下载蜜桃| 精品乱码久久久久久夜夜嗨| 久久精品人人做人人妻人人玩 | 久久久久久九九99精品| 久久久国产99久久国产一| 日本精品久久久久中文字幕8| 亚洲AV成人无码久久精品老人| 久久精品亚洲精品国产欧美| 久久青青草原国产精品免费| 久久国产乱子伦免费精品| 久久精品亚洲日本波多野结衣| 日批日出水久久亚洲精品tv| 久久九九免费高清视频| 热久久国产精品| 色噜噜狠狠先锋影音久久| 亚洲国产成人久久综合一 | 99精品久久久久久久婷婷| 国内精品伊人久久久久AV影院| 伊人久久大香线蕉综合Av| 久久99精品国产麻豆宅宅| 亚洲级αV无码毛片久久精品| 国产69精品久久久久9999APGF| 国产精品中文久久久久久久| 久久www免费人成看片| 久久国产高潮流白浆免费观看| 99久久久精品免费观看国产| 国产精品久久久久9999|