Hallo,
ich versuche ein Foto eines Fensters zu machen das ich über 2 Monitore hinweg gezogen habe, da der 2te Monitor allerdings etwas kleiner ist als der Hauptbildschirm schneidet er mir einen Teil des Fenster weg, der allerdings wichtig ist. Bei dem Fenster handelt es sich um ein Spiel namens EVE Online(DirectX). Und obwohl hier für gewöhnlich sich jedes HUD Element verschieben lässt, ist es genau dieses eine Element das er nicht verschieben lassen mag.
Abgeschnitten bringt es mir allerdings nicht viel deshalb dachte ich gestern noch darüber nach das Windows diesen bereich des Fensters doch weiterhin berechnet & das wollte ich direkt einmal überprüfen. Meine ergebnisse sind bescheiden, da ich super das Fenster im ganzen fotografieren kann, doch der eine Teil weiterhin fehlt.
Darauf hin machte ich mich auf den Weg zu duckduckgo und ließ mich per Präfix suche mit ergebnissen beraten und bekam einige teils jahrealte beispiele wo mit _WinAPI_CreateCompatibleBitmap ein Foto eines fensters gemacht wurde das vorher außerhalb der Monitore geschoben wurde. Dies wurde super angezeigt & ich probierte eben jenes sofort auch mit dem DirectX fenster was mir dann wiederum nur ein Schwarzes bild speicherte.
Hier ein Beispiel
[Blockierte Grafik: http://oi67.tinypic.com/qppjli.jpg]
Ich habe bisher schon mit dem hier gearbeitet bekam aber kein einziges zufriedenstellendes ergebnis wo mir der verschwundene Teil angezeigt wurde.
#include <ScreenCapture.au3>
#include <GDIPlus.au3>
#include <WinAPI.au3>
Global $fPath = @ScriptDir & "\TestEve.jpg"
Exit ;cut
_WinCapture(WinGetHandle("[CLASS:triuiScreen]"))
Exit ;cut, damit ich den code nicht löschen muss, fals er mir nocheinmal im findungs prozess nützlich wird.
_ScreenCapture_SetJPGQuality(80)
$picture = _ScreenCapture_CaptureWnd($fPath, WinGetHandle("[CLASS:triuiScreen]"), -1, -1)
ShellExecute($fPath)
Func _WinCapture($hWnd, $iWidth = -1, $iHeight = -1)
Local $iH, $iW, $hDDC, $hCDC, $hBMP
If $iWidth = -1 Then $iWidth = _WinAPI_GetWindowWidth($hWnd)
If $iHeight = -1 Then $iHeight = _WinAPI_GetWindowHeight($hWnd)
$hDDC = _WinAPI_GetDC($hWnd)
$hCDC = _WinAPI_CreateCompatibleDC($hDDC)
$hBMP = _WinAPI_CreateCompatibleBitmap($hDDC, $iWidth, $iHeight)
_WinAPI_SelectObject($hCDC, $hBMP)
DllCall("User32.dll", "int", "PrintWindow", "hwnd", $hWnd, "hwnd", $hCDC, "int", 0)
_WinAPI_BitBlt($hCDC, 0, 0, $iW, $iH, $hDDC, 0, 0, 0x00330008)
_WinAPI_ReleaseDC($hWnd, $hDDC)
_WinAPI_DeleteDC($hCDC)
_ScreenCapture_SaveImage($fPath, $hBMP, False)
Return $hBMP
EndFunc ;==>_WinCapture
Func _ScreenCaptureDesktop_ToFile($fPath)
if FileExists($fPath) Then FileDelete($fPath)
_ScreenCapture_SetJPGQuality(80)
$picture = _ScreenCapture_Capture($fPath)
if @error Then Return False
Return True
EndFunc
Func _ScreenCaptureDesktop_Data($fPath = @TempDir & "\" & Random("0", "9999999", 1) & '.jpg')
if FileExists($fPath) Then FileDelete($fPath)
_ScreenCapture_SetJPGQuality(80)
$picture = _ScreenCapture_Capture($fPath)
if @error Then SetError(-1, False, 0)
$h_picture = FileOpen($fPath)
if $h_picture = -1 Then SetError(-2, False, 0)
$r_picture = FileRead($h_picture)
if @error Then SetError(-3, False, 0)
FileClose($h_picture)
FileDelete($fPath)
Return $r_picture
EndFunc
Alles anzeigen
Mir fällt es sehr schwer herauszufinden worauf ich achten muss um diesen off screen Teil heraus zu fotografieren. Schlußendlich habe ich vor diesen teil des Fenster mir in einem Seperatem Fenster, mit immer im Vordergrund, anzeigen zu lassen. Doch vorher muss die Innere technik funktionieren.
Kann mir wer von euch Profis sagen wo ich genauer hinschauen sollte?