From fb6d1154732a9de8f502a985a29d56d5b0033b4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=81=8D=E5=85=AE=E6=83=9A=E5=85=AE?= <101191390+HIllya51@users.noreply.github.com> Date: Sun, 11 Aug 2024 02:54:33 +0800 Subject: [PATCH] anki --- .../LunaTranslator/gui/dialog_savedgame.py | 18 ---- LunaTranslator/LunaTranslator/gui/showword.py | 100 ++++++++++++++---- .../LunaTranslator/myutils/config.py | 17 ++- .../files/defaultconfig/config.json | 5 +- plugins/CMakeLists.txt | 2 +- 5 files changed, 100 insertions(+), 42 deletions(-) diff --git a/LunaTranslator/LunaTranslator/gui/dialog_savedgame.py b/LunaTranslator/LunaTranslator/gui/dialog_savedgame.py index 8e64f9a6..22944533 100644 --- a/LunaTranslator/LunaTranslator/gui/dialog_savedgame.py +++ b/LunaTranslator/LunaTranslator/gui/dialog_savedgame.py @@ -761,7 +761,6 @@ class dialog_setting_game_internal(QWidget): ("翻译优化", functools.partial(self.___tabf, self.gettransoptimi)), ("语音", functools.partial(self.___tabf, self.getttssetting)), ("预翻译", functools.partial(self.___tabf, self.getpretranstab)), - ("Anki", functools.partial(self.___tabf, self.maketabforanki)), ] methodtab, do = makesubtab_lazy( [_[0] for _ in functs], @@ -1116,23 +1115,6 @@ class dialog_setting_game_internal(QWidget): ), ) - def maketabforanki(self, formLayout: LFormLayout, gameuid): - - savehook_new_data[gameuid]["anki_DeckName"] = savehook_new_data[gameuid].get( - "anki_DeckName", globalconfig["ankiconnect"]["DeckName"] - ) - - formLayout2 = self.createfollowdefault( - savehook_new_data[gameuid], "follow_default_ankisettings", formLayout - ) - formLayout2.addRow( - "DeckName", - getlineedit( - savehook_new_data[gameuid], - "anki_DeckName", - ), - ) - def getpretranstab(self, formLayout: LFormLayout, gameuid): def selectimg(gameuid, key, res): diff --git a/LunaTranslator/LunaTranslator/gui/showword.py b/LunaTranslator/LunaTranslator/gui/showword.py index 3cb20cef..adc3ce8d 100644 --- a/LunaTranslator/LunaTranslator/gui/showword.py +++ b/LunaTranslator/LunaTranslator/gui/showword.py @@ -6,7 +6,7 @@ import qtawesome, requests, gobject, windows import myutils.ankiconnect as anki from myutils.hwnd import grabwindow from myutils.config import globalconfig, _TR, static_data, savehook_new_data -from myutils.utils import loopbackrecorder +from myutils.utils import loopbackrecorder, parsekeystringtomodvkcode from myutils.wrapper import threader, tryprint from myutils.ocrutil import imageCut, ocr_run_2 from gui.rangeselect import rangeselct_function @@ -15,6 +15,7 @@ from gui.usefulwidget import ( statusbutton, getQMessageBox, auto_select_webview, + FocusCombo, getboxlayout, getspinbox, getsimplecombobox, @@ -290,7 +291,36 @@ class AnkiWindow(QWidget): layout.addRow( "端口号", getspinbox(0, 65536, globalconfig["ankiconnect"], "port") ) - layout.addRow("DeckName", getlineedit(globalconfig["ankiconnect"], "DeckName")) + combox = getsimplecombobox( + globalconfig["ankiconnect"]["DeckNameS"], + globalconfig["ankiconnect"], + "DeckName_i", + ) + + def refreshcombo(combo: QComboBox): + combo.clear() + if len(globalconfig["ankiconnect"]["DeckNameS"]) == 0: + globalconfig["ankiconnect"]["DeckNameS"].append("lunadeck") + combo.addItems(globalconfig["ankiconnect"]["DeckNameS"]) + + layout.addRow( + "DeckName", + getboxlayout( + [ + getIconButton( + lambda: listediter( + self, + "DeckName", + "DeckName", + globalconfig["ankiconnect"]["DeckNameS"], + closecallback=functools.partial(refreshcombo, combox), + ), + icon="fa.gear", + ), + combox, + ] + ), + ) layout.addRow( "ModelName", getlineedit(globalconfig["ankiconnect"], "ModelName5") ) @@ -345,9 +375,50 @@ class AnkiWindow(QWidget): namemapfunction=lambda k: globalconfig["cishu"][k]["name"], ) + @threader + def simulate_key(self, i): + def __internal__keystring(i): + try: + for _ in (0,): + + if not gobject.baseobject.textsource: + break + + gameuid = gobject.baseobject.textsource.gameuid + if not gameuid: + break + if savehook_new_data[gameuid]["follow_default_ankisettings"]: + break + if not savehook_new_data[gameuid][f"anki_simulate_key_{i}_use"]: + return None + return savehook_new_data[gameuid][ + f"anki_simulate_key_{i}_keystring" + ] + except: + pass + return globalconfig["ankiconnect"]["simulate_key"][i]["keystring"] + + keystring = __internal__keystring(i) + if not keystring: + return + windows.SetForegroundWindow(gobject.baseobject.textsource.hwnd) + time.sleep(0.1) + try: + modes, vkcode = parsekeystringtomodvkcode(keystring, modes=True) + except: + return + for mode in modes: + windows.keybd_event(mode, 0, 0, 0) + windows.keybd_event(vkcode, 0, 0, 0) + time.sleep(0.1) + windows.keybd_event(vkcode, 0, windows.KEYEVENTF_KEYUP, 0) + for mode in modes: + windows.keybd_event(mode, 0, windows.KEYEVENTF_KEYUP, 0) + def startorendrecord(self, target: QLineEdit, idx): if idx == 1: self.recorder = loopbackrecorder() + self.simulate_key(idx) else: self.recorder.end(callback=target.setText) @@ -553,29 +624,16 @@ class AnkiWindow(QWidget): def addanki(self): - def __internal__DeckName(): - try: - for _ in (0,): - - if not gobject.baseobject.textsource: - break - - gameuid = gobject.baseobject.textsource.gameuid - if not gameuid: - break - if savehook_new_data[gameuid]["follow_default_ankisettings"]: - break - - return savehook_new_data[gameuid]["anki_DeckName"] - except: - pass - return globalconfig["ankiconnect"]["DeckName"] - autoUpdateModel = globalconfig["ankiconnect"]["autoUpdateModel"] allowDuplicate = globalconfig["ankiconnect"]["allowDuplicate"] anki.global_port = globalconfig["ankiconnect"]["port"] ModelName = globalconfig["ankiconnect"]["ModelName5"] - DeckName = __internal__DeckName() + try: + DeckName = globalconfig["ankiconnect"]["DeckNameS"][ + globalconfig["ankiconnect"]["DeckName_i"] + ] + except: + DeckName = "lunadeck" model_htmlfront, model_htmlback, model_css = self.tryloadankitemplates() tags = globalconfig["ankiconnect"]["tags"] anki.Deck.create(DeckName) diff --git a/LunaTranslator/LunaTranslator/myutils/config.py b/LunaTranslator/LunaTranslator/myutils/config.py index 55b8ee44..fc417197 100644 --- a/LunaTranslator/LunaTranslator/myutils/config.py +++ b/LunaTranslator/LunaTranslator/myutils/config.py @@ -131,7 +131,6 @@ def getdefaultsavehook(title=None): # "private_srclang_2": 0,# 显示时再加载,缺省用global中的键 # "private_tgtlang_2": 0, "follow_default_ankisettings": True, - # "anki_DeckName":str # "localeswitcher": 0,废弃 "onloadautochangemode2": 0, "needinserthookcode": [], @@ -468,6 +467,22 @@ for key in globalconfig["toolbutton"]["rank2"]: for key in ___: globalconfig["toolbutton"]["rank2"].remove(key) +if "DeckName" in globalconfig["ankiconnect"]: + if ( + globalconfig["ankiconnect"]["DeckName"] + not in globalconfig["ankiconnect"]["DeckNameS"] + ): + globalconfig["ankiconnect"]["DeckNameS"].append( + globalconfig["ankiconnect"].pop("DeckName") + ) + + for data in savehook_new_data.values(): + deck = data.get("anki_DeckName", "") + if not deck: + continue + if deck in globalconfig["ankiconnect"]["DeckNameS"]: + continue + globalconfig["ankiconnect"]["DeckNameS"].append(deck) for group in ["webview", "textbrowser"]: diff --git a/LunaTranslator/files/defaultconfig/config.json b/LunaTranslator/files/defaultconfig/config.json index 8a9089f2..3637c404 100644 --- a/LunaTranslator/files/defaultconfig/config.json +++ b/LunaTranslator/files/defaultconfig/config.json @@ -472,7 +472,10 @@ "jiamingcolor": "black", "ankiconnect": { "port": 8765, - "DeckName": "lunadeck", + "DeckName_i": 0, + "DeckNameS": [ + "lunadeck" + ], "ModelName5": "lunamodel5", "allowDuplicate": true, "autoUpdateModel": true, diff --git a/plugins/CMakeLists.txt b/plugins/CMakeLists.txt index 3580ee38..44dd5105 100644 --- a/plugins/CMakeLists.txt +++ b/plugins/CMakeLists.txt @@ -29,7 +29,7 @@ include(generate_product_version) set(VERSION_MAJOR 5) set(VERSION_MINOR 25) -set(VERSION_PATCH 0) +set(VERSION_PATCH 1) add_library(pch pch.cpp) target_precompile_headers(pch PUBLIC pch.h)