Solved

Removing ghost icon from the system tray

Posted on 2011-02-14
6
1,324 Views
Last Modified: 2012-06-27
I have one VB6 app that shells a second VB6 app to perform FTP file uploads asynchronously.  The FTP client puts an icon in the system tray.  When the upload is complete, the app issues a NIM_DELETE and terminates, but its icon sometimes doesn't disappear -- instead it persists until the mouse is moved over it.  It seems that this behavior only began when I added logic to issue NIM_MODIFY to update the tool tip to reflect upload progress as a percent.

I took the NIM_ADD, MODIFY and DELETE code directly from an MS article, and I've triple-checked to be sure I got it right.  The article included code for a sample program, and I don't see a problem when running it, although it doesn't do anything but display an icon, allow it to be changed, allow the tool tip to be changed, and delete the icon.

In 17472429, Mark FreeSoftware suggested controlling the mouse to mouse-over the ghost icon, but only the FTP app knows when its done, and the ghost icon is only a problem after the app has terminated, therefore the app cannot do the cleanup.  The first app doesn't know when the FTP app has completed -- the user may have proceeded with some totally unrelated function.

The first app could start a timer that waits until the FTP app is no longer running, but how would i know if there is actually a ghost icon, and if so, how would I get its x/y coordinates to control the mouse?  What I'd really like is some API command that simply refreshes the System Tray...but apparently that doesn't exist.

Any ideas or suggestions would be greatly appreciated!  I'm developing and testing on XP, but the app must run on XP through Win7.

Thanks,

Pete
0
Comment
Question by:petekipe
  • 3
  • 3
6 Comments
 
LVL 26

Expert Comment

by:EDDYKT
ID: 34887360
strange, normally NIM_DELETE will remove the icon,
Do you do any doevents inside after NIM_DELETE?
may be call serval time in 1 second before your ftp client terminates
0
 

Author Comment

by:petekipe
ID: 34888559
I added a DoEvents after every Shell_NotifyIcon, and even tried a loop of 100 after the NIM_DELETE in Form_Terminate.  No luck.
0
 
LVL 26

Expert Comment

by:EDDYKT
ID: 34888590
does it happen when you have mutliple instances running?
0
Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

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.

 

Author Comment

by:petekipe
ID: 34888659
Normally, we don't run multiple instances of the FTP client concurrently.  But the icons remain until I mouse over them -- If I don't mouse over, I'll see multiple icons after repeated runs of the client.  I've seen as many as 6 or 8 icons.
0
 
LVL 26

Accepted Solution

by:
EDDYKT earned 500 total points
ID: 34888972
that's normally when you task crash and not even call the NIM_DELETE.

Are you sure that routine get call?
0
 

Author Comment

by:petekipe
ID: 34889081
Your last question caused me to move the NIM_DELETE out of Form_Terminate and into one that actually does the FTP, immediately after the FTP is complete.  The icon is now being removed from the System Tray.  Apparently there was a timing issue with trying to delete in either Form_Terminate or Form_Unload (which I had tried earlier).  Many thanks for your help, EDDYKT!
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

I’ve seen a number of people looking for examples of how to access web services from VB6.  I’ve been using a test harness I built in VB6 (using many resources I found online) that I use for small projects to work out how to communicate with web serv…
When trying to find the cause of a problem in VBA or VB6 it's often valuable to know what procedures were executed prior to the error. You can use the Call Stack for that but it is often inadequate because it may show procedures you aren't intereste…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…

840 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