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
bb1dbb5a
Commit
bb1dbb5a
authored
Jun 14, 2005
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Get rid of the PerfectGraphics option, that's not really useful.
parent
c913efa2
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
20 additions
and
56 deletions
+20
-56
bitblt.c
dlls/x11drv/bitblt.c
+20
-56
No files found.
dlls/x11drv/bitblt.c
View file @
bb1dbb5a
...
@@ -535,35 +535,6 @@ int main()
...
@@ -535,35 +535,6 @@ int main()
#endif
/* BITBLT_TEST */
#endif
/* BITBLT_TEST */
/***********************************************************************
* perfect_graphics
*
* Favor correctness or speed?
*/
static
int
perfect_graphics
(
void
)
{
static
int
perfect
=
-
1
;
if
(
perfect
==
-
1
)
{
HKEY
hkey
;
char
buffer
[
20
];
/* default value */
perfect
=
0
;
/* @@ Wine registry key: HKLM\Software\Wine\Wine\Config\x11drv */
if
(
!
RegOpenKeyA
(
HKEY_LOCAL_MACHINE
,
"Software
\\
Wine
\\
Wine
\\
Config
\\
x11drv"
,
&
hkey
))
{
DWORD
type
,
count
=
sizeof
(
buffer
);
if
(
!
RegQueryValueExA
(
hkey
,
"PerfectGraphics"
,
0
,
&
type
,
buffer
,
&
count
))
{
char
ch
=
buffer
[
0
];
perfect
=
(
ch
==
'y'
||
ch
==
'Y'
||
ch
==
't'
||
ch
==
'T'
||
ch
==
'1'
);
}
RegCloseKey
(
hkey
);
}
}
return
perfect
;
}
static
void
get_colors
(
X11DRV_PDEVICE
*
physDevDst
,
X11DRV_PDEVICE
*
physDevSrc
,
static
void
get_colors
(
X11DRV_PDEVICE
*
physDevDst
,
X11DRV_PDEVICE
*
physDevSrc
,
int
*
fg
,
int
*
bg
)
int
*
fg
,
int
*
bg
)
{
{
...
@@ -1350,36 +1321,30 @@ static BOOL BITBLT_InternalStretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT
...
@@ -1350,36 +1321,30 @@ static BOOL BITBLT_InternalStretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT
return
TRUE
;
return
TRUE
;
case
DSTINVERT
:
/* 0x55 */
case
DSTINVERT
:
/* 0x55 */
if
((
physDevDst
->
depth
==
1
)
||
!
X11DRV_PALETTE_PaletteToXPixel
||
wine_tsx11_lock
();
!
perfect_graphics
())
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXinvert
);
{
wine_tsx11_lock
();
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXinvert
);
if
(
X11DRV_PALETTE_PaletteFlags
&
(
X11DRV_PALETTE_PRIVATE
|
X11DRV_PALETTE_VIRTUAL
)
)
if
(
X11DRV_PALETTE_PaletteFlags
&
(
X11DRV_PALETTE_PRIVATE
|
X11DRV_PALETTE_VIRTUAL
)
)
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXinvert
);
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXinvert
);
else
else
{
{
/* Xor is much better when we do not have full colormap. */
/* Xor is much better when we do not have full colormap. */
/* Using white^black ensures that we invert at least black */
/* Using white^black ensures that we invert at least black */
/* and white. */
/* and white. */
Pixel
xor_pix
=
(
WhitePixel
(
gdi_display
,
DefaultScreen
(
gdi_display
)
)
^
Pixel
xor_pix
=
(
WhitePixel
(
gdi_display
,
DefaultScreen
(
gdi_display
)
)
^
BlackPixel
(
gdi_display
,
DefaultScreen
(
gdi_display
)
));
BlackPixel
(
gdi_display
,
DefaultScreen
(
gdi_display
)
));
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXxor
);
XSetFunction
(
gdi_display
,
physDevDst
->
gc
,
GXxor
);
XSetForeground
(
gdi_display
,
physDevDst
->
gc
,
xor_pix
);
XSetForeground
(
gdi_display
,
physDevDst
->
gc
,
xor_pix
);
XSetFillStyle
(
gdi_display
,
physDevDst
->
gc
,
FillSolid
);
XSetFillStyle
(
gdi_display
,
physDevDst
->
gc
,
FillSolid
);
}
XFillRectangle
(
gdi_display
,
physDevDst
->
drawable
,
physDevDst
->
gc
,
physDevDst
->
org
.
x
+
visRectDst
.
left
,
physDevDst
->
org
.
y
+
visRectDst
.
top
,
width
,
height
);
wine_tsx11_unlock
();
return
TRUE
;
}
}
break
;
XFillRectangle
(
gdi_display
,
physDevDst
->
drawable
,
physDevDst
->
gc
,
physDevDst
->
org
.
x
+
visRectDst
.
left
,
physDevDst
->
org
.
y
+
visRectDst
.
top
,
width
,
height
);
wine_tsx11_unlock
();
return
TRUE
;
case
PATINVERT
:
/* 0x5a */
case
PATINVERT
:
/* 0x5a */
if
(
perfect_graphics
())
break
;
if
(
X11DRV_SetupGCForBrush
(
physDevDst
))
if
(
X11DRV_SetupGCForBrush
(
physDevDst
))
{
{
wine_tsx11_lock
();
wine_tsx11_lock
();
...
@@ -1393,7 +1358,6 @@ static BOOL BITBLT_InternalStretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT
...
@@ -1393,7 +1358,6 @@ static BOOL BITBLT_InternalStretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT
return
TRUE
;
return
TRUE
;
case
0xa50065
:
case
0xa50065
:
if
(
perfect_graphics
())
break
;
if
(
X11DRV_SetupGCForBrush
(
physDevDst
))
if
(
X11DRV_SetupGCForBrush
(
physDevDst
))
{
{
wine_tsx11_lock
();
wine_tsx11_lock
();
...
...
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