Solved

API to delete GDI objects that are not in use

Posted on 2003-11-19
5
718 Views
Last Modified: 2008-02-01
Is there an API that I can call, that will free up the GDI objects that I have created, and finished using ?

We have a heavy application in terms of GDI objects count, and this might be a work around for the main problem.
0
Comment
Question by:UriS
  • 3
5 Comments
 
LVL 3

Expert Comment

by:NBrownoh
ID: 9783409
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
0
 
LVL 85

Expert Comment

by:Mike Tomlinson
ID: 9783515
You have to be careful when creating and deleting GDI objecst as you can suck the life (memory) out of a system really fast by creating too many GDI objects.

As NBrownoh pointed out, you use the DeleteObject() API to delete your objects.

Here is some wisdom I just learned earlier today.  When you use the SelectObject() API, it returns a handle to the previously selected object.  You should then put this object back as the selected object and before deleting the object you just created and used.

Dim hbrush As Long
Dim ret As Long
   
hbrush = GetStockObject(NULLBRUSH) ' create an object
ret = SelectObject(hDC, hbrush) ' store handle to previous object
Polygon hDC, points(0), Me.numVertices ' use the object
SelectObject hDC, ret ' put previous object back
DeleteObject hbrush ' delte the object we created

Regards,

Idle_Mind
0
 
LVL 2

Author Comment

by:UriS
ID: 9784912
how can I delete the objects without first saving a pointer to them?
0
 
LVL 85

Expert Comment

by:Mike Tomlinson
ID: 9788277
You can't.

Idle_Mind
0
 
LVL 85

Accepted Solution

by:
Mike Tomlinson earned 125 total points
ID: 9828296
When you create objects and no longer have pointers to them, you create what is commonly known as a "memory leak".  The API calls you are making are not part of Visual Basic and as such, do not fall under its garbage collection scheme.  You have to manage your pointers and free the resources yourself.  Failure to do so will cause the system memory to be lost to all applications running until the system is rebooted.

Idle_Mind
0

Featured Post

6 Surprising Benefits of Threat Intelligence

All sorts of threat intelligence is available on the web. Intelligence you can learn from, and use to anticipate and prepare for future attacks.

Join & Write a Comment

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…
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

744 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

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now