mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2025-01-15 08:53:53 +08:00
screenshot
This commit is contained in:
parent
32dcf73971
commit
7efce3c41a
@ -15,11 +15,14 @@ def GetDllpath(_, base=None):
|
|||||||
return os.path.join(base, _[isbit64])
|
return os.path.join(base, _[isbit64])
|
||||||
|
|
||||||
|
|
||||||
def getcachedir(name, basedir="cache"):
|
def getcachedir(name, basedir="cache", abspath=True):
|
||||||
|
|
||||||
fd = os.path.dirname(name)
|
fd = os.path.dirname(name)
|
||||||
fn = os.path.basename(name)
|
fn = os.path.basename(name)
|
||||||
|
if abspath:
|
||||||
fn1 = os.path.abspath(basedir)
|
fn1 = os.path.abspath(basedir)
|
||||||
|
else:
|
||||||
|
fn1 = basedir
|
||||||
fn1 = os.path.join(fn1, fd)
|
fn1 = os.path.join(fn1, fd)
|
||||||
os.makedirs(fn1, exist_ok=True)
|
os.makedirs(fn1, exist_ok=True)
|
||||||
fn1 = os.path.join(fn1, fn)
|
fn1 = os.path.join(fn1, fn)
|
||||||
|
@ -2,18 +2,23 @@ import windows
|
|||||||
import threading
|
import threading
|
||||||
from qtsymbols import *
|
from qtsymbols import *
|
||||||
import gobject
|
import gobject
|
||||||
import os, subprocess
|
import os, subprocess, functools
|
||||||
import time, winrtutils, winsharedutils, hashlib
|
import time, winrtutils, winsharedutils, hashlib
|
||||||
|
from myutils.config import savehook_new_data
|
||||||
from myutils.wrapper import threader
|
from myutils.wrapper import threader
|
||||||
|
|
||||||
|
|
||||||
@threader
|
@threader
|
||||||
def grabwindow(app="PNG", callback=None):
|
def grabwindow(app="PNG", callback_origin=None):
|
||||||
if callback:
|
if callback_origin:
|
||||||
fname = gobject.gettempdir(time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime()))
|
fname = gobject.gettempdir(time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime()))
|
||||||
|
uid = None
|
||||||
else:
|
else:
|
||||||
dirname = "0"
|
dirname = "0"
|
||||||
|
try:
|
||||||
|
uid = gobject.baseobject.textsource.gameuid
|
||||||
|
except:
|
||||||
|
uid = None
|
||||||
try:
|
try:
|
||||||
if gobject.baseobject.textsource.md5 != "0":
|
if gobject.baseobject.textsource.md5 != "0":
|
||||||
dirname = gobject.baseobject.textsource.basename
|
dirname = gobject.baseobject.textsource.basename
|
||||||
@ -22,8 +27,18 @@ def grabwindow(app="PNG", callback=None):
|
|||||||
fname = gobject.getcachedir(
|
fname = gobject.getcachedir(
|
||||||
f"screenshot/{dirname}/"
|
f"screenshot/{dirname}/"
|
||||||
+ time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime()),
|
+ time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime()),
|
||||||
|
abspath=False,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def callback_1(callback, uid, fn):
|
||||||
|
if not os.path.exists(fn):
|
||||||
|
return
|
||||||
|
if callback:
|
||||||
|
callback(os.path.abspath(fn))
|
||||||
|
if uid:
|
||||||
|
savehook_new_data[uid]["imagepath_all"].append(fn)
|
||||||
|
|
||||||
|
callback = functools.partial(callback_1, callback_origin, uid)
|
||||||
hwnd = windows.FindWindow(
|
hwnd = windows.FindWindow(
|
||||||
"Window_Magpie_967EB565-6F73-4E94-AE53-00CC42592A22", None
|
"Window_Magpie_967EB565-6F73-4E94-AE53-00CC42592A22", None
|
||||||
)
|
)
|
||||||
@ -32,8 +47,7 @@ def grabwindow(app="PNG", callback=None):
|
|||||||
@threader
|
@threader
|
||||||
def _():
|
def _():
|
||||||
winrtutils._winrt_capture_window(fname + "_winrt_magpie." + app, hwnd)
|
winrtutils._winrt_capture_window(fname + "_winrt_magpie." + app, hwnd)
|
||||||
if callback and os.path.exists(fname + "_winrt_magpie." + app):
|
callback(fname + "_winrt_magpie." + app)
|
||||||
callback(os.path.abspath(fname + "_winrt_magpie." + app))
|
|
||||||
|
|
||||||
_()
|
_()
|
||||||
hwnd = windows.FindWindow("LosslessScaling", None)
|
hwnd = windows.FindWindow("LosslessScaling", None)
|
||||||
@ -42,8 +56,7 @@ def grabwindow(app="PNG", callback=None):
|
|||||||
@threader
|
@threader
|
||||||
def _():
|
def _():
|
||||||
winrtutils._winrt_capture_window(fname + "_winrt_lossless." + app, hwnd)
|
winrtutils._winrt_capture_window(fname + "_winrt_lossless." + app, hwnd)
|
||||||
if callback and os.path.exists(fname + "_winrt_lossless." + app):
|
callback(fname + "_winrt_lossless." + app)
|
||||||
callback(os.path.abspath(fname + "_winrt_lossless." + app))
|
|
||||||
|
|
||||||
_()
|
_()
|
||||||
try:
|
try:
|
||||||
@ -57,10 +70,9 @@ def grabwindow(app="PNG", callback=None):
|
|||||||
p = screenshot(0, 0, _[2], _[3], hwnd).toImage()
|
p = screenshot(0, 0, _[2], _[3], hwnd).toImage()
|
||||||
if not p.allGray():
|
if not p.allGray():
|
||||||
p.save(fname + "_gdi." + app)
|
p.save(fname + "_gdi." + app)
|
||||||
if callback and os.path.exists(fname + "_gdi." + app):
|
callback(fname + "_gdi." + app)
|
||||||
callback(os.path.abspath(fname + "_gdi." + app))
|
|
||||||
|
|
||||||
if not callback:
|
if not callback_origin:
|
||||||
|
|
||||||
gobject.baseobject.translation_ui.displaystatus.emit(
|
gobject.baseobject.translation_ui.displaystatus.emit(
|
||||||
"saved to " + fname, "red", True, True
|
"saved to " + fname, "red", True, True
|
||||||
@ -69,10 +81,9 @@ def grabwindow(app="PNG", callback=None):
|
|||||||
@threader
|
@threader
|
||||||
def _():
|
def _():
|
||||||
winrtutils._winrt_capture_window(fname + "_winrt." + app, hwnd)
|
winrtutils._winrt_capture_window(fname + "_winrt." + app, hwnd)
|
||||||
if callback and os.path.exists(fname + "_winrt." + app):
|
callback(fname + "_winrt." + app)
|
||||||
callback(os.path.abspath(fname + "_winrt." + app))
|
|
||||||
|
|
||||||
if p.allGray() or (not callback):
|
if p.allGray() or (not callback_origin):
|
||||||
_()
|
_()
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user