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
d43cc0cd
Commit
d43cc0cd
authored
Sep 24, 2010
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Fix the window positions when moving a child window for a RTL window.
parent
0df8855b
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
27 deletions
+33
-27
winpos.c
dlls/user32/winpos.c
+33
-27
No files found.
dlls/user32/winpos.c
View file @
d43cc0cd
...
@@ -2310,25 +2310,28 @@ UINT WINAPI ArrangeIconicWindows( HWND parent )
...
@@ -2310,25 +2310,28 @@ UINT WINAPI ArrangeIconicWindows( HWND parent )
*
*
* Draw the frame used when moving or resizing window.
* Draw the frame used when moving or resizing window.
*/
*/
static
void
draw_moving_frame
(
H
DC
hdc
,
RECT
*
rect
,
BOOL
thickframe
)
static
void
draw_moving_frame
(
H
WND
parent
,
HDC
hdc
,
RECT
*
screen_
rect
,
BOOL
thickframe
)
{
{
RECT
rect
=
*
screen_rect
;
if
(
parent
)
MapWindowPoints
(
0
,
parent
,
(
POINT
*
)
&
rect
,
2
);
if
(
thickframe
)
if
(
thickframe
)
{
{
const
int
width
=
GetSystemMetrics
(
SM_CXFRAME
);
const
int
width
=
GetSystemMetrics
(
SM_CXFRAME
);
const
int
height
=
GetSystemMetrics
(
SM_CYFRAME
);
const
int
height
=
GetSystemMetrics
(
SM_CYFRAME
);
HBRUSH
hbrush
=
SelectObject
(
hdc
,
GetStockObject
(
GRAY_BRUSH
)
);
HBRUSH
hbrush
=
SelectObject
(
hdc
,
GetStockObject
(
GRAY_BRUSH
)
);
PatBlt
(
hdc
,
rect
->
left
,
rect
->
top
,
PatBlt
(
hdc
,
rect
.
left
,
rect
.
top
,
rect
->
right
-
rect
->
left
-
width
,
height
,
PATINVERT
);
rect
.
right
-
rect
.
left
-
width
,
height
,
PATINVERT
);
PatBlt
(
hdc
,
rect
->
left
,
rect
->
top
+
height
,
width
,
PatBlt
(
hdc
,
rect
.
left
,
rect
.
top
+
height
,
width
,
rect
->
bottom
-
rect
->
top
-
height
,
PATINVERT
);
rect
.
bottom
-
rect
.
top
-
height
,
PATINVERT
);
PatBlt
(
hdc
,
rect
->
left
+
width
,
rect
->
bottom
-
1
,
PatBlt
(
hdc
,
rect
.
left
+
width
,
rect
.
bottom
-
1
,
rect
->
right
-
rect
->
left
-
width
,
-
height
,
PATINVERT
);
rect
.
right
-
rect
.
left
-
width
,
-
height
,
PATINVERT
);
PatBlt
(
hdc
,
rect
->
right
-
1
,
rect
->
top
,
-
width
,
PatBlt
(
hdc
,
rect
.
right
-
1
,
rect
.
top
,
-
width
,
rect
->
bottom
-
rect
->
top
-
height
,
PATINVERT
);
rect
.
bottom
-
rect
.
top
-
height
,
PATINVERT
);
SelectObject
(
hdc
,
hbrush
);
SelectObject
(
hdc
,
hbrush
);
}
}
else
DrawFocusRect
(
hdc
,
rect
);
else
DrawFocusRect
(
hdc
,
&
rect
);
}
}
...
@@ -2486,10 +2489,13 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
...
@@ -2486,10 +2489,13 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
WINPOS_GetMinMaxInfo
(
hwnd
,
NULL
,
NULL
,
&
minTrack
,
&
maxTrack
);
WINPOS_GetMinMaxInfo
(
hwnd
,
NULL
,
NULL
,
&
minTrack
,
&
maxTrack
);
WIN_GetRectangles
(
hwnd
,
COORDS_PARENT
,
&
sizingRect
,
NULL
);
WIN_GetRectangles
(
hwnd
,
COORDS_PARENT
,
&
sizingRect
,
NULL
);
origRect
=
sizingRect
;
if
(
style
&
WS_CHILD
)
if
(
style
&
WS_CHILD
)
{
{
parent
=
GetParent
(
hwnd
);
parent
=
GetParent
(
hwnd
);
GetClientRect
(
parent
,
&
mouseRect
);
GetClientRect
(
parent
,
&
mouseRect
);
MapWindowPoints
(
parent
,
0
,
(
LPPOINT
)
&
mouseRect
,
2
);
MapWindowPoints
(
parent
,
0
,
(
LPPOINT
)
&
sizingRect
,
2
);
}
}
else
else
{
{
...
@@ -2500,7 +2506,6 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
...
@@ -2500,7 +2506,6 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
mouseRect
.
right
=
mouseRect
.
left
+
GetSystemMetrics
(
SM_CXVIRTUALSCREEN
);
mouseRect
.
right
=
mouseRect
.
left
+
GetSystemMetrics
(
SM_CXVIRTUALSCREEN
);
mouseRect
.
bottom
=
mouseRect
.
top
+
GetSystemMetrics
(
SM_CYVIRTUALSCREEN
);
mouseRect
.
bottom
=
mouseRect
.
top
+
GetSystemMetrics
(
SM_CYVIRTUALSCREEN
);
}
}
origRect
=
sizingRect
;
if
(
ON_LEFT_BORDER
(
hittest
))
if
(
ON_LEFT_BORDER
(
hittest
))
{
{
...
@@ -2522,7 +2527,6 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
...
@@ -2522,7 +2527,6 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
mouseRect
.
top
=
max
(
mouseRect
.
top
,
sizingRect
.
top
+
minTrack
.
y
);
mouseRect
.
top
=
max
(
mouseRect
.
top
,
sizingRect
.
top
+
minTrack
.
y
);
mouseRect
.
bottom
=
min
(
mouseRect
.
bottom
,
sizingRect
.
top
+
maxTrack
.
y
);
mouseRect
.
bottom
=
min
(
mouseRect
.
bottom
,
sizingRect
.
top
+
maxTrack
.
y
);
}
}
if
(
parent
)
MapWindowPoints
(
parent
,
0
,
(
LPPOINT
)
&
mouseRect
,
2
);
/* Retrieve a default cache DC (without using the window style) */
/* Retrieve a default cache DC (without using the window style) */
hdc
=
GetDCEx
(
parent
,
0
,
DCX_CACHE
);
hdc
=
GetDCEx
(
parent
,
0
,
DCX_CACHE
);
...
@@ -2593,39 +2597,40 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
...
@@ -2593,39 +2597,40 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
WINPOS_ShowIconTitle
(
hwnd
,
FALSE
);
WINPOS_ShowIconTitle
(
hwnd
,
FALSE
);
}
}
else
if
(
!
DragFullWindows
)
else
if
(
!
DragFullWindows
)
draw_moving_frame
(
hdc
,
&
sizingRect
,
thickframe
);
draw_moving_frame
(
parent
,
hdc
,
&
sizingRect
,
thickframe
);
}
}
if
(
msg
.
message
==
WM_KEYDOWN
)
SetCursorPos
(
pt
.
x
,
pt
.
y
);
if
(
msg
.
message
==
WM_KEYDOWN
)
SetCursorPos
(
pt
.
x
,
pt
.
y
);
else
else
{
{
RECT
newRect
=
sizingRect
;
WPARAM
wpSizingHit
=
0
;
WPARAM
wpSizingHit
=
0
;
if
(
hittest
==
HTCAPTION
)
OffsetRect
(
&
newRect
,
dx
,
dy
);
if
(
!
iconic
&&
!
DragFullWindows
)
draw_moving_frame
(
parent
,
hdc
,
&
sizingRect
,
thickframe
);
if
(
ON_LEFT_BORDER
(
hittest
))
newRect
.
left
+=
dx
;
if
(
hittest
==
HTCAPTION
)
OffsetRect
(
&
sizingRect
,
dx
,
dy
)
;
else
if
(
ON_RIGHT_BORDER
(
hittest
))
newRect
.
righ
t
+=
dx
;
if
(
ON_LEFT_BORDER
(
hittest
))
sizingRect
.
lef
t
+=
dx
;
if
(
ON_TOP_BORDER
(
hittest
))
newRect
.
top
+=
dy
;
else
if
(
ON_RIGHT_BORDER
(
hittest
))
sizingRect
.
right
+=
dx
;
else
if
(
ON_BOTTOM_BORDER
(
hittest
))
newRect
.
bottom
+=
dy
;
if
(
ON_TOP_BORDER
(
hittest
))
sizingRect
.
top
+=
dy
;
if
(
!
iconic
&&
!
DragFullWindows
)
draw_moving_frame
(
hdc
,
&
sizingRect
,
thickframe
)
;
else
if
(
ON_BOTTOM_BORDER
(
hittest
))
sizingRect
.
bottom
+=
dy
;
capturePoint
=
pt
;
capturePoint
=
pt
;
/* determine the hit location */
/* determine the hit location */
if
(
hittest
>=
HTLEFT
&&
hittest
<=
HTBOTTOMRIGHT
)
if
(
hittest
>=
HTLEFT
&&
hittest
<=
HTBOTTOMRIGHT
)
wpSizingHit
=
WMSZ_LEFT
+
(
hittest
-
HTLEFT
);
wpSizingHit
=
WMSZ_LEFT
+
(
hittest
-
HTLEFT
);
SendMessageW
(
hwnd
,
WM_SIZING
,
wpSizingHit
,
(
LPARAM
)
&
new
Rect
);
SendMessageW
(
hwnd
,
WM_SIZING
,
wpSizingHit
,
(
LPARAM
)
&
sizing
Rect
);
if
(
!
iconic
)
if
(
!
iconic
)
{
{
if
(
!
DragFullWindows
)
if
(
!
DragFullWindows
)
draw_moving_frame
(
hdc
,
&
new
Rect
,
thickframe
);
draw_moving_frame
(
parent
,
hdc
,
&
sizing
Rect
,
thickframe
);
else
else
SetWindowPos
(
hwnd
,
0
,
newRect
.
left
,
newRect
.
top
,
{
newRect
.
right
-
newRect
.
left
,
RECT
rect
=
sizingRect
;
newRect
.
bottom
-
newRect
.
top
,
MapWindowPoints
(
0
,
parent
,
(
POINT
*
)
&
rect
,
2
);
SetWindowPos
(
hwnd
,
0
,
rect
.
left
,
rect
.
top
,
rect
.
right
-
rect
.
left
,
rect
.
bottom
-
rect
.
top
,
(
hittest
==
HTCAPTION
)
?
SWP_NOSIZE
:
0
);
(
hittest
==
HTCAPTION
)
?
SWP_NOSIZE
:
0
);
}
}
}
sizingRect
=
newRect
;
}
}
}
}
}
}
...
@@ -2640,11 +2645,12 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
...
@@ -2640,11 +2645,12 @@ void WINPOS_SysCommandSizeMove( HWND hwnd, WPARAM wParam )
}
}
else
if
(
moved
&&
!
DragFullWindows
)
else
if
(
moved
&&
!
DragFullWindows
)
{
{
draw_moving_frame
(
hdc
,
&
sizingRect
,
thickframe
);
draw_moving_frame
(
parent
,
hdc
,
&
sizingRect
,
thickframe
);
}
}
set_capture_window
(
0
,
GUI_INMOVESIZE
,
NULL
);
set_capture_window
(
0
,
GUI_INMOVESIZE
,
NULL
);
ReleaseDC
(
parent
,
hdc
);
ReleaseDC
(
parent
,
hdc
);
if
(
parent
)
MapWindowPoints
(
0
,
parent
,
(
POINT
*
)
&
sizingRect
,
2
);
if
(
HOOK_CallHooks
(
WH_CBT
,
HCBT_MOVESIZE
,
(
WPARAM
)
hwnd
,
(
LPARAM
)
&
sizingRect
,
TRUE
))
if
(
HOOK_CallHooks
(
WH_CBT
,
HCBT_MOVESIZE
,
(
WPARAM
)
hwnd
,
(
LPARAM
)
&
sizingRect
,
TRUE
))
moved
=
FALSE
;
moved
=
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