Die Community zu .NET und Classic VB.
Menü

VB 5/6-Tipp 0430: Zeichnen im DC einer fremden Anwendung

 von 

Beschreibung 

Dieses Beipiel kopiert eine Grafik in einen bieliebigen DC fremder und eigener Anwendung. Das Fenster wird dabei durch Verändern der Mausposition festgelegt.

Schwierigkeitsgrad:

Schwierigkeitsgrad 2

Verwendete API-Aufrufe:

BitBlt, GetCursorPos, GetDC, ReleaseDC, WindowFromPoint

Download:

Download des Beispielprojektes [5,46 KB]

'Dieser Quellcode stammt von http://www.activevb.de
'und kann frei verwendet werden. Für eventuelle Schäden
'wird nicht gehaftet.

'Um Fehler oder Fragen zu klären, nutzen Sie bitte unser Forum.
'Ansonsten viel Spaß und Erfolg mit diesem Source!

'------------- Anfang Projektdatei Projekt1.vbp -------------
'--------- Anfang Formular "Form1" alias Form1.frm  ---------
' Steuerelement: Timersteuerelement "timMain"
' Steuerelement: Bildfeld-Steuerelement "picMain"
' Steuerelement: Beschriftungsfeld "Label2"
' Steuerelement: Beschriftungsfeld "Label1"


'Autor: Michael G.
'E-Mail: MrNicely@gmx.de

Option Explicit

Private Declare Function GetCursorPos Lib "user32" (lpPoint _
        As POINTAPI) As Long
        
Private Declare Function WindowFromPoint Lib "user32" (ByVal _
        x As Long, ByVal y As Long) As Long
        
Private Declare Function GetDC Lib "user32" (ByVal hwnd As _
        Long) As Long
        
Private Declare Function ReleaseDC Lib "user32" (ByVal hwnd _
        As Long, ByVal hdc As Long) As Long
        
Private Declare Function BitBlt Lib "gdi32" (ByVal hDestDC As _
        Long, ByVal x As Long, ByVal y As Long, ByVal nWidth _
        As Long, ByVal nHeight As Long, ByVal hSrcDC As Long, _
        ByVal xSrc As Long, ByVal ySrc As Long, ByVal dwRop _
        As Long) As Long

Private Type POINTAPI
    x As Long
    y As Long
End Type

Private Sub Form_Load()
    timMain.Interval = 1000
    timMain.Enabled = True
    
    picMain.Picture = LoadPicture(App.Path & _
        IIf(Right(App.Path, 1) = "\", "", "\") & "Pic.jpg")
End Sub

Private Sub timMain_Timer()
    Dim Pos As POINTAPI, mDC As Long
    Static TimePaint As Integer
    
    Call GetCursorPos(Pos)
    
    If TimePaint <= 1 Then
        mDC = GetDC(WindowFromPoint(Pos.x, Pos.y))
        
        Call BitBlt(mDC, 0, 0, picMain.ScaleWidth, _
                    picMain.ScaleHeight, picMain.hdc, _
                    0, 0, vbSrcCopy)
        
        Call ReleaseDC(WindowFromPoint(Pos.x, Pos.y), mDC)
        TimePaint = 3
    End If
    
    TimePaint = TimePaint - 1
    Label1.Caption = "hWnd unterm Cursor: " _
                      & WindowFromPoint(Pos.x, Pos.y)
    
    Label2.Caption = "Bild wir gemalt in: " & TimePaint & "sek"
End Sub
'---------- Ende Formular "Form1" alias Form1.frm  ----------
'-------------- Ende Projektdatei Projekt1.vbp --------------

Tipp-Kompatibilität:

Windows/VB-VersionWin32sWin95Win98WinMEWinNT4Win2000WinXP
VB4
VB5
VB6

Hat dieser Tipp auf Ihrem Betriebsystem und mit Ihrer VB-Version funktioniert?

Ja, funktioniert!

Nein, funktioniert nicht bei mir!

VB-Version:

Windows-Version:

Ihre Meinung  

Falls Sie Fragen zu diesem Artikel haben oder Ihre Erfahrung mit anderen Nutzern austauschen möchten, dann teilen Sie uns diese bitte in einem der unten vorhandenen Themen oder über einen neuen Beitrag mit. Hierzu können sie einfach einen Beitrag in einem zum Thema passenden Forum anlegen, welcher automatisch mit dieser Seite verknüpft wird.

Archivierte Nutzerkommentare 

Klicken Sie diesen Text an, wenn Sie die 2 archivierten Kommentare ansehen möchten.
Diese stammen noch von der Zeit, als es noch keine direkte Forenunterstützung für Fragen und Kommentare zu einzelnen Artikeln gab.
Aus Gründen der Vollständigkeit können Sie sich die ausgeblendeten Kommentare zu diesem Artikel aber gerne weiterhin ansehen.

Kommentar von timo am 20.09.2011 um 20:07

Google sei dank habe ich ein gutes Beispiel für WindowFromPoint auf AVB gefunden.

Kommentar von Kai.M am 31.01.2008 um 15:52

gibt es auch eine möglichkeit nciht das bild zu "Schreiben" sondern auszulesen????