=?UTF-8?Q?Rico=20Sch=C3=BCller=20?=: d3dx9: Handle a special case in ID3DXBaseEffect::GetInt().

Alexandre Julliard julliard at winehq.org
Mon Nov 28 14:00:12 CST 2011


Module: wine
Branch: master
Commit: aaa593c094f416c9d63989c673836235d480ec93
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=aaa593c094f416c9d63989c673836235d480ec93

Author: Rico Schüller <kgbricola at web.de>
Date:   Thu Nov 24 22:36:13 2011 +0100

d3dx9: Handle a special case in ID3DXBaseEffect::GetInt().

---

 dlls/d3dx9_36/effect.c |   31 +++++++++++++++++++++++++++----
 1 files changed, 27 insertions(+), 4 deletions(-)

diff --git a/dlls/d3dx9_36/effect.c b/dlls/d3dx9_36/effect.c
index 9e0063a..3458b45 100644
--- a/dlls/d3dx9_36/effect.c
+++ b/dlls/d3dx9_36/effect.c
@@ -26,6 +26,9 @@
 #include "wingdi.h"
 #include "d3dx9_36_private.h"
 
+/* Constants for special INT/FLOAT conversation */
+#define INT_FLOAT_MULTI 255.0f
+
 WINE_DEFAULT_DEBUG_CHANNEL(d3dx);
 
 static const struct ID3DXEffectVtbl ID3DXEffect_Vtbl;
@@ -1703,11 +1706,31 @@ static HRESULT WINAPI ID3DXBaseEffectImpl_GetInt(ID3DXBaseEffect *iface, D3DXHAN
 
     TRACE("iface %p, parameter %p, n %p\n", This, parameter, n);
 
-    if (n && param && !param->element_count && param->columns == 1 && param->rows == 1)
+    if (n && param && !param->element_count)
     {
-        *n = get_int(param->type, param->data);
-        TRACE("Returning %i\n", *n);
-        return D3D_OK;
+        if (param->columns == 1 && param->rows == 1)
+        {
+            *n = get_int(param->type, param->data);
+            TRACE("Returning %i\n", *n);
+            return D3D_OK;
+        }
+
+        if (param->type == D3DXPT_FLOAT &&
+                ((param->class == D3DXPC_VECTOR && param->columns != 2)
+                || (param->class == D3DXPC_MATRIX_ROWS && param->rows != 2 && param->columns == 1)))
+        {
+            /* all components (3,4) are clamped (0,255) and put in the INT */
+            *n = (INT)(min(max(0.0f, *((FLOAT *)param->data + 2)), 1.0f) * INT_FLOAT_MULTI);
+            *n += ((INT)(min(max(0.0f, *((FLOAT *)param->data + 1)), 1.0f) * INT_FLOAT_MULTI)) << 8;
+            *n += ((INT)(min(max(0.0f, *((FLOAT *)param->data + 0)), 1.0f) * INT_FLOAT_MULTI)) << 16;
+            if (param->columns * param->rows > 3)
+            {
+                *n += ((INT)(min(max(0.0f, *((FLOAT *)param->data + 3)), 1.0f) * INT_FLOAT_MULTI)) << 24;
+            }
+
+            TRACE("Returning %i\n", *n);
+            return D3D_OK;
+        }
     }
 
     WARN("Invalid argument specified\n");




More information about the wine-cvs mailing list