mirror of
https://github.com/libretro/RetroArch
synced 2025-02-06 09:40:06 +00:00
Create d3d_device_set_render_target
This commit is contained in:
parent
30af756969
commit
8b1ae9427e
@ -563,6 +563,19 @@ void d3d_enable_blend_func(void *data)
|
|||||||
d3d_set_render_state(dev, D3DRS_ALPHABLENDENABLE, true);
|
d3d_set_render_state(dev, D3DRS_ALPHABLENDENABLE, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void d3d_device_set_render_target(LPDIRECT3DDEVICE dev, unsigned idx,
|
||||||
|
void *data)
|
||||||
|
{
|
||||||
|
LPDIRECT3DSURFACE surf = (LPDIRECT3DSURFACE)data;
|
||||||
|
#if defined(HAVE_D3D9) && !defined(__cplusplus)
|
||||||
|
IDirect3DDevice9_SetRenderTarget(dev, idx, surf);
|
||||||
|
#elif defined(HAVE_D3D8) && !defined(__cplusplus)
|
||||||
|
IDirect3DDevice8_SetRenderTarget(dev, idx, surf);
|
||||||
|
#else
|
||||||
|
dev->SetRenderTarget(idx, surf);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void d3d_enable_alpha_blend_texture_func(void *data)
|
void d3d_enable_alpha_blend_texture_func(void *data)
|
||||||
{
|
{
|
||||||
LPDIRECT3DDEVICE dev = (LPDIRECT3DDEVICE)data;
|
LPDIRECT3DDEVICE dev = (LPDIRECT3DDEVICE)data;
|
||||||
|
@ -113,8 +113,14 @@ void d3d_surface_free(void *data);
|
|||||||
bool d3d_device_get_render_target(LPDIRECT3DDEVICE dev,
|
bool d3d_device_get_render_target(LPDIRECT3DDEVICE dev,
|
||||||
unsigned idx, void **data);
|
unsigned idx, void **data);
|
||||||
|
|
||||||
|
void d3d_device_set_render_target(LPDIRECT3DDEVICE dev, unsigned idx,
|
||||||
|
void *data);
|
||||||
|
|
||||||
void d3d_set_render_state(void *data, D3DRENDERSTATETYPE state, DWORD value);
|
void d3d_set_render_state(void *data, D3DRENDERSTATETYPE state, DWORD value);
|
||||||
|
|
||||||
|
void d3d_device_set_render_target(LPDIRECT3DDEVICE dev, unsigned idx,
|
||||||
|
void *data);
|
||||||
|
|
||||||
bool d3d_reset(LPDIRECT3DDEVICE dev, D3DPRESENT_PARAMETERS *d3dpp);
|
bool d3d_reset(LPDIRECT3DDEVICE dev, D3DPRESENT_PARAMETERS *d3dpp);
|
||||||
|
|
||||||
void d3d_device_free(LPDIRECT3DDEVICE dev, LPDIRECT3D pd3d);
|
void d3d_device_free(LPDIRECT3DDEVICE dev, LPDIRECT3D pd3d);
|
||||||
|
@ -1424,7 +1424,8 @@ static bool d3d9_cg_renderchain_render(
|
|||||||
Pass *to_pass = (Pass*)&chain->passes[i + 1];
|
Pass *to_pass = (Pass*)&chain->passes[i + 1];
|
||||||
|
|
||||||
to_pass->tex->GetSurfaceLevel(0, &target);
|
to_pass->tex->GetSurfaceLevel(0, &target);
|
||||||
d3dr->SetRenderTarget(0, target);
|
|
||||||
|
d3d_device_set_render_target(d3dr, 0, (void*)target);
|
||||||
|
|
||||||
d3d9_cg_renderchain_convert_geometry(chain, &from_pass->info,
|
d3d9_cg_renderchain_convert_geometry(chain, &from_pass->info,
|
||||||
&out_width, &out_height,
|
&out_width, &out_height,
|
||||||
@ -1459,7 +1460,7 @@ static bool d3d9_cg_renderchain_render(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Final pass */
|
/* Final pass */
|
||||||
d3dr->SetRenderTarget(0, back_buffer);
|
d3d_device_set_render_target(d3dr, 0, (void*)back_buffer);
|
||||||
|
|
||||||
last_pass = (Pass*)&chain->passes.back();
|
last_pass = (Pass*)&chain->passes.back();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user