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
902049c0
Commit
902049c0
authored
Aug 15, 2012
by
Matteo Bruni
Committed by
Alexandre Julliard
Aug 15, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Fix pixel format masks.
parent
0a37a86f
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
26 additions
and
14 deletions
+26
-14
context.c
dlls/wined3d/context.c
+1
-1
state.c
dlls/wined3d/state.c
+3
-3
surface.c
dlls/wined3d/surface.c
+14
-6
utils.c
dlls/wined3d/utils.c
+0
-0
wined3d_private.h
dlls/wined3d/wined3d_private.h
+8
-4
No files found.
dlls/wined3d/context.c
View file @
902049c0
...
@@ -2398,7 +2398,7 @@ static void context_setup_target(struct wined3d_context *context, struct wined3d
...
@@ -2398,7 +2398,7 @@ static void context_setup_target(struct wined3d_context *context, struct wined3d
if
(
old
->
id
!=
new
->
id
)
if
(
old
->
id
!=
new
->
id
)
{
{
/* Disable blending when the alpha mask has changed and when a format doesn't support blending. */
/* Disable blending when the alpha mask has changed and when a format doesn't support blending. */
if
((
old
->
alpha_
mask
&&
!
new
->
alpha_mask
)
||
(
!
old
->
alpha_mask
&&
new
->
alpha_mask
)
if
((
old
->
alpha_
size
&&
!
new
->
alpha_size
)
||
(
!
old
->
alpha_size
&&
new
->
alpha_size
)
||
!
(
new
->
flags
&
WINED3DFMT_FLAG_POSTPIXELSHADER_BLENDING
))
||
!
(
new
->
flags
&
WINED3DFMT_FLAG_POSTPIXELSHADER_BLENDING
))
context_invalidate_state
(
context
,
STATE_RENDER
(
WINED3D_RS_ALPHABLENDENABLE
));
context_invalidate_state
(
context
,
STATE_RENDER
(
WINED3D_RS_ALPHABLENDENABLE
));
...
...
dlls/wined3d/state.c
View file @
902049c0
...
@@ -379,9 +379,9 @@ static GLenum gl_blend_factor(enum wined3d_blend factor, const struct wined3d_fo
...
@@ -379,9 +379,9 @@ static GLenum gl_blend_factor(enum wined3d_blend factor, const struct wined3d_fo
* returns 1.0, so WINED3D_BLEND_DESTALPHA becomes GL_ONE, and
* returns 1.0, so WINED3D_BLEND_DESTALPHA becomes GL_ONE, and
* WINED3D_BLEND_INVDESTALPHA becomes GL_ZERO. */
* WINED3D_BLEND_INVDESTALPHA becomes GL_ZERO. */
case
WINED3D_BLEND_DESTALPHA
:
case
WINED3D_BLEND_DESTALPHA
:
return
dst_format
->
alpha_
mask
?
GL_DST_ALPHA
:
GL_ONE
;
return
dst_format
->
alpha_
size
?
GL_DST_ALPHA
:
GL_ONE
;
case
WINED3D_BLEND_INVDESTALPHA
:
case
WINED3D_BLEND_INVDESTALPHA
:
return
dst_format
->
alpha_
mask
?
GL_ONE_MINUS_DST_ALPHA
:
GL_ZERO
;
return
dst_format
->
alpha_
size
?
GL_ONE_MINUS_DST_ALPHA
:
GL_ZERO
;
case
WINED3D_BLEND_SRCALPHASAT
:
case
WINED3D_BLEND_SRCALPHASAT
:
return
GL_SRC_ALPHA_SATURATE
;
return
GL_SRC_ALPHA_SATURATE
;
case
WINED3D_BLEND_BLENDFACTOR
:
case
WINED3D_BLEND_BLENDFACTOR
:
...
@@ -3253,7 +3253,7 @@ void tex_alphaop(struct wined3d_context *context, const struct wined3d_state *st
...
@@ -3253,7 +3253,7 @@ void tex_alphaop(struct wined3d_context *context, const struct wined3d_state *st
{
{
struct
wined3d_surface
*
surf
=
surface_from_resource
(
texture
->
sub_resources
[
0
]);
struct
wined3d_surface
*
surf
=
surface_from_resource
(
texture
->
sub_resources
[
0
]);
if
(
surf
->
CKeyFlags
&
WINEDDSD_CKSRCBLT
&&
!
surf
->
resource
.
format
->
alpha_
mask
)
if
(
surf
->
CKeyFlags
&
WINEDDSD_CKSRCBLT
&&
!
surf
->
resource
.
format
->
alpha_
size
)
{
{
/* Color keying needs to pass alpha values from the texture through to have the alpha test work
/* Color keying needs to pass alpha values from the texture through to have the alpha test work
* properly. On the other hand applications can still use texture combiners apparently. This code
* properly. On the other hand applications can still use texture combiners apparently. This code
...
...
dlls/wined3d/surface.c
View file @
902049c0
...
@@ -371,6 +371,14 @@ void draw_textured_quad(const struct wined3d_surface *src_surface, struct wined3
...
@@ -371,6 +371,14 @@ void draw_textured_quad(const struct wined3d_surface *src_surface, struct wined3
}
}
}
}
/* Works correctly only for <= 4 bpp formats. */
static
void
get_color_masks
(
const
struct
wined3d_format
*
format
,
DWORD
*
masks
)
{
masks
[
0
]
=
((
1
<<
format
->
red_size
)
-
1
)
<<
format
->
red_offset
;
masks
[
1
]
=
((
1
<<
format
->
green_size
)
-
1
)
<<
format
->
green_offset
;
masks
[
2
]
=
((
1
<<
format
->
blue_size
)
-
1
)
<<
format
->
blue_offset
;
}
static
HRESULT
surface_create_dib_section
(
struct
wined3d_surface
*
surface
)
static
HRESULT
surface_create_dib_section
(
struct
wined3d_surface
*
surface
)
{
{
const
struct
wined3d_format
*
format
=
surface
->
resource
.
format
;
const
struct
wined3d_format
*
format
=
surface
->
resource
.
format
;
...
@@ -456,9 +464,7 @@ static HRESULT surface_create_dib_section(struct wined3d_surface *surface)
...
@@ -456,9 +464,7 @@ static HRESULT surface_create_dib_section(struct wined3d_surface *surface)
case
WINED3DFMT_B5G6R5_UNORM
:
case
WINED3DFMT_B5G6R5_UNORM
:
case
WINED3DFMT_R16G16B16A16_UNORM
:
case
WINED3DFMT_R16G16B16A16_UNORM
:
b_info
->
bmiHeader
.
biCompression
=
BI_BITFIELDS
;
b_info
->
bmiHeader
.
biCompression
=
BI_BITFIELDS
;
masks
[
0
]
=
format
->
red_mask
;
get_color_masks
(
format
,
masks
);
masks
[
1
]
=
format
->
green_mask
;
masks
[
2
]
=
format
->
blue_mask
;
break
;
break
;
default:
default:
...
@@ -6971,9 +6977,11 @@ do { \
...
@@ -6971,9 +6977,11 @@ do { \
}
}
else
else
{
{
keymask
=
src_format
->
red_mask
DWORD
masks
[
3
];
|
src_format
->
green_mask
get_color_masks
(
src_format
,
masks
);
|
src_format
->
blue_mask
;
keymask
=
masks
[
0
]
|
masks
[
1
]
|
masks
[
2
];
}
}
flags
&=
~
(
WINEDDBLT_KEYSRC
|
WINEDDBLT_KEYDEST
|
WINEDDBLT_KEYSRCOVERRIDE
|
WINEDDBLT_KEYDESTOVERRIDE
);
flags
&=
~
(
WINEDDBLT_KEYSRC
|
WINEDDBLT_KEYDEST
|
WINEDDBLT_KEYSRCOVERRIDE
|
WINEDDBLT_KEYDESTOVERRIDE
);
}
}
...
...
dlls/wined3d/utils.c
View file @
902049c0
This diff is collapsed.
Click to expand it.
dlls/wined3d/wined3d_private.h
View file @
902049c0
...
@@ -2796,10 +2796,14 @@ struct wined3d_format
...
@@ -2796,10 +2796,14 @@ struct wined3d_format
{
{
enum
wined3d_format_id
id
;
enum
wined3d_format_id
id
;
DWORD
red_mask
;
DWORD
red_size
;
DWORD
green_mask
;
DWORD
green_size
;
DWORD
blue_mask
;
DWORD
blue_size
;
DWORD
alpha_mask
;
DWORD
alpha_size
;
DWORD
red_offset
;
DWORD
green_offset
;
DWORD
blue_offset
;
DWORD
alpha_offset
;
UINT
byte_count
;
UINT
byte_count
;
BYTE
depth_size
;
BYTE
depth_size
;
BYTE
stencil_size
;
BYTE
stencil_size
;
...
...
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