mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2025-01-01 10:04:12 +08:00
issues/558
This commit is contained in:
parent
951268095f
commit
a9a9160d3b
@ -43,7 +43,6 @@ class MAINUI() :
|
|||||||
self.lasttranslatorindex=0
|
self.lasttranslatorindex=0
|
||||||
self.translators={}
|
self.translators={}
|
||||||
self.cishus={}
|
self.cishus={}
|
||||||
self.iterresstatus={}
|
|
||||||
self.reader=None
|
self.reader=None
|
||||||
self.textsource_p=None
|
self.textsource_p=None
|
||||||
self.currentmd5='0'
|
self.currentmd5='0'
|
||||||
@ -153,7 +152,7 @@ class MAINUI() :
|
|||||||
self.currentsignature=time.time()
|
self.currentsignature=time.time()
|
||||||
if type(text)==str:
|
if type(text)==str:
|
||||||
if text.startswith('<notrans>'):
|
if text.startswith('<notrans>'):
|
||||||
self.translation_ui.displayres.emit('',globalconfig['rawtextcolor'],text[len('<notrans>'):],onlytrans,[])
|
self.translation_ui.displayres.emit(dict(color=globalconfig['rawtextcolor'],res=text[len('<notrans>'):],onlytrans=onlytrans))
|
||||||
self.currenttext=text
|
self.currenttext=text
|
||||||
self.currentread=text
|
self.currentread=text
|
||||||
return
|
return
|
||||||
@ -250,7 +249,7 @@ class MAINUI() :
|
|||||||
_colork=k
|
_colork=k
|
||||||
else:
|
else:
|
||||||
_colork='premt'
|
_colork='premt'
|
||||||
self.GetTranslationCallback(onlytrans,_colork,self.currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,text,res[k],embedcallback,False)
|
self.GetTranslationCallback(onlytrans,_colork,self.currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,text,res[k],embedcallback,0)
|
||||||
|
|
||||||
except:
|
except:
|
||||||
print_exc()
|
print_exc()
|
||||||
@ -265,7 +264,6 @@ class MAINUI() :
|
|||||||
keys=list(self.translators.keys())+list(self.translators.keys())
|
keys=list(self.translators.keys())+list(self.translators.keys())
|
||||||
keys=keys[self.lasttranslatorindex:self.lasttranslatorindex+_len]
|
keys=keys[self.lasttranslatorindex:self.lasttranslatorindex+_len]
|
||||||
#print(keys,usenum,self.lasttranslatorindex)
|
#print(keys,usenum,self.lasttranslatorindex)
|
||||||
self.iterresstatus.clear()
|
|
||||||
for engine in keys:
|
for engine in keys:
|
||||||
if engine not in self.premtalready:
|
if engine not in self.premtalready:
|
||||||
self.translators[engine].gettask((partial(self.GetTranslationCallback,onlytrans,engine,self.currentsignature, optimization_params,_showrawfunction,_showrawfunction_sig,text),text,text_solved,skip,embedcallback,is_auto_run,hira))
|
self.translators[engine].gettask((partial(self.GetTranslationCallback,onlytrans,engine,self.currentsignature, optimization_params,_showrawfunction,_showrawfunction_sig,text),text,text_solved,skip,embedcallback,is_auto_run,hira))
|
||||||
@ -275,13 +273,13 @@ class MAINUI() :
|
|||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
def GetTranslationCallback(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,embedcallback,is_iter_res):
|
def GetTranslationCallback(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,embedcallback,iter_res_status):
|
||||||
|
|
||||||
if classname in self.usefultranslators:
|
if classname in self.usefultranslators:
|
||||||
self.usefultranslators.remove(classname)
|
self.usefultranslators.remove(classname)
|
||||||
if embedcallback is None and currentsignature!=self.currentsignature:return
|
if embedcallback is None and currentsignature!=self.currentsignature:return
|
||||||
|
|
||||||
embedtrans=self.GetTranslationCallback_(onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,is_iter_res)
|
embedtrans=self.GetTranslationCallback_(onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,iter_res_status)
|
||||||
|
|
||||||
|
|
||||||
if embedtrans is None and len(self.usefultranslators)==0:
|
if embedtrans is None and len(self.usefultranslators)==0:
|
||||||
@ -289,7 +287,7 @@ class MAINUI() :
|
|||||||
if embedcallback and embedtrans is not None:
|
if embedcallback and embedtrans is not None:
|
||||||
embedcallback(embedtrans)
|
embedcallback(embedtrans)
|
||||||
|
|
||||||
def GetTranslationCallback_(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,is_iter_res):
|
def GetTranslationCallback_(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,iter_res_status):
|
||||||
|
|
||||||
|
|
||||||
if type(res)==str:
|
if type(res)==str:
|
||||||
@ -311,19 +309,17 @@ class MAINUI() :
|
|||||||
_showrawfunction()
|
_showrawfunction()
|
||||||
|
|
||||||
if currentsignature==self.currentsignature and globalconfig['showfanyi']:
|
if currentsignature==self.currentsignature and globalconfig['showfanyi']:
|
||||||
if is_iter_res:
|
displayreskwargs=dict(name=globalconfig['fanyi'][classname]['name'],color=globalconfig['fanyi'][classname]['color'],res=res,onlytrans=onlytrans)
|
||||||
if classname not in self.iterresstatus:
|
if iter_res_status:
|
||||||
self.iterresstatus[classname]=1
|
displayreskwargs.update(iter_context=(iter_res_status,classname))
|
||||||
self.translation_ui.displayres.emit(globalconfig['fanyi'][classname]['name'],globalconfig['fanyi'][classname]['color'],res,onlytrans,[True,classname])
|
self.translation_ui.displayres.emit(displayreskwargs)
|
||||||
else:
|
|
||||||
self.translation_ui.displayres.emit(globalconfig['fanyi'][classname]['name'],globalconfig['fanyi'][classname]['color'],res,onlytrans,[False,classname])
|
|
||||||
else:
|
|
||||||
self.translation_ui.displayres.emit(globalconfig['fanyi'][classname]['name'],globalconfig['fanyi'][classname]['color'],res,onlytrans,[])
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
if iter_res_status in (0,2):#0为普通,1为iter,2为iter终止,3为起始
|
||||||
self.textsource.sqlqueueput((contentraw,classname,res))
|
self.textsource.sqlqueueput((contentraw,classname,res))
|
||||||
except:pass
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
if globalconfig['embedded']['as_fast_as_posible'] or classname==list(globalconfig['fanyi'])[globalconfig['embedded']['translator']]:
|
if globalconfig['embedded']['as_fast_as_posible'] or classname==list(globalconfig['fanyi'])[globalconfig['embedded']['translator']]:
|
||||||
|
|
||||||
|
@ -121,6 +121,7 @@ class Textbrowser( ):
|
|||||||
self.setselectable()
|
self.setselectable()
|
||||||
self.blockcount=0
|
self.blockcount=0
|
||||||
self.needdouble=False
|
self.needdouble=False
|
||||||
|
self.iteryinyinglabelsave={}
|
||||||
def setselectable(self):
|
def setselectable(self):
|
||||||
self.masklabel.setHidden(globalconfig['selectable'])
|
self.masklabel.setHidden(globalconfig['selectable'])
|
||||||
self.toplabel2.setHidden(globalconfig['selectable'] and globalconfig['zitiyangshi']!=3)
|
self.toplabel2.setHidden(globalconfig['selectable'] and globalconfig['zitiyangshi']!=3)
|
||||||
@ -187,7 +188,7 @@ class Textbrowser( ):
|
|||||||
else:
|
else:
|
||||||
self.align=False
|
self.align=False
|
||||||
|
|
||||||
def append(self,x ,tag,origin ):
|
def append(self,x,tag,origin):
|
||||||
|
|
||||||
if self.cleared:
|
if self.cleared:
|
||||||
_space=''
|
_space=''
|
||||||
@ -243,6 +244,44 @@ class Textbrowser( ):
|
|||||||
self.textcursor.setPosition(p1,QTextCursor.MoveAnchor)
|
self.textcursor.setPosition(p1,QTextCursor.MoveAnchor)
|
||||||
self.textcursor.setPosition(p2,QTextCursor.KeepAnchor)
|
self.textcursor.setPosition(p2,QTextCursor.KeepAnchor)
|
||||||
self.textcursor.removeSelectedText()
|
self.textcursor.removeSelectedText()
|
||||||
|
def showyinyingtext2(self,color,iter_context_class,pos,text):
|
||||||
|
if iter_context_class not in self.iteryinyinglabelsave:
|
||||||
|
self.iteryinyinglabelsave[iter_context_class]=[]
|
||||||
|
for label in self.iteryinyinglabelsave[iter_context_class]:
|
||||||
|
label.hide()
|
||||||
|
|
||||||
|
|
||||||
|
subtext=[]
|
||||||
|
subpos=[]
|
||||||
|
lastpos=None
|
||||||
|
posx=pos
|
||||||
|
for i in range(len(text)):
|
||||||
|
if text[i] =='\n':continue
|
||||||
|
self.textcursor.setPosition(posx)
|
||||||
|
posx+=1
|
||||||
|
tl1=self.textbrowser.cursorRect(self.textcursor).topLeft()
|
||||||
|
if lastpos is None or tl1.y()!=lastpos.y():
|
||||||
|
lastpos=tl1
|
||||||
|
subpos.append(lastpos)
|
||||||
|
subtext.append('')
|
||||||
|
subtext[-1]+=text[i]
|
||||||
|
|
||||||
|
|
||||||
|
if (len(subtext))>len(self.iteryinyinglabelsave[iter_context_class]):
|
||||||
|
_newlabels=[QLabel(self.toplabel2) for i in range(len(subtext)-len(self.iteryinyinglabelsave[iter_context_class]))]
|
||||||
|
self.iteryinyinglabelsave[iter_context_class]+=_newlabels
|
||||||
|
for lb in _newlabels:
|
||||||
|
lb.setTextFormat(Qt.PlainText)
|
||||||
|
for i in range(len(subtext)):
|
||||||
|
_=self.iteryinyinglabelsave[iter_context_class][i]
|
||||||
|
_.move(subpos[i])
|
||||||
|
_.setText(subtext[i])
|
||||||
|
_.setFont(self.textbrowser.currentCharFormat().font())
|
||||||
|
|
||||||
|
_.setStyleSheet("color:{}; background-color:rgba(0,0,0,0)".format(globalconfig['miaobiancolor']))
|
||||||
|
_.setGraphicsEffect(self.geteffect(globalconfig['fontsize'],color,globalconfig['shadowforce']))
|
||||||
|
_.show()
|
||||||
|
|
||||||
def showyinyingtext(self,color ):
|
def showyinyingtext(self,color ):
|
||||||
|
|
||||||
linei=self.yinyingposline
|
linei=self.yinyingposline
|
||||||
@ -610,6 +649,9 @@ class Textbrowser( ):
|
|||||||
label.hide()
|
label.hide()
|
||||||
for label in self.yinyinglabels:
|
for label in self.yinyinglabels:
|
||||||
label.hide()
|
label.hide()
|
||||||
|
for klass,labels in self.iteryinyinglabelsave.items():
|
||||||
|
for label in labels:
|
||||||
|
label.hide()
|
||||||
# self.textbrowser.clear()
|
# self.textbrowser.clear()
|
||||||
# self.textbrowserback.clear()
|
# self.textbrowserback.clear()
|
||||||
self.yinyingpos=0
|
self.yinyingpos=0
|
||||||
|
@ -28,8 +28,8 @@ from gui.rangeselect import moveresizegame ,rangeselct_function
|
|||||||
from gui.usefulwidget import resizableframeless
|
from gui.usefulwidget import resizableframeless
|
||||||
from gui.dialog_savedgame import browserdialog
|
from gui.dialog_savedgame import browserdialog
|
||||||
class QUnFrameWindow(resizableframeless):
|
class QUnFrameWindow(resizableframeless):
|
||||||
displayres = pyqtSignal(str,str,str ,bool,list)
|
displayres=pyqtSignal(dict)
|
||||||
displayraw1 = pyqtSignal(list, str,str,bool)
|
displayraw1=pyqtSignal(list, str,str,bool)
|
||||||
displaystatus=pyqtSignal(str,str,bool,bool)
|
displaystatus=pyqtSignal(str,str,bool,bool)
|
||||||
showhideuisignal=pyqtSignal()
|
showhideuisignal=pyqtSignal()
|
||||||
hookfollowsignal=pyqtSignal(int,tuple)
|
hookfollowsignal=pyqtSignal(int,tuple)
|
||||||
@ -71,18 +71,22 @@ class QUnFrameWindow(resizableframeless):
|
|||||||
pass
|
pass
|
||||||
self.move(self.pos().x()+ other[0],self.pos().y()+ other[1])
|
self.move(self.pos().x()+ other[0],self.pos().y()+ other[1])
|
||||||
|
|
||||||
def showres(self,name,color,res,onlyshowhist,iter_res_info):
|
def showres(self,kwargs):#name,color,res,onlyshowhist,iter_context):
|
||||||
try:
|
try:
|
||||||
if len(iter_res_info):
|
name=kwargs.get('name','')
|
||||||
starting,klass=iter_res_info
|
color=kwargs.get('color')
|
||||||
if not starting and klass in self.saveiterclasspointer:
|
res=kwargs.get('res')
|
||||||
if res=='\0':#清除前面的输出
|
onlyshowhist=kwargs.get('onlyshowhist')
|
||||||
self.translate_text.deletebetween(self.saveiterclasspointer[klass]['start'],self.translate_text.getcurrpointer())
|
iter_context=kwargs.get('iter_context',None)
|
||||||
else:
|
|
||||||
self.translate_text.insertatpointer(self.saveiterclasspointer[klass]['curr'],res)
|
if iter_context:
|
||||||
self.saveiterclasspointer[klass]['curr']=self.translate_text.getcurrpointer()
|
iter_res_status,iter_context_class=iter_context
|
||||||
return
|
if iter_res_status==2: #iter结束
|
||||||
gobject.baseobject.transhis.getnewtranssignal.emit(name,res)
|
gobject.baseobject.transhis.getnewtranssignal.emit(name,res)
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
gobject.baseobject.transhis.getnewtranssignal.emit(name,res)
|
||||||
|
|
||||||
if onlyshowhist:
|
if onlyshowhist:
|
||||||
return
|
return
|
||||||
clear=name==''
|
clear=name==''
|
||||||
@ -95,10 +99,8 @@ class QUnFrameWindow(resizableframeless):
|
|||||||
_showtext=name+' '+_res
|
_showtext=name+' '+_res
|
||||||
else:
|
else:
|
||||||
_showtext=_res
|
_showtext=_res
|
||||||
self.showline(clear,[None,_showtext],color,1,False)
|
self.showline(clear=clear,text=_showtext,color=color,origin=False,iter_context=iter_context)
|
||||||
|
|
||||||
if len(iter_res_info) and starting:
|
|
||||||
self.saveiterclasspointer[klass]={'curr':self.translate_text.getcurrpointer()+len(_showtext),'start':self.translate_text.getcurrpointer()+len(_showtext)-len(res)}
|
|
||||||
except:
|
except:
|
||||||
print_exc()
|
print_exc()
|
||||||
def showraw(self,hira,res,color ,onlyshowhist):
|
def showraw(self,hira,res,color ,onlyshowhist):
|
||||||
@ -111,22 +113,30 @@ class QUnFrameWindow(resizableframeless):
|
|||||||
else:
|
else:
|
||||||
_res=res
|
_res=res
|
||||||
if globalconfig['isshowhira'] and globalconfig['isshowrawtext']:
|
if globalconfig['isshowhira'] and globalconfig['isshowrawtext']:
|
||||||
self.showline(clear,[hira,_res],color , 2 )
|
self.showline(clear=clear,text=_res,hira=hira,color=color)
|
||||||
elif globalconfig['isshowrawtext']:
|
elif globalconfig['isshowrawtext']:
|
||||||
self.showline(clear,[hira,_res],color,1)
|
self.showline(clear=clear,text=_res,color=color)
|
||||||
else:
|
else:
|
||||||
self.showline(clear,None,None,1)
|
self.showline(clear=clear)
|
||||||
|
|
||||||
gobject.baseobject.edittextui.getnewsentencesignal.emit(res)
|
gobject.baseobject.edittextui.getnewsentencesignal.emit(res)
|
||||||
def showstatus(self,res,color,clear,origin):
|
def showstatus(self,res,color,clear,origin):
|
||||||
self.showline(clear,[None,res],color,1,origin)
|
self.showline(clear=clear,text=res,color=color,origin=origin)
|
||||||
def showline (self,clear,res,color ,type_=1,origin=True):
|
def showline (self,**kwargs):# clear,res,color ,type_=1,origin=True):
|
||||||
|
clear=kwargs.get('clear',True)
|
||||||
|
origin=kwargs.get('origin',True)
|
||||||
|
text=kwargs.get('text',None)
|
||||||
|
color=kwargs.get('color',None)
|
||||||
|
hira=kwargs.get('hira',[])
|
||||||
|
iter_context=kwargs.get('iter_context',None)
|
||||||
|
|
||||||
if clear:
|
if clear:
|
||||||
self.translate_text.clear()
|
self.translate_text.clear()
|
||||||
self.translate_text.setnextfont(origin)
|
if text is None:
|
||||||
if res is None:
|
|
||||||
return
|
return
|
||||||
|
|
||||||
|
self.translate_text.setnextfont(origin)
|
||||||
|
|
||||||
if globalconfig['showatcenter']:
|
if globalconfig['showatcenter']:
|
||||||
self.translate_text.setAlignment(Qt.AlignCenter)
|
self.translate_text.setAlignment(Qt.AlignCenter)
|
||||||
else:
|
else:
|
||||||
@ -143,19 +153,32 @@ class QUnFrameWindow(resizableframeless):
|
|||||||
self.translate_text.simplecharformat(color)
|
self.translate_text.simplecharformat(color)
|
||||||
elif globalconfig['zitiyangshi'] ==3:
|
elif globalconfig['zitiyangshi'] ==3:
|
||||||
self.translate_text.simplecharformat(color)
|
self.translate_text.simplecharformat(color)
|
||||||
if type_==1:
|
|
||||||
self.translate_text.append (res[1],[],origin)
|
if iter_context:
|
||||||
|
iter_res_status,iter_context_class=iter_context
|
||||||
|
if iter_res_status==3:
|
||||||
|
self.translate_text.append(text,hira,origin)
|
||||||
|
self.saveiterclasspointer[iter_context_class]={'curr':self.translate_text.getcurrpointer()+len(text),'start':self.translate_text.getcurrpointer()}
|
||||||
else:
|
else:
|
||||||
self.translate_text.append (res[1],res[0],origin)
|
self.translate_text.deletebetween(self.saveiterclasspointer[iter_context_class]['start'],self.saveiterclasspointer[iter_context_class]['curr'])
|
||||||
|
self.translate_text.insertatpointer(self.saveiterclasspointer[iter_context_class]['start'],text)
|
||||||
|
self.saveiterclasspointer[iter_context_class]['curr']=self.translate_text.getcurrpointer()
|
||||||
|
|
||||||
if globalconfig['zitiyangshi'] ==3:
|
if globalconfig['zitiyangshi'] ==3:
|
||||||
self.translate_text.showyinyingtext(color )
|
self.translate_text.showyinyingtext2(color,iter_context_class,self.saveiterclasspointer[iter_context_class]['start'],text)
|
||||||
if (globalconfig['usesearchword'] or globalconfig['usecopyword'] or globalconfig['show_fenci'] ) and res[0]:
|
return
|
||||||
|
|
||||||
|
else:
|
||||||
|
self.translate_text.append(text,hira,origin)
|
||||||
|
if globalconfig['zitiyangshi'] ==3:
|
||||||
|
self.translate_text.showyinyingtext(color)
|
||||||
|
if (globalconfig['usesearchword'] or globalconfig['usecopyword'] or globalconfig['show_fenci'] ) and hira:
|
||||||
def callback(word):
|
def callback(word):
|
||||||
if globalconfig['usecopyword'] :
|
if globalconfig['usecopyword'] :
|
||||||
winsharedutils.clipboard_set(word)
|
winsharedutils.clipboard_set(word)
|
||||||
if globalconfig['usesearchword']:
|
if globalconfig['usesearchword']:
|
||||||
gobject.baseobject.searchwordW.getnewsentencesignal.emit(word)
|
gobject.baseobject.searchwordW.getnewsentencesignal.emit(word)
|
||||||
self.translate_text.addsearchwordmask(res[0],res[1],callback )
|
self.translate_text.addsearchwordmask(hira,text,callback)
|
||||||
|
|
||||||
|
|
||||||
if globalconfig['autodisappear']:
|
if globalconfig['autodisappear']:
|
||||||
@ -313,7 +336,7 @@ class QUnFrameWindow(resizableframeless):
|
|||||||
windows.SetForegroundWindow(int(self.winId()))
|
windows.SetForegroundWindow(int(self.winId()))
|
||||||
def showEvent(self, a0 ) -> None:
|
def showEvent(self, a0 ) -> None:
|
||||||
if self.isfirstshow:
|
if self.isfirstshow:
|
||||||
self.showline(True,[None,_TR('欢迎使用')],'',1,False)
|
self.showline(clear=True,text=_TR('欢迎使用'),origin=False)
|
||||||
|
|
||||||
|
|
||||||
showAction = QAction(_TR("&显示"), self, triggered = self.show_and_enableautohide)
|
showAction = QAction(_TR("&显示"), self, triggered = self.show_and_enableautohide)
|
||||||
|
@ -262,18 +262,25 @@ class basetrans(commonbase):
|
|||||||
def __callback(_,is_iter_res):
|
def __callback(_,is_iter_res):
|
||||||
if self.needzhconv:
|
if self.needzhconv:
|
||||||
_=zhconv.convert(_, 'zh-tw' )
|
_=zhconv.convert(_, 'zh-tw' )
|
||||||
callback(_,embedcallback,is_iter_res)
|
if _=='\0':#清除前面的输出
|
||||||
|
collectiterres.clear()
|
||||||
|
pass
|
||||||
|
else:
|
||||||
collectiterres.append(_)
|
collectiterres.append(_)
|
||||||
|
callback(''.join(collectiterres),embedcallback,is_iter_res)
|
||||||
|
|
||||||
if isinstance(res,types.GeneratorType):
|
if isinstance(res,types.GeneratorType):
|
||||||
def _iterget():
|
def _iterget():
|
||||||
rid=self.requestid
|
rid=self.requestid
|
||||||
|
__callback('',3)
|
||||||
for _res in res:
|
for _res in res:
|
||||||
if self.requestid!=rid:break
|
if self.requestid!=rid:break
|
||||||
__callback(_res,True)
|
__callback(_res,1)
|
||||||
|
__callback('',2)
|
||||||
timeoutfunction(_iterget,checktutukufunction=checktutukufunction )
|
timeoutfunction(_iterget,checktutukufunction=checktutukufunction )
|
||||||
|
|
||||||
else:
|
else:
|
||||||
__callback(res,False)
|
__callback(res,0)
|
||||||
self.cachesetatend(contentsolved,''.join(collectiterres))
|
self.cachesetatend(contentsolved,''.join(collectiterres))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
if self.using and globalconfig['showtranexception']:
|
if self.using and globalconfig['showtranexception']:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user