diff --git a/cpp/version.cmake b/cpp/version.cmake index ae07e6cd..aace0731 100644 --- a/cpp/version.cmake +++ b/cpp/version.cmake @@ -1,7 +1,7 @@ set(VERSION_MAJOR 6) set(VERSION_MINOR 14) -set(VERSION_PATCH 10) +set(VERSION_PATCH 11) set(VERSION_REVISION 0) set(LUNA_VERSION "{${VERSION_MAJOR},${VERSION_MINOR},${VERSION_PATCH},${VERSION_REVISION}}") add_library(VERSION_DEF ${CMAKE_CURRENT_LIST_DIR}/version_def.cpp) diff --git a/py/LunaTranslator/cishu/mdict.py b/py/LunaTranslator/cishu/mdict.py index 18d612c9..4f573eae 100644 --- a/py/LunaTranslator/cishu/mdict.py +++ b/py/LunaTranslator/cishu/mdict.py @@ -2,6 +2,7 @@ import math, base64, uuid, gobject from cishu.cishubase import DictTree from myutils.config import isascii from traceback import print_exc +from myutils.audioplayer import bass_decode class FlexBuffer: @@ -2235,21 +2236,6 @@ class mdict(cishubase): # print(html) return html - def parseaudio(self, html_content, url, file_content): - base64_content = base64.b64encode(file_content).decode("utf-8") - - uid = str(uuid.uuid4()) - # with open(uid+'.mp3','wb') as ff: - # ff.write(file_content) - audio = ''.format( - uid, base64_content - ) - html_content = audio + html_content.replace( - url, - "javascript:document.getElementById('{}').play()".format(uid), - ) - return html_content - def parse_url_in_mdd(self, index: IndexBuilder, url1: str): url1 = url1.replace("/", "\\") if not url1.startswith("\\"): @@ -2282,12 +2268,17 @@ class mdict(cishubase): return ext = os.path.splitext(url)[1].lower() if ext in (".aac", ".spx"): - varname = "var_" + hashlib.md5(file_content).hexdigest() - audiob64vals[varname] = base64.b64encode(file_content).decode() - return 3, "javascript:safe_mdict_sound_call('{}',{})".format( - ext, varname - ) - return 2, file_content + mp3 = bass_decode(file_content, ext) + if not mp3: + print(ext, "decode error") + return + file_content = mp3 + ext = ".mp3" + varname = "var_" + hashlib.md5(file_content).hexdigest() + audiob64vals[varname] = base64.b64encode(file_content).decode() + return 3, "javascript:mdict_play_sound('{}',{})".format( + ext[1:], varname + ) file_content = self.parse_url_in_mdd(index, url) if not file_content: return @@ -2433,8 +2424,6 @@ class mdict(cishubase): if css: csscollect[url] = css html_content = html_content.replace(url, "") - elif _type == 2: - html_content = self.parseaudio(html_content, url, file_content) elif _type == 0: varname = "var_" + hashlib.md5(file_content).hexdigest() hrefsrcvals[varname] = base64.b64encode(file_content).decode() @@ -2470,7 +2459,7 @@ class mdict(cishubase): print_exc() if not results: return - divid = "luna_internal_" + str(uuid.uuid4()) + divid = "luna_" + str(uuid.uuid4()) csscollect = {} for i in range(len(results)): results[i] = self.repairtarget( @@ -2648,11 +2637,16 @@ let elements = document.querySelectorAll('[src="'+varname+'"]'); for(let i=0;i None: self.handle = None @@ -100,6 +143,51 @@ BASS_Init(-1, 44100, 0, 0, 0) # https://www.un4seen.com/ plugins = {".spx": "bass_spx.dll"} +pluginshandle = {} + + +def load_ext(ext=None): + if ext and plugins.get(ext) and not pluginshandle.get(ext): + pluginshandle[ext] = BASS_PluginLoad( + gobject.GetDllpath(plugins.get(ext)).encode("utf8"), 0 + ) + + +def bass_decode(bs, ext=None): + load_ext(ext) + stream = BASS_StreamCreateFile(True, bs, 0, len(bs), BASS_STREAM_DECODE) + if not stream: + return + info = BASS_CHANNELINFO() + if not BASS_ChannelGetInfo(stream, pointer(info)): + return + wf = WAVEFORMATEX() + wf.wFormatTag = 1 + wf.nChannels = info.chans + wf.wBitsPerSample = 8 if info.flags & BASS_SAMPLE_8BITS else 16 + wf.nBlockAlign = wf.nChannels * wf.wBitsPerSample // 8 + wf.nSamplesPerSec = info.freq + wf.nAvgBytesPerSec = wf.nSamplesPerSec * wf.nBlockAlign + res = [] + size = 0 + buff = create_string_buffer(0x10000) + while BASS_ChannelIsActive(stream): + get = BASS_ChannelGetData(stream, buff, 0x10000) + res.append(buff[:get]) + size += get + header = [] + header.append(b"RIFF") + header.append(bytes(c_int(size + 44))) + header.append(b"WAVE") + header.append(b"fmt ") + header.append(bytes(c_int(sizeof(WAVEFORMATEX)))) + header.append(bytes(wf)) + header.append(b"data") + header.append(bytes(c_int(size))) + header.extend(res) + data = b"".join(header) + return winsharedutils.encodemp3(data) + class series_audioplayer: def __init__(self, playovercallback=None): @@ -111,7 +199,6 @@ class series_audioplayer: self.lock.acquire() self.timestamp = None self.lastcontext = None - self.plugins = {} threading.Thread(target=self.__dotasks).start() def stop(self): @@ -126,10 +213,7 @@ class series_audioplayer: if timestamp and (timestamp != self.timestamp): return self.timestamp = timestamp - if ext and plugins.get(ext) and not self.plugins.get(ext): - self.plugins[ext] = BASS_PluginLoad( - gobject.GetDllpath(plugins.get(ext)).encode("utf8"), 0 - ) + load_ext(ext) try: self.tasks = (binary, volume, force) self.lock.release()