This commit is contained in:
恍兮惚兮 2024-08-11 02:54:33 +08:00
parent afa4744b14
commit fb6d115473
5 changed files with 100 additions and 42 deletions

View File

@ -761,7 +761,6 @@ class dialog_setting_game_internal(QWidget):
("翻译优化", functools.partial(self.___tabf, self.gettransoptimi)), ("翻译优化", functools.partial(self.___tabf, self.gettransoptimi)),
("语音", functools.partial(self.___tabf, self.getttssetting)), ("语音", functools.partial(self.___tabf, self.getttssetting)),
("预翻译", functools.partial(self.___tabf, self.getpretranstab)), ("预翻译", functools.partial(self.___tabf, self.getpretranstab)),
("Anki", functools.partial(self.___tabf, self.maketabforanki)),
] ]
methodtab, do = makesubtab_lazy( methodtab, do = makesubtab_lazy(
[_[0] for _ in functs], [_[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 getpretranstab(self, formLayout: LFormLayout, gameuid):
def selectimg(gameuid, key, res): def selectimg(gameuid, key, res):

View File

@ -6,7 +6,7 @@ import qtawesome, requests, gobject, windows
import myutils.ankiconnect as anki import myutils.ankiconnect as anki
from myutils.hwnd import grabwindow from myutils.hwnd import grabwindow
from myutils.config import globalconfig, _TR, static_data, savehook_new_data 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.wrapper import threader, tryprint
from myutils.ocrutil import imageCut, ocr_run_2 from myutils.ocrutil import imageCut, ocr_run_2
from gui.rangeselect import rangeselct_function from gui.rangeselect import rangeselct_function
@ -15,6 +15,7 @@ from gui.usefulwidget import (
statusbutton, statusbutton,
getQMessageBox, getQMessageBox,
auto_select_webview, auto_select_webview,
FocusCombo,
getboxlayout, getboxlayout,
getspinbox, getspinbox,
getsimplecombobox, getsimplecombobox,
@ -290,7 +291,36 @@ class AnkiWindow(QWidget):
layout.addRow( layout.addRow(
"端口号", getspinbox(0, 65536, globalconfig["ankiconnect"], "port") "端口号", 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( layout.addRow(
"ModelName", getlineedit(globalconfig["ankiconnect"], "ModelName5") "ModelName", getlineedit(globalconfig["ankiconnect"], "ModelName5")
) )
@ -345,9 +375,50 @@ class AnkiWindow(QWidget):
namemapfunction=lambda k: globalconfig["cishu"][k]["name"], 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): def startorendrecord(self, target: QLineEdit, idx):
if idx == 1: if idx == 1:
self.recorder = loopbackrecorder() self.recorder = loopbackrecorder()
self.simulate_key(idx)
else: else:
self.recorder.end(callback=target.setText) self.recorder.end(callback=target.setText)
@ -553,29 +624,16 @@ class AnkiWindow(QWidget):
def addanki(self): 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"] autoUpdateModel = globalconfig["ankiconnect"]["autoUpdateModel"]
allowDuplicate = globalconfig["ankiconnect"]["allowDuplicate"] allowDuplicate = globalconfig["ankiconnect"]["allowDuplicate"]
anki.global_port = globalconfig["ankiconnect"]["port"] anki.global_port = globalconfig["ankiconnect"]["port"]
ModelName = globalconfig["ankiconnect"]["ModelName5"] 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() model_htmlfront, model_htmlback, model_css = self.tryloadankitemplates()
tags = globalconfig["ankiconnect"]["tags"] tags = globalconfig["ankiconnect"]["tags"]
anki.Deck.create(DeckName) anki.Deck.create(DeckName)

View File

@ -131,7 +131,6 @@ def getdefaultsavehook(title=None):
# "private_srclang_2": 0,# 显示时再加载缺省用global中的键 # "private_srclang_2": 0,# 显示时再加载缺省用global中的键
# "private_tgtlang_2": 0, # "private_tgtlang_2": 0,
"follow_default_ankisettings": True, "follow_default_ankisettings": True,
# "anki_DeckName":str
# "localeswitcher": 0,废弃 # "localeswitcher": 0,废弃
"onloadautochangemode2": 0, "onloadautochangemode2": 0,
"needinserthookcode": [], "needinserthookcode": [],
@ -468,6 +467,22 @@ for key in globalconfig["toolbutton"]["rank2"]:
for key in ___: for key in ___:
globalconfig["toolbutton"]["rank2"].remove(key) 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"]: for group in ["webview", "textbrowser"]:

View File

@ -472,7 +472,10 @@
"jiamingcolor": "black", "jiamingcolor": "black",
"ankiconnect": { "ankiconnect": {
"port": 8765, "port": 8765,
"DeckName": "lunadeck", "DeckName_i": 0,
"DeckNameS": [
"lunadeck"
],
"ModelName5": "lunamodel5", "ModelName5": "lunamodel5",
"allowDuplicate": true, "allowDuplicate": true,
"autoUpdateModel": true, "autoUpdateModel": true,

View File

@ -29,7 +29,7 @@ include(generate_product_version)
set(VERSION_MAJOR 5) set(VERSION_MAJOR 5)
set(VERSION_MINOR 25) set(VERSION_MINOR 25)
set(VERSION_PATCH 0) set(VERSION_PATCH 1)
add_library(pch pch.cpp) add_library(pch pch.cpp)
target_precompile_headers(pch PUBLIC pch.h) target_precompile_headers(pch PUBLIC pch.h)