Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
be74c47e
Commit
be74c47e
authored
Jul 18, 2011
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winex11: Remap pixels to system palette in Get/PutImage for 4 and 8 bpp.
parent
5d22f3aa
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
9 deletions
+29
-9
bitblt.c
dlls/winex11.drv/bitblt.c
+29
-9
No files found.
dlls/winex11.drv/bitblt.c
View file @
be74c47e
...
@@ -1642,7 +1642,7 @@ static void set_color_info( const ColorShifts *color_shifts, BITMAPINFO *info )
...
@@ -1642,7 +1642,7 @@ static void set_color_info( const ColorShifts *color_shifts, BITMAPINFO *info )
/* copy the image bits, fixing up alignment and byte swapping as necessary */
/* copy the image bits, fixing up alignment and byte swapping as necessary */
static
DWORD
copy_image_bits
(
BITMAPINFO
*
info
,
const
ColorShifts
*
color_shifts
,
XImage
*
image
,
static
DWORD
copy_image_bits
(
BITMAPINFO
*
info
,
const
ColorShifts
*
color_shifts
,
XImage
*
image
,
const
struct
gdi_image_bits
*
src_bits
,
struct
gdi_image_bits
*
dst_bits
,
const
struct
gdi_image_bits
*
src_bits
,
struct
gdi_image_bits
*
dst_bits
,
unsigned
int
zeropad_mask
)
const
int
*
mapping
,
unsigned
int
zeropad_mask
)
{
{
#ifdef WORDS_BIGENDIAN
#ifdef WORDS_BIGENDIAN
static
const
int
client_byte_order
=
MSBFirst
;
static
const
int
client_byte_order
=
MSBFirst
;
...
@@ -1678,6 +1678,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
...
@@ -1678,6 +1678,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
if
((
need_byteswap
&&
!
src_bits
->
is_copy
)
||
/* need to swap bytes */
if
((
need_byteswap
&&
!
src_bits
->
is_copy
)
||
/* need to swap bytes */
(
zeropad_mask
!=
~
0u
&&
!
src_bits
->
is_copy
)
||
/* need to clear padding bytes */
(
zeropad_mask
!=
~
0u
&&
!
src_bits
->
is_copy
)
||
/* need to clear padding bytes */
(
mapping
&&
!
src_bits
->
is_copy
)
||
/* need to remap pixels */
(
width_bytes
&
3
)
||
/* need to fixup line alignment */
(
width_bytes
&
3
)
||
/* need to fixup line alignment */
(
info
->
bmiHeader
.
biHeight
>
0
))
/* need to flip vertically */
(
info
->
bmiHeader
.
biHeight
>
0
))
/* need to flip vertically */
{
{
...
@@ -1696,7 +1697,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
...
@@ -1696,7 +1697,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
dst_bits
->
offset
=
src_bits
->
offset
;
dst_bits
->
offset
=
src_bits
->
offset
;
dst_bits
->
is_copy
=
src_bits
->
is_copy
;
dst_bits
->
is_copy
=
src_bits
->
is_copy
;
dst_bits
->
free
=
NULL
;
dst_bits
->
free
=
NULL
;
if
(
!
need_byteswap
&&
zeropad_mask
==
~
0u
)
return
ERROR_SUCCESS
;
/* nothing to do */
if
(
!
need_byteswap
&&
zeropad_mask
==
~
0u
&&
!
mapping
)
return
ERROR_SUCCESS
;
/* nothing to do */
}
}
src
=
src_bits
->
ptr
;
src
=
src_bits
->
ptr
;
...
@@ -1709,7 +1710,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
...
@@ -1709,7 +1710,7 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
width_bytes
=
-
width_bytes
;
width_bytes
=
-
width_bytes
;
}
}
if
(
need_byteswap
)
if
(
need_byteswap
||
mapping
)
{
{
switch
(
info
->
bmiHeader
.
biBitCount
)
switch
(
info
->
bmiHeader
.
biBitCount
)
{
{
...
@@ -1724,11 +1725,23 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
...
@@ -1724,11 +1725,23 @@ static DWORD copy_image_bits( BITMAPINFO *info, const ColorShifts *color_shifts,
case
4
:
case
4
:
for
(
y
=
0
;
y
<
height
;
y
++
,
src
+=
image
->
bytes_per_line
,
dst
+=
width_bytes
)
for
(
y
=
0
;
y
<
height
;
y
++
,
src
+=
image
->
bytes_per_line
,
dst
+=
width_bytes
)
{
{
if
(
mapping
)
for
(
x
=
0
;
x
<
image
->
bytes_per_line
;
x
++
)
dst
[
x
]
=
(
mapping
[
src
[
x
]
&
0x0f
]
<<
4
)
|
mapping
[
src
[
x
]
>>
4
];
else
for
(
x
=
0
;
x
<
image
->
bytes_per_line
;
x
++
)
for
(
x
=
0
;
x
<
image
->
bytes_per_line
;
x
++
)
dst
[
x
]
=
(
src
[
x
]
<<
4
)
|
(
src
[
x
]
>>
4
);
dst
[
x
]
=
(
src
[
x
]
<<
4
)
|
(
src
[
x
]
>>
4
);
((
unsigned
int
*
)
dst
)[
padding_pos
]
&=
zeropad_mask
;
((
unsigned
int
*
)
dst
)[
padding_pos
]
&=
zeropad_mask
;
}
}
break
;
break
;
case
8
:
for
(
y
=
0
;
y
<
height
;
y
++
,
src
+=
image
->
bytes_per_line
,
dst
+=
width_bytes
)
{
for
(
x
=
0
;
x
<
image
->
bytes_per_line
;
x
++
)
dst
[
x
]
=
mapping
[
src
[
x
]];
((
unsigned
int
*
)
dst
)[
padding_pos
]
&=
zeropad_mask
;
}
break
;
case
16
:
case
16
:
for
(
y
=
0
;
y
<
height
;
y
++
,
src
+=
image
->
bytes_per_line
,
dst
+=
width_bytes
)
for
(
y
=
0
;
y
<
height
;
y
++
,
src
+=
image
->
bytes_per_line
,
dst
+=
width_bytes
)
{
{
...
@@ -1787,6 +1800,8 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
...
@@ -1787,6 +1800,8 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
struct
gdi_image_bits
dst_bits
;
struct
gdi_image_bits
dst_bits
;
const
XPixmapFormatValues
*
format
;
const
XPixmapFormatValues
*
format
;
const
ColorShifts
*
color_shifts
;
const
ColorShifts
*
color_shifts
;
const
BYTE
*
opcode
=
BITBLT_Opcodes
[(
rop
>>
16
)
&
0xff
];
const
int
*
mapping
=
NULL
;
if
(
hbitmap
)
if
(
hbitmap
)
{
{
...
@@ -1845,7 +1860,13 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
...
@@ -1845,7 +1860,13 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
wine_tsx11_unlock
();
wine_tsx11_unlock
();
if
(
!
image
)
return
ERROR_OUTOFMEMORY
;
if
(
!
image
)
return
ERROR_OUTOFMEMORY
;
ret
=
copy_image_bits
(
info
,
color_shifts
,
image
,
bits
,
&
dst_bits
,
~
0u
);
if
(
image
->
bits_per_pixel
==
4
||
image
->
bits_per_pixel
==
8
)
{
if
(
bitmap
||
(
!
opcode
[
1
]
&&
OP_SRCDST
(
opcode
[
0
])
==
OP_ARGS
(
SRC
,
DST
)))
mapping
=
X11DRV_PALETTE_PaletteToXPixel
;
}
ret
=
copy_image_bits
(
info
,
color_shifts
,
image
,
bits
,
&
dst_bits
,
mapping
,
~
0u
);
if
(
!
ret
)
if
(
!
ret
)
{
{
...
@@ -1862,8 +1883,6 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
...
@@ -1862,8 +1883,6 @@ DWORD X11DRV_PutImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info, const str
}
}
else
else
{
{
const
BYTE
*
opcode
=
BITBLT_Opcodes
[(
rop
>>
16
)
&
0xff
];
X11DRV_LockDIBSection
(
physdev
,
DIB_Status_GdiMod
);
X11DRV_LockDIBSection
(
physdev
,
DIB_Status_GdiMod
);
/* optimization for single-op ROPs */
/* optimization for single-op ROPs */
...
@@ -1931,6 +1950,7 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
...
@@ -1931,6 +1950,7 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
struct
gdi_image_bits
src_bits
;
struct
gdi_image_bits
src_bits
;
const
XPixmapFormatValues
*
format
;
const
XPixmapFormatValues
*
format
;
const
ColorShifts
*
color_shifts
;
const
ColorShifts
*
color_shifts
;
const
int
*
mapping
=
NULL
;
if
(
hbitmap
)
if
(
hbitmap
)
{
{
...
@@ -1952,8 +1972,8 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
...
@@ -1952,8 +1972,8 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
switch
(
format
->
bits_per_pixel
)
switch
(
format
->
bits_per_pixel
)
{
{
case
1
:
align
=
32
;
break
;
case
1
:
align
=
32
;
break
;
case
4
:
align
=
8
;
break
;
case
4
:
align
=
8
;
mapping
=
X11DRV_PALETTE_XPixelToPalette
;
break
;
case
8
:
align
=
4
;
break
;
case
8
:
align
=
4
;
mapping
=
X11DRV_PALETTE_XPixelToPalette
;
break
;
case
16
:
align
=
2
;
break
;
case
16
:
align
=
2
;
break
;
case
24
:
align
=
4
;
break
;
case
24
:
align
=
4
;
break
;
case
32
:
align
=
1
;
break
;
case
32
:
align
=
1
;
break
;
...
@@ -2021,7 +2041,7 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
...
@@ -2021,7 +2041,7 @@ DWORD X11DRV_GetImage( PHYSDEV dev, HBITMAP hbitmap, BITMAPINFO *info,
src_bits
.
ptr
=
image
->
data
;
src_bits
.
ptr
=
image
->
data
;
src_bits
.
is_copy
=
TRUE
;
src_bits
.
is_copy
=
TRUE
;
ret
=
copy_image_bits
(
info
,
color_shifts
,
image
,
&
src_bits
,
bits
,
ret
=
copy_image_bits
(
info
,
color_shifts
,
image
,
&
src_bits
,
bits
,
mapping
,
zeropad_masks
[(
width
*
image
->
bits_per_pixel
)
&
31
]
);
zeropad_masks
[(
width
*
image
->
bits_per_pixel
)
&
31
]
);
if
(
!
ret
&&
bits
->
ptr
==
image
->
data
)
if
(
!
ret
&&
bits
->
ptr
==
image
->
data
)
...
...
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