4 * Copyright 1998 Anders Carlsson
5 * Copyright 1999 Alex Priem <alexp@sci.kun.nl>
11 * Updown control support
22 #define TAB_GetInfoPtr(wndPtr) ((TAB_INFO *)wndPtr->wExtra[0])
27 static void TAB_Refresh (WND *wndPtr, HDC32 hdc);
31 TAB_SendSimpleNotify (WND *wndPtr, UINT32 code)
35 nmhdr.hwndFrom = wndPtr->hwndSelf;
36 nmhdr.idFrom = wndPtr->wIDmenu;
39 return (BOOL32) SendMessage32A (GetParent32 (wndPtr->hwndSelf), WM_NOTIFY,
40 (WPARAM32) nmhdr.idFrom, (LPARAM) &nmhdr);
45 TAB_RelayEvent (HWND32 hwndTip, HWND32 hwndMsg, UINT32 uMsg,
46 WPARAM32 wParam, LPARAM lParam)
54 msg.time = GetMessageTime ();
55 msg.pt.x = LOWORD(GetMessagePos ());
56 msg.pt.y = HIWORD(GetMessagePos ());
58 SendMessage32A (hwndTip, TTM_RELAYEVENT, 0, (LPARAM)&msg);
64 TAB_GetCurSel (WND *wndPtr)
66 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
68 return infoPtr->iSelected;
72 TAB_GetCurFocus (WND *wndPtr)
74 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
76 return infoPtr->uFocus;
80 TAB_GetToolTips (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
82 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
84 if (infoPtr == NULL) return 0;
85 return infoPtr->hwndToolTip;
90 TAB_SetCurSel (WND *wndPtr,WPARAM32 wParam)
92 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
93 INT32 iItem=(INT32) wParam;
97 if ((iItem >= 0) && (iItem < infoPtr->uNumItem)) {
98 prevItem=infoPtr->iSelected;
99 infoPtr->iSelected=iItem;
105 TAB_SetCurFocus (WND *wndPtr,WPARAM32 wParam)
107 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
108 INT32 iItem=(INT32) wParam;
111 if ((iItem < 0) || (iItem > infoPtr->uNumItem)) return 0;
113 infoPtr->uFocus=iItem;
114 if (wndPtr->dwStyle & TCS_BUTTONS) {
115 FIXME (tab,"Should set input focus\n");
117 if (infoPtr->iSelected != iItem) {
118 if (TAB_SendSimpleNotify(wndPtr, TCN_SELCHANGING)!=TRUE) {
119 infoPtr->iSelected = iItem;
120 TAB_SendSimpleNotify(wndPtr, TCN_SELCHANGE);
121 hdc = GetDC32 (wndPtr->hwndSelf);
122 TAB_Refresh (wndPtr, hdc);
123 ReleaseDC32 (wndPtr->hwndSelf, hdc);
131 TAB_SetToolTips (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
133 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
135 if (infoPtr == NULL) return 0;
136 infoPtr->hwndToolTip = (HWND32)wParam;
141 static HWND32 TAB_InternalHitTest (TAB_INFO *infoPtr, POINT32 pt,
148 for (iCount = 0; iCount < infoPtr->uNumItem; iCount++) {
149 rect = infoPtr->items[iCount].rect;
150 if (PtInRect32 (&rect, pt)) return iCount;
157 TAB_HitTest (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
159 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
160 LPTCHITTESTINFO lptest=(LPTCHITTESTINFO) lParam;
162 return TAB_InternalHitTest (infoPtr,lptest->pt,&lptest->flags);
167 TAB_LButtonDown (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
169 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
171 if (infoPtr->hwndToolTip)
172 TAB_RelayEvent (infoPtr->hwndToolTip, wndPtr->hwndSelf,
173 WM_LBUTTONDOWN, wParam, lParam);
175 if (wndPtr->dwStyle & TCS_FOCUSONBUTTONDOWN ) {
176 SetFocus32 (wndPtr->hwndSelf);
182 TAB_LButtonUp (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
184 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
189 if (infoPtr->hwndToolTip)
190 TAB_RelayEvent (infoPtr->hwndToolTip, wndPtr->hwndSelf,
191 WM_LBUTTONDOWN, wParam, lParam);
193 pt.x = (INT32)LOWORD(lParam);
194 pt.y = (INT32)HIWORD(lParam);
196 newItem=TAB_InternalHitTest (infoPtr,pt,&dummy);
197 if (!newItem) return 0;
198 TRACE(tab, "On Tab, item %d\n", newItem);
200 if (infoPtr->iSelected != newItem) {
201 if (TAB_SendSimpleNotify(wndPtr, TCN_SELCHANGING)!=TRUE) {
202 infoPtr->iSelected = newItem;
203 TAB_SendSimpleNotify(wndPtr, TCN_SELCHANGE);
204 hdc = GetDC32 (wndPtr->hwndSelf);
205 TAB_Refresh (wndPtr, hdc);
206 ReleaseDC32 (wndPtr->hwndSelf, hdc);
209 TAB_SendSimpleNotify(wndPtr, NM_CLICK);
215 TAB_RButtonDown (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
217 TAB_SendSimpleNotify(wndPtr, NM_RCLICK);
222 TAB_MouseMove (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
224 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
226 if (infoPtr->hwndToolTip)
227 TAB_RelayEvent (infoPtr->hwndToolTip, wndPtr->hwndSelf,
228 WM_LBUTTONDOWN, wParam, lParam);
233 TAB_AdjustRect (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
237 FIXME (tab,"Should set display rectangle\n");
239 FIXME (tab,"Should set window rectangle\n");
246 TAB_SetItemBounds (WND *wndPtr)
248 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
250 HFONT32 hFont, hOldFont;
255 /* FIXME: Is this needed? */
256 GetClientRect32 (wndPtr->hwndSelf, &rect);
257 left += (size.cx + 11);
259 hdc = GetDC32(wndPtr->hwndSelf);
261 hFont = infoPtr->hFont ? infoPtr->hFont : GetStockObject32 (SYSTEM_FONT);
262 hOldFont = SelectObject32 (hdc, hFont);
266 for (i = 0; i < infoPtr->uNumItem; i++)
268 if (wndPtr->dwStyle & TCS_BOTTOM) {
269 infoPtr->items[i].rect.bottom = rect.bottom;
270 infoPtr->items[i].rect.top = rect.bottom-20;
272 infoPtr->items[i].rect.top = rect.top;
273 infoPtr->items[i].rect.bottom = rect.top + 20;
275 infoPtr->items[i].rect.left = left;
277 GetTextExtentPoint32A(hdc,
278 infoPtr->items[i].pszText,
279 lstrlen32A(infoPtr->items[i].pszText), &size);
280 infoPtr->items[i].rect.right = left + size.cx+2*5;
281 TRACE(tab, "TextSize: %i\n ", size.cx);
282 TRACE(tab, "Rect: T %i, L %i, B %i, R %i\n",
283 infoPtr->items[i].rect.top,
284 infoPtr->items[i].rect.left,
285 infoPtr->items[i].rect.bottom,
286 infoPtr->items[i].rect.right);
287 left += (size.cx + 11);
290 SelectObject32 (hdc, hOldFont);
291 ReleaseDC32 (wndPtr->hwndSelf, hdc);
295 TAB_DrawItem (WND *wndPtr, HDC32 hdc, INT32 iItem)
297 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
298 TAB_ITEM *pti = &infoPtr->items[iItem];
300 INT32 oldBkMode,cx,cy;
301 HBRUSH32 hbr = CreateSolidBrush32 (COLOR_BACKGROUND);
303 HPEN32 hwPen = GetSysColorPen32 (COLOR_3DHILIGHT);
304 HPEN32 hbPen = GetSysColorPen32 (COLOR_BTNSHADOW);
305 HPEN32 hsdPen = GetSysColorPen32 (COLOR_BTNTEXT);
306 HPEN32 htmpPen = (HPEN32)NULL;
308 CopyRect32(&r, &pti->rect);
311 FillRect32(hdc, &r, hbr);
317 htmpPen = SelectObject32 (hdc, htmpPen);
318 if (wndPtr->dwStyle & TCS_BOTTOM) {
319 MoveToEx32 (hdc, r.left, r.top, NULL);
320 LineTo32 (hdc, r.left, r.bottom - 2);
321 LineTo32 (hdc, r.left +2, r.bottom);
322 LineTo32 (hdc, r.right -1, r.bottom);
323 htmpPen = SelectObject32 (hdc, hbPen);
324 MoveToEx32 (hdc, r.right-1, r.top, NULL);
325 LineTo32 (hdc,r.right-1, r.bottom-1);
326 hbPen = SelectObject32 (hdc, hsdPen);
327 MoveToEx32 (hdc, r.right, r.top+1, NULL);
328 LineTo32(hdc, r.right,r.bottom);
330 MoveToEx32 (hdc, r.left, r.bottom, NULL);
331 LineTo32 (hdc, r.left, r.top + 2);
332 LineTo32 (hdc, r.left +2, r.top);
333 LineTo32 (hdc, r.right -1, r.top);
334 htmpPen = SelectObject32 (hdc, hbPen);
335 MoveToEx32 (hdc, r.right-1, r.bottom, NULL);
336 LineTo32 (hdc,r.right-1, r.top+1);
337 hbPen = SelectObject32 (hdc, hsdPen);
338 MoveToEx32 (hdc, r.right, r.bottom-1, NULL);
339 LineTo32(hdc, r.right,r.top);
342 hsdPen = SelectObject32(hdc,htmpPen);
344 oldBkMode = SetBkMode32(hdc, TRANSPARENT);
349 ImageList_Draw (infoPtr->himl, iItem, hdc,
350 r.left, r.top+1, ILD_NORMAL);
351 ImageList_GetIconSize (infoPtr->himl, &cx, &cy);
354 SetTextColor32 (hdc, COLOR_BTNTEXT);
355 DrawText32A(hdc, pti->pszText, lstrlen32A(pti->pszText),
356 &r, DT_LEFT|DT_SINGLELINE|DT_VCENTER);
357 if (oldBkMode != TRANSPARENT)
358 SetBkMode32(hdc, oldBkMode);
362 TAB_DrawBorder (WND *wndPtr, HDC32 hdc)
365 HPEN32 hwPen = GetSysColorPen32 (COLOR_3DHILIGHT);
366 HPEN32 hbPen = GetSysColorPen32 (COLOR_3DDKSHADOW);
367 HPEN32 hShade = GetSysColorPen32 (COLOR_BTNSHADOW);
371 htmPen = SelectObject32 (hdc, hwPen);
372 GetClientRect32 (wndPtr->hwndSelf, &rect);
374 MoveToEx32 (hdc, rect.left, rect.bottom, NULL);
375 LineTo32 (hdc, rect.left, rect.top+20);
377 LineTo32 (hdc, rect.right, rect.top+20);
379 hwPen = SelectObject32 (hdc, htmPen);
380 LineTo32 (hdc, rect.right, rect.bottom );
381 LineTo32 (hdc, rect.left, rect.bottom);
382 hbPen = SelectObject32 (hdc, hShade );
383 MoveToEx32 (hdc, rect.right-1, rect.top+20, NULL);
384 LineTo32 (hdc, rect.right-1, rect.bottom-1);
385 LineTo32 (hdc, rect.left, rect.bottom-1);
386 hShade = SelectObject32(hdc, hShade);
391 TAB_Refresh (WND *wndPtr, HDC32 hdc)
393 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
397 if (!infoPtr->DoRedraw) return;
399 TAB_DrawBorder (wndPtr, hdc);
401 hOldFont = SelectObject32 (hdc, infoPtr->hFont);
402 for (i = 0; i < infoPtr->uNumItem; i++) {
403 TAB_DrawItem (wndPtr, hdc, i);
405 SelectObject32 (hdc, hOldFont);
409 TAB_SetRedraw (WND *wndPtr, WPARAM32 wParam)
411 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
413 infoPtr->DoRedraw=(BOOL32) wParam;
418 TAB_Paint (WND *wndPtr, WPARAM32 wParam)
423 hdc = wParam== 0 ? BeginPaint32 (wndPtr->hwndSelf, &ps) : (HDC32)wParam;
424 TAB_Refresh (wndPtr, hdc);
427 EndPaint32 (wndPtr->hwndSelf, &ps);
432 TAB_InsertItem (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
434 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
440 GetClientRect32 (wndPtr->hwndSelf, &rect);
441 TRACE(tab, "Rect: %x T %i, L %i, B %i, R %i\n", wndPtr->hwndSelf,
442 rect.top, rect.left, rect.bottom, rect.right);
444 pti = (TCITEM32A *)lParam;
445 iItem = (INT32)wParam;
447 if (iItem < 0) return -1;
448 if (iItem > infoPtr->uNumItem)
449 iItem = infoPtr->uNumItem;
451 if (infoPtr->uNumItem == 0) {
452 infoPtr->items = COMCTL32_Alloc (sizeof (TAB_ITEM));
456 TAB_ITEM *oldItems = infoPtr->items;
459 infoPtr->items = COMCTL32_Alloc (sizeof (TAB_ITEM) * infoPtr->uNumItem);
461 /* pre insert copy */
463 memcpy (&infoPtr->items[0], &oldItems[0],
464 iItem * sizeof(TAB_ITEM));
467 /* post insert copy */
468 if (iItem < infoPtr->uNumItem - 1) {
469 memcpy (&infoPtr->items[iItem+1], &oldItems[iItem],
470 (infoPtr->uNumItem - iItem - 1) * sizeof(TAB_ITEM));
474 COMCTL32_Free (oldItems);
477 infoPtr->items[iItem].mask = pti->mask;
478 if (pti->mask & TCIF_TEXT) {
479 len = lstrlen32A (pti->pszText);
480 infoPtr->items[iItem].pszText = COMCTL32_Alloc (len+1);
481 lstrcpy32A (infoPtr->items[iItem].pszText, pti->pszText);
482 infoPtr->items[iItem].cchTextMax = pti->cchTextMax;
485 if (pti->mask & TCIF_IMAGE)
486 infoPtr->items[iItem].iImage = pti->iImage;
488 if (pti->mask & TCIF_PARAM)
489 infoPtr->items[iItem].lParam = pti->lParam;
491 hdc = GetDC32 (wndPtr->hwndSelf);
492 TAB_Refresh (wndPtr, hdc);
493 ReleaseDC32 (wndPtr->hwndSelf, hdc);
495 TRACE(tab, "[%04x]: added item %d '%s'\n",
496 wndPtr->hwndSelf, iItem, infoPtr->items[iItem].pszText);
498 TAB_SetItemBounds(wndPtr);
503 TAB_SetItem32A (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
505 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
510 iItem=(INT32) wParam;
511 tabItem=(LPTCITEM32A ) lParam;
512 TRACE (tab,"%d %p\n",iItem, tabItem);
513 if ((iItem<0) || (iItem>infoPtr->uNumItem)) return FALSE;
515 wineItem=& infoPtr->items[iItem];
517 if (tabItem->mask & TCIF_IMAGE)
518 wineItem->iImage=tabItem->iImage;
520 if (tabItem->mask & TCIF_PARAM)
521 wineItem->lParam=tabItem->lParam;
523 if (tabItem->mask & TCIF_RTLREADING)
524 FIXME (tab,"TCIF_RTLREADING\n");
526 if (tabItem->mask & TCIF_STATE)
527 wineItem->dwState=tabItem->dwState;
529 if (tabItem->mask & TCIF_TEXT) {
530 len=lstrlen32A (tabItem->pszText);
531 if (len>wineItem->cchTextMax)
532 wineItem->pszText= COMCTL32_ReAlloc (wineItem->pszText, len+1);
533 lstrcpyn32A (wineItem->pszText, tabItem->pszText, len);
540 TAB_GetItemCount (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
542 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
544 return infoPtr->uNumItem;
549 TAB_GetItem32A (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
551 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
556 iItem=(INT32) wParam;
557 tabItem=(LPTCITEM32A) lParam;
559 if ((iItem<0) || (iItem>infoPtr->uNumItem)) return FALSE;
561 wineItem=& infoPtr->items[iItem];
563 if (tabItem->mask & TCIF_IMAGE)
564 tabItem->iImage=wineItem->iImage;
566 if (tabItem->mask & TCIF_PARAM)
567 tabItem->lParam=wineItem->lParam;
569 if (tabItem->mask & TCIF_RTLREADING)
570 FIXME (tab, "TCIF_RTLREADING\n");
572 if (tabItem->mask & TCIF_STATE)
573 tabItem->dwState=wineItem->dwState;
575 if (tabItem->mask & TCIF_TEXT)
576 lstrcpyn32A (tabItem->pszText, wineItem->pszText, tabItem->cchTextMax);
582 TAB_DeleteItem (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
584 FIXME (tab,"stub \n");
589 TAB_DeleteAllItems (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
591 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
593 COMCTL32_Free (infoPtr->items);
601 TAB_GetFont (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
603 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
606 return (LRESULT)infoPtr->hFont;
610 TAB_SetFont (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
613 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
615 HFONT32 hFont, hOldFont;
618 TRACE (tab,"%x %lx\n",wParam, lParam);
620 infoPtr->hFont = (HFONT32)wParam;
622 hFont = infoPtr->hFont ? infoPtr->hFont : GetStockObject32 (SYSTEM_FONT);
625 hOldFont = SelectObject32 (hdc, hFont);
626 GetTextMetrics32A (hdc, &tm);
627 infoPtr->nHeight= tm.tmHeight + tm.tmExternalLeading;
628 SelectObject32 (hdc, hOldFont);
630 if (lParam) TAB_Refresh (wndPtr,hdc);
631 ReleaseDC32 (0, hdc);
638 TAB_GetImageList (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
640 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
643 return (LRESULT)infoPtr->himl;
647 TAB_SetImageList (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
649 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
653 himlPrev = infoPtr->himl;
654 infoPtr->himl= (HIMAGELIST)lParam;
655 return (LRESULT)himlPrev;
660 TAB_Size (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
666 UINT32 uPosFlags,cx,cy;
670 parent = GetParent32 (wndPtr->hwndSelf);
671 GetClientRect32(parent, &parent_rect);
674 if (wndPtr->dwStyle & CCS_NORESIZE)
675 uPosFlags |= (SWP_NOSIZE | SWP_NOMOVE);
677 SetWindowPos32 (wndPtr->hwndSelf, 0, parent_rect.left, parent_rect.top,
678 cx, cy, uPosFlags | SWP_NOZORDER);
680 FIXME (tab,"WM_SIZE flag %x %lx not handled\n", wParam, lParam);
683 TAB_SetItemBounds (wndPtr);
684 hdc = GetDC32 (wndPtr->hwndSelf);
685 TAB_Refresh (wndPtr, hdc);
686 ReleaseDC32 (wndPtr->hwndSelf, hdc);
693 TAB_Create (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
697 infoPtr = (TAB_INFO *)COMCTL32_Alloc (sizeof(TAB_INFO));
698 wndPtr->wExtra[0] = (DWORD)infoPtr;
700 infoPtr->uNumItem = 0;
703 infoPtr->hcurArrow = LoadCursor32A (0, IDC_ARROW32A);
704 infoPtr->iSelected = -1;
705 infoPtr->hwndToolTip=0;
707 TRACE(tab, "Created tab control, hwnd [%04x]\n", wndPtr->hwndSelf);
708 if (wndPtr->dwStyle & TCS_TOOLTIPS) {
709 /* Create tooltip control */
710 infoPtr->hwndToolTip =
711 CreateWindowEx32A (0, TOOLTIPS_CLASS32A, NULL, 0,
712 CW_USEDEFAULT32, CW_USEDEFAULT32,
713 CW_USEDEFAULT32, CW_USEDEFAULT32,
714 wndPtr->hwndSelf, 0, 0, 0);
716 /* Send NM_TOOLTIPSCREATED notification */
717 if (infoPtr->hwndToolTip) {
718 NMTOOLTIPSCREATED nmttc;
720 nmttc.hdr.hwndFrom = wndPtr->hwndSelf;
721 nmttc.hdr.idFrom = wndPtr->wIDmenu;
722 nmttc.hdr.code = NM_TOOLTIPSCREATED;
723 nmttc.hwndToolTips = infoPtr->hwndToolTip;
725 SendMessage32A (GetParent32 (wndPtr->hwndSelf), WM_NOTIFY,
726 (WPARAM32)wndPtr->wIDmenu, (LPARAM)&nmttc);
735 TAB_Destroy (WND *wndPtr, WPARAM32 wParam, LPARAM lParam)
737 TAB_INFO *infoPtr = TAB_GetInfoPtr(wndPtr);
740 if (infoPtr->items) {
741 for (iItem = 0; iItem < infoPtr->uNumItem; iItem++) {
742 if (infoPtr->items[iItem].pszText)
743 COMCTL32_Free (infoPtr->items[iItem].pszText);
745 COMCTL32_Free (infoPtr->items);
748 if (infoPtr->hwndToolTip)
749 DestroyWindow32 (infoPtr->hwndToolTip);
751 COMCTL32_Free (infoPtr);
756 TAB_WindowProc (HWND32 hwnd, UINT32 uMsg, WPARAM32 wParam, LPARAM lParam)
758 WND *wndPtr = WIN_FindWndPtr(hwnd);
763 case TCM_GETIMAGELIST:
764 return TAB_GetImageList (wndPtr, wParam, lParam);
766 case TCM_SETIMAGELIST:
767 return TAB_SetImageList (wndPtr, wParam, lParam);
769 case TCM_GETITEMCOUNT:
770 return TAB_GetItemCount (wndPtr, wParam, lParam);
773 return TAB_GetItem32A (wndPtr, wParam, lParam);
776 FIXME (tab, "Unimplemented msg TCM_GETITEM32W\n");
780 return TAB_SetItem32A (wndPtr, wParam, lParam);
783 FIXME (tab, "Unimplemented msg TCM_GETITEM32W\n");
787 return TAB_DeleteItem (wndPtr, wParam, lParam);
789 case TCM_DELETEALLITEMS:
790 return TAB_DeleteAllItems (wndPtr, wParam, lParam);
792 case TCM_GETITEMRECT:
793 FIXME (tab, "Unimplemented msg TCM_GETITEMRECT\n");
797 return TAB_GetCurSel (wndPtr);
800 return TAB_HitTest (wndPtr, wParam, lParam);
803 return TAB_SetCurSel (wndPtr, wParam);
805 case TCM_INSERTITEM32A:
806 return TAB_InsertItem (wndPtr, wParam, lParam);
808 case TCM_INSERTITEM32W:
809 FIXME (tab, "Unimplemented msg TCM_INSERTITEM32W\n");
812 case TCM_SETITEMEXTRA:
813 FIXME (tab, "Unimplemented msg TCM_SETITEMEXTRA\n");
817 return TAB_AdjustRect (wndPtr, wParam, lParam);
819 case TCM_SETITEMSIZE:
820 FIXME (tab, "Unimplemented msg TCM_SETITEMSIZE\n");
823 case TCM_REMOVEIMAGE:
824 FIXME (tab, "Unimplemented msg TCM_REMOVEIMAGE\n");
828 FIXME (tab, "Unimplemented msg TCM_SETPADDING\n");
831 case TCM_GETROWCOUNT:
832 FIXME (tab, "Unimplemented msg TCM_GETROWCOUNT\n");
835 case TCM_GETTOOLTIPS:
836 return TAB_GetToolTips (wndPtr, wParam, lParam);
838 case TCM_SETTOOLTIPS:
839 return TAB_SetToolTips (wndPtr, wParam, lParam);
841 case TCM_GETCURFOCUS:
842 return TAB_GetCurFocus (wndPtr);
844 case TCM_SETCURFOCUS:
845 return TAB_SetCurFocus (wndPtr, wParam);
847 case TCM_SETMINTTABWIDTH:
848 FIXME (tab, "Unimplemented msg TCM_SETMINTTABWIDTH\n");
851 case TCM_DESELECTALL:
852 FIXME (tab, "Unimplemented msg TCM_DESELECTALL\n");
856 return TAB_GetFont (wndPtr, wParam, lParam);
859 return TAB_SetFont (wndPtr, wParam, lParam);
862 return TAB_Create (wndPtr, wParam, lParam);
865 return TAB_Destroy (wndPtr, wParam, lParam);
868 return DLGC_WANTARROWS | DLGC_WANTCHARS;
871 return TAB_LButtonDown (wndPtr, wParam, lParam);
874 return TAB_LButtonUp (wndPtr, wParam, lParam);
877 return TAB_RButtonDown (wndPtr, wParam, lParam);
880 return TAB_MouseMove (wndPtr, wParam, lParam);
883 return TAB_Paint (wndPtr, wParam);
885 return TAB_Size (wndPtr, wParam, lParam);
888 return TAB_SetRedraw (wndPtr, wParam);
893 ERR (tab, "unknown msg %04x wp=%08x lp=%08lx\n",
894 uMsg, wParam, lParam);
895 return DefWindowProc32A (hwnd, uMsg, wParam, lParam);
904 WNDCLASS32A wndClass;
906 if (GlobalFindAtom32A (WC_TABCONTROL32A)) return;
908 ZeroMemory (&wndClass, sizeof(WNDCLASS32A));
909 wndClass.style = CS_GLOBALCLASS | CS_DBLCLKS | CS_SAVEBITS;
910 wndClass.lpfnWndProc = (WNDPROC32)TAB_WindowProc;
911 wndClass.cbClsExtra = 0;
912 wndClass.cbWndExtra = sizeof(TAB_INFO *);
913 wndClass.hCursor = LoadCursor32A (0, IDC_ARROW32A);
914 wndClass.hbrBackground = 0;
915 wndClass.lpszClassName = WC_TABCONTROL32A;
917 RegisterClass32A (&wndClass);
922 TAB_Unregister (VOID)
924 if (GlobalFindAtom32A (WC_TABCONTROL32A))
925 UnregisterClass32A (WC_TABCONTROL32A, (HINSTANCE32)NULL);