vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Top-Preis! AP-Access-Tools-CD Volume 1  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Fortgeschrittene
Speicher läuft über ... 
Autor: Jojo
Datum: 02.12.10 09:41

Hallo,

ich habe das folgende Problem:

Ich habe eine Funktion gebaut die Bilder beschneiden kann. Das funktioniert auch super. Das Problem ist, dass bei sehr vielen Bildern der Speicher immer weiter voll läuft.
Ich vermute, dass es daran liegt, das ich die Objekte nicht richtig schliesse.

Mit den Return fixBmp wird die Function verlassen. Ich vermute aber, dass dabei das Object offen bleibt und den Fehler verursacht.

    Public Function Beschneiden(ByVal Bmp As Bitmap) As Bitmap
 
        Dim CropRight As Integer, CropLeft As Integer, CropTop As Integer, _
          CropBottom As Integer
 
        'von Links
        For CropLeft = 0 To Bmp.Width - 1
            If beschneiden_check_row(Bmp, CropLeft) = False Then CropLeft -= 1 _
              : Exit For
        Next
        If CropLeft = -1 Then CropLeft = 0
        'von Rechts
        For CropRight = Bmp.Width - 1 To 0 Step -1
            If beschneiden_check_row(Bmp, CropRight) = False Then CropRight += _
              1 : Exit For
        Next
        'von Oben
        For CropTop = 0 To Bmp.Height - 1
            If beschneiden_check_col(Bmp, CropTop) = False Then CropTop -= 1 : _
              Exit For
        Next
        If CropTop = -1 Then CropTop = 0
        'von Unten
        For CropBottom = Bmp.Height - 1 To 1 Step -1
            If beschneiden_check_col(Bmp, CropBottom) = False Then CropBottom _
              += 1 : Exit For
        Next
 
        If CropBottom = Bmp.Height And CropTop = 0 And CropLeft = 0 And _
          CropRight = Bmp.Width Or CropBottom - CropTop < 0 Or CropRight - _
          CropLeft < 0 Then Return Bmp
 
        Dim NewWidth As Integer = CropRight - CropLeft
        Dim NewHeight As Integer = CropBottom - CropTop
 
        Dim fixBmp As Bitmap = New Bitmap(NewWidth, NewHeight, _
          PixelFormat.Format32bppArgb)
 
        Dim g As Drawing.Graphics = Graphics.FromImage(fixBmp)
        g.Clear(Color.White)
        g.SmoothingMode = SmoothingMode.HighQuality
        g.CompositingQuality = CompositingQuality.HighQuality
        g.InterpolationMode = InterpolationMode.High
 
        g.DrawImage(Bmp, New RectangleF(0, 0, NewWidth, NewHeight), New _
          RectangleF(CropLeft, CropTop, NewWidth, NewHeight), _
          GraphicsUnit.Pixel)
 
        Return fixBmp
    End Function
Wie kann ich das Problem lösen?

Joachim

Joachim

alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Speicher läuft über ...1.914Jojo02.12.10 09:41
Re: Speicher läuft über ...1.134DotNetErbse02.12.10 10:34
Re: Speicher läuft über ...1.126Jojo02.12.10 10:42
Re: Speicher läuft über ...1.179ModeratorFZelle02.12.10 10:35
Re: Speicher läuft über ...1.207Jojo02.12.10 10:55
Re: Speicher läuft über ...1.155ModeratorFZelle02.12.10 12:12
Re: Speicher läuft über ...1.132Jan536604.12.10 14:55
Re: Speicher läuft über ...1.095ModeratorFZelle04.12.10 23:43
Re: Speicher läuft über ...1.152Jan536605.12.10 12:25
Re: Speicher läuft über ...1.067ModeratorDaveS05.12.10 12:41

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel