ddraw: Update the primary stateblock in d3d_device1_SetMatrix().

Signed-off-by: Zebediah Figura <z.figura12@gmail.com>
Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Zebediah Figura 2020-01-29 19:24:44 -06:00 committed by Alexandre Julliard
parent 69a9c2be72
commit 703a290fcf
1 changed files with 29 additions and 16 deletions

View File

@ -1332,18 +1332,19 @@ static HRESULT WINAPI d3d_device1_CreateMatrix(IDirect3DDevice *iface, D3DMATRIX
* *
*****************************************************************************/ *****************************************************************************/
static HRESULT WINAPI d3d_device1_SetMatrix(IDirect3DDevice *iface, static HRESULT WINAPI d3d_device1_SetMatrix(IDirect3DDevice *iface,
D3DMATRIXHANDLE D3DMatHandle, D3DMATRIX *D3DMatrix) D3DMATRIXHANDLE matrix_handle, D3DMATRIX *matrix)
{ {
struct d3d_device *This = impl_from_IDirect3DDevice(iface); struct d3d_device *device = impl_from_IDirect3DDevice(iface);
D3DMATRIX *m; D3DMATRIX *m;
TRACE("iface %p, matrix_handle %#x, matrix %p.\n", iface, D3DMatHandle, D3DMatrix); TRACE("iface %p, matrix_handle %#x, matrix %p.\n", iface, matrix_handle, matrix);
if (!D3DMatrix) return DDERR_INVALIDPARAMS; if (!matrix)
return DDERR_INVALIDPARAMS;
wined3d_mutex_lock(); wined3d_mutex_lock();
m = ddraw_get_object(&This->handle_table, D3DMatHandle - 1, DDRAW_HANDLE_MATRIX); m = ddraw_get_object(&device->handle_table, matrix_handle - 1, DDRAW_HANDLE_MATRIX);
if (!m) if (!m)
{ {
WARN("Invalid matrix handle.\n"); WARN("Invalid matrix handle.\n");
@ -1352,21 +1353,33 @@ static HRESULT WINAPI d3d_device1_SetMatrix(IDirect3DDevice *iface,
} }
if (TRACE_ON(ddraw)) if (TRACE_ON(ddraw))
dump_D3DMATRIX(D3DMatrix); dump_D3DMATRIX(matrix);
*m = *D3DMatrix; *m = *matrix;
if (D3DMatHandle == This->world) if (matrix_handle == device->world)
wined3d_device_set_transform(This->wined3d_device, {
WINED3D_TS_WORLD_MATRIX(0), (struct wined3d_matrix *)D3DMatrix); wined3d_stateblock_set_transform(device->state,
WINED3D_TS_WORLD_MATRIX(0), (struct wined3d_matrix *)matrix);
wined3d_device_set_transform(device->wined3d_device,
WINED3D_TS_WORLD_MATRIX(0), (struct wined3d_matrix *)matrix);
}
if (D3DMatHandle == This->view) if (matrix_handle == device->view)
wined3d_device_set_transform(This->wined3d_device, {
WINED3D_TS_VIEW, (struct wined3d_matrix *)D3DMatrix); wined3d_stateblock_set_transform(device->state,
WINED3D_TS_VIEW, (struct wined3d_matrix *)matrix);
wined3d_device_set_transform(device->wined3d_device,
WINED3D_TS_VIEW, (struct wined3d_matrix *)matrix);
}
if (D3DMatHandle == This->proj) if (matrix_handle == device->proj)
wined3d_device_set_transform(This->wined3d_device, {
WINED3D_TS_PROJECTION, (struct wined3d_matrix *)D3DMatrix); wined3d_stateblock_set_transform(device->state,
WINED3D_TS_PROJECTION, (struct wined3d_matrix *)matrix);
wined3d_device_set_transform(device->wined3d_device,
WINED3D_TS_PROJECTION, (struct wined3d_matrix *)matrix);
}
wined3d_mutex_unlock(); wined3d_mutex_unlock();