vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 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 - Ein- und Umsteiger
Re: Lupenfunktion 
Autor: lakamabi
Datum: 10.01.08 13:33

Noch mal ein schneller Tipp von mir :

Um ein ruckeln bei der Bilddarstellung zu verhindern, sollte man einen Timer benutzen, der wenn er abläuft das Bild darstellt. Beim Mausbewegungen wird er immer wieder gestoppt und neu gestartet.

Ich habs so gelöst und es funktioniert wunderbar !!!

pbLupe und pbAuswahl sind Pictureboxes
tLupe ist ein Timer mit einem Interval von 15 ms

class test
    Private r As Rectangle
    Private intXGroesse As Integer = 50 * PB_XFAKTOR
    Private dblFaktor As Double
    Private b As Bitmap
    Private i As Image
    Private tbmp As Bitmap
    Private AlreadyCreated As Boolean
    Private g As Graphics
    Private MausPosi As Point
 
    Private Sub pbAuswahl_MouseEnter(ByVal sender As Object, ByVal e As _
      System.EventArgs) Handles pbAuswahl.MouseEnter
        'Einmaliges Anlegen der fixen Parameter
        If Not AlreadyCreated Then
            r = New Rectangle
            r.Height = pbAuswahl.Height
            r.Width = pbAuswahl.Width
            dblFaktor = pbLupe.Width / pbLupe.Height
            b = New Bitmap(pbLupe.Width, pbLupe.Height)
            i = pbAuswahl.Image
            tbmp = New Bitmap(pbAuswahl.Width, pbAuswahl.Height) 'temporäres 
            ' Bitmap erzeugen
            g = Graphics.FromImage(b)
            AlreadyCreated = True
        End If
 
        pbLupe.Visible = True
        tLupe.Enabled = True
    End Sub
 
    Private Sub pbAuswahl_MouseLeave(ByVal sender As Object, ByVal e As _
      System.EventArgs) Handles pbAuswahl.MouseLeave
        pbLupe.Visible = False
        tLupe.Enabled = False
    End Sub
 
    Private Sub pbAuswahl_MouseMove(ByVal sender As Object, ByVal e As _
      System.Windows.Forms.MouseEventArgs) Handles pbAuswahl.MouseMove
        MausPosi.X = e.X
        MausPosi.Y = e.Y
        tLupe.Stop()
        tLupe.Start()
    End Sub
 
    Private Sub tLupe_Tick(ByVal sender As System.Object, ByVal e As _
      System.EventArgs) Handles tLupe.Tick
        pbAuswahl.DrawToBitmap(tbmp, r) 'Inhalt der Picturebox Hineinzeichnen
        g.DrawImage(tbmp, New Rectangle(0, 0, pbAuswahl.Width, _
          pbAuswahl.Height), _
                            New Rectangle(MausPosi.X - intXGroesse, MausPosi.Y _
                            - CInt(intXGroesse / dblFaktor), _
                            intXGroesse * 2, CInt(intXGroesse / dblFaktor) * _
                            2), GraphicsUnit.Pixel)
        pbLupe.Image = b
    End Sub
end class
ist natürlich jetzt auf mein Programm angepasst aber ich denke die Systematik sollte klar sein.


Vielen Dank nochmal für die Hilfe hier.

Gruß
Sebastian
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Lupenfunktion2.898lakamabi08.01.08 15:39
Re: Lupenfunktion1.319mikeb6908.01.08 15:45
Re: Lupenfunktion1.268lakamabi08.01.08 16:15
Re: Lupenfunktion1.284mikeb6908.01.08 17:15
Re: Lupenfunktion1.226lakamabi08.01.08 17:42
Re: Lupenfunktion1.606mikeb6908.01.08 17:56
Re: Lupenfunktion1.190lakamabi08.01.08 18:31
Re: Lupenfunktion1.272mikeb6908.01.08 21:41
Re: Lupenfunktion1.219lakamabi09.01.08 09:28
Re: Lupenfunktion1.399lakamabi09.01.08 09:15
Re: Lupenfunktion1.341lakamabi09.01.08 09:45
Re: Lupenfunktion1.283lakamabi09.01.08 09:47
Re: Lupenfunktion1.145lakamabi09.01.08 09:49
Re: Lupenfunktion1.234cookstdu09.01.08 10:32
Re: Lupenfunktion1.172lakamabi09.01.08 11:47
Re: Lupenfunktion1.207lakamabi10.01.08 11:09
Re: Lupenfunktion1.196lakamabi10.01.08 11:17
Re: Lupenfunktion1.301lakamabi10.01.08 13:33
Re: Lupenfunktion1.273lakamabi10.01.08 15:55

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