青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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

Direct3D中的字體與文本顯示(1)

圖形系統(tǒng)中為了獲得當(dāng)前運行程序的相關(guān)信息,往往需要在屏幕上顯示文本,Direct3D的功能擴(kuò)展接口ID3DXFont對此提供了方便的解決方法。

 

創(chuàng)建ID3DXFont對象

使用接口ID3DXFont繪制文本,首先需要通過函數(shù)D3DXCreateFont()創(chuàng)建ID3DXFont字體對象。ID3DXFont接口封裝了Windows字體和Direct3D設(shè)備指針,D3DXCreateFont()函數(shù)通過Windows字體和Direct3D設(shè)備指針創(chuàng)建ID3DXFont對象,該函數(shù)的聲明如下:

Creates a font object for a device and font.

HRESULT D3DXCreateFont(
LPDIRECT3DDEVICE9 pDevice,
INT Height,
UINT Width,
UINT Weight,
UINT MipLevels,
BOOL Italic,
DWORD CharSet,
DWORD OutputPrecision,
DWORD Quality,
DWORD PitchAndFamily,
LPCTSTR pFacename,
LPD3DXFONT * ppFont
);

Parameters

pDevice
[in] Pointer to an IDirect3DDevice9 interface, the device to be associated with the font object.
Height
[in] The height of the characters in logical units.
Width
[in] The width of the characters in logical units.
Weight
[in] Typeface weight. One example is bold.
MipLevels
[in] The number of mipmap levels.
Italic
[in] True for italic font, false otherwise.
CharSet
[in] The character set of the font.
OutputPrecision
[in] Specifies how Windows should attempt to match the desired font sizes and characteristics with actual fonts. Use OUT_TT_ONLY_PRECIS for instance, to ensure that you always get a TrueType font.
Quality
[in] Specifies how Windows should match the desired font with a real font. It applies to raster fonts only and should not affect TrueType fonts.
PitchAndFamily
[in] Pitch and family index.
pFacename
[in] String containing the typeface name. If the compiler settings require Unicode, the data type LPCTSTR resolves to LPCWSTR. Otherwise, the string data type resolves to LPCSTR. See Remarks.
ppFont
[out] Returns a pointer to an ID3DXFont interface, representing the created font object.

Return Values

If the function succeeds, the return value is S_OK. If the function fails, the return value can be one of the following: D3DERR_INVALIDCALL, D3DXERR_INVALIDDATA, E_OUTOFMEMORY.

Remarks

The creation of an ID3DXFont object requires that the device supports 32-bit color.

The compiler setting also determines the function version. If Unicode is defined, the function call resolves to D3DXCreateFontW. Otherwise, the function call resolves to D3DXCreateFontA because ANSI strings are being used.

If you want more information about font parameters, see The Logical Font.

示例代碼如下:

D3DXCreateFont(g_device, 50, 20, 20, 0, FALSE, DEFAULT_CHARSET, 0, 0, 0, "Arial", &g_font);

 

使用ID3DXFont對象繪制二維文本

創(chuàng)建了ID3DXFont對象后,就可以使用其接口函數(shù)ID3DXFont::DrawText()在指定位置繪制二維文本,該函數(shù)支持ANSI和雙字節(jié)字符串,聲明如下:

Draws formatted text. This method supports ANSI and Unicode strings.

INT DrawText(
LPD3DXSPRITE pSprite,
LPCTSTR pString,
INT Count,
LPRECT pRect,
DWORD Format,
D3DCOLOR Color
);

Parameters

pSprite
[in] Pointer to an ID3DXSprite object that contains the string. Can be NULL, in which case Direct3D will render the string with its own sprite object. To improve efficiency, a sprite object should be specified if ID3DXFont::DrawText is to be called more than once in a row.
pString
[in] Pointer to a string to draw.If the Count parameter is -1, the string must be null-terminated.
Count
[in] Specifies the number of characters in the string. If Count is -1, then the pString parameter is assumed to be a pointer to a null-terminated string and ID3DXFont::DrawText computes the character count automatically.
pRect
[in] Pointer to a RECT structure that contains the rectangle, in logical coordinates, in which the text is to be formatted. As with any RECT object, the coordinate value of the rectangle's right side must be greater than that of its left side. Likewise, the coordinate value of the bottom must be greater than that of the top.
Format
[in] Specifies the method of formatting the text. It can be any combination of the following values:
DT_BOTTOM
Justifies the text to the bottom of the rectangle. This value must be combined with DT_SINGLELINE.
DT_CALCRECT
Determines the width and height of the rectangle. If there are multiple lines of text, ID3DXFont::DrawText uses the width of the rectangle pointed to by the pRect parameter and extends the base of the rectangle to bound the last line of text. If there is only one line of text, ID3DXFont::DrawText modifies the right side of the rectangle so that it bounds the last character in the line. In either case, ID3DXFont::DrawText returns the height of the formatted text but does not draw the text.
DT_CENTER
Centers text horizontally in the rectangle.
DT_EXPANDTABS
Expands tab characters. The default number of characters per tab is eight.
DT_LEFT
Aligns text to the left.
DT_NOCLIP
Draws without clipping. ID3DXFont::DrawText is somewhat faster when DT_NOCLIP is used.
DT_RIGHT
Aligns text to the right.
DT_RTLREADING
Displays text in right-to-left reading order for bidirectional text when a Hebrew or Arabic font is selected. The default reading order for all text is left-to-right.
DT_SINGLELINE
Displays text on a single line only. Carriage returns and line feeds do not break the line.
DT_TOP
Top-justifies text.
DT_VCENTER
Centers text vertically (single line only).
DT_WORDBREAK
Breaks words. Lines are automatically broken between words if a word would extend past the edge of the rectangle specified by the pRect parameter. A carriage return/line feed sequence also breaks the line.
Color
[in] Color of the text. For more information, see D3DCOLOR.

Return Values

If the function succeeds, the return value is the height of the text in logical units. If DT_VCENTER or DT_BOTTOM is specified, the return value is the offset from pRect (top to the bottom) of the drawn text. If the function fails, the return value is zero.

Remarks

The parameters of this method are very similar to those of the GDI DrawText function.

This method supports both ANSI and Unicode strings.

This method must be called inside a IDirect3DDevice9::BeginScene ... IDirect3DDevice9::EndScene block. The only exception is when an application calls ID3DXFont::DrawText with DT_CALCRECT to calculate the size of a given block of text.

Unless the DT_NOCLIP format is used, this method clips the text so that it does not appear outside the specified rectangle. All formatting is assumed to have multiple lines unless the DT_SINGLELINE format is specified.

If the selected font is too large for the rectangle, this method does not attempt to substitute a smaller font.

This method supports only fonts whose escapement and orientation are both zero.

示例代碼如下:

g_device->BeginScene();

DWORD format = DT_SINGLELINE | DT_NOCLIP | DT_CENTER | DT_VCENTER;
g_font->DrawText(NULL, g_text, (INT) strlen(g_text), &g_client_rect, format, 0xFFFFFF00);

g_device->EndScene();

 

ID3DXFont其他相關(guān)接口函數(shù)

函數(shù)ID3DXFont::GetDevice()能夠獲得與ID3DXFont相關(guān)聯(lián)的Direct3D設(shè)備指針,該函數(shù)聲明如下:

Retrieves the Direct3D device associated with the font object.

HRESULT GetDevice(
LPDIRECT3DDEVICE9 * ppDevice
);

Parameters

ppDevice
[out] Address of a pointer to an IDirect3DDevice9 interface, representing the Direct3D device object associated with the font object.

Return Values

If the method succeeds, the return value is S_OK. If the method fails, the return value can be one of the following: D3DERR_INVALIDCALL, D3DXERR_INVALIDDATA.

Remarks

Note    Calling this method will increase the internal reference count on the IDirect3DDevice9 interface. Be sure to call IUnknown when you are done using this IDirect3DDevice9 interface or you will have a memory leak.

 

示例截圖:

 

源程序:

#include <D3D9.h>
#include 
<D3DX9Core.h>

#pragma warning(disable : 
4127)

#define CLASS_NAME    "GameApp"

#define release_com(p)    do { if(p) { (p)->Release(); (p) = NULL; } } while(0)

IDirect3D9
*                g_d3d;
IDirect3DDevice9
*        g_device;
ID3DXFont
*                g_font;

RECT                    g_client_rect;
const char*                g_text = "Welcome to Direct3D!";

bool init_d3d(HWND hwnd)
{
    g_d3d 
= Direct3DCreate9(D3D_SDK_VERSION);

    
if(g_d3d == NULL)
        
return false;

    D3DPRESENT_PARAMETERS d3dpp;
    ZeroMemory(
&d3dpp, sizeof(d3dpp));

    d3dpp.Windowed            
= TRUE;
    d3dpp.SwapEffect        
= D3DSWAPEFFECT_DISCARD;
    d3dpp.BackBufferFormat    
= D3DFMT_UNKNOWN;

    
if(FAILED(g_d3d->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hwnd, D3DCREATE_SOFTWARE_VERTEXPROCESSING,
                                  
&d3dpp, &g_device)))
    {
        
return false;
    }

    
/*
    D3DXCreateFontA(
        LPDIRECT3DDEVICE9       pDevice,  
        INT                     Height,
        UINT                    Width,
        UINT                    Weight,
        UINT                    MipLevels,
        BOOL                    Italic,
        DWORD                   CharSet,
        DWORD                   OutputPrecision,
        DWORD                   Quality,
        DWORD                   PitchAndFamily,
        LPCSTR                  pFaceName,
        LPD3DXFONT*             ppFont);
    
*/

    D3DXCreateFont(g_device, 
5020200, FALSE, DEFAULT_CHARSET, 000"Arial"&g_font);
        
    GetClientRect(hwnd, 
&g_client_rect);

    
return true;
}

void cleanup()
{
    release_com(g_font);
    release_com(g_device);
    release_com(g_d3d);
}

void render()
{
    g_device
->Clear(0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(555), 1.0f0);

    g_device
->BeginScene();

    DWORD format 
= DT_SINGLELINE | DT_NOCLIP | DT_CENTER | DT_VCENTER;
    g_font
->DrawText(NULL, g_text, (INT) strlen(g_text), &g_client_rect, format, 0xFFFFFF00);

    g_device
->EndScene();

    g_device
->Present(NULL, NULL, NULL, NULL);
}

LRESULT WINAPI WinProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
    
switch(msg)
    {
    
case WM_KEYDOWN:
        
if(wParam == VK_ESCAPE)
            DestroyWindow(hwnd);
        
break;

    
case WM_DESTROY:        
        PostQuitMessage(
0);
        
return 0;
    }

    
return DefWindowProc(hwnd, msg, wParam, lParam);
}

int WINAPI WinMain(HINSTANCE inst, HINSTANCE, LPSTR, INT)
{
    WNDCLASSEX wc;

    wc.cbSize            
= sizeof(WNDCLASSEX);
    wc.style            
= CS_CLASSDC;
    wc.lpfnWndProc        
= WinProc;
    wc.cbClsExtra        
= 0;
    wc.cbWndExtra        
= 0;
    wc.hInstance        
= inst;
    wc.hIcon            
= NULL;
    wc.hCursor            
= NULL;
    wc.hbrBackground    
= NULL;
    wc.lpszMenuName        
= NULL;
    wc.lpszClassName    
= CLASS_NAME;
    wc.hIconSm            
= NULL;

    
if(! RegisterClassEx(&wc))
        
return -1;

    HWND hwnd 
= CreateWindow(CLASS_NAME, "Direct3D App", WS_OVERLAPPEDWINDOW, 200100600500,
                             NULL, NULL, wc.hInstance, NULL);

    
if(hwnd == NULL)
        
return -1;

    
if(init_d3d(hwnd))
    {
        ShowWindow(hwnd, SW_SHOWDEFAULT);
        UpdateWindow(hwnd);

        MSG msg;
        ZeroMemory(
&msg, sizeof(msg));

        
while(msg.message != WM_QUIT)
        {
            
if(PeekMessage(&msg, NULL, 00, PM_REMOVE))
            {
                TranslateMessage(
&msg);
                DispatchMessage(
&msg);
            }
                
            render();
            Sleep(
10);
        }
    }

    cleanup();

    UnregisterClass(CLASS_NAME, wc.hInstance);    

    
return 0;
}

 

posted on 2008-05-11 19:26 lovedday 閱讀(4555) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導(dǎo)航

統(tǒng)計

常用鏈接

隨筆分類(178)

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

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            av成人免费| 欧美精品成人一区二区在线观看| 亚洲一区在线观看免费观看电影高清| 欧美一区二区播放| 99re8这里有精品热视频免费 | 日韩一区二区福利| 欧美bbbxxxxx| 亚洲高清自拍| 91久久久久| 亚洲精品免费一区二区三区| 久久久久免费| 欧美国产日韩一区二区| 欧美77777| 亚洲精品美女久久久久| 99精品国产热久久91蜜凸| 亚洲精品欧美精品| 亚洲伊人伊色伊影伊综合网| 亚洲一本视频| 欧美一区网站| 欧美成人有码| 国产日韩欧美在线一区| 亚洲第一伊人| 午夜精品视频| 欧美激情第3页| 亚洲综合日韩| 久久精品亚洲热| 欧美日韩一区二区免费在线观看 | 日韩视频中文| 久久久国产午夜精品| 久久一区二区视频| 欧美激情一区二区三区成人| 欧美在线一二三区| 久久婷婷丁香| 欧美va亚洲va国产综合| 男男成人高潮片免费网站| 欧美精品日韩| 国产精品亚洲综合| 亚洲黑丝在线| 久久国产精品久久国产精品| 欧美不卡在线| 亚洲欧美日本国产有色| 欧美精品三级在线观看| 国模 一区 二区 三区| 在线亚洲精品福利网址导航| 欧美一区二区三区免费观看视频| 亚洲日本欧美日韩高观看| 亚洲一区二区在线| 久久精品综合| 欧美婷婷六月丁香综合色| 亚洲欧洲在线看| 正在播放亚洲一区| 久久青草久久| 先锋影音久久久| 国产精品wwwwww| 99精品视频免费| 一区电影在线观看| 久久只精品国产| 午夜老司机精品| 欧美视频免费看| 欧美精品乱码久久久久久按摩| 激情av一区二区| 亚洲女同精品视频| 亚洲精品一区在线观看香蕉| 欧美大胆成人| 亚洲国产一区二区三区a毛片| 久久国产黑丝| 欧美中文字幕| 怡红院精品视频| 久久夜色精品国产欧美乱| 午夜一区不卡| 韩国自拍一区| 久久精品青青大伊人av| 亚洲欧美日韩国产精品| 国产亚洲欧美色| 久久久久9999亚洲精品| 欧美一区在线视频| 亚洲成人直播| 最新高清无码专区| 欧美激情导航| 亚洲一本大道在线| 亚洲一区二区三区四区中文| 国产亚洲精品久久久久婷婷瑜伽| 久久久国产一区二区| 久久久精品日韩| 免费成人在线观看视频| 欧美91视频| 亚洲电影免费观看高清完整版在线观看 | 久久精品人人做人人综合| 亚洲欧美日韩在线一区| 国产美女诱惑一区二区| 久久久国产成人精品| 久久综合久久综合九色| 99在线精品视频| 亚洲小视频在线| 在线看欧美视频| av成人国产| 国模一区二区三区| 亚洲国语精品自产拍在线观看| 国产精品男人爽免费视频1| 麻豆精品91| 国产精品久久久久aaaa| 鲁大师成人一区二区三区| 欧美激情视频给我| 午夜精品www| 麻豆乱码国产一区二区三区| 亚洲一区二区高清| 久久久久久久网| 亚洲午夜av在线| 久久理论片午夜琪琪电影网| 亚洲精品久久久久久久久久久久| 一本久久知道综合久久| 国产亚洲福利社区一区| 久久久久久91香蕉国产| 久久国产黑丝| 免费不卡在线观看| 99成人在线| 亚洲第一黄网| 亚洲一区二区三区四区五区午夜 | 亚洲电影中文字幕| 亚洲视频图片小说| 亚洲国产美女| 欧美亚洲综合久久| 国内精品视频在线播放| 久久男人av资源网站| 欧美综合第一页| 亚洲婷婷在线| 久久精品女人的天堂av| 欧美不卡视频一区发布| 欧美一区二区三区久久精品茉莉花| 亚洲影音一区| 亚洲一区www| 美女国产精品| 国产三区二区一区久久 | 亚洲国产福利在线| 国产麻豆精品视频| 美国十次成人| 在线成人免费视频| 亚洲午夜在线观看视频在线| 欧美成人高清| 久久男人av资源网站| 嫩草影视亚洲| 国产欧美日韩中文字幕在线| 久久亚洲综合色一区二区三区| 国产麻豆精品theporn| 欧美成人一区二区| 亚洲激情国产精品| 欧美一区二区网站| 欧美成人亚洲成人| 亚洲国产日日夜夜| 国产日韩综合| 久久久久国产精品厨房| 国产精品免费观看在线| 一本色道久久综合亚洲91| 亚洲一区不卡| 欧美成人精品一区二区三区| 亚洲精品久久视频| 欧美日韩视频| 91久久精品美女高潮| 亚洲特级毛片| 亚洲丰满在线| 午夜日韩电影| 国产精品嫩草99a| 久久精品30| 亚洲激情女人| 极品av少妇一区二区| 久久免费精品日本久久中文字幕| 久久综合色影院| 国产综合色产在线精品| 免费不卡中文字幕视频| 久久激五月天综合精品| 亚洲激情视频| 国产精品福利片| 99国产精品久久久久久久久久 | 久久婷婷人人澡人人喊人人爽| 在线精品国产欧美| 一区二区三区高清不卡| 一本色道精品久久一区二区三区 | 在线国产亚洲欧美| 欧美日韩成人在线| 久久成人免费电影| 久久久www| 一本色道久久综合亚洲精品不| 久久精品欧洲| 中文国产成人精品久久一| 久久久久久久久一区二区| 国产欧美午夜| 欧美日韩在线免费观看| 亚洲国产美女精品久久久久∴| 校园春色国产精品| 日韩一区二区免费高清| 噜噜噜噜噜久久久久久91| 亚洲视频在线看| 国产精品久久福利| 欧美护士18xxxxhd| 亚洲精品免费网站| 欧美国产视频在线| 久久九九免费| 亚洲人成欧美中文字幕| 影音先锋国产精品| 欧美国产第二页|