Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
dba1304b
Commit
dba1304b
authored
Jan 25, 2019
by
Matteo Bruni
Committed by
Alexandre Julliard
Jan 25, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
d3dx9: Improve D3DXMatrixTransformation2D().
Signed-off-by:
Matteo Bruni
<
mbruni@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
f54260a7
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
62 deletions
+36
-62
math.c
dlls/d3dx9_36/math.c
+36
-62
No files found.
dlls/d3dx9_36/math.c
View file @
dba1304b
...
@@ -810,79 +810,53 @@ D3DXMATRIX * WINAPI D3DXMatrixTransformation(D3DXMATRIX *out, const D3DXVECTOR3
...
@@ -810,79 +810,53 @@ D3DXMATRIX * WINAPI D3DXMatrixTransformation(D3DXMATRIX *out, const D3DXVECTOR3
return
out
;
return
out
;
}
}
D3DXMATRIX
*
WINAPI
D3DXMatrixTransformation2D
(
D3DXMATRIX
*
pout
,
const
D3DXVECTOR2
*
pscalingcenter
,
FLOAT
scalingrotation
,
const
D3DXVECTOR2
*
pscaling
,
const
D3DXVECTOR2
*
protationcenter
,
FLOAT
rotation
,
const
D3DXVECTOR2
*
ptranslation
)
static
void
vec3_from_vec2
(
D3DXVECTOR3
*
v3
,
const
D3DXVECTOR2
*
v2
)
{
{
D3DXQUATERNION
rot
,
sca_rot
;
if
(
!
v2
)
D3DXVECTOR3
rot_center
,
sca
,
sca_center
,
trans
;
return
;
TRACE
(
"pout %p, pscalingcenter %p, scalingrotation %f, pscaling %p, protztioncenter %p, rotation %f, ptranslation %p
\n
"
,
v3
->
x
=
v2
->
x
;
pout
,
pscalingcenter
,
scalingrotation
,
pscaling
,
protationcenter
,
rotation
,
ptranslation
);
v3
->
y
=
v2
->
y
;
v3
->
z
=
0
.
0
f
;
}
if
(
pscalingcenter
)
D3DXMATRIX
*
WINAPI
D3DXMatrixTransformation2D
(
D3DXMATRIX
*
out
,
const
D3DXVECTOR2
*
scaling_center
,
{
float
scaling_rotation
,
const
D3DXVECTOR2
*
scaling
,
const
D3DXVECTOR2
*
rotation_center
,
sca_center
.
x
=
pscalingcenter
->
x
;
float
rotation
,
const
D3DXVECTOR2
*
translation
)
sca_center
.
y
=
pscalingcenter
->
y
;
{
sca_center
.
z
=
0
.
0
f
;
D3DXVECTOR3
r_c
,
s
,
s_c
,
t
;
}
D3DXQUATERNION
r
,
s_r
;
else
{
sca_center
.
x
=
0
.
0
f
;
sca_center
.
y
=
0
.
0
f
;
sca_center
.
z
=
0
.
0
f
;
}
if
(
pscaling
)
TRACE
(
"out %p, scaling_center %p, scaling_rotation %.8e, scaling %p, rotation_center %p, "
{
"rotation %.8e, translation %p.
\n
"
,
sca
.
x
=
pscaling
->
x
;
out
,
scaling_center
,
scaling_rotation
,
scaling
,
rotation_center
,
rotation
,
translation
);
sca
.
y
=
pscaling
->
y
;
sca
.
z
=
1
.
0
f
;
}
else
{
sca
.
x
=
1
.
0
f
;
sca
.
y
=
1
.
0
f
;
sca
.
z
=
1
.
0
f
;
}
if
(
protationcenter
)
vec3_from_vec2
(
&
s_c
,
scaling_center
);
{
vec3_from_vec2
(
&
s
,
scaling
);
rot_center
.
x
=
protationcenter
->
x
;
if
(
scaling
)
rot_center
.
y
=
protationcenter
->
y
;
s
.
z
=
1
.
0
f
;
rot_center
.
z
=
0
.
0
f
;
vec3_from_vec2
(
&
r_c
,
rotation_center
);
}
vec3_from_vec2
(
&
t
,
translation
);
else
{
rot_center
.
x
=
0
.
0
f
;
rot_center
.
y
=
0
.
0
f
;
rot_center
.
z
=
0
.
0
f
;
}
if
(
ptranslation
)
if
(
rotation
)
{
{
trans
.
x
=
ptranslation
->
x
;
r
.
w
=
cosf
(
rotation
/
2
.
0
f
);
trans
.
y
=
ptranslation
->
y
;
r
.
x
=
0
.
0
f
;
trans
.
z
=
0
.
0
f
;
r
.
y
=
0
.
0
f
;
r
.
z
=
sinf
(
rotation
/
2
.
0
f
);
}
}
else
if
(
scaling_rotation
)
{
{
trans
.
x
=
0
.
0
f
;
s_r
.
w
=
cosf
(
scaling_rotation
/
2
.
0
f
);
trans
.
y
=
0
.
0
f
;
s_r
.
x
=
0
.
0
f
;
trans
.
z
=
0
.
0
f
;
s_r
.
y
=
0
.
0
f
;
s_r
.
z
=
sinf
(
scaling_rotation
/
2
.
0
f
);
}
}
rot
.
w
=
cosf
(
rotation
/
2
.
0
f
);
return
D3DXMatrixTransformation
(
out
,
scaling_center
?
&
s_c
:
NULL
,
rot
.
x
=
0
.
0
f
;
scaling_rotation
?
&
s_r
:
NULL
,
scaling
?
&
s
:
NULL
,
rotation_center
?
&
r_c
:
NULL
,
rot
.
y
=
0
.
0
f
;
rotation
?
&
r
:
NULL
,
translation
?
&
t
:
NULL
);
rot
.
z
=
sinf
(
rotation
/
2
.
0
f
);
sca_rot
.
w
=
cosf
(
scalingrotation
/
2
.
0
f
);
sca_rot
.
x
=
0
.
0
f
;
sca_rot
.
y
=
0
.
0
f
;
sca_rot
.
z
=
sinf
(
scalingrotation
/
2
.
0
f
);
D3DXMatrixTransformation
(
pout
,
&
sca_center
,
&
sca_rot
,
&
sca
,
&
rot_center
,
&
rot
,
&
trans
);
return
pout
;
}
}
D3DXMATRIX
*
WINAPI
D3DXMatrixTranslation
(
D3DXMATRIX
*
pout
,
FLOAT
x
,
FLOAT
y
,
FLOAT
z
)
D3DXMATRIX
*
WINAPI
D3DXMatrixTranslation
(
D3DXMATRIX
*
pout
,
FLOAT
x
,
FLOAT
y
,
FLOAT
z
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment