Update ocrutil.py

This commit is contained in:
恍兮惚兮 2024-08-14 16:19:57 +08:00
parent 78fcf9c356
commit b3d0294398

View File

@ -80,6 +80,7 @@ def imageCut(hwnd, x1, y1, x2, y2, viscompare=True, rawimage=False) -> QImage:
return image2 return image2
_nowuseocrx = None
_nowuseocr = None _nowuseocr = None
_ocrengine = None _ocrengine = None
_initlock = threading.Lock() _initlock = threading.Lock()
@ -89,6 +90,7 @@ def ocr_end():
global _ocrengine, _nowuseocr global _ocrengine, _nowuseocr
with _initlock: with _initlock:
_nowuseocr = None _nowuseocr = None
_nowuseocrx = None
_ocrengine = None _ocrengine = None
@ -98,7 +100,7 @@ def ocr_init():
def __ocr_init(): def __ocr_init():
global _nowuseocr, _ocrengine global _nowuseocr, _ocrengine, _nowuseocrx
use = None use = None
for k in globalconfig["ocr"]: for k in globalconfig["ocr"]:
if globalconfig["ocr"][k]["use"] == True and os.path.exists( if globalconfig["ocr"][k]["use"] == True and os.path.exists(
@ -110,6 +112,7 @@ def __ocr_init():
raise Exception("no engine") raise Exception("no engine")
if _nowuseocr == use: if _nowuseocr == use:
return return
_nowuseocrx = use
_ocrengine = None _ocrengine = None
_nowuseocr = None _nowuseocr = None
aclass = importlib.import_module("ocrengines." + use).OCR aclass = importlib.import_module("ocrengines." + use).OCR
@ -121,7 +124,7 @@ def ocr_run(qimage: QImage):
image = qimage2binary(qimage, "PNG") image = qimage2binary(qimage, "PNG")
if not image: if not image:
return "" return ""
global _nowuseocr, _ocrengine global _nowuseocrx, _ocrengine
try: try:
ocr_init() ocr_init()
text = _ocrengine._private_ocr(image) text = _ocrengine._private_ocr(image)
@ -133,7 +136,7 @@ def ocr_run(qimage: QImage):
msg = stringfyerror(e) msg = stringfyerror(e)
msg = ( msg = (
"<msg_error_refresh>" "<msg_error_refresh>"
+ _TR(globalconfig["ocr"][_nowuseocr]["name"]) + _TR(globalconfig["ocr"][_nowuseocrx]["name"])
+ " " + " "
+ msg + msg
) )