[Webinar] Learn how to a build a cloud-first strategyRegister Now

x
?
Solved

SetWindowText or painting problem !

Posted on 2006-10-23
11
Medium Priority
?
628 Views
Last Modified: 2013-11-20
I have created a derived CEdit control who displays a tooltip control to show how much character can still be displayed to reach the GetLimitText value.

Therefore, I have created a tooltip from scratch using CreateWindow all is working fine until I wanted to set the background color of my tooltip
to an other color that the default STATIC color (gray).

Tooltip is created like this :

     m_hToolTipWnd = CreateWindowEx(0, "STATIC", "", WS_BORDER | WS_POPUP | SS_CENTER | SS_CENTERIMAGE, 0, 0, 10, 10, m_hWnd, NULL, hInstance, 0);

To change the background color, I have added :

     LONG nRet = SetWindowLong(m_hToolTipWnd, GWL_WNDPROC, (LONG)(LRESULT)ToolTipWndProc);

     LRESULT CALLBACK CEditWithLimitToolTip::ToolTipWndProc(HWND hWnd, UINT uiMsg, WPARAM wParam, LPARAM lParam)
      {
       switch(uiMsg)
        {
         case WM_ERASEBKGND :
                              {
                               CDC *pDC = CDC::FromHandle( (HDC)wParam );
                         
                               CRect rect;
                         
                               ::GetClientRect(hWnd, &rect);
                         
                               pDC->FillSolidRect(&rect, GetSysColor(COLOR_INFOBK));

                               return TRUE;
                              }
        }

       return ::DefWindowProc(hWnd, uiMsg, wParam, lParam);
      }

The background is correctly painted but the text is no more painted also if I call SetWindowText with a new string

P.S. : I have the same problem if I use RegisterClassEx and use the Atom value instead of "STATIC"
0
Comment
Question by:mike_marquet
  • 6
  • 4
11 Comments
 
LVL 45

Accepted Solution

by:
AndyAinscow earned 80 total points
ID: 17788390
This might be a silly question but why not use a 'normal' tooltip control with a callback for the text to be displayed?
0
 

Author Comment

by:mike_marquet
ID: 17788568
Because I want to set the position of the tooltip myself and not at the cursor position.
0
 
LVL 45

Expert Comment

by:AndyAinscow
ID: 17788590
You could do that with the normal windows functions (MoveWindow or SetWindowPos)
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 

Author Comment

by:mike_marquet
ID: 17801833
If I use the CToolTipCtrl instead, I have the problem that the mouse pointer must be over the edit control for the tooltip to be displayed and the mouse pointer can NOT be over it. How can I force the CToolTipCtrl to be displayed without mouse pointer over edit control ?
0
 
LVL 22

Assisted Solution

by:mahesh1402
mahesh1402 earned 120 total points
ID: 17810645
>>Because I want to set the position of the tooltip myself and not at the cursor position.

Send a TTM_TRACKPOSITION message  which sets the coordinates of ToolTip ..

SendMessage (hwndTT, TTM_TRACKPOSITION, 0, (LPARAM) (DWORD) MAKELONG (X, Y)); // X & Y position of tooltip

For more see : Display ToolTip in any place on the screen : http://www.codeproject.com/miscctrl/tooltipzen.asp

-MAHESH
0
 

Author Comment

by:mike_marquet
ID: 17810947
To mahesh1402 :

I have used the flag TTF_TRACK when creating the tooltip control but when I use the TTM_TRACKPOSITION message, the tooltip is always under the cursor postion and not at specified position.

I'm using Microsoft Visual Studio .NET 2003 and use the CToolTipCtrl MFC Class instead of the Win32 API functions.

Full code can be provided !
0
 
LVL 45

Expert Comment

by:AndyAinscow
ID: 17810988
As a tooltip is a CWnd based window you can use the normal MoveWindow or SetWindowPos functions to try to position it where you want.
0
 

Author Comment

by:mike_marquet
ID: 17811038
It's the same using MoveWindow or SetWindowPos.

Seems to be that the TTF_TRACK flag has no effect !
0
 
LVL 45

Expert Comment

by:AndyAinscow
ID: 17811056
Do I understand correctly that you want the 'tip' to be displayed even when the mouse isn't over the edit box ?
0
 

Author Comment

by:mike_marquet
ID: 17811135
Yes, the tip must be displayed ALSO when the mouse is not over the control for which the tip is registered.
0
 

Author Comment

by:mike_marquet
ID: 17811375
It's now working.

I have used the win32 API instead of the MFC CToolTipCtrl class.

Thanks to all for help.
0

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Here is how to use MFC's automatic Radio Button handling in your dialog boxes and forms.  Beginner programmers usually start with a OnClick handler for each radio button and that's just not the right way to go.  MFC has a very cool system for handli…
If you use Adobe Reader X it is possible you can't open OLE PDF documents in the standard. The reason is the 'save box mode' in adobe reader X. Many people think the protected Mode of adobe reader x is only to stop the write access. But this fe…
This video will show you how to get GIT to work in Eclipse.   It will walk you through how to install the EGit plugin in eclipse and how to checkout an existing repository.
Please read the paragraph below before following the instructions in the video — there are important caveats in the paragraph that I did not mention in the video. If your PaperPort 12 or PaperPort 14 is failing to start, or crashing, or hanging, …
Suggested Courses
Course of the Month20 days, 11 hours left to enroll

864 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question