• <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>
            隨筆-341  評論-2670  文章-0  trackbacks-0

                之前一邊做腳本引擎,一邊山寨一個(gè)自繪的native C++的GUI框架并且可以切換GDI或者Direct2D渲染模式。因?yàn)槌薟PF的那種高級自動布局功能,所以必然需要知道如何測量文字大小。Direct2D測量文字大小比較麻煩,不像GDI有直接函數(shù),并且用中英文搜好像都沒人直接給出結(jié)果,還有人在博客上寫“這種事情好像辦不到”這樣的文字。不過經(jīng)過我遍歷MSDN,還是找到了一個(gè)曲線救國的方法的,直接上代碼:

                首先是創(chuàng)建IDWriteTextFormat:

             1                     IDWriteFactory* dwriteFactory=GetDirectWriteFactory();
             2                     IDWriteTextFormat* format=0;
             3                     HRESULT hr=dwriteFactory->CreateTextFormat(
             4                         fontProperties.fontFamily.Buffer(),
             5                         NULL,
             6                         (fontProperties.bold?DWRITE_FONT_WEIGHT_BOLD:DWRITE_FONT_WEIGHT_NORMAL),
             7                         (fontProperties.italic?DWRITE_FONT_STYLE_ITALIC:DWRITE_FONT_STYLE_NORMAL),
             8                         DWRITE_FONT_STRETCH_NORMAL,
             9                         (FLOAT)fontProperties.size,
            10                         L"",
            11                         &format);
            12                     if(!FAILED(hr))
            13                     {
            14                         format->SetWordWrapping(DWRITE_WORD_WRAPPING_NO_WRAP);
            15                         return format;
            16                     }
            17                     else
            18                     {
            19                         return 0;
            20                     }

                fontProperties是我自定義的一個(gè)結(jié)構(gòu)就不用去管它了,參考MSDN就知道CreateTextFormat如何使用了。其中fontProperties.fontFamily是字體的名字。然后IDWriteTextFormat就扮演著GDI的“字體對象”的角色,可以用ID2D1RenderTarget進(jìn)行繪制。ID2D1RenderTarget除了用IDWriteTextFormat當(dāng)字體以外,還可以用IDWriteTextLayout當(dāng)“添加多余信息的更復(fù)雜的字體”。測量文字的關(guān)鍵正是在這里。

                接下來我們借助IDWriteTextFormat來創(chuàng)建IDWriteTextLayout:

             1                     IDWriteTextLayout* textLayout=0;
             2                     HRESULT hr=GetDirectWriteFactory()->CreateTextLayout(
             3                         oldText.Buffer(),
             4                         oldText.Length(),
             5                         textFormat,
             6                         0,
             7                         0,
             8                         &textLayout);
             9                     if(!FAILED(hr))
            10                     {
            11                         DWRITE_TEXT_METRICS metrics;
            12                         hr=textLayout->GetMetrics(&metrics);
            13                         if(!FAILED(hr))
            14                         {
            15                             minSize=Size((int)ceil(metrics.widthIncludingTrailingWhitespace), (int)ceil(metrics.height));
            16                         }
            17                         textLayout->Release();
            18                         return;
            19                     }

                這里看minSize就知道如何測量文字的字體了。

                在這里放一張暫時(shí)的圖片。我抄了WPF的那種方法,從布局和繪圖元素直接開始可以構(gòu)造GUI,因此演示了如何使用這些東西來創(chuàng)造一個(gè)Win7的按鈕(帶動畫的哦)打開Vczh Library++3.0,下載代碼并打開Candidate\GUI\GuiDemo\GuiDemo.sln,按F5就可以看到了效果了:



                這一個(gè)是Direct2D渲染的結(jié)果(我在工程文件指定了DXSDK的絕對路徑,如果你們安裝的地方不同改掉它既可編譯了)。按鈕基本上跟win7的效果一摸一樣,但是這里使用Direct2D進(jìn)行渲染。當(dāng)按鈕尺寸變化的時(shí)候,那個(gè)復(fù)雜的邊框和里面的兩個(gè)漸變和文字都可以自動對齊——但是這并不是hard code的,而是GUI的“布局功能”可以配置成這個(gè)樣子。像這兩個(gè)按鈕一直處于右下角也是“布局功能”可以提供的功能。大家可以理解為這東西類似于C#的TableLayoutPanel。

                現(xiàn)在剛剛做好了按鈕——跟WPF一樣可以更換template,不過因?yàn)榉凑龥]人需要動態(tài)更換template所以我把template寫在了構(gòu)造函數(shù)里面,因此換膚這種事情就變得相當(dāng)簡單了——只要用布局功能跟圖元拼湊成一個(gè)復(fù)雜的圖形,然后實(shí)現(xiàn)各個(gè)控件所規(guī)定的“template接口”響應(yīng)外觀控制的消息就行了,內(nèi)置動畫支持(這個(gè)要運(yùn)行的時(shí)候才能觀察到)。

                為了方便,我在工程里面除了Debug和Release以外還加入了DebugDirect2D和ReleaseDirect2D兩個(gè)配置,可以自由切換觀看demo。


            posted on 2011-10-11 07:42 陳梓瀚(vczh) 閱讀(5535) 評論(11)  編輯 收藏 引用 所屬分類: 2D

            評論:
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-11 17:08 | phoenixbing
            終于更新博客了,沒有重磅炸彈來點(diǎn)小品文也行  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-11 18:25 | DiryBoy
            一直覺得WPF Layout的Measure和Arrange兩個(gè)方法好坑爹  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-11 19:31 | 陳梓瀚(vczh)
            @phoenixbing
            重磅炸彈豈能天天有,現(xiàn)在不像讀書那會兒了,這個(gè)博客在08和09年的時(shí)候幾乎每一兩天就更新……  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-11 19:32 | 陳梓瀚(vczh)
            @DiryBoy
            其實(shí),我也是這么做的,因?yàn)閷?shí)在想不出更好的——唯一的改變就是我沒有把a(bǔ)rrange的結(jié)果存下來,每次都重新算不過反正很快,啊哈哈哈  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-11 19:36 | megax
            DirectWrite  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2011-10-12 11:55 | sblz
            XP選手表示D2D毫無鴨梨,用不到。。。  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2012-01-11 18:32 | lidongwei
            你好,我有一部份代碼要從GDI 上轉(zhuǎn)到 Direct2d上,但用到了SetROP2函數(shù),
            查了很長時(shí)間,Direct2d好像沒有直接支持光柵操作的函數(shù),所以請教下:Direct2d里怎么能實(shí)現(xiàn)類似于SetROP2的操作。謝謝了。  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2012-01-11 19:51 | 陳梓瀚(vczh)
            @lidongwei
            因?yàn)樵陲@卡里默認(rèn)都是浮點(diǎn)運(yùn)算(哪怕是RGBA也會每一個(gè)通道都轉(zhuǎn)換成0-1的float)所以我覺得沒戲了……除非把那一部分在D3D做,然后你自己寫shader做ROP。  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2012-01-12 01:16 | lidongwei
            @陳梓瀚(vczh)
            謝謝。我去研究研究 像素著色器的東西。  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2013-02-14 18:10 | defined(LIUNX)
            LZNB..不錯(cuò)此標(biāo)題讓我們這些菜鳥何堪,不過話說測量字體貌似不止一種方法,只要對點(diǎn)陣字庫進(jìn)行解碼且檢測每個(gè)文字的邊緣幾個(gè)測出字體的大小,因?yàn)樽煮w就想birmap一樣也是按位點(diǎn)真存儲的,因此根據(jù)存儲在字庫中的每一位(用動態(tài)數(shù)組(vector array[向量數(shù)組])將每一位按位存儲FB之后判斷FB中得register的MAX_WIDTH/MAX_HEIGHT應(yīng)該也行)..表設(shè)計(jì)哦本人菜鳥還沒學(xué)到FreeType..D3D也還沒開始接觸,還多指教(就是覺得標(biāo)題有點(diǎn)刺眼)  回復(fù)  更多評論
              
            # re: 偶爾發(fā)布一下弱智知識——如何用Direct2D測量文字大小 2013-03-08 16:45 | 陳梓瀚(vczh)
            @defined(LIUNX)
            我很想跟你說,文字其實(shí)是一堆bezier曲線,只有當(dāng)size很小的時(shí)候才是保存點(diǎn)陣的。  回復(fù)  更多評論
              
            精品多毛少妇人妻AV免费久久| 久久99久久99小草精品免视看| 久久久久久毛片免费看| 久久露脸国产精品| 国产亚洲精久久久久久无码77777| 欧美黑人激情性久久| 亚洲国产精品久久久久网站| 久久青青国产| 久久精品国产第一区二区三区 | 99久久精品国产毛片| 无码人妻久久一区二区三区蜜桃| 亚洲精品无码久久久影院相关影片| 久久精品国产亚洲AV高清热 | 99久久777色| 久久婷婷五月综合成人D啪| 午夜久久久久久禁播电影| 久久九九有精品国产23百花影院| 久久综合色区| 久久亚洲精品中文字幕三区| 久久精品中文字幕一区| 99久久亚洲综合精品成人| 国产成人无码精品久久久性色| 国产精品熟女福利久久AV| 久久国产色AV免费看| 色综合久久天天综线观看| 国产精品嫩草影院久久| 国产综合久久久久| 蜜臀av性久久久久蜜臀aⅴ| 日产精品久久久久久久| 国产成人综合久久精品尤物| 1000部精品久久久久久久久| 日韩精品久久久肉伦网站| 一极黄色视频久久网站| 色99久久久久高潮综合影院| 国产精久久一区二区三区| 伊人久久大香线焦综合四虎| 久久久久久久人妻无码中文字幕爆| 午夜久久久久久禁播电影| 亚洲va久久久噜噜噜久久狠狠 | 国产亚洲美女精品久久久| av国内精品久久久久影院|