Рисование LPDIRECT3DTEXTURE9 на LPDIRECT3DSURFACE9

Есть ли в DirectX9 специальная функция, позволяющая указать, где LPD3DXSPRITE скрывает спрайт? Я пытаюсь загрузить поверхность информацией о плитке, а затем отобразить часть этой поверхности в буфер. Я понял, что с LPD3DXSPRITE :: Draw (), что нет параметра для поверхности назначения, это, вероятно, автоматически буфер. Тогда мой рисунок поверхности игрового мира покрывает спрайтов.

Есть ли решение, или я должен по-другому подойти к этой проблеме? Мне нужна прозрачность, поэтому я подумал об использовании объекта LPDIRECT3DTEXTURE9 для обработки моих спрайтов тайлов, но карта не помещается в буферном буфере, поэтому я подумал о загрузке карты на поверхность, а затем о ее рисовании.

//Filename: MyDirectX.h
//Direct3D objects
extern LPDIRECT3D9 d3d;
extern LPDIRECT3DDEVICE9 d3ddev;
extern LPDIRECT3DSURFACE9 backbuffer;
extern LPD3DXSPRITE spriteobj;

LPDIRECT3DTEXTURE9 LoadTexture(string filename, D3DCOLOR transcolor = D3DCOLOR_XRGB(0,0,0));

void DrawTile(LPDIRECT3DTEXTURE9 source, int frame, int width, int height, int columns, LPDIRECT3DSURFACE9 dest, int destx, int desty, D3DCOLOR color);
void BuildGameWorld();
void ScrollScreen();
/////////////////////////////////////////////////////////////////////////////
//Filename: MyGame.cpp
#include "MyDirectX.h"
//THIS FUNCTION HERE
void DrawTile(LPDIRECT3DTEXTURE9 source, int frame, int width, int height, int columns, LPDIRECT3DSURFACE9 dest, int destx, int desty, D3DCOLOR color)
{
//get dimensions for the tile
RECT r1;
r1.left = (frame % columns) * width;
r1.top = (frame / columns) * height;
r1.right = r1.left + width;
r1.bottom = r1.top + height;

//can only draw to the backbuffer? Any work around?
spriteobj->Draw(source, &r1, &D3DXVECTOR3(r1.right / 2, r1.bottom / 2, 0), &D3DXVECTOR3(destx, desty, 0), color);
}

void BuildGameWorld()
{
int x, y;
LPDIRECT3DTEXTURE9 tiles = nullptr;

//load the texture file
tiles = LoadTexture("goodly-2x.png", D3DCOLOR_XRGB(255, 0, 255));

spriteobj->Begin(D3DXSPRITE_ALPHABLEND);

for(y = 0; y < MAPHEIGHT; y++)
{
for(x = 0; x < MAPWIDTH; x++)
{
DrawTile(tiles, MAP_LAYER1[y * MAPWIDTH + x], 32, 32, 16, gameworld, x * 32, y * 32, D3DCOLOR_XRGB(255,255,255));
}
}

spriteobj->End();

//release the texture file
tiles->Release();
}

//Without this function, and placing BuildGameWorld() inside the Game_Run()
//rendering phase the screen displays stripes of blue which I can only
//assume is the transparent tiles working incorrectly*/
void ScrollScreen()
{
//update horizontal scrolling position and speed
ScrollX += SpeedX;
if (ScrollX < 0)
{
ScrollX = 0;
SpeedX = 0;
}
else if (ScrollX > GAMEWORLDWIDTH - SCREENW)
{
ScrollX = GAMEWORLDWIDTH - SCREENW;
SpeedX = 0;
}

//update vertical scrolling position and speed
ScrollY += SpeedY;
if (ScrollY < 0)
{
ScrollY = 0;
SpeedY = 0;
}
else if (ScrollY > GAMEWORLDHEIGHT - SCREENH)
{
ScrollY = GAMEWORLDHEIGHT - SCREENH;
SpeedY = 0;
}

//set dimensions of the source image
RECT r1 = {ScrollX, ScrollY, ScrollX+SCREENW-1,
ScrollY+SCREENH-1};

//set the destination rect
RECT r2 = {0, 0, SCREENW-1, SCREENH-1};

d3ddev->StretchRect(gameworld, &r1, backbuffer, &r2,
D3DTEXF_NONE);

}

1

Решение

Поскольку вы используете ID3DXSprite, самый простой способ указать цель рендеринга — использовать ID3DXRenderToSurface следующим образом:

// inside IDirect3DDevice9::BeginScene() / EndScene() block
ID3DXRenderToSurface::BeginScene()
ID3DXSprite::Begin()

// draw your sprites

ID3DXSprite::End()
ID3DXRenderToSurface::EndScene()
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]