4 * Copyright 1998,1999 Eric Kohl
7 * - A little bug in TOOLBAR_DrawMasked()
8 * - Button wrapping (under construction).
12 * - Tooltip support (almost complete).
14 * - Internal COMMCTL32 bitmaps.
15 * - Fix TOOLBAR_SetButtonInfo32A.
16 * - Customize dialog (under construction).
19 * - Run tests using Waite Group Windows95 API Bible Volume 2.
20 * The second cdrom contains executables addstr.exe, btncount.exe,
21 * btnstate.exe, butstrsz.exe, chkbtn.exe, chngbmp.exe, customiz.exe,
22 * enablebtn.exe, getbmp.exe, getbtn.exe, getflags.exe, hidebtn.exe,
23 * indetbtn.exe, insbtn.exe, pressbtn.exe, setbtnsz.exe, setcmdid.exe,
24 * setparnt.exe, setrows.exe, toolwnd.exe.
25 * - Microsofts controlspy examples.
37 #include "debugtools.h"
39 DEFAULT_DEBUG_CHANNEL(toolbar)
41 #define SEPARATOR_WIDTH 8
43 #define BOTTOM_BORDER 2
45 #define TOOLBAR_GetInfoPtr(wndPtr) ((TOOLBAR_INFO *)GetWindowLongA(hwnd,0))
49 TOOLBAR_DrawFlatSeparator (LPRECT lpRect, HDC hdc)
51 INT x = (lpRect->left + lpRect->right) / 2 - 1;
52 INT yBottom = lpRect->bottom - 3;
53 INT yTop = lpRect->top + 1;
55 SelectObject ( hdc, GetSysColorPen (COLOR_3DSHADOW));
56 MoveToEx (hdc, x, yBottom, NULL);
57 LineTo (hdc, x, yTop);
59 SelectObject ( hdc, GetSysColorPen (COLOR_3DHILIGHT));
60 MoveToEx (hdc, x, yBottom, NULL);
61 LineTo (hdc, x, yTop);
66 TOOLBAR_DrawString (TOOLBAR_INFO *infoPtr, TBUTTON_INFO *btnPtr,
69 RECT rcText = btnPtr->rect;
75 if ((btnPtr->iString > -1) && (btnPtr->iString < infoPtr->nNumStrings)) {
76 InflateRect (&rcText, -3, -3);
77 rcText.top += infoPtr->nBitmapHeight;
78 if (nState & (TBSTATE_PRESSED | TBSTATE_CHECKED))
79 OffsetRect (&rcText, 1, 1);
81 hOldFont = SelectObject (hdc, infoPtr->hFont);
82 nOldBkMode = SetBkMode (hdc, TRANSPARENT);
83 if (!(nState & TBSTATE_ENABLED)) {
84 clrOld = SetTextColor (hdc, GetSysColor (COLOR_3DHILIGHT));
85 OffsetRect (&rcText, 1, 1);
86 DrawTextW (hdc, infoPtr->strings[btnPtr->iString], -1,
87 &rcText, infoPtr->dwDTFlags);
88 SetTextColor (hdc, GetSysColor (COLOR_3DSHADOW));
89 OffsetRect (&rcText, -1, -1);
90 DrawTextW (hdc, infoPtr->strings[btnPtr->iString], -1,
91 &rcText, infoPtr->dwDTFlags);
93 else if (nState & TBSTATE_INDETERMINATE) {
94 clrOld = SetTextColor (hdc, GetSysColor (COLOR_3DSHADOW));
95 DrawTextW (hdc, infoPtr->strings[btnPtr->iString], -1,
96 &rcText, infoPtr->dwDTFlags);
99 clrOld = SetTextColor (hdc, GetSysColor (COLOR_BTNTEXT));
100 DrawTextW (hdc, infoPtr->strings[btnPtr->iString], -1,
101 &rcText, infoPtr->dwDTFlags);
104 SetTextColor (hdc, clrOld);
105 SelectObject (hdc, hOldFont);
106 if (nOldBkMode != TRANSPARENT)
107 SetBkMode (hdc, nOldBkMode);
113 TOOLBAR_DrawPattern (HDC hdc, LPRECT lpRect)
115 HBRUSH hbr = SelectObject (hdc, CACHE_GetPattern55AABrush ());
116 INT cx = lpRect->right - lpRect->left;
117 INT cy = lpRect->bottom - lpRect->top;
118 PatBlt (hdc, lpRect->left, lpRect->top, cx, cy, 0x00FA0089);
119 SelectObject (hdc, hbr);
124 TOOLBAR_DrawMasked (TOOLBAR_INFO *infoPtr, TBUTTON_INFO *btnPtr,
125 HDC hdc, INT x, INT y)
127 /* FIXME: this function is a hack since it uses image list
128 internals directly */
130 HDC hdcImageList = CreateCompatibleDC (0);
131 HDC hdcMask = CreateCompatibleDC (0);
132 HIMAGELIST himl = infoPtr->himlDef;
135 /* create new bitmap */
136 hbmMask = CreateBitmap (himl->cx, himl->cy, 1, 1, NULL);
137 SelectObject (hdcMask, hbmMask);
139 /* copy the mask bitmap */
140 SelectObject (hdcImageList, himl->hbmMask);
141 SetBkColor (hdcImageList, RGB(255, 255, 255));
142 SetTextColor (hdcImageList, RGB(0, 0, 0));
143 BitBlt (hdcMask, 0, 0, himl->cx, himl->cy,
144 hdcImageList, himl->cx * btnPtr->iBitmap, 0, SRCCOPY);
147 /* add white mask from image */
148 SelectObject (hdcImageList, himl->hbmImage);
149 SetBkColor (hdcImageList, RGB(0, 0, 0));
150 BitBlt (hdcMask, 0, 0, himl->cx, himl->cy,
151 hdcImageList, himl->cx * btnPtr->iBitmap, 0, MERGEPAINT);
154 /* draw the new mask */
155 SelectObject (hdc, GetSysColorBrush (COLOR_3DHILIGHT));
156 BitBlt (hdc, x+1, y+1, himl->cx, himl->cy,
157 hdcMask, 0, 0, 0xB8074A);
159 SelectObject (hdc, GetSysColorBrush (COLOR_3DSHADOW));
160 BitBlt (hdc, x, y, himl->cx, himl->cy,
161 hdcMask, 0, 0, 0xB8074A);
163 DeleteObject (hbmMask);
165 DeleteDC (hdcImageList);
170 TOOLBAR_DrawButton (HWND hwnd, TBUTTON_INFO *btnPtr, HDC hdc)
172 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
173 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
176 if (btnPtr->fsState & TBSTATE_HIDDEN)
182 if (btnPtr->fsStyle & TBSTYLE_SEP) {
183 if ((dwStyle & TBSTYLE_FLAT) && (btnPtr->idCommand == 0))
184 TOOLBAR_DrawFlatSeparator (&rc, hdc);
189 if (!(btnPtr->fsState & TBSTATE_ENABLED)) {
190 if (!(dwStyle & TBSTYLE_FLAT))
191 DrawEdge (hdc, &rc, EDGE_RAISED,
192 BF_SOFT | BF_RECT | BF_MIDDLE | BF_ADJUST);
194 if (infoPtr->himlDis)
195 ImageList_Draw (infoPtr->himlDis, btnPtr->iBitmap, hdc,
196 rc.left+1, rc.top+1, ILD_NORMAL);
198 TOOLBAR_DrawMasked (infoPtr, btnPtr, hdc, rc.left+1, rc.top+1);
200 TOOLBAR_DrawString (infoPtr, btnPtr, hdc, btnPtr->fsState);
204 /* pressed TBSTYLE_BUTTON */
205 if (btnPtr->fsState & TBSTATE_PRESSED) {
206 DrawEdge (hdc, &rc, EDGE_SUNKEN, BF_RECT | BF_MIDDLE | BF_ADJUST);
207 ImageList_Draw (infoPtr->himlDef, btnPtr->iBitmap, hdc,
208 rc.left+2, rc.top+2, ILD_NORMAL);
209 TOOLBAR_DrawString (infoPtr, btnPtr, hdc, btnPtr->fsState);
213 /* checked TBSTYLE_CHECK */
214 if ((btnPtr->fsStyle & TBSTYLE_CHECK) &&
215 (btnPtr->fsState & TBSTATE_CHECKED)) {
216 if (dwStyle & TBSTYLE_FLAT)
217 DrawEdge (hdc, &rc, BDR_SUNKENOUTER,
218 BF_RECT | BF_MIDDLE | BF_ADJUST);
220 DrawEdge (hdc, &rc, EDGE_SUNKEN,
221 BF_RECT | BF_MIDDLE | BF_ADJUST);
223 TOOLBAR_DrawPattern (hdc, &rc);
225 ImageList_Draw (infoPtr->himlDef, btnPtr->iBitmap, hdc,
226 rc.left+2, rc.top+2, ILD_NORMAL);
228 TOOLBAR_DrawString (infoPtr, btnPtr, hdc, btnPtr->fsState);
233 if (btnPtr->fsState & TBSTATE_INDETERMINATE) {
234 DrawEdge (hdc, &rc, EDGE_RAISED,
235 BF_SOFT | BF_RECT | BF_MIDDLE | BF_ADJUST);
237 TOOLBAR_DrawPattern (hdc, &rc);
238 TOOLBAR_DrawMasked (infoPtr, btnPtr, hdc, rc.left+1, rc.top+1);
239 TOOLBAR_DrawString (infoPtr, btnPtr, hdc, btnPtr->fsState);
244 if (dwStyle & TBSTYLE_FLAT)
247 DrawEdge (hdc, &rc, BDR_RAISEDINNER,
248 BF_RECT | BF_MIDDLE | BF_SOFT);
249 if (btnPtr->bHot && infoPtr->himlHot)
250 ImageList_Draw (infoPtr->himlHot, btnPtr->iBitmap, hdc,
251 rc.left +2, rc.top +2, ILD_NORMAL);
253 ImageList_Draw (infoPtr->himlDef, btnPtr->iBitmap, hdc,
254 rc.left +2, rc.top +2, ILD_NORMAL);
258 DrawEdge (hdc, &rc, EDGE_RAISED,
259 BF_SOFT | BF_RECT | BF_MIDDLE | BF_ADJUST);
261 ImageList_Draw (infoPtr->himlDef, btnPtr->iBitmap, hdc,
262 rc.left+1, rc.top+1, ILD_NORMAL);
265 TOOLBAR_DrawString (infoPtr, btnPtr, hdc, btnPtr->fsState);
270 TOOLBAR_Refresh (HWND hwnd, HDC hdc)
272 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
273 TBUTTON_INFO *btnPtr;
277 btnPtr = infoPtr->buttons;
278 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++)
279 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
284 TOOLBAR_CalcStrings (HWND hwnd, LPSIZE lpSize)
286 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
287 TBUTTON_INFO *btnPtr;
296 hOldFont = SelectObject (hdc, infoPtr->hFont);
298 btnPtr = infoPtr->buttons;
299 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++) {
300 if (!(btnPtr->fsState & TBSTATE_HIDDEN) &&
301 (btnPtr->iString > -1) &&
302 (btnPtr->iString < infoPtr->nNumStrings)) {
303 LPWSTR lpText = infoPtr->strings[btnPtr->iString];
304 GetTextExtentPoint32W (hdc, lpText, lstrlenW (lpText), &sz);
305 if (sz.cx > lpSize->cx)
307 if (sz.cy > lpSize->cy)
312 SelectObject (hdc, hOldFont);
315 TRACE("string size %d x %d!\n", lpSize->cx, lpSize->cy);
318 /***********************************************************************
319 * TOOLBAR_WrapToolbar
321 * This function walks through the buttons and seperators in the
322 * toolbar, and sets the TBSTATE_WRAP flag only on those items where
323 * wrapping should occur based on the width of the toolbar window.
324 * It does *not* calculate button placement itself. That task
325 * takes place in TOOLBAR_CalcToolbar. If the program wants to manage
326 * the toolbar wrapping on it's own, it can use the TBSTYLE_WRAPPABLE
327 * flag, and set the TBSTATE_WRAP flags manually on the appropriate items.
331 TOOLBAR_WrapToolbar( HWND hwnd )
333 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
334 TBUTTON_INFO *btnPtr;
335 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
338 BOOL bWrap, bButtonWrap;
340 /* When the toolbar window style is not TBSTYLE_WRAPABLE, */
341 /* no layout is necessary. Applications may use this style */
342 /* to perform their own layout on the toolbar. */
343 if( !(dwStyle & TBSTYLE_WRAPABLE) )
346 btnPtr = infoPtr->buttons;
347 x = infoPtr->nIndent;
349 GetClientRect( GetParent(hwnd), &rc );
350 infoPtr->nWidth = rc.right - rc.left;
353 for (i = 0; i < infoPtr->nNumButtons; i++ )
356 btnPtr[i].fsState &= ~TBSTATE_WRAP;
358 if (btnPtr[i].fsState & TBSTATE_HIDDEN)
361 /* UNDOCUMENTED: If a separator has a non zero bitmap index, */
362 /* it is the actual width of the separator. This is used for */
363 /* custom controls in toolbars. */
364 if (btnPtr[i].fsStyle & TBSTYLE_SEP)
365 cx = (btnPtr[i].iBitmap > 0) ?
366 btnPtr[i].iBitmap : SEPARATOR_WIDTH;
368 cx = infoPtr->nButtonWidth;
370 /* Two or more adjacent separators form a separator group. */
371 /* The first separator in a group should be wrapped to the */
372 /* next row if the previous wrapping is on a button. */
374 (btnPtr[i].fsStyle & TBSTYLE_SEP) &&
375 (i + 1 < infoPtr->nNumButtons ) &&
376 (btnPtr[i + 1].fsStyle & TBSTYLE_SEP) )
378 btnPtr[i].fsState |= TBSTATE_WRAP;
379 x = infoPtr->nIndent;
385 /* The layout makes sure the bitmap is visible, but not the button. */
386 if ( x + cx - (infoPtr->nButtonWidth - infoPtr->nBitmapWidth) / 2
391 /* If the current button is a separator and not hidden, */
392 /* go to the next until it reaches a non separator. */
393 /* Wrap the last separator if it is before a button. */
394 while( ( (btnPtr[i].fsStyle & TBSTYLE_SEP) ||
395 (btnPtr[i].fsState & TBSTATE_HIDDEN) ) &&
396 i < infoPtr->nNumButtons )
402 if( bFound && i < infoPtr->nNumButtons )
405 btnPtr[i].fsState |= TBSTATE_WRAP;
406 x = infoPtr->nIndent;
410 else if ( i >= infoPtr->nNumButtons)
413 /* If the current button is not a separator, find the last */
414 /* separator and wrap it. */
415 for ( j = i - 1; j >= 0 && !(btnPtr[j].fsState & TBSTATE_WRAP); j--)
417 if ((btnPtr[j].fsStyle & TBSTYLE_SEP) &&
418 !(btnPtr[j].fsState & TBSTATE_HIDDEN))
422 x = infoPtr->nIndent;
423 btnPtr[j].fsState |= TBSTATE_WRAP;
429 /* If no separator available for wrapping, wrap one of */
430 /* non-hidden previous button. */
434 j >= 0 && !(btnPtr[j].fsState & TBSTATE_WRAP); j--)
436 if (btnPtr[j].fsState & TBSTATE_HIDDEN)
441 x = infoPtr->nIndent;
442 btnPtr[j].fsState |= TBSTATE_WRAP;
448 /* If all above failed, wrap the current button. */
451 btnPtr[i].fsState |= TBSTATE_WRAP;
453 x = infoPtr->nIndent;
454 if (btnPtr[i].fsState & TBSTYLE_SEP )
465 /***********************************************************************
466 * TOOLBAR_CalcToolbar
468 * This function calculates button and separator placement. It first
469 * calculates the button sizes, gets the toolbar window width and then
470 * calls TOOLBAR_WrapToolbar to determine which buttons we need to wrap
471 * on. It assigns a new location to each item and sends this location to
472 * the tooltip window if appropriate. Finally, it updates the rcBound
473 * rect and calculates the new required toolbar window height.
477 TOOLBAR_CalcToolbar (HWND hwnd)
479 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr(hwnd);
480 TBUTTON_INFO *btnPtr;
481 INT i, nRows, nSepRows;
487 TOOLBAR_CalcStrings (hwnd, &sizeString);
489 if (sizeString.cy > 0)
490 infoPtr->nButtonHeight = sizeString.cy + infoPtr->nBitmapHeight + 6;
491 else if (infoPtr->nButtonHeight < infoPtr->nBitmapHeight + 6)
492 infoPtr->nButtonHeight = infoPtr->nBitmapHeight + 6;
494 if (sizeString.cx > infoPtr->nBitmapWidth)
495 infoPtr->nButtonWidth = sizeString.cx + 6;
496 else if (infoPtr->nButtonWidth < infoPtr->nBitmapWidth + 6)
497 infoPtr->nButtonWidth = infoPtr->nBitmapWidth + 6;
499 TOOLBAR_WrapToolbar( hwnd );
501 x = infoPtr->nIndent;
503 cx = infoPtr->nButtonWidth;
504 cy = infoPtr->nButtonHeight;
505 nRows = nSepRows = 0;
507 infoPtr->rcBound.top = y;
508 infoPtr->rcBound.left = x;
509 infoPtr->rcBound.bottom = y + cy;
510 infoPtr->rcBound.right = x;
512 btnPtr = infoPtr->buttons;
513 GetClientRect( GetParent(hwnd), &rc );
514 infoPtr->nWidth = rc.right - rc.left;
516 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++ )
519 if (btnPtr->fsState & TBSTATE_HIDDEN)
521 SetRectEmpty (&btnPtr->rect);
525 /* UNDOCUMENTED: If a separator has a non zero bitmap index, */
526 /* it is the actual width of the separator. This is used for */
527 /* custom controls in toolbars. */
528 if (btnPtr->fsStyle & TBSTYLE_SEP)
529 cx = (btnPtr->iBitmap > 0) ?
530 btnPtr->iBitmap : SEPARATOR_WIDTH;
532 cx = infoPtr->nButtonWidth;
534 if (btnPtr->fsState & TBSTATE_WRAP )
537 SetRect (&btnPtr->rect, x, y, x + cx, y + cy);
539 if (infoPtr->rcBound.left > x)
540 infoPtr->rcBound.left = x;
541 if (infoPtr->rcBound.right < x + cx)
542 infoPtr->rcBound.right = x + cx;
543 if (infoPtr->rcBound.bottom < y + cy)
544 infoPtr->rcBound.bottom = y + cy;
546 /* Set the toolTip only for non-hidden, non-separator button */
547 if (infoPtr->hwndToolTip && !(btnPtr->fsStyle & TBSTYLE_SEP ))
551 ZeroMemory (&ti, sizeof(TTTOOLINFOA));
552 ti.cbSize = sizeof(TTTOOLINFOA);
554 ti.uId = btnPtr->idCommand;
555 ti.rect = btnPtr->rect;
556 SendMessageA (infoPtr->hwndToolTip, TTM_NEWTOOLRECTA,
560 /* btnPtr->nRow is zero based. The space between the rows is */
561 /* also considered as a row. */
562 btnPtr->nRow = nRows + nSepRows;
565 if ( !(btnPtr->fsStyle & TBSTYLE_SEP) )
569 /* UNDOCUMENTED: If a separator has a non zero bitmap index, */
570 /* it is the actual width of the separator. This is used for */
571 /* custom controls in toolbars. */
572 y += cy + ( (btnPtr->iBitmap > 0 ) ?
573 btnPtr->iBitmap : SEPARATOR_WIDTH) * 2 /3;
575 /* nSepRows is used to calculate the extra height follwoing */
579 x = infoPtr->nIndent;
586 /* infoPtr->nRows is the number of rows on the toolbar */
587 infoPtr->nRows = nRows + nSepRows + 1;
589 /* nSepRows * (infoPtr->nBitmapHeight + 1) is the space following */
591 infoPtr->nHeight = TOP_BORDER + (nRows + 1) * infoPtr->nButtonHeight +
592 nSepRows * SEPARATOR_WIDTH * 2 / 3 +
593 nSepRows * (infoPtr->nBitmapHeight + 1) +
595 TRACE("toolbar height %d\n", infoPtr->nHeight);
600 TOOLBAR_InternalHitTest (HWND hwnd, LPPOINT lpPt)
602 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
603 TBUTTON_INFO *btnPtr;
606 btnPtr = infoPtr->buttons;
607 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++) {
608 if (btnPtr->fsState & TBSTATE_HIDDEN)
611 if (btnPtr->fsStyle & TBSTYLE_SEP) {
612 if (PtInRect (&btnPtr->rect, *lpPt)) {
613 TRACE(" ON SEPARATOR %d!\n", i);
618 if (PtInRect (&btnPtr->rect, *lpPt)) {
619 TRACE(" ON BUTTON %d!\n", i);
625 TRACE(" NOWHERE!\n");
631 TOOLBAR_GetButtonIndex (TOOLBAR_INFO *infoPtr, INT idCommand)
633 TBUTTON_INFO *btnPtr;
636 btnPtr = infoPtr->buttons;
637 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++) {
638 if (btnPtr->idCommand == idCommand) {
639 TRACE("command=%d index=%d\n", idCommand, i);
643 TRACE("no index found for command=%d\n", idCommand);
649 TOOLBAR_GetCheckedGroupButtonIndex (TOOLBAR_INFO *infoPtr, INT nIndex)
651 TBUTTON_INFO *btnPtr;
654 if ((nIndex < 0) || (nIndex > infoPtr->nNumButtons))
657 /* check index button */
658 btnPtr = &infoPtr->buttons[nIndex];
659 if ((btnPtr->fsStyle & TBSTYLE_CHECKGROUP) == TBSTYLE_CHECKGROUP) {
660 if (btnPtr->fsState & TBSTATE_CHECKED)
664 /* check previous buttons */
665 nRunIndex = nIndex - 1;
666 while (nRunIndex >= 0) {
667 btnPtr = &infoPtr->buttons[nRunIndex];
668 if ((btnPtr->fsStyle & TBSTYLE_CHECKGROUP) == TBSTYLE_CHECKGROUP) {
669 if (btnPtr->fsState & TBSTATE_CHECKED)
677 /* check next buttons */
678 nRunIndex = nIndex + 1;
679 while (nRunIndex < infoPtr->nNumButtons) {
680 btnPtr = &infoPtr->buttons[nRunIndex];
681 if ((btnPtr->fsStyle & TBSTYLE_CHECKGROUP) == TBSTYLE_CHECKGROUP) {
682 if (btnPtr->fsState & TBSTATE_CHECKED)
695 TOOLBAR_RelayEvent (HWND hwndTip, HWND hwndMsg, UINT uMsg,
696 WPARAM wParam, LPARAM lParam)
704 msg.time = GetMessageTime ();
705 msg.pt.x = LOWORD(GetMessagePos ());
706 msg.pt.y = HIWORD(GetMessagePos ());
708 SendMessageA (hwndTip, TTM_RELAYEVENT, 0, (LPARAM)&msg);
712 /***********************************************************************
713 * TOOLBAR_CustomizeDialogProc
714 * This function implements the toolbar customization dialog.
717 TOOLBAR_CustomizeDialogProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
719 TOOLBAR_INFO *infoPtr = (TOOLBAR_INFO *)GetWindowLongA (hwnd, DWL_USER);
720 static HDSA hDsa = NULL;
725 infoPtr = (TOOLBAR_INFO *)lParam;
726 SetWindowLongA (hwnd, DWL_USER, (DWORD)infoPtr);
728 hDsa = DSA_Create (sizeof(TBUTTON_INFO), 5);
732 TBUTTON_INFO *btnPtr;
735 /* insert 'virtual' separator button into 'available buttons' list */
736 SendDlgItemMessageA (hwnd, IDC_AVAILBTN_LBOX, LB_ADDSTRING, 0, (LPARAM)"");
738 /* copy all buttons and append them to the right listbox */
739 btnPtr = infoPtr->buttons;
740 for (i = 0; i < infoPtr->nNumButtons; i++, btnPtr++)
742 DSA_InsertItem (hDsa, i, btnPtr);
744 if (btnPtr->fsState & TBSTATE_HIDDEN)
746 SendDlgItemMessageA (hwnd, IDC_AVAILBTN_LBOX, LB_ADDSTRING, 0, (LPARAM)"");
750 SendDlgItemMessageA (hwnd, IDC_TOOLBARBTN_LBOX, LB_ADDSTRING, 0, (LPARAM)"");
754 /* append 'virtual' sepatator button to the 'toolbar buttons' list */
760 EndDialog(hwnd, FALSE);
764 switch (LOWORD(wParam))
767 EndDialog(hwnd, FALSE);
778 if (wParam == IDC_AVAILBTN_LBOX || wParam == IDC_TOOLBARBTN_LBOX)
780 LPDRAWITEMSTRUCT lpdis = (LPDRAWITEMSTRUCT)lParam;
785 COLORREF oldText = 0;
788 FIXME("action: %x itemState: %x\n",
789 lpdis->itemAction, lpdis->itemState);
791 if (lpdis->itemState & ODS_FOCUS)
793 oldBk = SetBkColor (lpdis->hDC, GetSysColor(COLOR_HIGHLIGHT));
794 oldText = SetTextColor (lpdis->hDC, GetSysColor(COLOR_HIGHLIGHTTEXT));
797 hOldPen = SelectObject (lpdis->hDC, GetSysColorPen ((lpdis->itemState & ODS_SELECTED)?COLOR_HIGHLIGHT:COLOR_WINDOW));
798 hOldBrush = SelectObject (lpdis->hDC, GetSysColorBrush ((lpdis->itemState & ODS_FOCUS)?COLOR_HIGHLIGHT:COLOR_WINDOW));
800 /* fill background rectangle */
801 Rectangle (lpdis->hDC, lpdis->rcItem.left, lpdis->rcItem.top,
802 lpdis->rcItem.right, lpdis->rcItem.bottom);
804 /* calculate button and text rectangles */
805 CopyRect (&rcButton, &lpdis->rcItem);
806 InflateRect (&rcButton, -1, -1);
807 CopyRect (&rcText, &rcButton);
808 rcButton.right = rcButton.left + infoPtr->nBitmapWidth + 6;
809 rcText.left = rcButton.right + 2;
811 /* draw focus rectangle */
812 if (lpdis->itemState & ODS_FOCUS)
813 DrawFocusRect (lpdis->hDC, &lpdis->rcItem);
816 DrawEdge (lpdis->hDC, &rcButton, EDGE_RAISED, BF_RECT|BF_MIDDLE|BF_SOFT);
819 if (wParam == IDC_AVAILBTN_LBOX && lpdis->itemID == 0)
820 DrawTextA (lpdis->hDC, "Separator", -1, &rcText,
821 DT_LEFT | DT_VCENTER | DT_SINGLELINE);
823 if (lpdis->itemState & ODS_FOCUS)
825 SetBkColor (lpdis->hDC, oldBk);
826 SetTextColor (lpdis->hDC, oldText);
829 SelectObject (lpdis->hDC, hOldBrush);
830 SelectObject (lpdis->hDC, hOldPen);
837 if (wParam == IDC_AVAILBTN_LBOX || wParam == IDC_TOOLBARBTN_LBOX)
839 MEASUREITEMSTRUCT *lpmis = (MEASUREITEMSTRUCT*)lParam;
842 lpmis->itemHeight = infoPtr->nBitmapHeight + 8;
844 lpmis->itemHeight = 16 + 8; /* default height */
856 /***********************************************************************
857 * TOOLBAR_AddBitmap: Add the bitmaps to the default image list.
861 TOOLBAR_AddBitmap (HWND hwnd, WPARAM wParam, LPARAM lParam)
863 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
864 LPTBADDBITMAP lpAddBmp = (LPTBADDBITMAP)lParam;
865 INT nIndex = 0, nButtons;
870 if (lpAddBmp->hInst == HINST_COMMCTRL)
872 if ((lpAddBmp->nID & ~1) == IDB_STD_SMALL_COLOR)
874 else if ((lpAddBmp->nID & ~1) == IDB_VIEW_SMALL_COLOR)
876 else if ((lpAddBmp->nID & ~1) == IDB_HIST_SMALL_COLOR)
881 TRACE ("adding %d internal bitmaps!\n", nButtons);
883 /* Windows resize all the buttons to the size of a newly added STandard Image*/
884 if (lpAddBmp->nID & 1)
887 SendMessageA (hwnd, TB_SETBITMAPSIZE, 0,
888 MAKELPARAM((WORD)26, (WORD)26));
889 SendMessageA (hwnd, TB_SETBUTTONSIZE, 0,
890 MAKELPARAM((WORD)33, (WORD)33));
895 SendMessageA (hwnd, TB_SETBITMAPSIZE, 0,
896 MAKELPARAM((WORD)16, (WORD)16));
897 SendMessageA (hwnd, TB_SETBUTTONSIZE, 0,
898 MAKELPARAM((WORD)22, (WORD)22));
901 TOOLBAR_CalcToolbar (hwnd);
905 nButtons = (INT)wParam;
909 TRACE ("adding %d bitmaps!\n", nButtons);
912 if (!(infoPtr->himlDef)) {
913 /* create new default image list */
914 TRACE ("creating default image list!\n");
917 ImageList_Create (infoPtr->nBitmapWidth, infoPtr->nBitmapHeight,
918 ILC_COLOR | ILC_MASK, nButtons, 2);
919 infoPtr->himlInt = infoPtr->himlDef;
922 /* Add bitmaps to the default image list */
923 if (lpAddBmp->hInst == (HINSTANCE)0)
926 ImageList_AddMasked (infoPtr->himlDef, (HBITMAP)lpAddBmp->nID,
929 else if (lpAddBmp->hInst == HINST_COMMCTRL)
931 /* add internal bitmaps */
932 FIXME ("internal bitmaps not supported!\n");
934 /* Hack to "add" some reserved images within the image list
935 to get the right image indices */
936 nIndex = ImageList_GetImageCount (infoPtr->himlDef);
937 ImageList_SetImageCount (infoPtr->himlDef, nIndex + nButtons);
942 LoadBitmapA (lpAddBmp->hInst, (LPSTR)lpAddBmp->nID);
943 nIndex = ImageList_AddMasked (infoPtr->himlDef, hBmp, CLR_DEFAULT);
948 infoPtr->nNumBitmaps += nButtons;
955 TOOLBAR_AddButtonsA (HWND hwnd, WPARAM wParam, LPARAM lParam)
957 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
958 LPTBBUTTON lpTbb = (LPTBBUTTON)lParam;
959 INT nOldButtons, nNewButtons, nAddButtons, nCount;
961 TRACE("adding %d buttons!\n", wParam);
963 nAddButtons = (UINT)wParam;
964 nOldButtons = infoPtr->nNumButtons;
965 nNewButtons = nOldButtons + nAddButtons;
967 if (infoPtr->nNumButtons == 0) {
969 COMCTL32_Alloc (sizeof(TBUTTON_INFO) * nNewButtons);
972 TBUTTON_INFO *oldButtons = infoPtr->buttons;
974 COMCTL32_Alloc (sizeof(TBUTTON_INFO) * nNewButtons);
975 memcpy (&infoPtr->buttons[0], &oldButtons[0],
976 nOldButtons * sizeof(TBUTTON_INFO));
977 COMCTL32_Free (oldButtons);
980 infoPtr->nNumButtons = nNewButtons;
982 /* insert new button data */
983 for (nCount = 0; nCount < nAddButtons; nCount++) {
984 TBUTTON_INFO *btnPtr = &infoPtr->buttons[nOldButtons+nCount];
985 btnPtr->iBitmap = lpTbb[nCount].iBitmap;
986 btnPtr->idCommand = lpTbb[nCount].idCommand;
987 btnPtr->fsState = lpTbb[nCount].fsState;
988 btnPtr->fsStyle = lpTbb[nCount].fsStyle;
989 btnPtr->dwData = lpTbb[nCount].dwData;
990 btnPtr->iString = lpTbb[nCount].iString;
991 btnPtr->bHot = FALSE;
993 if ((infoPtr->hwndToolTip) && !(btnPtr->fsStyle & TBSTYLE_SEP)) {
996 ZeroMemory (&ti, sizeof(TTTOOLINFOA));
997 ti.cbSize = sizeof (TTTOOLINFOA);
999 ti.uId = btnPtr->idCommand;
1001 ti.lpszText = LPSTR_TEXTCALLBACKA;
1003 SendMessageA (infoPtr->hwndToolTip, TTM_ADDTOOLA,
1008 TOOLBAR_CalcToolbar (hwnd);
1010 InvalidateRect(hwnd, NULL, FALSE);
1016 /* << TOOLBAR_AddButtons32W >> */
1020 TOOLBAR_AddStringA (HWND hwnd, WPARAM wParam, LPARAM lParam)
1022 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1025 if ((wParam) && (HIWORD(lParam) == 0)) {
1028 TRACE("adding string from resource!\n");
1030 len = LoadStringA ((HINSTANCE)wParam, (UINT)lParam,
1033 TRACE("len=%d \"%s\"\n", len, szString);
1034 nIndex = infoPtr->nNumStrings;
1035 if (infoPtr->nNumStrings == 0) {
1037 COMCTL32_Alloc (sizeof(LPWSTR));
1040 LPWSTR *oldStrings = infoPtr->strings;
1042 COMCTL32_Alloc (sizeof(LPWSTR) * (infoPtr->nNumStrings + 1));
1043 memcpy (&infoPtr->strings[0], &oldStrings[0],
1044 sizeof(LPWSTR) * infoPtr->nNumStrings);
1045 COMCTL32_Free (oldStrings);
1048 infoPtr->strings[infoPtr->nNumStrings] =
1049 COMCTL32_Alloc (sizeof(WCHAR)*(len+1));
1050 lstrcpyAtoW (infoPtr->strings[infoPtr->nNumStrings], szString);
1051 infoPtr->nNumStrings++;
1054 LPSTR p = (LPSTR)lParam;
1059 TRACE("adding string(s) from array!\n");
1060 nIndex = infoPtr->nNumStrings;
1063 TRACE("len=%d \"%s\"\n", len, p);
1065 if (infoPtr->nNumStrings == 0) {
1067 COMCTL32_Alloc (sizeof(LPWSTR));
1070 LPWSTR *oldStrings = infoPtr->strings;
1072 COMCTL32_Alloc (sizeof(LPWSTR) * (infoPtr->nNumStrings + 1));
1073 memcpy (&infoPtr->strings[0], &oldStrings[0],
1074 sizeof(LPWSTR) * infoPtr->nNumStrings);
1075 COMCTL32_Free (oldStrings);
1078 infoPtr->strings[infoPtr->nNumStrings] =
1079 COMCTL32_Alloc (sizeof(WCHAR)*(len+1));
1080 lstrcpyAtoW (infoPtr->strings[infoPtr->nNumStrings], p);
1081 infoPtr->nNumStrings++;
1092 TOOLBAR_AddStringW (HWND hwnd, WPARAM wParam, LPARAM lParam)
1094 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1097 if ((wParam) && (HIWORD(lParam) == 0)) {
1098 WCHAR szString[256];
1100 TRACE("adding string from resource!\n");
1102 len = LoadStringW ((HINSTANCE)wParam, (UINT)lParam,
1105 TRACE("len=%d \"%s\"\n", len, debugstr_w(szString));
1106 nIndex = infoPtr->nNumStrings;
1107 if (infoPtr->nNumStrings == 0) {
1109 COMCTL32_Alloc (sizeof(LPWSTR));
1112 LPWSTR *oldStrings = infoPtr->strings;
1114 COMCTL32_Alloc (sizeof(LPWSTR) * (infoPtr->nNumStrings + 1));
1115 memcpy (&infoPtr->strings[0], &oldStrings[0],
1116 sizeof(LPWSTR) * infoPtr->nNumStrings);
1117 COMCTL32_Free (oldStrings);
1120 infoPtr->strings[infoPtr->nNumStrings] =
1121 COMCTL32_Alloc (sizeof(WCHAR)*(len+1));
1122 lstrcpyW (infoPtr->strings[infoPtr->nNumStrings], szString);
1123 infoPtr->nNumStrings++;
1126 LPWSTR p = (LPWSTR)lParam;
1131 TRACE("adding string(s) from array!\n");
1132 nIndex = infoPtr->nNumStrings;
1135 TRACE("len=%d \"%s\"\n", len, debugstr_w(p));
1137 if (infoPtr->nNumStrings == 0) {
1139 COMCTL32_Alloc (sizeof(LPWSTR));
1142 LPWSTR *oldStrings = infoPtr->strings;
1144 COMCTL32_Alloc (sizeof(LPWSTR) * (infoPtr->nNumStrings + 1));
1145 memcpy (&infoPtr->strings[0], &oldStrings[0],
1146 sizeof(LPWSTR) * infoPtr->nNumStrings);
1147 COMCTL32_Free (oldStrings);
1150 infoPtr->strings[infoPtr->nNumStrings] =
1151 COMCTL32_Alloc (sizeof(WCHAR)*(len+1));
1152 lstrcpyW (infoPtr->strings[infoPtr->nNumStrings], p);
1153 infoPtr->nNumStrings++;
1164 TOOLBAR_AutoSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
1166 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1167 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
1174 TRACE("resize forced!\n");
1176 parent = GetParent (hwnd);
1177 GetClientRect(parent, &parent_rect);
1179 if (dwStyle & CCS_NORESIZE) {
1180 uPosFlags |= (SWP_NOSIZE | SWP_NOMOVE);
1185 infoPtr->nWidth = parent_rect.right - parent_rect.left;
1186 TOOLBAR_CalcToolbar (hwnd);
1187 InvalidateRect( hwnd, NULL, TRUE );
1188 cy = infoPtr->nHeight;
1189 cx = infoPtr->nWidth;
1192 if (dwStyle & CCS_NOPARENTALIGN)
1193 uPosFlags |= SWP_NOMOVE;
1195 if (!(dwStyle & CCS_NODIVIDER))
1196 cy += GetSystemMetrics(SM_CYEDGE);
1198 infoPtr->bAutoSize = TRUE;
1199 SetWindowPos (hwnd, HWND_TOP, parent_rect.left, parent_rect.top,
1207 TOOLBAR_ButtonCount (HWND hwnd, WPARAM wParam, LPARAM lParam)
1209 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1211 return infoPtr->nNumButtons;
1216 TOOLBAR_ButtonStructSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
1218 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1220 if (infoPtr == NULL) {
1221 ERR("(0x%x, 0x%x, 0x%lx)\n", hwnd, wParam, lParam);
1222 ERR("infoPtr == NULL!\n");
1226 infoPtr->dwStructSize = (DWORD)wParam;
1233 TOOLBAR_ChangeBitmap (HWND hwnd, WPARAM wParam, LPARAM lParam)
1235 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1236 TBUTTON_INFO *btnPtr;
1240 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1244 btnPtr = &infoPtr->buttons[nIndex];
1245 btnPtr->iBitmap = LOWORD(lParam);
1248 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
1249 ReleaseDC (hwnd, hdc);
1256 TOOLBAR_CheckButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1258 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1259 TBUTTON_INFO *btnPtr;
1264 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1268 btnPtr = &infoPtr->buttons[nIndex];
1270 if (!(btnPtr->fsStyle & TBSTYLE_CHECK))
1273 if (LOWORD(lParam) == FALSE)
1274 btnPtr->fsState &= ~TBSTATE_CHECKED;
1276 if (btnPtr->fsStyle & TBSTYLE_GROUP) {
1278 TOOLBAR_GetCheckedGroupButtonIndex (infoPtr, nIndex);
1279 if (nOldIndex == nIndex)
1281 if (nOldIndex != -1)
1282 infoPtr->buttons[nOldIndex].fsState &= ~TBSTATE_CHECKED;
1284 btnPtr->fsState |= TBSTATE_CHECKED;
1288 if (nOldIndex != -1)
1289 TOOLBAR_DrawButton (hwnd, &infoPtr->buttons[nOldIndex], hdc);
1290 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
1291 ReleaseDC (hwnd, hdc);
1293 /* FIXME: Send a WM_NOTIFY?? */
1300 TOOLBAR_CommandToIndex (HWND hwnd, WPARAM wParam, LPARAM lParam)
1302 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1304 return TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1309 TOOLBAR_Customize (HWND hwnd)
1311 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1317 /* send TBN_BEGINADJUST notification */
1318 nmhdr.hwndFrom = hwnd;
1319 nmhdr.idFrom = GetWindowLongA (hwnd, GWL_ID);
1320 nmhdr.code = TBN_BEGINADJUST;
1322 SendMessageA (infoPtr->hwndNotify, WM_NOTIFY,
1323 (WPARAM)nmhdr.idFrom, (LPARAM)&nmhdr);
1325 if (!(hRes = FindResourceA (COMCTL32_hModule,
1326 MAKEINTRESOURCEA(IDD_TBCUSTOMIZE),
1330 if(!(template = (LPVOID)LoadResource (COMCTL32_hModule, hRes)))
1333 ret = DialogBoxIndirectParamA (GetWindowLongA (hwnd, GWL_HINSTANCE),
1334 (LPDLGTEMPLATEA)template,
1336 (DLGPROC)TOOLBAR_CustomizeDialogProc,
1339 /* send TBN_ENDADJUST notification */
1340 nmhdr.code = TBN_ENDADJUST;
1342 SendMessageA (infoPtr->hwndNotify, WM_NOTIFY,
1343 (WPARAM)nmhdr.idFrom, (LPARAM)&nmhdr);
1350 TOOLBAR_DeleteButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1352 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1353 INT nIndex = (INT)wParam;
1355 if ((nIndex < 0) || (nIndex >= infoPtr->nNumButtons))
1358 if ((infoPtr->hwndToolTip) &&
1359 !(infoPtr->buttons[nIndex].fsStyle & TBSTYLE_SEP)) {
1362 ZeroMemory (&ti, sizeof(TTTOOLINFOA));
1363 ti.cbSize = sizeof (TTTOOLINFOA);
1365 ti.uId = infoPtr->buttons[nIndex].idCommand;
1367 SendMessageA (infoPtr->hwndToolTip, TTM_DELTOOLA, 0, (LPARAM)&ti);
1370 if (infoPtr->nNumButtons == 1) {
1371 TRACE(" simple delete!\n");
1372 COMCTL32_Free (infoPtr->buttons);
1373 infoPtr->buttons = NULL;
1374 infoPtr->nNumButtons = 0;
1377 TBUTTON_INFO *oldButtons = infoPtr->buttons;
1378 TRACE("complex delete! [nIndex=%d]\n", nIndex);
1380 infoPtr->nNumButtons--;
1381 infoPtr->buttons = COMCTL32_Alloc (sizeof (TBUTTON_INFO) * infoPtr->nNumButtons);
1383 memcpy (&infoPtr->buttons[0], &oldButtons[0],
1384 nIndex * sizeof(TBUTTON_INFO));
1387 if (nIndex < infoPtr->nNumButtons) {
1388 memcpy (&infoPtr->buttons[nIndex], &oldButtons[nIndex+1],
1389 (infoPtr->nNumButtons - nIndex) * sizeof(TBUTTON_INFO));
1392 COMCTL32_Free (oldButtons);
1395 TOOLBAR_CalcToolbar (hwnd);
1397 InvalidateRect (hwnd, NULL, TRUE);
1404 TOOLBAR_EnableButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1406 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1407 TBUTTON_INFO *btnPtr;
1411 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1415 btnPtr = &infoPtr->buttons[nIndex];
1416 if (LOWORD(lParam) == FALSE)
1417 btnPtr->fsState &= ~(TBSTATE_ENABLED | TBSTATE_PRESSED);
1419 btnPtr->fsState |= TBSTATE_ENABLED;
1422 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
1423 ReleaseDC (hwnd, hdc);
1429 /* << TOOLBAR_GetAnchorHighlight >> */
1433 TOOLBAR_GetBitmap (HWND hwnd, WPARAM wParam, LPARAM lParam)
1435 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1438 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1442 return infoPtr->buttons[nIndex].iBitmap;
1446 static inline LRESULT
1447 TOOLBAR_GetBitmapFlags (HWND hwnd, WPARAM wParam, LPARAM lParam)
1449 return (GetDeviceCaps (0, LOGPIXELSX) >= 120) ? TBBF_LARGE : 0;
1454 TOOLBAR_GetButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1456 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1457 LPTBBUTTON lpTbb = (LPTBBUTTON)lParam;
1458 INT nIndex = (INT)wParam;
1459 TBUTTON_INFO *btnPtr;
1461 if (infoPtr == NULL)
1467 if ((nIndex < 0) || (nIndex >= infoPtr->nNumButtons))
1470 btnPtr = &infoPtr->buttons[nIndex];
1471 lpTbb->iBitmap = btnPtr->iBitmap;
1472 lpTbb->idCommand = btnPtr->idCommand;
1473 lpTbb->fsState = btnPtr->fsState;
1474 lpTbb->fsStyle = btnPtr->fsStyle;
1475 lpTbb->dwData = btnPtr->dwData;
1476 lpTbb->iString = btnPtr->iString;
1483 TOOLBAR_GetButtonInfoA (HWND hwnd, WPARAM wParam, LPARAM lParam)
1485 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1486 LPTBBUTTONINFOA lpTbInfo = (LPTBBUTTONINFOA)lParam;
1487 TBUTTON_INFO *btnPtr;
1490 if (infoPtr == NULL)
1492 if (lpTbInfo == NULL)
1494 if (lpTbInfo->cbSize < sizeof(TBBUTTONINFOA))
1497 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1501 btnPtr = &infoPtr->buttons[nIndex];
1503 if (lpTbInfo->dwMask & TBIF_COMMAND)
1504 lpTbInfo->idCommand = btnPtr->idCommand;
1505 if (lpTbInfo->dwMask & TBIF_IMAGE)
1506 lpTbInfo->iImage = btnPtr->iBitmap;
1507 if (lpTbInfo->dwMask & TBIF_LPARAM)
1508 lpTbInfo->lParam = btnPtr->dwData;
1509 if (lpTbInfo->dwMask & TBIF_SIZE)
1510 lpTbInfo->cx = (WORD)(btnPtr->rect.right - btnPtr->rect.left);
1511 if (lpTbInfo->dwMask & TBIF_STATE)
1512 lpTbInfo->fsState = btnPtr->fsState;
1513 if (lpTbInfo->dwMask & TBIF_STYLE)
1514 lpTbInfo->fsStyle = btnPtr->fsStyle;
1515 if (lpTbInfo->dwMask & TBIF_TEXT) {
1516 if ((btnPtr->iString >= 0) || (btnPtr->iString < infoPtr->nNumStrings))
1517 lstrcpynA (lpTbInfo->pszText,
1518 (LPSTR)infoPtr->strings[btnPtr->iString],
1526 /* << TOOLBAR_GetButtonInfo32W >> */
1530 TOOLBAR_GetButtonSize (HWND hwnd)
1532 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1534 return MAKELONG((WORD)infoPtr->nButtonWidth,
1535 (WORD)infoPtr->nButtonHeight);
1540 TOOLBAR_GetButtonTextA (HWND hwnd, WPARAM wParam, LPARAM lParam)
1542 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1543 INT nIndex, nStringIndex;
1545 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1549 nStringIndex = infoPtr->buttons[nIndex].iString;
1551 TRACE("index=%d stringIndex=%d\n", nIndex, nStringIndex);
1553 if ((nStringIndex < 0) || (nStringIndex >= infoPtr->nNumStrings))
1556 if (lParam == 0) return -1;
1558 lstrcpyA ((LPSTR)lParam, (LPSTR)infoPtr->strings[nStringIndex]);
1560 return lstrlenA ((LPSTR)infoPtr->strings[nStringIndex]);
1564 /* << TOOLBAR_GetButtonText32W >> */
1565 /* << TOOLBAR_GetColorScheme >> */
1569 TOOLBAR_GetDisabledImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
1571 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1573 return (LRESULT)infoPtr->himlDis;
1577 inline static LRESULT
1578 TOOLBAR_GetExtendedStyle (HWND hwnd)
1580 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1582 return infoPtr->dwExStyle;
1587 TOOLBAR_GetHotImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
1589 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1591 return (LRESULT)infoPtr->himlHot;
1595 /* << TOOLBAR_GetHotItem >> */
1599 TOOLBAR_GetImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
1601 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1603 return (LRESULT)infoPtr->himlDef;
1607 /* << TOOLBAR_GetInsertMark >> */
1608 /* << TOOLBAR_GetInsertMarkColor >> */
1612 TOOLBAR_GetItemRect (HWND hwnd, WPARAM wParam, LPARAM lParam)
1614 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1615 TBUTTON_INFO *btnPtr;
1619 if (infoPtr == NULL)
1621 nIndex = (INT)wParam;
1622 btnPtr = &infoPtr->buttons[nIndex];
1623 if ((nIndex < 0) || (nIndex >= infoPtr->nNumButtons))
1625 lpRect = (LPRECT)lParam;
1628 if (btnPtr->fsState & TBSTATE_HIDDEN)
1631 TOOLBAR_CalcToolbar( hwnd );
1633 lpRect->left = btnPtr->rect.left;
1634 lpRect->right = btnPtr->rect.right;
1635 lpRect->bottom = btnPtr->rect.bottom;
1636 lpRect->top = btnPtr->rect.top;
1643 TOOLBAR_GetMaxSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
1645 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1646 LPSIZE lpSize = (LPSIZE)lParam;
1651 lpSize->cx = infoPtr->rcBound.right - infoPtr->rcBound.left;
1652 lpSize->cy = infoPtr->rcBound.bottom - infoPtr->rcBound.top;
1654 TRACE("maximum size %d x %d\n",
1655 infoPtr->rcBound.right - infoPtr->rcBound.left,
1656 infoPtr->rcBound.bottom - infoPtr->rcBound.top);
1662 /* << TOOLBAR_GetObject >> */
1663 /* << TOOLBAR_GetPadding >> */
1667 TOOLBAR_GetRect (HWND hwnd, WPARAM wParam, LPARAM lParam)
1669 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1670 TBUTTON_INFO *btnPtr;
1674 if (infoPtr == NULL)
1676 nIndex = (INT)wParam;
1677 btnPtr = &infoPtr->buttons[nIndex];
1678 if ((nIndex < 0) || (nIndex >= infoPtr->nNumButtons))
1680 lpRect = (LPRECT)lParam;
1684 lpRect->left = btnPtr->rect.left;
1685 lpRect->right = btnPtr->rect.right;
1686 lpRect->bottom = btnPtr->rect.bottom;
1687 lpRect->top = btnPtr->rect.top;
1694 TOOLBAR_GetRows (HWND hwnd, WPARAM wParam, LPARAM lParam)
1696 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1698 if (GetWindowLongA (hwnd, GWL_STYLE) & TBSTYLE_WRAPABLE)
1699 return infoPtr->nRows;
1706 TOOLBAR_GetState (HWND hwnd, WPARAM wParam, LPARAM lParam)
1708 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1711 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1715 return infoPtr->buttons[nIndex].fsState;
1720 TOOLBAR_GetStyle (HWND hwnd, WPARAM wParam, LPARAM lParam)
1722 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1725 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1729 return infoPtr->buttons[nIndex].fsStyle;
1734 TOOLBAR_GetTextRows (HWND hwnd, WPARAM wParam, LPARAM lParam)
1736 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1738 if (infoPtr == NULL)
1741 return infoPtr->nMaxTextRows;
1746 TOOLBAR_GetToolTips (HWND hwnd, WPARAM wParam, LPARAM lParam)
1748 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1750 if (infoPtr == NULL)
1752 return infoPtr->hwndToolTip;
1757 TOOLBAR_GetUnicodeFormat (HWND hwnd, WPARAM wParam, LPARAM lParam)
1759 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1761 TRACE("%s hwnd=0x%x stub!\n",
1762 infoPtr->bUnicode ? "TRUE" : "FALSE", hwnd);
1764 return infoPtr->bUnicode;
1769 TOOLBAR_HideButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1771 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1772 TBUTTON_INFO *btnPtr;
1775 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1779 btnPtr = &infoPtr->buttons[nIndex];
1780 if (LOWORD(lParam) == FALSE)
1781 btnPtr->fsState &= ~TBSTATE_HIDDEN;
1783 btnPtr->fsState |= TBSTATE_HIDDEN;
1785 TOOLBAR_CalcToolbar (hwnd);
1787 InvalidateRect (hwnd, NULL, TRUE);
1793 inline static LRESULT
1794 TOOLBAR_HitTest (HWND hwnd, WPARAM wParam, LPARAM lParam)
1796 return TOOLBAR_InternalHitTest (hwnd, (LPPOINT)lParam);
1801 TOOLBAR_Indeterminate (HWND hwnd, WPARAM wParam, LPARAM lParam)
1803 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1804 TBUTTON_INFO *btnPtr;
1808 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1812 btnPtr = &infoPtr->buttons[nIndex];
1813 if (LOWORD(lParam) == FALSE)
1814 btnPtr->fsState &= ~TBSTATE_INDETERMINATE;
1816 btnPtr->fsState |= TBSTATE_INDETERMINATE;
1819 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
1820 ReleaseDC (hwnd, hdc);
1827 TOOLBAR_InsertButtonA (HWND hwnd, WPARAM wParam, LPARAM lParam)
1829 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1830 LPTBBUTTON lpTbb = (LPTBBUTTON)lParam;
1831 INT nIndex = (INT)wParam;
1832 TBUTTON_INFO *oldButtons;
1839 TRACE("inserting button index=%d\n", nIndex);
1840 if (nIndex > infoPtr->nNumButtons) {
1841 nIndex = infoPtr->nNumButtons;
1842 TRACE("adjust index=%d\n", nIndex);
1845 oldButtons = infoPtr->buttons;
1846 infoPtr->nNumButtons++;
1847 infoPtr->buttons = COMCTL32_Alloc (sizeof (TBUTTON_INFO) * infoPtr->nNumButtons);
1848 /* pre insert copy */
1850 memcpy (&infoPtr->buttons[0], &oldButtons[0],
1851 nIndex * sizeof(TBUTTON_INFO));
1854 /* insert new button */
1855 infoPtr->buttons[nIndex].iBitmap = lpTbb->iBitmap;
1856 infoPtr->buttons[nIndex].idCommand = lpTbb->idCommand;
1857 infoPtr->buttons[nIndex].fsState = lpTbb->fsState;
1858 infoPtr->buttons[nIndex].fsStyle = lpTbb->fsStyle;
1859 infoPtr->buttons[nIndex].dwData = lpTbb->dwData;
1860 infoPtr->buttons[nIndex].iString = lpTbb->iString;
1862 if ((infoPtr->hwndToolTip) && !(lpTbb->fsStyle & TBSTYLE_SEP)) {
1865 ZeroMemory (&ti, sizeof(TTTOOLINFOA));
1866 ti.cbSize = sizeof (TTTOOLINFOA);
1868 ti.uId = lpTbb->idCommand;
1870 ti.lpszText = LPSTR_TEXTCALLBACKA;
1872 SendMessageA (infoPtr->hwndToolTip, TTM_ADDTOOLA,
1876 /* post insert copy */
1877 if (nIndex < infoPtr->nNumButtons - 1) {
1878 memcpy (&infoPtr->buttons[nIndex+1], &oldButtons[nIndex],
1879 (infoPtr->nNumButtons - nIndex - 1) * sizeof(TBUTTON_INFO));
1882 COMCTL32_Free (oldButtons);
1884 TOOLBAR_CalcToolbar (hwnd);
1886 InvalidateRect (hwnd, NULL, FALSE);
1892 /* << TOOLBAR_InsertButton32W >> */
1893 /* << TOOLBAR_InsertMarkHitTest >> */
1897 TOOLBAR_IsButtonChecked (HWND hwnd, WPARAM wParam, LPARAM lParam)
1899 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1902 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1906 return (infoPtr->buttons[nIndex].fsState & TBSTATE_CHECKED);
1911 TOOLBAR_IsButtonEnabled (HWND hwnd, WPARAM wParam, LPARAM lParam)
1913 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1916 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1920 return (infoPtr->buttons[nIndex].fsState & TBSTATE_ENABLED);
1925 TOOLBAR_IsButtonHidden (HWND hwnd, WPARAM wParam, LPARAM lParam)
1927 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1930 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1934 return (infoPtr->buttons[nIndex].fsState & TBSTATE_HIDDEN);
1939 TOOLBAR_IsButtonHighlighted (HWND hwnd, WPARAM wParam, LPARAM lParam)
1941 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1944 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1948 return (infoPtr->buttons[nIndex].fsState & TBSTATE_MARKED);
1953 TOOLBAR_IsButtonIndeterminate (HWND hwnd, WPARAM wParam, LPARAM lParam)
1955 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1958 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1962 return (infoPtr->buttons[nIndex].fsState & TBSTATE_INDETERMINATE);
1967 TOOLBAR_IsButtonPressed (HWND hwnd, WPARAM wParam, LPARAM lParam)
1969 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1972 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1976 return (infoPtr->buttons[nIndex].fsState & TBSTATE_PRESSED);
1980 /* << TOOLBAR_LoadImages >> */
1981 /* << TOOLBAR_MapAccelerator >> */
1982 /* << TOOLBAR_MarkButton >> */
1983 /* << TOOLBAR_MoveButton >> */
1987 TOOLBAR_PressButton (HWND hwnd, WPARAM wParam, LPARAM lParam)
1989 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
1990 TBUTTON_INFO *btnPtr;
1994 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
1998 btnPtr = &infoPtr->buttons[nIndex];
1999 if (LOWORD(lParam) == FALSE)
2000 btnPtr->fsState &= ~TBSTATE_PRESSED;
2002 btnPtr->fsState |= TBSTATE_PRESSED;
2005 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2006 ReleaseDC (hwnd, hdc);
2012 /* << TOOLBAR_ReplaceBitmap >> */
2016 TOOLBAR_SaveRestoreA (HWND hwnd, WPARAM wParam, LPARAM lParam)
2019 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2020 LPTBSAVEPARAMSA lpSave = (LPTBSAVEPARAMSA)lParam;
2022 if (lpSave == NULL) return 0;
2025 /* save toolbar information */
2026 FIXME("save to \"%s\" \"%s\"\n",
2027 lpSave->pszSubKey, lpSave->pszValueName);
2032 /* restore toolbar information */
2034 FIXME("restore from \"%s\" \"%s\"\n",
2035 lpSave->pszSubKey, lpSave->pszValueName);
2045 /* << TOOLBAR_SaveRestore32W >> */
2046 /* << TOOLBAR_SetAnchorHighlight >> */
2050 TOOLBAR_SetBitmapSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
2052 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2054 if ((LOWORD(lParam) <= 0) || (HIWORD(lParam)<=0))
2057 infoPtr->nBitmapWidth = (INT)LOWORD(lParam);
2058 infoPtr->nBitmapHeight = (INT)HIWORD(lParam);
2065 TOOLBAR_SetButtonInfoA (HWND hwnd, WPARAM wParam, LPARAM lParam)
2067 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2068 LPTBBUTTONINFOA lptbbi = (LPTBBUTTONINFOA)lParam;
2069 TBUTTON_INFO *btnPtr;
2074 if (lptbbi->cbSize < sizeof(TBBUTTONINFOA))
2077 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
2081 btnPtr = &infoPtr->buttons[nIndex];
2082 if (lptbbi->dwMask & TBIF_COMMAND)
2083 btnPtr->idCommand = lptbbi->idCommand;
2084 if (lptbbi->dwMask & TBIF_IMAGE)
2085 btnPtr->iBitmap = lptbbi->iImage;
2086 if (lptbbi->dwMask & TBIF_LPARAM)
2087 btnPtr->dwData = lptbbi->lParam;
2088 /* if (lptbbi->dwMask & TBIF_SIZE) */
2089 /* btnPtr->cx = lptbbi->cx; */
2090 if (lptbbi->dwMask & TBIF_STATE)
2091 btnPtr->fsState = lptbbi->fsState;
2092 if (lptbbi->dwMask & TBIF_STYLE)
2093 btnPtr->fsStyle = lptbbi->fsStyle;
2095 if (lptbbi->dwMask & TBIF_TEXT) {
2096 if ((btnPtr->iString >= 0) ||
2097 (btnPtr->iString < infoPtr->nNumStrings)) {
2099 CHAR **lpString = &infoPtr->strings[btnPtr->iString];
2100 INT len = lstrlenA (lptbbi->pszText);
2101 *lpString = COMCTL32_ReAlloc (lpString, sizeof(char)*(len+1));
2104 /* this is the ultimate sollution */
2105 /* Str_SetPtrA (&infoPtr->strings[btnPtr->iString], lptbbi->pszText); */
2113 /* << TOOLBAR_SetButtonInfo32W >> */
2117 TOOLBAR_SetButtonSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
2119 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2121 if ((LOWORD(lParam) <= 0) || (HIWORD(lParam)<=0))
2124 infoPtr->nButtonWidth = (INT)LOWORD(lParam);
2125 infoPtr->nButtonHeight = (INT)HIWORD(lParam);
2132 TOOLBAR_SetButtonWidth (HWND hwnd, WPARAM wParam, LPARAM lParam)
2134 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2136 if (infoPtr == NULL)
2139 infoPtr->cxMin = (INT)LOWORD(lParam);
2140 infoPtr->cxMax = (INT)HIWORD(lParam);
2147 TOOLBAR_SetCmdId (HWND hwnd, WPARAM wParam, LPARAM lParam)
2149 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2150 INT nIndex = (INT)wParam;
2152 if ((nIndex < 0) || (nIndex >= infoPtr->nNumButtons))
2155 infoPtr->buttons[nIndex].idCommand = (INT)lParam;
2157 if (infoPtr->hwndToolTip) {
2159 FIXME("change tool tip!\n");
2167 /* << TOOLBAR_SetColorScheme >> */
2171 TOOLBAR_SetDisabledImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
2173 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2174 HIMAGELIST himlTemp;
2176 himlTemp = infoPtr->himlDis;
2177 infoPtr->himlDis = (HIMAGELIST)lParam;
2179 /* FIXME: redraw ? */
2181 return (LRESULT)himlTemp;
2186 TOOLBAR_SetDrawTextFlags (HWND hwnd, WPARAM wParam, LPARAM lParam)
2188 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2191 dwTemp = infoPtr->dwDTFlags;
2192 infoPtr->dwDTFlags =
2193 (infoPtr->dwDTFlags & (DWORD)wParam) | (DWORD)lParam;
2195 return (LRESULT)dwTemp;
2200 TOOLBAR_SetExtendedStyle (HWND hwnd, WPARAM wParam, LPARAM lParam)
2202 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2205 dwTemp = infoPtr->dwExStyle;
2206 infoPtr->dwExStyle = (DWORD)lParam;
2208 return (LRESULT)dwTemp;
2213 TOOLBAR_SetHotImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
2215 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr(hwnd);
2216 HIMAGELIST himlTemp;
2218 himlTemp = infoPtr->himlHot;
2219 infoPtr->himlHot = (HIMAGELIST)lParam;
2221 /* FIXME: redraw ? */
2223 return (LRESULT)himlTemp;
2227 /* << TOOLBAR_SetHotItem >> */
2231 TOOLBAR_SetImageList (HWND hwnd, WPARAM wParam, LPARAM lParam)
2233 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2234 HIMAGELIST himlTemp;
2236 himlTemp = infoPtr->himlDef;
2237 infoPtr->himlDef = (HIMAGELIST)lParam;
2239 /* FIXME: redraw ? */
2241 return (LRESULT)himlTemp;
2246 TOOLBAR_SetIndent (HWND hwnd, WPARAM wParam, LPARAM lParam)
2248 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2250 infoPtr->nIndent = (INT)wParam;
2252 TOOLBAR_CalcToolbar (hwnd);
2254 InvalidateRect(hwnd, NULL, FALSE);
2260 /* << TOOLBAR_SetInsertMark >> */
2264 TOOLBAR_SetInsertMarkColor (HWND hwnd, WPARAM wParam, LPARAM lParam)
2266 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2268 infoPtr->clrInsertMark = (COLORREF)lParam;
2270 /* FIXME : redraw ??*/
2277 TOOLBAR_SetMaxTextRows (HWND hwnd, WPARAM wParam, LPARAM lParam)
2279 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2281 if (infoPtr == NULL)
2284 infoPtr->nMaxTextRows = (INT)wParam;
2290 /* << TOOLBAR_SetPadding >> */
2294 TOOLBAR_SetParent (HWND hwnd, WPARAM wParam, LPARAM lParam)
2296 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2299 if (infoPtr == NULL)
2301 hwndOldNotify = infoPtr->hwndNotify;
2302 infoPtr->hwndNotify = (HWND)wParam;
2304 return hwndOldNotify;
2309 TOOLBAR_SetRows (HWND hwnd, WPARAM wParam, LPARAM lParam)
2311 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2312 LPRECT lprc = (LPRECT)lParam;
2314 if (LOWORD(wParam) > 1) {
2316 FIXME("multiple rows not supported!\n");
2320 /* recalculate toolbar */
2321 TOOLBAR_CalcToolbar (hwnd);
2323 /* return bounding rectangle */
2325 lprc->left = infoPtr->rcBound.left;
2326 lprc->right = infoPtr->rcBound.right;
2327 lprc->top = infoPtr->rcBound.top;
2328 lprc->bottom = infoPtr->rcBound.bottom;
2331 /* repaint toolbar */
2332 InvalidateRect(hwnd, NULL, FALSE);
2339 TOOLBAR_SetState (HWND hwnd, WPARAM wParam, LPARAM lParam)
2341 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2342 TBUTTON_INFO *btnPtr;
2346 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
2350 btnPtr = &infoPtr->buttons[nIndex];
2351 btnPtr->fsState = LOWORD(lParam);
2354 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2355 ReleaseDC (hwnd, hdc);
2362 TOOLBAR_SetStyle (HWND hwnd, WPARAM wParam, LPARAM lParam)
2364 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2365 TBUTTON_INFO *btnPtr;
2369 nIndex = TOOLBAR_GetButtonIndex (infoPtr, (INT)wParam);
2373 btnPtr = &infoPtr->buttons[nIndex];
2374 btnPtr->fsStyle = LOWORD(lParam);
2377 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2378 ReleaseDC (hwnd, hdc);
2380 if (infoPtr->hwndToolTip) {
2382 FIXME("change tool tip!\n");
2390 inline static LRESULT
2391 TOOLBAR_SetToolTips (HWND hwnd, WPARAM wParam, LPARAM lParam)
2393 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2395 if (infoPtr == NULL)
2397 infoPtr->hwndToolTip = (HWND)wParam;
2403 TOOLBAR_SetUnicodeFormat (HWND hwnd, WPARAM wParam, LPARAM lParam)
2405 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2408 TRACE("%s hwnd=0x%04x stub!\n",
2409 ((BOOL)wParam) ? "TRUE" : "FALSE", hwnd);
2411 bTemp = infoPtr->bUnicode;
2412 infoPtr->bUnicode = (BOOL)wParam;
2419 TOOLBAR_Create (HWND hwnd, WPARAM wParam, LPARAM lParam)
2421 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2422 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
2425 /* initialize info structure */
2426 infoPtr->nButtonHeight = 22;
2427 infoPtr->nButtonWidth = 23;
2428 infoPtr->nBitmapHeight = 15;
2429 infoPtr->nBitmapWidth = 16;
2431 infoPtr->nHeight = infoPtr->nButtonHeight + TOP_BORDER + BOTTOM_BORDER;
2433 infoPtr->nMaxTextRows = 1;
2434 infoPtr->cxMin = -1;
2435 infoPtr->cxMax = -1;
2437 infoPtr->bCaptured = FALSE;
2438 infoPtr->bUnicode = IsWindowUnicode (hwnd);
2439 infoPtr->nButtonDown = -1;
2440 infoPtr->nOldHit = -1;
2441 infoPtr->nHotItem = -2; /* It has to be initially different from nOldHit */
2442 infoPtr->hwndNotify = GetParent (hwnd);
2443 infoPtr->bTransparent = (dwStyle & TBSTYLE_FLAT);
2444 infoPtr->dwDTFlags = DT_CENTER;
2446 SystemParametersInfoA (SPI_GETICONTITLELOGFONT, 0, &logFont, 0);
2447 infoPtr->hFont = CreateFontIndirectA (&logFont);
2449 if (dwStyle & TBSTYLE_TOOLTIPS) {
2450 /* Create tooltip control */
2451 infoPtr->hwndToolTip =
2452 CreateWindowExA (0, TOOLTIPS_CLASSA, NULL, 0,
2453 CW_USEDEFAULT, CW_USEDEFAULT,
2454 CW_USEDEFAULT, CW_USEDEFAULT,
2457 /* Send NM_TOOLTIPSCREATED notification */
2458 if (infoPtr->hwndToolTip) {
2459 NMTOOLTIPSCREATED nmttc;
2461 nmttc.hdr.hwndFrom = hwnd;
2462 nmttc.hdr.idFrom = GetWindowLongA (hwnd, GWL_ID);
2463 nmttc.hdr.code = NM_TOOLTIPSCREATED;
2464 nmttc.hwndToolTips = infoPtr->hwndToolTip;
2466 SendMessageA (infoPtr->hwndNotify, WM_NOTIFY,
2467 (WPARAM)nmttc.hdr.idFrom, (LPARAM)&nmttc);
2476 TOOLBAR_Destroy (HWND hwnd, WPARAM wParam, LPARAM lParam)
2478 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2480 /* delete tooltip control */
2481 if (infoPtr->hwndToolTip)
2482 DestroyWindow (infoPtr->hwndToolTip);
2484 /* delete button data */
2485 if (infoPtr->buttons)
2486 COMCTL32_Free (infoPtr->buttons);
2488 /* delete strings */
2489 if (infoPtr->strings) {
2491 for (i = 0; i < infoPtr->nNumStrings; i++)
2492 if (infoPtr->strings[i])
2493 COMCTL32_Free (infoPtr->strings[i]);
2495 COMCTL32_Free (infoPtr->strings);
2498 /* destroy internal image list */
2499 if (infoPtr->himlInt)
2500 ImageList_Destroy (infoPtr->himlInt);
2502 /* delete default font */
2504 DeleteObject (infoPtr->hFont);
2506 /* free toolbar info data */
2507 COMCTL32_Free (infoPtr);
2514 TOOLBAR_EraseBackground (HWND hwnd, WPARAM wParam, LPARAM lParam)
2516 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2518 if (infoPtr->bTransparent)
2519 return SendMessageA (GetParent (hwnd), WM_ERASEBKGND, wParam, lParam);
2521 return DefWindowProcA (hwnd, WM_ERASEBKGND, wParam, lParam);
2526 TOOLBAR_LButtonDblClk (HWND hwnd, WPARAM wParam, LPARAM lParam)
2528 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2529 TBUTTON_INFO *btnPtr;
2534 pt.x = (INT)LOWORD(lParam);
2535 pt.y = (INT)HIWORD(lParam);
2536 nHit = TOOLBAR_InternalHitTest (hwnd, &pt);
2539 btnPtr = &infoPtr->buttons[nHit];
2540 if (!(btnPtr->fsState & TBSTATE_ENABLED))
2543 infoPtr->bCaptured = TRUE;
2544 infoPtr->nButtonDown = nHit;
2546 btnPtr->fsState |= TBSTATE_PRESSED;
2549 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2550 ReleaseDC (hwnd, hdc);
2552 else if (GetWindowLongA (hwnd, GWL_STYLE) & CCS_ADJUSTABLE)
2553 TOOLBAR_Customize (hwnd);
2560 TOOLBAR_LButtonDown (HWND hwnd, WPARAM wParam, LPARAM lParam)
2562 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2563 TBUTTON_INFO *btnPtr;
2568 if (infoPtr->hwndToolTip)
2569 TOOLBAR_RelayEvent (infoPtr->hwndToolTip, hwnd,
2570 WM_LBUTTONDOWN, wParam, lParam);
2572 pt.x = (INT)LOWORD(lParam);
2573 pt.y = (INT)HIWORD(lParam);
2574 nHit = TOOLBAR_InternalHitTest (hwnd, &pt);
2577 btnPtr = &infoPtr->buttons[nHit];
2578 if (!(btnPtr->fsState & TBSTATE_ENABLED))
2582 infoPtr->bCaptured = TRUE;
2583 infoPtr->nButtonDown = nHit;
2584 infoPtr->nOldHit = nHit;
2586 btnPtr->fsState |= TBSTATE_PRESSED;
2589 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2590 ReleaseDC (hwnd, hdc);
2598 TOOLBAR_LButtonUp (HWND hwnd, WPARAM wParam, LPARAM lParam)
2600 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2601 TBUTTON_INFO *btnPtr;
2606 BOOL bSendMessage = TRUE;
2608 if (infoPtr->hwndToolTip)
2609 TOOLBAR_RelayEvent (infoPtr->hwndToolTip, hwnd,
2610 WM_LBUTTONUP, wParam, lParam);
2612 pt.x = (INT)LOWORD(lParam);
2613 pt.y = (INT)HIWORD(lParam);
2614 nHit = TOOLBAR_InternalHitTest (hwnd, &pt);
2616 if ((infoPtr->bCaptured) && (infoPtr->nButtonDown >= 0)) {
2617 infoPtr->bCaptured = FALSE;
2619 btnPtr = &infoPtr->buttons[infoPtr->nButtonDown];
2620 btnPtr->fsState &= ~TBSTATE_PRESSED;
2622 if (nHit == infoPtr->nButtonDown) {
2623 if (btnPtr->fsStyle & TBSTYLE_CHECK) {
2624 if (btnPtr->fsStyle & TBSTYLE_GROUP) {
2625 nOldIndex = TOOLBAR_GetCheckedGroupButtonIndex (infoPtr,
2626 infoPtr->nButtonDown);
2627 if (nOldIndex == infoPtr->nButtonDown)
2628 bSendMessage = FALSE;
2629 if ((nOldIndex != infoPtr->nButtonDown) &&
2631 infoPtr->buttons[nOldIndex].fsState &= ~TBSTATE_CHECKED;
2632 btnPtr->fsState |= TBSTATE_CHECKED;
2635 if (btnPtr->fsState & TBSTATE_CHECKED)
2636 btnPtr->fsState &= ~TBSTATE_CHECKED;
2638 btnPtr->fsState |= TBSTATE_CHECKED;
2643 bSendMessage = FALSE;
2646 if (nOldIndex != -1)
2647 TOOLBAR_DrawButton (hwnd, &infoPtr->buttons[nOldIndex], hdc);
2648 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2649 ReleaseDC (hwnd, hdc);
2652 SendMessageA (infoPtr->hwndNotify, WM_COMMAND,
2653 MAKEWPARAM(btnPtr->idCommand, 0), (LPARAM)hwnd);
2655 infoPtr->nButtonDown = -1;
2656 infoPtr->nOldHit = -1;
2664 TOOLBAR_MouseMove (HWND hwnd, WPARAM wParam, LPARAM lParam)
2666 TBUTTON_INFO *btnPtr, *oldBtnPtr;
2667 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2672 if (infoPtr->hwndToolTip)
2673 TOOLBAR_RelayEvent (infoPtr->hwndToolTip, hwnd,
2674 WM_MOUSEMOVE, wParam, lParam);
2676 pt.x = (INT)LOWORD(lParam);
2677 pt.y = (INT)HIWORD(lParam);
2679 nHit = TOOLBAR_InternalHitTest (hwnd, &pt);
2681 if (infoPtr->nOldHit != nHit)
2683 /* Remove the effect of an old hot button */
2684 if(infoPtr->nOldHit == infoPtr->nHotItem)
2686 oldBtnPtr = &infoPtr->buttons[infoPtr->nOldHit];
2687 oldBtnPtr->bHot = FALSE;
2689 InvalidateRect (hwnd, &oldBtnPtr->rect, TRUE);
2692 /* It's not a separator or in nowhere. It's a hot button. */
2695 btnPtr = &infoPtr->buttons[nHit];
2696 btnPtr->bHot = TRUE;
2699 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2700 ReleaseDC (hwnd, hdc);
2702 infoPtr->nHotItem = nHit;
2705 if (infoPtr->bCaptured) {
2706 btnPtr = &infoPtr->buttons[infoPtr->nButtonDown];
2707 if (infoPtr->nOldHit == infoPtr->nButtonDown) {
2708 btnPtr->fsState &= ~TBSTATE_PRESSED;
2710 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2711 ReleaseDC (hwnd, hdc);
2713 else if (nHit == infoPtr->nButtonDown) {
2714 btnPtr->fsState |= TBSTATE_PRESSED;
2716 TOOLBAR_DrawButton (hwnd, btnPtr, hdc);
2717 ReleaseDC (hwnd, hdc);
2720 infoPtr->nOldHit = nHit;
2726 inline static LRESULT
2727 TOOLBAR_NCActivate (HWND hwnd, WPARAM wParam, LPARAM lParam)
2729 /* if (wndPtr->dwStyle & CCS_NODIVIDER) */
2730 return DefWindowProcA (hwnd, WM_NCACTIVATE, wParam, lParam);
2732 /* return TOOLBAR_NCPaint (wndPtr, wParam, lParam); */
2736 inline static LRESULT
2737 TOOLBAR_NCCalcSize (HWND hwnd, WPARAM wParam, LPARAM lParam)
2739 if (!(GetWindowLongA (hwnd, GWL_STYLE) & CCS_NODIVIDER))
2740 ((LPRECT)lParam)->top += GetSystemMetrics(SM_CYEDGE);
2742 return DefWindowProcA (hwnd, WM_NCCALCSIZE, wParam, lParam);
2747 TOOLBAR_NCCreate (HWND hwnd, WPARAM wParam, LPARAM lParam)
2749 TOOLBAR_INFO *infoPtr;
2751 /* allocate memory for info structure */
2752 infoPtr = (TOOLBAR_INFO *)COMCTL32_Alloc (sizeof(TOOLBAR_INFO));
2753 SetWindowLongA (hwnd, 0, (DWORD)infoPtr);
2756 infoPtr->dwStructSize = sizeof(TBBUTTON);
2758 /* fix instance handle, if the toolbar was created by CreateToolbarEx() */
2759 if (!GetWindowLongA (hwnd, GWL_HINSTANCE)) {
2760 HINSTANCE hInst = (HINSTANCE)GetWindowLongA (GetParent (hwnd), GWL_HINSTANCE);
2761 SetWindowLongA (hwnd, GWL_HINSTANCE, (DWORD)hInst);
2764 return DefWindowProcA (hwnd, WM_NCCREATE, wParam, lParam);
2769 TOOLBAR_NCPaint (HWND hwnd, WPARAM wParam, LPARAM lParam)
2771 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
2775 if (dwStyle & WS_MINIMIZE)
2776 return 0; /* Nothing to do */
2778 DefWindowProcA (hwnd, WM_NCPAINT, wParam, lParam);
2780 if (!(hdc = GetDCEx (hwnd, 0, DCX_USESTYLE | DCX_WINDOW)))
2783 if (!(dwStyle & CCS_NODIVIDER))
2785 GetWindowRect (hwnd, &rcWindow);
2786 OffsetRect (&rcWindow, -rcWindow.left, -rcWindow.top);
2787 DrawEdge (hdc, &rcWindow, EDGE_ETCHED, BF_TOP);
2790 ReleaseDC( hwnd, hdc );
2796 inline static LRESULT
2797 TOOLBAR_Notify (HWND hwnd, WPARAM wParam, LPARAM lParam)
2799 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2800 LPNMHDR lpnmh = (LPNMHDR)lParam;
2802 TRACE("passing WM_NOTIFY!\n");
2804 if ((infoPtr->hwndToolTip) && (lpnmh->hwndFrom == infoPtr->hwndToolTip)) {
2805 SendMessageA (infoPtr->hwndNotify, WM_NOTIFY, wParam, lParam);
2808 if (lpnmh->code == TTN_GETDISPINFOA) {
2809 LPNMTTDISPINFOA lpdi = (LPNMTTDISPINFOA)lParam;
2811 FIXME("retrieving ASCII string\n");
2814 else if (lpnmh->code == TTN_GETDISPINFOW) {
2815 LPNMTTDISPINFOW lpdi = (LPNMTTDISPINFOW)lParam;
2817 FIXME("retrieving UNICODE string\n");
2828 TOOLBAR_Paint (HWND hwnd, WPARAM wParam)
2833 TOOLBAR_CalcToolbar( hwnd );
2834 hdc = wParam==0 ? BeginPaint (hwnd, &ps) : (HDC)wParam;
2835 TOOLBAR_Refresh (hwnd, hdc);
2837 EndPaint (hwnd, &ps);
2843 TOOLBAR_Size (HWND hwnd, WPARAM wParam, LPARAM lParam)
2845 TOOLBAR_INFO *infoPtr = TOOLBAR_GetInfoPtr (hwnd);
2846 DWORD dwStyle = GetWindowLongA (hwnd, GWL_STYLE);
2854 /* Resize deadlock check */
2855 if (infoPtr->bAutoSize) {
2856 infoPtr->bAutoSize = FALSE;
2860 flags = (INT) wParam;
2862 /* FIXME for flags =
2863 * SIZE_MAXIMIZED, SIZE_MAXSHOW, SIZE_MINIMIZED
2866 TRACE("sizing toolbar!\n");
2868 if (flags == SIZE_RESTORED) {
2869 /* width and height don't apply */
2870 parent = GetParent (hwnd);
2871 GetClientRect(parent, &parent_rect);
2873 if (dwStyle & CCS_NORESIZE) {
2874 uPosFlags |= (SWP_NOSIZE | SWP_NOMOVE);
2877 /* infoPtr->nWidth = parent_rect.right - parent_rect.left; */
2878 cy = infoPtr->nHeight;
2879 cx = infoPtr->nWidth;
2880 TOOLBAR_CalcToolbar (hwnd);
2881 infoPtr->nWidth = cx;
2882 infoPtr->nHeight = cy;
2885 infoPtr->nWidth = parent_rect.right - parent_rect.left;
2886 TOOLBAR_CalcToolbar (hwnd);
2887 cy = infoPtr->nHeight;
2888 cx = infoPtr->nWidth;
2891 if (dwStyle & CCS_NOPARENTALIGN) {
2892 uPosFlags |= SWP_NOMOVE;
2893 cy = infoPtr->nHeight;
2894 cx = infoPtr->nWidth;
2897 if (!(dwStyle & CCS_NODIVIDER))
2898 cy += GetSystemMetrics(SM_CYEDGE);
2900 SetWindowPos (hwnd, 0, parent_rect.left, parent_rect.top,
2901 cx, cy, uPosFlags | SWP_NOZORDER);
2908 TOOLBAR_StyleChanged (HWND hwnd, WPARAM wParam, LPARAM lParam)
2910 TOOLBAR_AutoSize (hwnd, wParam, lParam);
2912 InvalidateRect(hwnd, NULL, FALSE);
2920 ToolbarWindowProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
2925 return TOOLBAR_AddBitmap (hwnd, wParam, lParam);
2927 case TB_ADDBUTTONSA:
2928 return TOOLBAR_AddButtonsA (hwnd, wParam, lParam);
2930 /* case TB_ADDBUTTONSW: */
2933 return TOOLBAR_AddStringA (hwnd, wParam, lParam);
2936 return TOOLBAR_AddStringW (hwnd, wParam, lParam);
2939 return TOOLBAR_AutoSize (hwnd, wParam, lParam);
2941 case TB_BUTTONCOUNT:
2942 return TOOLBAR_ButtonCount (hwnd, wParam, lParam);
2944 case TB_BUTTONSTRUCTSIZE:
2945 return TOOLBAR_ButtonStructSize (hwnd, wParam, lParam);
2947 case TB_CHANGEBITMAP:
2948 return TOOLBAR_ChangeBitmap (hwnd, wParam, lParam);
2950 case TB_CHECKBUTTON:
2951 return TOOLBAR_CheckButton (hwnd, wParam, lParam);
2953 case TB_COMMANDTOINDEX:
2954 return TOOLBAR_CommandToIndex (hwnd, wParam, lParam);
2957 return TOOLBAR_Customize (hwnd);
2959 case TB_DELETEBUTTON:
2960 return TOOLBAR_DeleteButton (hwnd, wParam, lParam);
2962 case TB_ENABLEBUTTON:
2963 return TOOLBAR_EnableButton (hwnd, wParam, lParam);
2965 /* case TB_GETANCHORHIGHLIGHT: */ /* 4.71 */
2968 return TOOLBAR_GetBitmap (hwnd, wParam, lParam);
2970 case TB_GETBITMAPFLAGS:
2971 return TOOLBAR_GetBitmapFlags (hwnd, wParam, lParam);
2974 return TOOLBAR_GetButton (hwnd, wParam, lParam);
2976 case TB_GETBUTTONINFOA:
2977 return TOOLBAR_GetButtonInfoA (hwnd, wParam, lParam);
2979 /* case TB_GETBUTTONINFOW: */ /* 4.71 */
2981 case TB_GETBUTTONSIZE:
2982 return TOOLBAR_GetButtonSize (hwnd);
2984 case TB_GETBUTTONTEXTA:
2985 return TOOLBAR_GetButtonTextA (hwnd, wParam, lParam);
2987 /* case TB_GETBUTTONTEXTW: */
2988 /* case TB_GETCOLORSCHEME: */ /* 4.71 */
2990 case TB_GETDISABLEDIMAGELIST:
2991 return TOOLBAR_GetDisabledImageList (hwnd, wParam, lParam);
2993 case TB_GETEXTENDEDSTYLE:
2994 return TOOLBAR_GetExtendedStyle (hwnd);
2996 case TB_GETHOTIMAGELIST:
2997 return TOOLBAR_GetHotImageList (hwnd, wParam, lParam);
2999 /* case TB_GETHOTITEM: */ /* 4.71 */
3001 case TB_GETIMAGELIST:
3002 return TOOLBAR_GetImageList (hwnd, wParam, lParam);
3004 /* case TB_GETINSERTMARK: */ /* 4.71 */
3005 /* case TB_GETINSERTMARKCOLOR: */ /* 4.71 */
3007 case TB_GETITEMRECT:
3008 return TOOLBAR_GetItemRect (hwnd, wParam, lParam);
3011 return TOOLBAR_GetMaxSize (hwnd, wParam, lParam);
3013 /* case TB_GETOBJECT: */ /* 4.71 */
3014 /* case TB_GETPADDING: */ /* 4.71 */
3017 return TOOLBAR_GetRect (hwnd, wParam, lParam);
3020 return TOOLBAR_GetRows (hwnd, wParam, lParam);
3023 return TOOLBAR_GetState (hwnd, wParam, lParam);
3026 return TOOLBAR_GetStyle (hwnd, wParam, lParam);
3028 case TB_GETTEXTROWS:
3029 return TOOLBAR_GetTextRows (hwnd, wParam, lParam);
3031 case TB_GETTOOLTIPS:
3032 return TOOLBAR_GetToolTips (hwnd, wParam, lParam);
3034 case TB_GETUNICODEFORMAT:
3035 return TOOLBAR_GetUnicodeFormat (hwnd, wParam, lParam);
3038 return TOOLBAR_HideButton (hwnd, wParam, lParam);
3041 return TOOLBAR_HitTest (hwnd, wParam, lParam);
3043 case TB_INDETERMINATE:
3044 return TOOLBAR_Indeterminate (hwnd, wParam, lParam);
3046 case TB_INSERTBUTTONA:
3047 return TOOLBAR_InsertButtonA (hwnd, wParam, lParam);
3049 /* case TB_INSERTBUTTONW: */
3050 /* case TB_INSERTMARKHITTEST: */ /* 4.71 */
3052 case TB_ISBUTTONCHECKED:
3053 return TOOLBAR_IsButtonChecked (hwnd, wParam, lParam);
3055 case TB_ISBUTTONENABLED:
3056 return TOOLBAR_IsButtonEnabled (hwnd, wParam, lParam);
3058 case TB_ISBUTTONHIDDEN:
3059 return TOOLBAR_IsButtonHidden (hwnd, wParam, lParam);
3061 case TB_ISBUTTONHIGHLIGHTED:
3062 return TOOLBAR_IsButtonHighlighted (hwnd, wParam, lParam);
3064 case TB_ISBUTTONINDETERMINATE:
3065 return TOOLBAR_IsButtonIndeterminate (hwnd, wParam, lParam);
3067 case TB_ISBUTTONPRESSED:
3068 return TOOLBAR_IsButtonPressed (hwnd, wParam, lParam);
3070 /* case TB_LOADIMAGES: */ /* 4.70 */
3071 /* case TB_MAPACCELERATORA: */ /* 4.71 */
3072 /* case TB_MAPACCELERATORW: */ /* 4.71 */
3073 /* case TB_MARKBUTTON: */ /* 4.71 */
3074 /* case TB_MOVEBUTTON: */ /* 4.71 */
3076 case TB_PRESSBUTTON:
3077 return TOOLBAR_PressButton (hwnd, wParam, lParam);
3079 /* case TB_REPLACEBITMAP: */
3081 case TB_SAVERESTOREA:
3082 return TOOLBAR_SaveRestoreA (hwnd, wParam, lParam);
3084 /* case TB_SAVERESTOREW: */
3085 /* case TB_SETANCHORHIGHLIGHT: */ /* 4.71 */
3087 case TB_SETBITMAPSIZE:
3088 return TOOLBAR_SetBitmapSize (hwnd, wParam, lParam);
3090 case TB_SETBUTTONINFOA:
3091 return TOOLBAR_SetButtonInfoA (hwnd, wParam, lParam);
3093 /* case TB_SETBUTTONINFOW: */ /* 4.71 */
3095 case TB_SETBUTTONSIZE:
3096 return TOOLBAR_SetButtonSize (hwnd, wParam, lParam);
3098 case TB_SETBUTTONWIDTH:
3099 return TOOLBAR_SetButtonWidth (hwnd, wParam, lParam);
3102 return TOOLBAR_SetCmdId (hwnd, wParam, lParam);
3104 /* case TB_SETCOLORSCHEME: */ /* 4.71 */
3106 case TB_SETDISABLEDIMAGELIST:
3107 return TOOLBAR_SetDisabledImageList (hwnd, wParam, lParam);
3109 case TB_SETDRAWTEXTFLAGS:
3110 return TOOLBAR_SetDrawTextFlags (hwnd, wParam, lParam);
3112 case TB_SETEXTENDEDSTYLE:
3113 return TOOLBAR_SetExtendedStyle (hwnd, wParam, lParam);
3115 case TB_SETHOTIMAGELIST:
3116 return TOOLBAR_SetHotImageList (hwnd, wParam, lParam);
3118 /* case TB_SETHOTITEM: */ /* 4.71 */
3120 case TB_SETIMAGELIST:
3121 return TOOLBAR_SetImageList (hwnd, wParam, lParam);
3124 return TOOLBAR_SetIndent (hwnd, wParam, lParam);
3126 /* case TB_SETINSERTMARK: */ /* 4.71 */
3128 case TB_SETINSERTMARKCOLOR:
3129 return TOOLBAR_SetInsertMarkColor (hwnd, wParam, lParam);
3131 case TB_SETMAXTEXTROWS:
3132 return TOOLBAR_SetMaxTextRows (hwnd, wParam, lParam);
3134 /* case TB_SETPADDING: */ /* 4.71 */
3137 return TOOLBAR_SetParent (hwnd, wParam, lParam);
3140 return TOOLBAR_SetRows (hwnd, wParam, lParam);
3143 return TOOLBAR_SetState (hwnd, wParam, lParam);
3146 return TOOLBAR_SetStyle (hwnd, wParam, lParam);
3148 case TB_SETTOOLTIPS:
3149 return TOOLBAR_SetToolTips (hwnd, wParam, lParam);
3151 case TB_SETUNICODEFORMAT:
3152 return TOOLBAR_SetUnicodeFormat (hwnd, wParam, lParam);
3158 return TOOLBAR_Create (hwnd, wParam, lParam);
3161 return TOOLBAR_Destroy (hwnd, wParam, lParam);
3164 return TOOLBAR_EraseBackground (hwnd, wParam, lParam);
3166 /* case WM_GETFONT: */
3167 /* case WM_KEYDOWN: */
3168 /* case WM_KILLFOCUS: */
3170 case WM_LBUTTONDBLCLK:
3171 return TOOLBAR_LButtonDblClk (hwnd, wParam, lParam);
3173 case WM_LBUTTONDOWN:
3174 return TOOLBAR_LButtonDown (hwnd, wParam, lParam);
3177 return TOOLBAR_LButtonUp (hwnd, wParam, lParam);
3180 return TOOLBAR_MouseMove (hwnd, wParam, lParam);
3183 return TOOLBAR_NCActivate (hwnd, wParam, lParam);
3186 return TOOLBAR_NCCalcSize (hwnd, wParam, lParam);
3189 return TOOLBAR_NCCreate (hwnd, wParam, lParam);
3192 return TOOLBAR_NCPaint (hwnd, wParam, lParam);
3195 return TOOLBAR_Notify (hwnd, wParam, lParam);
3197 /* case WM_NOTIFYFORMAT: */
3200 return TOOLBAR_Paint (hwnd, wParam);
3203 return TOOLBAR_Size (hwnd, wParam, lParam);
3205 case WM_STYLECHANGED:
3206 return TOOLBAR_StyleChanged (hwnd, wParam, lParam);
3208 /* case WM_SYSCOLORCHANGE: */
3210 /* case WM_WININICHANGE: */
3215 case WM_MEASUREITEM:
3217 return SendMessageA (GetParent (hwnd), uMsg, wParam, lParam);
3220 if (uMsg >= WM_USER)
3221 ERR("unknown msg %04x wp=%08x lp=%08lx\n",
3222 uMsg, wParam, lParam);
3223 return DefWindowProcA (hwnd, uMsg, wParam, lParam);
3230 TOOLBAR_Register (void)
3234 if (GlobalFindAtomA (TOOLBARCLASSNAMEA)) return;
3236 ZeroMemory (&wndClass, sizeof(WNDCLASSA));
3237 wndClass.style = CS_GLOBALCLASS | CS_DBLCLKS;
3238 wndClass.lpfnWndProc = (WNDPROC)ToolbarWindowProc;
3239 wndClass.cbClsExtra = 0;
3240 wndClass.cbWndExtra = sizeof(TOOLBAR_INFO *);
3241 wndClass.hCursor = LoadCursorA (0, IDC_ARROWA);
3242 wndClass.hbrBackground = (HBRUSH)(COLOR_3DFACE + 1);
3243 wndClass.lpszClassName = TOOLBARCLASSNAMEA;
3245 RegisterClassA (&wndClass);
3250 TOOLBAR_Unregister (void)
3252 if (GlobalFindAtomA (TOOLBARCLASSNAMEA))
3253 UnregisterClassA (TOOLBARCLASSNAMEA, (HINSTANCE)NULL);