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
e04aebd6
Commit
e04aebd6
authored
Jun 20, 2007
by
Misha Koshelev
Committed by
Alexandre Julliard
Jun 21, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gdi32: Allow arbitrary start entry types in PATH_DoArcPart, not just PT_MOVETOs.
parent
80b7134b
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
9 additions
and
9 deletions
+9
-9
path.c
dlls/gdi32/path.c
+9
-9
No files found.
dlls/gdi32/path.c
View file @
e04aebd6
...
@@ -97,7 +97,7 @@ static BOOL PATH_PathToRegion(GdiPath *pPath, INT nPolyFillMode,
...
@@ -97,7 +97,7 @@ static BOOL PATH_PathToRegion(GdiPath *pPath, INT nPolyFillMode,
static
void
PATH_EmptyPath
(
GdiPath
*
pPath
);
static
void
PATH_EmptyPath
(
GdiPath
*
pPath
);
static
BOOL
PATH_ReserveEntries
(
GdiPath
*
pPath
,
INT
numEntries
);
static
BOOL
PATH_ReserveEntries
(
GdiPath
*
pPath
,
INT
numEntries
);
static
BOOL
PATH_DoArcPart
(
GdiPath
*
pPath
,
FLOAT_POINT
corners
[],
static
BOOL
PATH_DoArcPart
(
GdiPath
*
pPath
,
FLOAT_POINT
corners
[],
double
angleStart
,
double
angleEnd
,
B
OOL
addMoveTo
);
double
angleStart
,
double
angleEnd
,
B
YTE
startEntryType
);
static
void
PATH_ScaleNormalizedPoint
(
FLOAT_POINT
corners
[],
double
x
,
static
void
PATH_ScaleNormalizedPoint
(
FLOAT_POINT
corners
[],
double
x
,
double
y
,
POINT
*
pPoint
);
double
y
,
POINT
*
pPoint
);
static
void
PATH_NormalizePoint
(
FLOAT_POINT
corners
[],
const
FLOAT_POINT
static
void
PATH_NormalizePoint
(
FLOAT_POINT
corners
[],
const
FLOAT_POINT
...
@@ -624,7 +624,7 @@ BOOL PATH_RoundRect(DC *dc, INT x1, INT y1, INT x2, INT y2, INT ell_width, INT e
...
@@ -624,7 +624,7 @@ BOOL PATH_RoundRect(DC *dc, INT x1, INT y1, INT x2, INT y2, INT ell_width, INT e
ellCorners
[
0
].
y
=
corners
[
0
].
y
;
ellCorners
[
0
].
y
=
corners
[
0
].
y
;
ellCorners
[
1
].
x
=
corners
[
1
].
x
;
ellCorners
[
1
].
x
=
corners
[
1
].
x
;
ellCorners
[
1
].
y
=
corners
[
0
].
y
+
ell_height
;
ellCorners
[
1
].
y
=
corners
[
0
].
y
+
ell_height
;
if
(
!
PATH_DoArcPart
(
pPath
,
ellCorners
,
0
,
-
M_PI_2
,
TRUE
))
if
(
!
PATH_DoArcPart
(
pPath
,
ellCorners
,
0
,
-
M_PI_2
,
PT_MOVETO
))
return
FALSE
;
return
FALSE
;
pointTemp
.
x
=
corners
[
0
].
x
+
ell_width
/
2
;
pointTemp
.
x
=
corners
[
0
].
x
+
ell_width
/
2
;
pointTemp
.
y
=
corners
[
0
].
y
;
pointTemp
.
y
=
corners
[
0
].
y
;
...
@@ -848,7 +848,7 @@ BOOL PATH_Arc(DC *dc, INT x1, INT y1, INT x2, INT y2,
...
@@ -848,7 +848,7 @@ BOOL PATH_Arc(DC *dc, INT x1, INT y1, INT x2, INT y2,
/* Add the Bezier spline to the path */
/* Add the Bezier spline to the path */
PATH_DoArcPart
(
pPath
,
corners
,
angleStartQuadrant
,
angleEndQuadrant
,
PATH_DoArcPart
(
pPath
,
corners
,
angleStartQuadrant
,
angleEndQuadrant
,
start
);
start
?
PT_MOVETO
:
FALSE
);
start
=
FALSE
;
start
=
FALSE
;
}
while
(
!
end
);
}
while
(
!
end
);
...
@@ -1521,12 +1521,12 @@ static BOOL PATH_ReserveEntries(GdiPath *pPath, INT numEntries)
...
@@ -1521,12 +1521,12 @@ static BOOL PATH_ReserveEntries(GdiPath *pPath, INT numEntries)
* Creates a Bezier spline that corresponds to part of an arc and appends the
* Creates a Bezier spline that corresponds to part of an arc and appends the
* corresponding points to the path. The start and end angles are passed in
* corresponding points to the path. The start and end angles are passed in
* "angleStart" and "angleEnd"; these angles should span a quarter circle
* "angleStart" and "angleEnd"; these angles should span a quarter circle
* at most. If "
addMoveTo" is true, a PT_MOVETO entry for the first control
* at most. If "
startEntryType" is non-zero, an entry of that type for the first
* point is added to the path; otherwise, it is assumed that the current
*
control
point is added to the path; otherwise, it is assumed that the current
* position is equal to the first control point.
* position is equal to the first control point.
*/
*/
static
BOOL
PATH_DoArcPart
(
GdiPath
*
pPath
,
FLOAT_POINT
corners
[],
static
BOOL
PATH_DoArcPart
(
GdiPath
*
pPath
,
FLOAT_POINT
corners
[],
double
angleStart
,
double
angleEnd
,
B
OOL
addMoveTo
)
double
angleStart
,
double
angleEnd
,
B
YTE
startEntryType
)
{
{
double
halfAngle
,
a
;
double
halfAngle
,
a
;
double
xNorm
[
4
],
yNorm
[
4
];
double
xNorm
[
4
],
yNorm
[
4
];
...
@@ -1559,10 +1559,10 @@ static BOOL PATH_DoArcPart(GdiPath *pPath, FLOAT_POINT corners[],
...
@@ -1559,10 +1559,10 @@ static BOOL PATH_DoArcPart(GdiPath *pPath, FLOAT_POINT corners[],
}
}
/* Add starting point to path if desired */
/* Add starting point to path if desired */
if
(
addMoveTo
)
if
(
startEntryType
)
{
{
PATH_ScaleNormalizedPoint
(
corners
,
xNorm
[
0
],
yNorm
[
0
],
&
point
);
PATH_ScaleNormalizedPoint
(
corners
,
xNorm
[
0
],
yNorm
[
0
],
&
point
);
if
(
!
PATH_AddEntry
(
pPath
,
&
point
,
PT_MOVETO
))
if
(
!
PATH_AddEntry
(
pPath
,
&
point
,
startEntryType
))
return
FALSE
;
return
FALSE
;
}
}
...
@@ -1937,7 +1937,7 @@ static BOOL PATH_WidenPath(DC *dc)
...
@@ -1937,7 +1937,7 @@ static BOOL PATH_WidenPath(DC *dc)
corners
[
0
].
y
=
yo
-
penWidthIn
;
corners
[
0
].
y
=
yo
-
penWidthIn
;
corners
[
1
].
x
=
xo
+
penWidthOut
;
corners
[
1
].
x
=
xo
+
penWidthOut
;
corners
[
1
].
y
=
yo
+
penWidthOut
;
corners
[
1
].
y
=
yo
+
penWidthOut
;
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
M_PI_2
,
theta
+
3
*
M_PI_4
,
(
j
==
0
?
TRUE
:
FALSE
));
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
M_PI_2
,
theta
+
3
*
M_PI_4
,
(
j
==
0
?
PT_MOVETO
:
FALSE
));
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
3
*
M_PI_4
,
theta
+
M_PI
,
FALSE
);
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
3
*
M_PI_4
,
theta
+
M_PI
,
FALSE
);
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
M_PI
,
theta
+
5
*
M_PI_4
,
FALSE
);
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
M_PI
,
theta
+
5
*
M_PI_4
,
FALSE
);
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
5
*
M_PI_4
,
theta
+
3
*
M_PI_2
,
FALSE
);
PATH_DoArcPart
(
pUpPath
,
corners
,
theta
+
5
*
M_PI_4
,
theta
+
3
*
M_PI_2
,
FALSE
);
...
...
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