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
b409cf62
Commit
b409cf62
authored
Sep 22, 2000
by
Susan Farley
Committed by
Alexandre Julliard
Sep 22, 2000
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added support for FLATBUTTON style tabs.
Made width of BUTTON style tabs no less than 2x their height. Expanded focus rect to be just inside the border.
parent
92dcad8a
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
7 deletions
+40
-7
tab.c
dlls/comctl32/tab.c
+40
-7
No files found.
dlls/comctl32/tab.c
View file @
b409cf62
...
@@ -67,13 +67,12 @@ typedef struct
...
@@ -67,13 +67,12 @@ typedef struct
#define HORIZONTAL_ITEM_PADDING 5
#define HORIZONTAL_ITEM_PADDING 5
#define VERTICAL_ITEM_PADDING 3
#define VERTICAL_ITEM_PADDING 3
#define ROUND_CORNER_SIZE 2
#define ROUND_CORNER_SIZE 2
#define FOCUS_RECT_HOFFSET 2
#define FOCUS_RECT_VOFFSET 1
#define DISPLAY_AREA_PADDINGX 2
#define DISPLAY_AREA_PADDINGX 2
#define DISPLAY_AREA_PADDINGY 2
#define DISPLAY_AREA_PADDINGY 2
#define CONTROL_BORDER_SIZEX 2
#define CONTROL_BORDER_SIZEX 2
#define CONTROL_BORDER_SIZEY 2
#define CONTROL_BORDER_SIZEY 2
#define BUTTON_SPACINGX 10
#define BUTTON_SPACINGX 4
#define FLAT_BTN_SPACINGX 8
#define DEFAULT_TAB_WIDTH 96
#define DEFAULT_TAB_WIDTH 96
#define TAB_GetInfoPtr(hwnd) ((TAB_INFO *)GetWindowLongA(hwnd,0))
#define TAB_GetInfoPtr(hwnd) ((TAB_INFO *)GetWindowLongA(hwnd,0))
...
@@ -1003,6 +1002,12 @@ static void TAB_SetItemBounds (HWND hwnd)
...
@@ -1003,6 +1002,12 @@ static void TAB_SetItemBounds (HWND hwnd)
*/
*/
GetTextExtentPoint32A
(
hdc
,
infoPtr
->
items
[
curItem
].
pszText
,
GetTextExtentPoint32A
(
hdc
,
infoPtr
->
items
[
curItem
].
pszText
,
lstrlenA
(
infoPtr
->
items
[
curItem
].
pszText
),
&
size
);
lstrlenA
(
infoPtr
->
items
[
curItem
].
pszText
),
&
size
);
/*
* under Windows, there seems to be a minimum width of 2x the height
* for button style tabs
*/
if
(
lStyle
&
TCS_BUTTONS
)
size
.
cx
=
max
(
size
.
cx
,
2
*
infoPtr
->
tabHeight
);
/*
/*
* Add the icon width
* Add the icon width
...
@@ -1039,7 +1044,7 @@ static void TAB_SetItemBounds (HWND hwnd)
...
@@ -1039,7 +1044,7 @@ static void TAB_SetItemBounds (HWND hwnd)
infoPtr
->
items
[
curItem
].
rect
.
bottom
=
0
;
infoPtr
->
items
[
curItem
].
rect
.
bottom
=
0
;
infoPtr
->
items
[
curItem
].
rect
.
top
=
curItemRowCount
;
infoPtr
->
items
[
curItem
].
rect
.
top
=
curItemRowCount
;
TRACE
(
"TextSize: %
i
\n
"
,
size
.
cx
);
TRACE
(
"TextSize: %
li
\n
"
,
size
.
cx
);
TRACE
(
"Rect: T %i, L %i, B %i, R %i
\n
"
,
TRACE
(
"Rect: T %i, L %i, B %i, R %i
\n
"
,
infoPtr
->
items
[
curItem
].
rect
.
top
,
infoPtr
->
items
[
curItem
].
rect
.
top
,
infoPtr
->
items
[
curItem
].
rect
.
left
,
infoPtr
->
items
[
curItem
].
rect
.
left
,
...
@@ -1051,7 +1056,11 @@ static void TAB_SetItemBounds (HWND hwnd)
...
@@ -1051,7 +1056,11 @@ static void TAB_SetItemBounds (HWND hwnd)
* of this one.
* of this one.
*/
*/
if
(
lStyle
&
TCS_BUTTONS
)
if
(
lStyle
&
TCS_BUTTONS
)
{
curItemLeftPos
=
infoPtr
->
items
[
curItem
].
rect
.
right
+
BUTTON_SPACINGX
;
curItemLeftPos
=
infoPtr
->
items
[
curItem
].
rect
.
right
+
BUTTON_SPACINGX
;
if
(
lStyle
&
TCS_FLATBUTTONS
)
curItemLeftPos
+=
FLAT_BTN_SPACINGX
;
}
else
else
curItemLeftPos
=
infoPtr
->
items
[
curItem
].
rect
.
right
;
curItemLeftPos
=
infoPtr
->
items
[
curItem
].
rect
.
right
;
}
}
...
@@ -1114,8 +1123,11 @@ static void TAB_SetItemBounds (HWND hwnd)
...
@@ -1114,8 +1123,11 @@ static void TAB_SetItemBounds (HWND hwnd)
infoPtr
->
items
[
iItm
].
rect
.
left
+=
curItemLeftPos
;
infoPtr
->
items
[
iItm
].
rect
.
left
+=
curItemLeftPos
;
infoPtr
->
items
[
iItm
].
rect
.
right
+=
curItemLeftPos
;
infoPtr
->
items
[
iItm
].
rect
.
right
+=
curItemLeftPos
;
if
(
lStyle
&
TCS_BUTTONS
)
if
(
lStyle
&
TCS_BUTTONS
)
curItemLeftPos
=
infoPtr
->
items
[
iItm
].
rect
.
right
+
{
BUTTON_SPACINGX
;
curItemLeftPos
=
infoPtr
->
items
[
iItm
].
rect
.
right
+
BUTTON_SPACINGX
;
if
(
lStyle
&
TCS_FLATBUTTONS
)
curItemLeftPos
+=
FLAT_BTN_SPACINGX
;
}
else
else
curItemLeftPos
=
infoPtr
->
items
[
iItm
].
rect
.
right
;
curItemLeftPos
=
infoPtr
->
items
[
iItm
].
rect
.
right
;
}
}
...
@@ -1401,6 +1413,22 @@ static void TAB_DrawItem(
...
@@ -1401,6 +1413,22 @@ static void TAB_DrawItem(
holdPen
=
SelectObject
(
hdc
,
hwPen
);
holdPen
=
SelectObject
(
hdc
,
hwPen
);
/*
* Separators between flat buttons
*/
if
(
lStyle
&
TCS_FLATBUTTONS
)
{
/* highlight */
int
x
=
r
.
right
+
FLAT_BTN_SPACINGX
-
2
;
MoveToEx
(
hdc
,
x
,
r
.
bottom
-
1
,
NULL
);
LineTo
(
hdc
,
x
,
r
.
top
-
1
);
x
--
;
/* shadow */
SelectObject
(
hdc
,
hbPen
);
MoveToEx
(
hdc
,
x
,
r
.
bottom
-
1
,
NULL
);
LineTo
(
hdc
,
x
,
r
.
top
-
1
);
}
if
(
iItem
==
infoPtr
->
iSelected
)
if
(
iItem
==
infoPtr
->
iSelected
)
{
{
/*
/*
...
@@ -1439,6 +1467,7 @@ static void TAB_DrawItem(
...
@@ -1439,6 +1467,7 @@ static void TAB_DrawItem(
r
.
bottom
--
;
r
.
bottom
--
;
/* highlight */
/* highlight */
SelectObject
(
hdc
,
hwPen
);
MoveToEx
(
hdc
,
r
.
left
,
r
.
bottom
,
NULL
);
MoveToEx
(
hdc
,
r
.
left
,
r
.
bottom
,
NULL
);
LineTo
(
hdc
,
r
.
right
,
r
.
bottom
);
LineTo
(
hdc
,
r
.
right
,
r
.
bottom
);
LineTo
(
hdc
,
r
.
right
,
r
.
top
);
LineTo
(
hdc
,
r
.
right
,
r
.
top
);
...
@@ -1455,6 +1484,8 @@ static void TAB_DrawItem(
...
@@ -1455,6 +1484,8 @@ static void TAB_DrawItem(
*/
*/
FillRect
(
hdc
,
&
r
,
hbr
);
FillRect
(
hdc
,
&
r
,
hbr
);
if
(
!
(
lStyle
&
TCS_FLATBUTTONS
))
{
/* highlight */
/* highlight */
MoveToEx
(
hdc
,
r
.
left
,
r
.
bottom
,
NULL
);
MoveToEx
(
hdc
,
r
.
left
,
r
.
bottom
,
NULL
);
LineTo
(
hdc
,
r
.
left
,
r
.
top
);
LineTo
(
hdc
,
r
.
left
,
r
.
top
);
...
@@ -1466,6 +1497,7 @@ static void TAB_DrawItem(
...
@@ -1466,6 +1497,7 @@ static void TAB_DrawItem(
LineTo
(
hdc
,
r
.
left
,
r
.
bottom
);
LineTo
(
hdc
,
r
.
left
,
r
.
bottom
);
}
}
}
}
}
else
else
{
{
/*
/*
...
@@ -1542,7 +1574,8 @@ static void TAB_DrawItem(
...
@@ -1542,7 +1574,8 @@ static void TAB_DrawItem(
(
GetFocus
()
==
hwnd
)
&&
(
GetFocus
()
==
hwnd
)
&&
(
iItem
==
infoPtr
->
uFocus
)
)
(
iItem
==
infoPtr
->
uFocus
)
)
{
{
InflateRect
(
&
r
,
FOCUS_RECT_HOFFSET
,
FOCUS_RECT_VOFFSET
);
r
=
itemRect
;
InflateRect
(
&
r
,
-
1
,
-
1
);
SelectObject
(
hdc
,
hfocusPen
);
SelectObject
(
hdc
,
hfocusPen
);
...
...
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