mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2024-12-29 16:44:13 +08:00
qweb
This commit is contained in:
parent
cb64beb810
commit
89de08bea9
@ -29,9 +29,7 @@ if __name__ == "__main__":
|
||||
) # 中文字符下不能自动加载
|
||||
QApplication.setAttribute(Qt.ApplicationAttribute.AA_EnableHighDpiScaling)
|
||||
QApplication.setAttribute(Qt.ApplicationAttribute.AA_UseHighDpiPixmaps)
|
||||
if os.path.exists(
|
||||
"./LunaTranslator/runtime/PyQt5/Qt5/bin/Qt5WebEngineCore.dll"
|
||||
):
|
||||
if gobject.testuseqwebengine():
|
||||
QApplication.setAttribute(
|
||||
Qt.ApplicationAttribute.AA_ShareOpenGLContexts
|
||||
) # maybe use qwebengine
|
||||
|
@ -29,3 +29,9 @@ def dopathexists(file):
|
||||
def overridepathexists():
|
||||
# win7上,如果假如没有D盘,然后os.path.exists("D:/..."),就会弹窗说不存在D盘
|
||||
os.path.exists = dopathexists
|
||||
|
||||
|
||||
def testuseqwebengine():
|
||||
return os.path.exists(
|
||||
"./LunaTranslator/runtime/PyQt5/Qt5/bin/Qt5WebEngineCore.dll"
|
||||
) or (len(sys.argv) and sys.argv[-1] == "test")
|
||||
|
@ -1,6 +1,6 @@
|
||||
from qtsymbols import *
|
||||
import platform, functools, sys, os
|
||||
import winsharedutils
|
||||
import winsharedutils, gobject
|
||||
from myutils.config import globalconfig, _TR, static_data, _TRL
|
||||
from myutils.wrapper import threader
|
||||
from myutils.utils import makehtml, getimageformatlist
|
||||
@ -141,7 +141,7 @@ def createimageview(self):
|
||||
|
||||
def setTab_aboutlazy(self, basel):
|
||||
webviews = ["IEFrame", "WebView2"]
|
||||
if os.path.exists("./LunaTranslator/runtime/PyQt5/Qt5/bin/Qt5WebEngineCore.dll"):
|
||||
if gobject.testuseqwebengine():
|
||||
webviews.append("QWebEngine")
|
||||
grid2 = [
|
||||
[
|
||||
|
@ -176,7 +176,8 @@ def createinternalfontsettings(self, group, _type):
|
||||
|
||||
|
||||
def resetgroudswitchcallback(self, group):
|
||||
|
||||
if group == "QWebEngine":
|
||||
group = "webview"
|
||||
try:
|
||||
self.goodfontgroupswitch.currentIndexChanged.disconnect()
|
||||
except:
|
||||
@ -220,7 +221,11 @@ def creategoodfontwid(self):
|
||||
|
||||
|
||||
def xianshigrid(self):
|
||||
|
||||
visengine = ["Webview2", "Qt"]
|
||||
visengine_internal = ["webview", "textbrowser"]
|
||||
if gobject.testuseqwebengine():
|
||||
visengine.append("QWebEngine")
|
||||
visengine_internal.append("QWebEngine")
|
||||
textgrid = [
|
||||
[
|
||||
(
|
||||
@ -280,10 +285,10 @@ def xianshigrid(self):
|
||||
("显示引擎_重启生效", 3),
|
||||
(
|
||||
D_getsimplecombobox(
|
||||
["Webview2", "Qt"],
|
||||
visengine,
|
||||
globalconfig,
|
||||
"rendertext_using",
|
||||
internallist=["webview", "textbrowser"],
|
||||
internallist=visengine_internal,
|
||||
callback=functools.partial(
|
||||
resetgroudswitchcallback, self
|
||||
),
|
||||
|
@ -729,7 +729,8 @@ class searchwordW(closeashidewindow):
|
||||
if self.current != timestamp:
|
||||
return
|
||||
if res is None:
|
||||
self.cache_results[k] = res
|
||||
return
|
||||
self.cache_results[k] = res
|
||||
|
||||
thisp = globalconfig["cishu"][k]["args"]["priority"]
|
||||
idx = 0
|
||||
|
@ -32,9 +32,10 @@ class Textbrowser(QLabel):
|
||||
self.contentsChanged.emit(QSize(size.width(), size.height()))
|
||||
|
||||
def loadinternal(self):
|
||||
tb = importlib.import_module(
|
||||
f'rendertext.{globalconfig["rendertext_using"]}'
|
||||
).TextBrowser
|
||||
__ = globalconfig["rendertext_using"]
|
||||
if __ == "QWebEngine":
|
||||
__ = "webview"
|
||||
tb = importlib.import_module(f"rendertext.{__}").TextBrowser
|
||||
try:
|
||||
self.textbrowser = tb(self)
|
||||
except webview_exception:
|
||||
|
@ -907,6 +907,15 @@ class abstractwebview(QWidget):
|
||||
def set_zoom(self, zoom):
|
||||
pass
|
||||
|
||||
def get_zoom(self):
|
||||
return 1
|
||||
|
||||
def bind(self, fname, func):
|
||||
pass
|
||||
|
||||
def eval(self, js, retsaver=None):
|
||||
pass
|
||||
|
||||
def set_transparent_background(self):
|
||||
pass
|
||||
|
||||
@ -970,6 +979,12 @@ class WebivewWidget(abstractwebview):
|
||||
self.__token,
|
||||
)
|
||||
|
||||
def bind(self, fname, func):
|
||||
self.webview.bind(fname, func)
|
||||
|
||||
def eval(self, js):
|
||||
self.webview.eval(js)
|
||||
|
||||
def get_controller(self):
|
||||
return self.webview.get_native_handle(
|
||||
webview_native_handle_kind_t.WEBVIEW_NATIVE_HANDLE_KIND_BROWSER_CONTROLLER
|
||||
@ -1013,14 +1028,11 @@ class WebivewWidget(abstractwebview):
|
||||
winsharedutils.put_PreferredColorScheme(self.get_controller(), dl)
|
||||
|
||||
def set_zoom(self, zoom):
|
||||
self.put_ZoomFactor(zoom)
|
||||
|
||||
def get_ZoomFactor(self):
|
||||
return winsharedutils.get_ZoomFactor(self.get_controller())
|
||||
|
||||
def put_ZoomFactor(self, zoom):
|
||||
winsharedutils.put_ZoomFactor(self.get_controller(), zoom)
|
||||
|
||||
def get_zoom(self):
|
||||
return winsharedutils.get_ZoomFactor(self.get_controller())
|
||||
|
||||
def _on_load(self, href):
|
||||
self.on_load.emit(href)
|
||||
|
||||
@ -1044,14 +1056,15 @@ class WebivewWidget(abstractwebview):
|
||||
|
||||
class QWebWrap(abstractwebview):
|
||||
|
||||
def __init__(self) -> None:
|
||||
super().__init__()
|
||||
def __init__(self, p=None) -> None:
|
||||
super().__init__(p)
|
||||
from PyQt5.QtWebEngineWidgets import QWebEngineView
|
||||
|
||||
self.internal = QWebEngineView(self)
|
||||
self.internal.page().urlChanged.connect(
|
||||
lambda qurl: self.on_load.emit(qurl.url())
|
||||
)
|
||||
# self.internal.page().urlChanged.connect(
|
||||
# lambda qurl: self.on_load.emit(qurl.url())
|
||||
# )
|
||||
self.internal.loadFinished.connect(self._loadFinish)
|
||||
self.internal_zoom = 1
|
||||
t = QTimer(self)
|
||||
t.setInterval(100)
|
||||
@ -1059,10 +1072,24 @@ class QWebWrap(abstractwebview):
|
||||
t.timeout.emit()
|
||||
t.start()
|
||||
|
||||
def _loadFinish(self):
|
||||
self.on_load.emit(self.internal.url().url())
|
||||
|
||||
def eval(self, js, retsaver=None):
|
||||
if not retsaver:
|
||||
retsaver = lambda _: 1
|
||||
self.internal.page().runJavaScript(js, retsaver)
|
||||
|
||||
def set_transparent_background(self):
|
||||
self.internal.page().setBackgroundColor(Qt.GlobalColor.transparent)
|
||||
|
||||
def set_zoom(self, zoom):
|
||||
self.internal_zoom = zoom
|
||||
self.internal.setZoomFactor(zoom)
|
||||
|
||||
def get_zoom(self):
|
||||
return self.internal.zoomFactor()
|
||||
|
||||
def __getzoomfactor(self):
|
||||
z = self.internal.zoomFactor()
|
||||
if z != self.internal_zoom:
|
||||
|
@ -4,7 +4,7 @@ from rendertext.somefunctions import dataget
|
||||
import gobject, uuid, json, os
|
||||
from urllib.parse import quote
|
||||
from myutils.config import globalconfig
|
||||
from gui.usefulwidget import WebivewWidget
|
||||
from gui.usefulwidget import WebivewWidget, QWebWrap
|
||||
|
||||
testsavejs = False
|
||||
|
||||
@ -18,21 +18,28 @@ class TextBrowser(QWidget, dataget):
|
||||
def __init__(self, parent) -> None:
|
||||
gobject.refwebview = self
|
||||
super().__init__(parent)
|
||||
self.webivewwidget = WebivewWidget(self)
|
||||
if globalconfig["rendertext_using"] == "QWebEngine":
|
||||
self.webivewwidget = QWebWrap(self)
|
||||
else:
|
||||
self.webivewwidget = WebivewWidget(self)
|
||||
|
||||
if isinstance(self.webivewwidget, QWebWrap):
|
||||
# webview2当会执行alert之类的弹窗js时,若qt窗口不可视,会卡住
|
||||
self.webivewwidget.on_load.connect(self.__loadextra)
|
||||
self.webivewwidget.navigate(
|
||||
os.path.abspath(r"LunaTranslator\rendertext\webview.html")
|
||||
)
|
||||
self.webivewwidget.set_transparent_background()
|
||||
self.webivewwidget.webview.bind("calllunaclickedword", self.calllunaclickedword)
|
||||
self.webivewwidget.webview.bind(
|
||||
"calllunaheightchange", self.calllunaheightchange
|
||||
)
|
||||
self.webivewwidget.bind("calllunaclickedword", self.calllunaclickedword)
|
||||
self.webivewwidget.bind("calllunaheightchange", self.calllunaheightchange)
|
||||
self.saveiterclasspointer = {}
|
||||
self.isfirst = True
|
||||
|
||||
def showEvent(self, e):
|
||||
if not self.isfirst:
|
||||
return
|
||||
if not isinstance(self.webivewwidget, WebivewWidget):
|
||||
return
|
||||
self.isfirst = False
|
||||
self.__loadextra(0)
|
||||
self.webivewwidget.on_load.connect(self.__loadextra)
|
||||
@ -44,7 +51,7 @@ class TextBrowser(QWidget, dataget):
|
||||
|
||||
def debugeval(self, js):
|
||||
# print(js)
|
||||
self.webivewwidget.webview.eval(js)
|
||||
self.webivewwidget.eval(js)
|
||||
|
||||
# js api
|
||||
|
||||
@ -65,6 +72,18 @@ class TextBrowser(QWidget, dataget):
|
||||
self.debugeval(
|
||||
f'create_internal_text("{style}","{styleargs}","{_id}","{text}","{args}");'
|
||||
)
|
||||
self._qweb_proactive_queryheigh()
|
||||
|
||||
def _qweb_proactive_queryheigh(self):
|
||||
if not isinstance(self.webivewwidget, QWebWrap):
|
||||
return
|
||||
|
||||
def __xxx(h):
|
||||
self.calllunaheightchange(h)
|
||||
|
||||
self.webivewwidget.eval(
|
||||
'document.getElementById("luna_root_div").offsetHeight', __xxx
|
||||
)
|
||||
|
||||
def create_internal_rubytext(self, style, styleargs, _id, tag, args):
|
||||
tag = quote(json.dumps(tag))
|
||||
@ -74,12 +93,14 @@ class TextBrowser(QWidget, dataget):
|
||||
f'create_internal_rubytext("{style}","{styleargs}","{_id}","{tag}","{args}");'
|
||||
)
|
||||
|
||||
self._qweb_proactive_queryheigh()
|
||||
|
||||
# js api end
|
||||
# native api
|
||||
|
||||
def calllunaheightchange(self, h):
|
||||
self.contentsChanged.emit(
|
||||
QSize(self.width(), int(h * self.webivewwidget.get_ZoomFactor()))
|
||||
QSize(self.width(), int(h * self.webivewwidget.get_zoom()))
|
||||
)
|
||||
|
||||
def calllunaclickedword(self, packedwordinfo):
|
||||
|
3
LunaTranslator/run37_test.bat
Normal file
3
LunaTranslator/run37_test.bat
Normal file
@ -0,0 +1,3 @@
|
||||
@echo off
|
||||
%LOCALAPPDATA%\Programs\Python\Python37\python.exe -B LunaTranslator\LunaTranslator_main.py test
|
||||
pause
|
Loading…
x
Reference in New Issue
Block a user