Commit 3b9332a4 authored by Tony Wasserka's avatar Tony Wasserka Committed by Alexandre Julliard

d3dx9: Recognize the D3DXSPRITE_DO_NOT_ADDREF_TEXTURE flag.

parent 02e43a52
...@@ -222,7 +222,6 @@ D3DXSPRITE_OBJECTSPACE: do not change device transforms ...@@ -222,7 +222,6 @@ D3DXSPRITE_OBJECTSPACE: do not change device transforms
D3DXSPRITE_SORT_DEPTH_BACKTOFRONT: sort by position D3DXSPRITE_SORT_DEPTH_BACKTOFRONT: sort by position
D3DXSPRITE_SORT_DEPTH_FRONTTOBACK: sort by position D3DXSPRITE_SORT_DEPTH_FRONTTOBACK: sort by position
D3DXSPRITE_SORT_TEXTURE: sort by texture (so that it doesn't change too often) D3DXSPRITE_SORT_TEXTURE: sort by texture (so that it doesn't change too often)
D3DXSPRITE_DO_NOT_ADDREF_TEXTURE: don't call AddRef/Release on every Draw/Flush call
*/ */
if(This->vdecl==NULL) { if(This->vdecl==NULL) {
static const D3DVERTEXELEMENT9 elements[] = static const D3DVERTEXELEMENT9 elements[] =
...@@ -283,7 +282,8 @@ static HRESULT WINAPI ID3DXSpriteImpl_Draw(LPD3DXSPRITE iface, LPDIRECT3DTEXTURE ...@@ -283,7 +282,8 @@ static HRESULT WINAPI ID3DXSpriteImpl_Draw(LPD3DXSPRITE iface, LPDIRECT3DTEXTURE
This->sprites=HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, This->sprites, This->allocated_sprites*sizeof(SPRITE)); This->sprites=HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, This->sprites, This->allocated_sprites*sizeof(SPRITE));
} }
This->sprites[This->sprite_count].texture=texture; This->sprites[This->sprite_count].texture=texture;
IUnknown_AddRef(texture); if(!(This->flags & D3DXSPRITE_DO_NOT_ADDREF_TEXTURE))
IDirect3DTexture9_AddRef(texture);
/* Reuse the texture desc if possible */ /* Reuse the texture desc if possible */
if(This->sprite_count) { if(This->sprite_count) {
...@@ -381,8 +381,8 @@ static HRESULT WINAPI ID3DXSpriteImpl_Flush(LPD3DXSPRITE iface) ...@@ -381,8 +381,8 @@ static HRESULT WINAPI ID3DXSpriteImpl_Flush(LPD3DXSPRITE iface)
} }
HeapFree(GetProcessHeap(), 0, vertices); HeapFree(GetProcessHeap(), 0, vertices);
if(!(This->flags & D3DXSPRITE_DO_NOT_ADDREF_TEXTURE))
for(i=0;i<This->sprite_count;i++) for(i=0;i<This->sprite_count;i++)
if(This->sprites[i].texture)
IDirect3DTexture9_Release(This->sprites[i].texture); IDirect3DTexture9_Release(This->sprites[i].texture);
This->sprite_count=0; This->sprite_count=0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment