xiaomianao666

小程序:微软语音

Aug 31st, 2022
91
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. 海阔视界规则分享,当前分享的是:小程序¥home_rule_v2¥base64://@微软语音@{"last_chapter_rule":"","title":"微软语音","author":"顺","url":"hiker://empty","version":20220816,"col_type":"movie_3","class_name":"","type":"music","class_url":"","area_name":"","area_url":"","sort_name":"","year_name":"","sort_url":"","year_url":"","find_rule":"js:\nvar d = [];\neval(JSON.parse(fetch(\"hiker://page/初用\")).rule);\neval(JSON.parse(fetch(\"hiker://page/文本框\")).rule);\neval(JSON.parse(fetch(\"hiker://page/载入数据\")).rule);\n\neval(JSON.parse(fetch(\"hiker://page/角色选框\")).rule);\neval(JSON.parse(fetch(\"hiker://page/语速\")).rule);\neval(JSON.parse(fetch(\"hiker://page/音调\")).rule);\neval(JSON.parse(fetch(\"hiker://page/风格选框\")).rule);\neval(JSON.parse(fetch(\"hiker://page/搭配试听\")).rule);\neval(JSON.parse(fetch(\"hiker://page/文转语音\")).rule);\neval(JSON.parse(fetch(\"hiker://page/管理文件\")).rule)\n\nd.push({\n    title: \"📚 生成引擎\",\n    url: $('生成支持【阅读ledago】的语音引擎\\n\\n' + '♦️当前：' + 角色名.split('（')[0] +'（'+风格名+'）'+ '\\n\\n请在阅读朗读设置中点添加，粘贴源').confirm(() => {\n        eval(JSON.parse(fetch(\"hiker://page/导入到阅读\")).rule)\n        return 'hiker://empty';\n    }),\n    col_type: \"text_2\",\n    extra: {\n        id: \"阅读\"\n    }\n});\nsetResult(d);","search_url":"","group":"⑤音频","searchFind":"","detail_col_type":"movie_1","detail_find_rule":"","sdetail_col_type":"movie_1","sdetail_find_rule":"","ua":"mobile","preRule":"","pages":"[{\"col_type\":\"movie_3\",\"name\":\"合成朗读\",\"path\":\"合成朗读\",\"rule\":\"function createSSML(text, voiceName, styleName, rate, pitch) {\\n    let ssml = `\\\\\\n        <speak xmlns=\\\"http://www.w3.org/2001/10/synthesis\\\" xmlns:mstts=\\\"http://www.w3.org/2001/mstts\\\" xmlns:emo=\\\"http://www.w3.org/2009/10/emotionml\\\" version=\\\"1.0\\\" xml:lang=\\\"zh-CN\\\">\\\\\\n          <voice name=\\\"${voiceName}\\\">\\\\\\n            <mstts:express-as style=\\\"${styleName}\\\" styledegree=\\\"1\\\">\\\\\\n              <prosody volume=\\\"+100.00%\\\" rate=\\\"${rate}\\\" pitch=\\\"${pitch}\\\">\\\\\\n                  ${text}\\\\\\n              </prosody >\\\\\\n            </mstts:express-as>\\\\\\n          </voice >\\\\\\n        </speak > `\\n    return ssml;\\n};\\nfunction preview() {\\n    /*\\n    let 文字 = '实话告诉你，小棉袄是真的帅';\\n    let 角色 = getItem(\\\"角色\\\", 'zh-CN-XiaoxiaoNeural');\\n    let 风格 = 'general';\\n    let 语速 = '0%'; //-100%到200%\\n    let 音调 = '0%'; //-50%到50%\\n    let 扮演 = ''; //只有部分角色有\\n    */\\n    let ssml = createSSML(文字, 角色, 风格, 语速, 音调)\\n    let 音频格式 = 'riff-8khz-8bit-mono-mulaw';//低音质\\n    //let 音频格式 = 'audio-48khz-192kbitrate-mono-mp3';//高音质\\n    let headers = {\\n        'Content-Type': 'text/plain',\\n        'Authorization': 'Bearer',\\n        'Format': 音频格式\\n    };\\n\\n    //备用：https://ms-ra-forwar.Vercel.app/api/azure\\n    //国外小水管，容易崩，自己搭最稳定：https://github.com/wxxxcxx/ms-ra-forwarder\\n    let res = request('http://test1.haikuoshijie.cn/api/azure', {\\n        method: 'post',\\n        headers: headers,\\n        body: ssml,\\n        toHex: true\\n    })\\n    return res\\n}\\nlet p = \\\"hiker://files/cache/微软语音合成.mp3\\\";\\nvar 文件 = preview()\\ndeleteFile(p)\\nwriteHexFile(p, 文件);\\nrefreshX5WebView(getPath(p + '?t=' + JSON.stringify(new Date().getTime())))\\n//return的值请放在eval外面\"},{\"col_type\":\"movie_3\",\"name\":\"角色选框\",\"path\":\"角色选框\",\"rule\":\"d.push({\\n    title: \\\"语音（\\\" + 角色名.split('（')[0] + \\\"）\\\",\\n    url: $(JSON.parse(request(ln + '缓存选名组.json')), 2, \\\"选择角色\\\").select(function(ln, 选名组, 真名组, voices) {\\n        let 选择 = []\\n        let input0 = input\\n        input = input.replace(/🔻/g, \\\"\\\")\\n        for (let i in 选名组) {\\n            var tss = new RegExp(input).test(选名组[i]);\\n            if (tss == true) {\\n                var 角色 = 真名组[i];\\n                选名组[i] = '🔻' + 选名组[i].replace(/🔻/g, \\\"\\\");\\n            } else {\\n                选名组[i] = 选名组[i].replace(/🔻/g, \\\"\\\");\\n            }\\n            选择.push(选名组[i])\\n            writeFile(ln + '缓存选名组.json', JSON.stringify(选择));\\n        }\\n\\n        setItem(\\\"角色\\\", 角色);\\n        setItem(\\\"角色名\\\", input);\\n        let 风格选择, 风格名;\\n        if (getItem('角色名') != input0) {\\n            风格选择 = getItem('风格', 'general')\\n            风格名 = getItem('风格名', '正常的')\\n        } else {\\n            风格选择 = 'general'\\n            风格名 = '正常的'\\n        }\\n        setItem('风格', 风格选择)\\n        setItem('风格名', 风格名)\\n        /* 说话风格*/\\n        deleteItem('风格')\\n        let 风格arr = ln + '微软语音风格.json';\\n        let voiceName = 角色 || 'zh-CN-XiaoxiaoNeural';\\n        //log(voices)\\n        let voice = voices[voiceName];\\n        let styleList = voice['StyleList']\\n        if (styleList) {\\n            writeFile(风格arr, '')\\n            styleList.forEach(style => {\\n                let 所有风格 = style;\\n                //log(所有风格)\\n                let 风格array = request(风格arr) || '[]'\\n                风格array = JSON.parse(风格array)\\n                风格array.push(所有风格)\\n                writeFile(风格arr, JSON.stringify(风格array));\\n            });\\n            let 风格array = JSON.parse(request(风格arr))\\n            风格array.unshift('general')\\n            writeFile(风格arr, JSON.stringify(风格array));\\n            \\n            eval(JSON.parse(fetch(\\\"hiker://page/翻译\\\")).rule)\\n            addItemAfter('分割线', {\\n                url: eval(JSON.parse(fetch(\\\"hiker://page/风格\\\")).rule),\\n                col_type: \\\"text_1\\\",\\n                title: '““”” <small><font color=grey>' + '&#8195说话风格：' + 风格名 + '</font> </small>',\\n                extra: {\\n                    id: '风格'\\n                }\\n            });\\n            setItem('锁定风格', '有')\\n            \\n        } else {\\n            setItem('锁定风格', '无')\\n        }\\n\\n        updateItem(\\\"角色\\\", {\\n            'title': \\\"语音（\\\" + input.split('（')[0] + \\\"）\\\",\\n            'url': $(选择, 2, \\\"选择角色\\\").select(arguments.callee, ln, 选名组, 真名组, voices)\\n        });\\n        updateItem(\\\"阅读\\\", {\\n            url: $('生成支持【阅读ledago】的语音引擎\\\\n\\\\n' + '♦️当前：' + input.split('（')[0] +'（'+风格名+'）'+ '\\\\n\\\\n请在阅读朗读设置中点添加，粘贴源').confirm(() => {\\n                eval(JSON.parse(fetch(\\\"hiker://page/导入到阅读\\\")).rule)\\n                return 'hiker://empty';\\n            }),\\n        });\\n\\n        let 文字 = '哈哈哈哈哈，实话告诉你，小棉袄是真的帅';\\n        let lj = 'hiker://files/cache/tts参数.json'\\n        let 参数 = request(lj) || '{}';\\n        参数 = JSON.parse(参数)\\n        参数['角色'] = 角色;\\n        writeFile(lj, JSON.stringify(参数))\\n\\n        let 语速 = '0%'; //-100%到200%\\n        let 音调 = '0%'; //-50%到50%\\n        let 风格 = 'general';\\n        var saveF = \\\"hiker://files/cache/微软tts角色预览/\\\" + input + '.mp3';\\n        let cache = request(saveF)\\n        if (cache) {\\n            refreshX5WebView(getPath(saveF))\\n        } else {\\n            eval(JSON.parse(fetch(\\\"hiker://page/合成朗读\\\")).rule)\\n            //合成朗读已传出'文件'变量\\n            writeHexFile(saveF, 文件);\\n        }\\n    }, ln, 选名组, 真名组, voices),\\n    col_type: \\\"text_3\\\",\\n    extra: {\\n        id: \\\"角色\\\"\\n    }\\n});\"},{\"col_type\":\"movie_3\",\"name\":\"导入到阅读\",\"path\":\"导入到阅读\",\"rule\":\"let 角色 = getItem(\\\"角色\\\",'zh-CN-XiaoxiaoNeural')\\nlet 角色名 = getItem(\\\"角色名\\\",'晓晓（zh-CN）').split('（')[0];\\nlet 风格 = getItem('风格', 'general')\\nlet 风格名 = getItem('风格名', '正常的')\\nlet 音调 = ((getItem(\\\"音调\\\", '1') - 1) * 100) / 2 + '%';\\nlet legado = {\\\"name\\\": \\\"微软：\\\"+角色名+\\\"（\\\"+风格名+\\\"）\\\",\\t\\\"contentType\\\": \\\"audio/x-wav\\\",\\t\\\"header\\\": \\\"{\\\\\\\"Content-Type\\\\\\\":\\\\\\\"text/plain\\\\\\\",\\\\\\\"Authorization\\\\\\\":\\\\\\\"Bearer \\\\\\\",\\\\\\\"Format\\\\\\\":\\\\\\\"riff-8khz-8bit-mono-mulaw\\\\\\\"}\\\",\\t\\\"url\\\": `https://ms-ra-forwar.Vercel.app/api/azure,{\\\\\\\"method\\\\\\\":\\\\\\\"POST\\\\\\\",\\\\\\\"body\\\\\\\":\\\\\\\"<speak xmlns=\\\\\\\\\\\\\\\"http://www.w3.org/2001/10/synthesis\\\\\\\\\\\\\\\" xmlns:mstts=\\\\\\\\\\\\\\\"http://www.w3.org/2001/mstts\\\\\\\\\\\\\\\" xmlns:emo=\\\\\\\\\\\\\\\"http://www.w3.org/2009/10/emotionml\\\\\\\\\\\\\\\" version=\\\\\\\\\\\\\\\"1.0\\\\\\\\\\\\\\\" xml:lang=\\\\\\\\\\\\\\\"zh-CN\\\\\\\\\\\\\\\"><voice name=\\\\\\\\\\\\\\\"${角色}\\\\\\\\\\\\\\\"><mstts:express-as style=\\\\\\\\\\\\\\\"${风格}\\\\\\\\\\\\\\\" styledegree=\\\\\\\\\\\\\\\"1.0\\\\\\\\\\\\\\\"><prosody volume=\\\\\\\\\\\\\\\"+100.00%\\\\\\\\\\\\\\\" rate=\\\\\\\\\\\\\\\"{{(speakSpeed - 10) * 2}}%\\\\\\\\\\\\\\\" pitch=\\\\\\\\\\\\\\\"${音调}\\\\\\\\\\\\\\\">{{String(speakText).replace(/&/g, '&amp;').replace(/\\\\\\\\\\\\\\\"/g, '&quot;').replace(/'/g, '&apos;').replace(/</g, '&lt;').replace(/>/g, '&gt;')}}</prosody> </mstts:express-as></voice></speak>\\\\\\\"}`}\\nlet ln = 'hiker://files/cache/';\\nwriteFile(ln +'生成阅读语音引擎.json', JSON.stringify(legado))\\ncopy(JSON.stringify(legado));\"},{\"col_type\":\"movie_3\",\"name\":\"保存音频文件\",\"path\":\"保存\",\"rule\":\"eval(JSON.parse(fetch(\\\"hiker://page/合成朗读\\\")).rule); \\nvar saveF = \\\"hiker://files/cache/微软tts/\\\";\\nvar 文件名 = getMyVar('文件名', '');\\nif (文件名 == ''){\\n   文件名 = '微软tts'+$.dateFormat(new Date,\\\"yyyyMMddHHmmss\\\")+'.mp3'\\n} else{\\n   文件名 = 文件名 +'.mp3'\\n}\\nvar saveD = saveF + 文件名\\n//合成朗读已传出'文件'变量\\nwriteHexFile(saveD, 文件);\"},{\"col_type\":\"movie_3\",\"name\":\"管理文件\",\"path\":\"管理文件\",\"rule\":\"<!--工具来自L佬，感谢L大神-->\\nlet Loy = require(\\\"http://hiker.nokia.press/hikerule/rulelist.json?id=5099\\\");\\nd.push({\\n    title: \\\"📂 管理文件\\\",\\n    url: Loy.fileSelectionUri({\\n        callback: $.toString(() => {\\n            setPageTitle('文件列表')\\n             if (TYPE=='.mp3') op='💽 播   放'\\n             if (TYPE=='.txt') op='📒 打   开'\\n            return $(['📝 重命名', '🗑️ 删   除', op, '🌀 分   享'], 2, \\\"选择操作\\\").select((PATH,TYPE, ID) => {\\n                if (input == '🌀 分   享') {\\n                    return 'share://file://' + PATH\\n                } else if (input == '🗑️ 删   除') {\\n                    return $('⛔ 确定删除吗?').confirm((PATH, ID) => {\\n                        let File = require(\\\"https://gitcode.net/qq_32394351/dr/-/raw/master/js/File.js\\\");\\n                        if(File.deleteFiles(PATH)){\\n                            deleteItem(ID);\\n                            return \\\"toast://已删除\\\";\\n                        }else{\\n                            return \\\"toast://删除失败\\\";\\n                        }\\n                    }, PATH, ID);\\n                } else if (input == '💽 播   放') {\\n                    return '#isMusic=true#' + 'file://' + PATH\\n                }else if (input == '📒 打   开') {\\n                    return 'editFile://' + 'file://' + PATH\\n                } else {\\n                    //重命名\\n                    return $(PATH.substring((PATH.lastIndexOf(\\\"/\\\") + 1), PATH.lastIndexOf(\\\".\\\")), \\\"重新命名\\\").input(function(PATH,TYPE,ID) {\\n                        let File = require(\\\"https://gitcode.net/qq_32394351/dr/-/raw/master/js/File.js\\\");\\n                        if(File.renameFile(PATH, input + TYPE)){\\n                            let v = findItem(ID);\\n                            v.title=input + TYPE;\\n                            v.extra.path = PATH.substring(0,(PATH.lastIndexOf(\\\"/\\\") + 1))+v.title;\\n                            updateItem(v);\\n                            return \\\"toast://已重命名\\\";\\n                        }else{\\n                            return \\\"toast://重命名失败\\\";\\n                        }\\n                    }, PATH, TYPE, ID);\\n                }\\n            }, PATH, TYPE, ID)\\n        }),\\n        //fileType: \\\".mp3\\\",//仅显示的文件格式\\n        exitSearchRefresh:true,//关搜索刷新列表\\n        initialPath: \\\"/storage/emulated/0/Android/data/com.example.hikerview/files/Documents/cache/微软tts/\\\",//初始目录\\n        rootDirPath: \\\"/storage/emulated/0/Android/data/com.example.hikerview/files/Documents/cache/微软tts/\\\",//根目录\\n        requireUrl: \\\"http://hiker.nokia.press/hikerule/rulelist.json?id=5099\\\",\\n    }),\\n    col_type: \\\"text_2\\\",\\n});\"},{\"col_type\":\"movie_3\",\"name\":\"文转语音\",\"path\":\"文转语音\",\"rule\":\"d.push({\\n    title: \\\"💬 文转语音\\\",\\n    url: $('#noLoading#').lazyRule((真名组) => {\\n         let 角色 = getItem(\\\"角色\\\", 'zh-CN-XiaoxiaoNeural');\\n         let 风格 = getItem('风格', 'general')\\n         let 文字 = getMyVar(\\\"文字\\\", \\\"\\\");\\n         if (文字 == \\\"\\\") return \\\"toast://请输入文本\\\";\\n         let 语速 = (getItem(\\\"语速\\\", '1') - 1) * 100 + '%';\\n         let 音调 = ((getItem(\\\"音调\\\", '1') - 1) * 100) / 2 + '%';\\n         var 文件名 = getMyVar(\\\"文件名\\\", \\\"\\\");\\n         if (文件名 == '') {\\n             return $('没有输入文件名，文件将自动命名').confirm((真名组,角色,风格,语速,音调,文字) => {\\n                   showLoading('语音合成中')\\n                   eval(JSON.parse(fetch(\\\"hiker://page/保存\\\")).rule);\\n                   hideLoading() \\n                   return 'toast://朗读中';\\n              },真名组,角色,风格,语速,音调,文字)\\n        } else {\\n            showLoading('语音合成中')\\n            eval(JSON.parse(fetch(\\\"hiker://page/保存\\\")).rule);\\n            hideLoading() \\n            return 'toast://朗读中';\\n        }\\n    },真名组),\\n    col_type: \\\"text_2\\\",\\n});\"},{\"col_type\":\"movie_3\",\"name\":\"语速\",\"path\":\"语速\",\"rule\":\"d.push({\\n    title: \\\"语速（\\\" + getItem(\\\"语速\\\", '1') + \\\"）\\\",\\n    url: $(getItem(\\\"语速\\\", \\\"1\\\"), \\\"语速 0.00 到 3\\\").input(function() {\\n        input = input.replace(/[^\\\\d\\\\.]/g, '');\\n        if (input == 01) input = '1';\\n        if (input == 02) input = '2';\\n        if (input == 03) input = '3';\\n        if (!input) input = '1';\\n        if (input > 3) input = '3';\\n        if (input < 0) input = '0';\\n        input = JSON.stringify(Math.round(input * 100) / 100);\\n        setItem(\\\"语速\\\", input)\\n        let lj='hiker://files/cache/tts参数.json'\\n        let 参数 = request(lj) || '{}';\\n        参数=JSON.parse(参数)\\n        参数['语速']= input;\\n        writeFile(lj, JSON.stringify(参数))\\n        updateItem(\\\"语速\\\", {\\n            \\\"title\\\": \\\"语速（\\\" + input + \\\"）\\\",\\n            'url': $(input, \\\"语速 0.00 到 3\\\").input(arguments.callee)\\n        });\\n        updateItem(\\\"试听\\\", {\\n            \\\"url\\\": eval(JSON.parse(fetch(\\\"hiker://page/试听\\\")).rule)\\n        })\\n        return \\\"toast://已设置语速为\\\" + input\\n    }),\\n    col_type: \\\"text_3\\\",\\n    extra: {\\n        id: \\\"语速\\\"\\n    }\\n})\"},{\"col_type\":\"movie_3\",\"name\":\"音调\",\"path\":\"音调\",\"rule\":\"d.push({\\n    title: \\\"音调（\\\" + getItem(\\\"音调\\\", '1') + \\\"）\\\",\\n    url: $(getItem(\\\"音调\\\", \\\"1\\\"), \\\"音调 0.00 到 2\\\").input(function() {\\n        input = input.replace(/[^\\\\d\\\\.]/g, '')\\n        if (!input) input = '1';\\n        if (input == 01) input = '1';\\n        if (input == 02) input = '2';\\n        if (input > 2) input = '2';\\n        if (input < 0) input = '0';\\n        input = JSON.stringify(Math.round(input * 100) / 100);\\n        setItem(\\\"音调\\\", input)\\n        let lj = 'hiker://files/cache/tts参数.json'\\n        let 参数 = request(lj) || '{}';\\n        参数 = JSON.parse(参数)\\n        参数['音调'] = input;\\n        writeFile(lj, JSON.stringify(参数))\\n        updateItem(\\\"试听\\\", {\\n            \\\"url\\\": eval(JSON.parse(fetch(\\\"hiker://page/试听\\\")).rule)\\n        });\\n        updateItem(\\\"音调\\\", {\\n            \\\"title\\\": \\\"音调（\\\" + input + \\\"）\\\",\\n            'url': $(input, \\\"音调 0.00 到 2\\\").input(arguments.callee)\\n        });\\n        updateItem(\\\"阅读\\\", {\\n            url: $('生成支持【阅读ledago】的语音引擎\\\\n\\\\n' + '♦️当前：' + getItem(\\\"角色名\\\",'晓晓（zh-CN）').split('（')[0]+\\\"（\\\"+getItem('风格名', '正常的')+\\\"）\\\" + '\\\\n\\\\n请在阅读朗读设置中点添加，粘贴源').confirm(() => {\\n                eval(JSON.parse(fetch(\\\"hiker://page/导入到阅读\\\")).rule)\\n                return 'hiker://empty';\\n            }),\\n        });\\n        return \\\"toast://已设置音调为\\\" + input\\n    }),\\n    col_type: \\\"text_3\\\",\\n    extra: {\\n        id: \\\"音调\\\"\\n    }\\n})\\nd.push({\\n    col_type: 'line',\\n    extra: {\\n        id: \\\"分割线\\\"\\n    }\\n})\"},{\"col_type\":\"movie_3\",\"name\":\"载入数据\",\"path\":\"载入数据\",\"rule\":\"let ln = 'hiker://files/cache/';\\nlet list = request(ln + '微软声音选择列表.json')\\nif (!list) {\\n    //备用：https://ms-ra-forwar.Vercel.app/api/azure\\n    //国外小水管，容易崩，自己搭最稳定：https://github.com/wxxxcxx/ms-ra-forwarder\\n    let load_list = fetch('http://test1.haikuoshijie.cn/api/azure');\\n    writeFile(ln + '微软声音选择列表.json', load_list);\\n    list = request(ln + '微软声音选择列表.json')\\n}\\nvar voices = {};\\nvar 名组 = ln + '微软语音中文名组.json';\\nlist = JSON.parse(list)\\n\\nlist.forEach(item => {\\n    if (['zh-CN', 'zh-TW', 'zh-HK'].includes(item['Locale'])) {\\n        voices[item['ShortName']] = item;\\n        writeFile(ln + '微软目标数据.json', JSON.stringify(voices));\\n\\n        let 真名 = item['ShortName'];\\n        let 显示名 = item['LocalName'] + '（' + item['Locale'] + '）';\\n        let 名字组 = request(名组) || '{}'\\n        if (名字组.indexOf(显示名) == -1) {\\n            名字组 = JSON.parse(名字组);\\n            名字组[显示名] = 真名;\\n            writeFile(名组, JSON.stringify(名字组));\\n        }\\n\\n    }\\n});\\n\\nvoices = JSON.parse(request(ln + '微软目标数据.json'))\\n/* 解锁微软内测角色 */\\neval(JSON.parse(fetch(\\\"hiker://page/新角色\\\")).rule)\\nvoices = Object.assign(voices, 新角色)\\nwriteFile(ln + '微软目标数据.json', JSON.stringify(voices));\\nvoices = JSON.parse(request(ln + '微软目标数据.json'))\\nlet o = {};\\nObject.values(voices).forEach(it => o[it.LocalName + '（' + it.Locale + '）'] = it.ShortName)\\n//log (o)\\nvar 中文组名 = o\\n//var 中文组名 = JSON.parse(request(名组))\\nlet 选名组 = Object.keys(中文组名)\\nlet 真名组 = Object.values(中文组名)\\nvar 角色名 = getItem(\\\"角色名\\\", '晓晓（zh-CN）');\\nlet 风格名 = getItem('风格名', '正常的')\\nlet 缓存选名组 = request(ln + '缓存选名组.json');\\nif (!缓存选名组) writeFile(ln + '缓存选名组.json', JSON.stringify(选名组));\"},{\"col_type\":\"movie_3\",\"name\":\"搭配试听\",\"path\":\"搭配试听\",\"rule\":\"d.push({\\n    title: \\\"🔊 搭配效果\\\",\\n    url: eval(JSON.parse(fetch(\\\"hiker://page/试听\\\")).rule),\\n    col_type: \\\"text_2\\\",\\n    extra: {\\n        id: \\\"试听\\\"\\n    }\\n});\"},{\"col_type\":\"movie_3\",\"name\":\"文本框\",\"path\":\"文本框\",\"rule\":\"d.push({\\n    col_type: 'x5_webview_single',\\n    desc: '0&&float'\\n}, {\\n    col_type: \\\"input\\\",\\n    desc: \\\"请输入要转换的文本\\\",\\n    extra: {\\n        defaultValue: getMyVar(\\\"文字\\\"),\\n        type: \\\"textarea\\\",\\n        height: 5,\\n        highlight: true,\\n        onChange: $.toString(() => {\\n            putMyVar(\\\"文字\\\", input.replace(/<[^<>]+>/g, '').substring(0,1399));\\n        })\\n    }\\n}, {\\n    url: \\\"\\\",\\n    col_type: \\\"input\\\",\\n    desc: \\\"输入要生成的文件名，无需后缀\\\",\\n    extra: {\\n        titleVisible: false,\\n        onChange: $.toString(() => {\\n            putMyVar(\\\"文件名\\\", input);\\n        })\\n    }\\n});\"},{\"col_type\":\"movie_3\",\"name\":\"试听url\",\"path\":\"试听\",\"rule\":\"$('#noLoading#').lazyRule(() => {\\n    //refreshPage()\\n    let 文字 = (getMyVar(\\\"文字\\\",'')||'小棉袄除了帅，还啥都会，嘿嘿嘿嘿').substring(0,30);\\n    let 角色 = getItem(\\\"角色\\\", 'zh-CN-XiaoxiaoNeural');\\n    let 风格 = getItem('风格', 'general')\\n    let 语速 = (getItem(\\\"语速\\\", '1') - 1) * 100 + '%';\\n    let 音调 = ((getItem(\\\"音调\\\", '1') - 1) * 100) / 2 + '%';\\n    eval(JSON.parse(fetch(\\\"hiker://page/合成朗读\\\")).rule)\\n    return 'toast://角色试听';\\n})\"},{\"col_type\":\"movie_3\",\"name\":\"外部引用\",\"path\":\"引用\",\"rule\":\"function 微软tts(arr, TEXT) {\\n    putVar('微软合成保存', '未')\\n    deleteFile(\\\"hiker://files/cache/微软tts/外调朗读.mp3\\\")\\n    arr.unshift({\\n        desc: '0&&float',\\n        col_type: 'x5_webview_single',\\n    }, {\\n        col_type: 'icon_small_3',\\n        url: \\\"hiker://empty\\\",\\n    }, {\\n        title: '🔈 朗读',\\n        col_type: 'text_3',\\n        url: $('#noLoading#').lazyRule(function(TEXT) {\\n            let 文字;\\n            if (TEXT == '' || TEXT == undefined) {\\n                文字 = '内容为空';\\n            } else {\\n                文字 = TEXT.replace(/<[^<>]+>/g, '').substring(0, 1399);\\n            }\\n            // log(文字)\\n            let lj = 'hiker://files/cache/tts参数.json'\\n            let 参数 = request(lj) || '{}';\\n            参数 = JSON.parse(参数)\\n            let 角色 = 参数.角色 || 'zh-CN-XiaoxiaoNeural';\\n            let 风格 = 参数.风格 || 'general';\\n            let 语速 = 参数.语速 || 1;\\n            语速 = (语速 - 1) * 100 + '%';\\n            let 音调 = 参数.音调 || 1;\\n            音调 = ((音调 - 1) * 100) / 2 + '%';\\n            let 外调判断 = request(\\\"hiker://files/cache/微软语音外调判断.json\\\")\\n            var saveF = \\\"hiker://files/cache/微软tts/外调朗读.mp3\\\";\\n            //let cache = request(saveF)\\n\\n            let r = \\\"hiker://files/cache/微软tts/\\\" + '[保存]外调朗读' + $.dateFormat(new Date, \\\"yyyyMMddHHmmss\\\");\\n            let sn = 'hiker://files/cache/微软外调保存名'\\n            writeFile(sn, r)\\n            r = request(sn)\\n            if (外调判断 === 文字 && fileExist(saveF) == true) {\\n                confirm({\\n                    title: '微软TTS提示',\\n                    content: '文章已合成播放过\\\\n\\\\n♦️是否保存成mp3文件？',\\n                    confirm: $.toString((saveF, sn, r, 文字) => {\\n                        return $('', \\\"如果输入为空，将自动命名\\\").input((saveF, sn, r, 文字) => {\\n                            let name = input;\\n                            if (name == '') {\\n                                name = r\\n                            } else {\\n                                name = \\\"hiker://files/cache/微软tts/\\\" + input\\n                            }\\n                            let sf = fetch(saveF, {\\n                                toHex: true\\n                            })\\n                            writeHexFile(name + '.mp3', sf)\\n                            writeFile(name + '.txt', 文字)\\n                            writeFile(sn, name + '.mp3')\\n                            updateItem(\\\"引入微软语音\\\", {\\n                                url: $('#noLoading#').lazyRule(() => {\\n                                    let s = request('hiker://files/cache/微软外调保存名') refreshX5WebView(getPath(s))\\n                                    return 'toast://mp3文件播放中';\\n                                }),\\n                            });\\n                            refreshX5WebView(getPath(saveF))\\n                            return 'toast://音频已保存为mp3文件\\\\n文章已保存为text文本';\\n                        }, saveF, sn, r, 文字)\\n                    }, saveF, sn, r, 文字),\\n\\n                    cancel: $.toString((saveF) => {\\n                        refreshX5WebView(getPath(saveF))\\n                        return 'toast://重新播放中';\\n                    }, saveF)\\n                });\\n                return 'hiker://empty'\\n            } else {\\n                showLoading('语音合成中')\\n                eval(JSON.parse(fetch(\\\"hiker://page/合成朗读?rule=微软语音\\\")).rule)\\n                hideLoading()\\n                //合成朗读已传出'文件'变量\\n                writeHexFile(saveF, 文件);\\n                writeFile(\\\"hiker://files/cache/微软语音外调判断.json\\\", 文字)\\n                return 'toast://开始朗读';\\n            }\\n        }, TEXT),\\n        extra: {\\n            id: \\\"引入微软语音\\\"\\n        }\\n    }, {\\n        col_type: 'blank_block',\\n    });\\n}\\n/*\\n<!-- 以下两行调用，d为你打印的数组名，text这里只做了简单处理，限制了文本长度 -->\\n\\neval(JSON.parse(fetch(\\\"hiker://page/引用?rule=微软语音\\\")).rule);\\n微软tts(d, text)\\n\\n*/\"},{\"col_type\":\"movie_3\",\"name\":\"风格选框\",\"path\":\"风格选框\",\"rule\":\"try {\\n    eval(JSON.parse(fetch(\\\"hiker://page/翻译\\\")).rule)\\n    if (getItem('锁定风格') == '有') {\\n\\n        d.push({\\n            url: eval(JSON.parse(fetch(\\\"hiker://page/风格\\\")).rule),\\n            col_type: \\\"text_1\\\",\\n            title: '““”” <small><font color=grey>' + '&#8195说话风格：' + getItem('风格名', '正常的') + '</font> </small>',\\n            extra: {\\n                id: '风格'\\n            }\\n        })\\n    }\\n} catch (e) {}\"},{\"col_type\":\"movie_3\",\"name\":\"风格url\",\"path\":\"风格\",\"rule\":\"$(风格翻译, 2, \\\"（\\\" + getItem('角色名').split('（')[0] + \\\"）\\\" + '说话风格').select(function(翻译) {\\n    let 选中风格 = Object.keys(翻译)[Object.values(翻译).indexOf(input)]\\n    //log(选中风格)\\n    setItem('风格名', input)\\n    setItem('风格', 选中风格)\\n    let lj = 'hiker://files/cache/tts参数.json'\\n    let 参数 = request(lj) || '{}';\\n    参数 = JSON.parse(参数)\\n    参数['风格'] = 选中风格;\\n    writeFile(lj, JSON.stringify(参数))\\n    updateItem(\\\"风格\\\", {\\n        'title': '““”” <small><font color=grey>' + '&#8195说话风格：' + input + '</font> </small>',\\n    });\\n    updateItem(\\\"阅读\\\", {\\n        url: $('生成支持【阅读ledago】的语音引擎\\\\n\\\\n' + '♦️当前：' + getItem(\\\"角色名\\\", '晓晓（zh-CN）').split('（')[0] + '（' + input + '）' + '\\\\n\\\\n请在阅读朗读设置中点添加，粘贴源').confirm(() => {\\n            eval(JSON.parse(fetch(\\\"hiker://page/导入到阅读\\\")).rule)\\n            return 'hiker://empty';\\n        }),\\n    });\\n\\n}, 翻译)\"},{\"col_type\":\"movie_3\",\"name\":\"风格翻译\",\"path\":\"翻译\",\"rule\":\"var 翻译 = {\\n    \\\"general\\\": \\\"正常的\\\",\\n    \\\"angry\\\": \\\"愤怒的\\\",\\n    \\\"assistant\\\": \\\"售货员\\\",\\n    \\\"affectionate\\\": \\\"充满深情\\\",\\n    \\\"chat\\\": \\\"闲聊\\\",\\n    \\\"calm\\\": \\\"平静的\\\",\\n    \\\"cheerful\\\": \\\"快乐的\\\",\\n    \\\"customerservice\\\": \\\"客服专员\\\",\\n    \\\"disgruntled\\\": \\\"不满的\\\",\\n    \\\"depressed\\\": \\\"沮丧的\\\",\\n    \\\"embarrassed\\\": \\\"尴尬的\\\",\\n    \\\"envious\\\": \\\"羡慕嫉妒的\\\",\\n    \\\"fearful\\\": \\\"害怕的\\\",\\n    \\\"gentle\\\": \\\"轻柔的\\\",\\n    \\\"lyrical\\\": \\\"抒情的\\\",\\n    \\\"sad\\\": \\\"悲哀的\\\",\\n    \\\"serious\\\": \\\"严肃的\\\",\\n    \\\"newscast\\\": \\\"新闻广播\\\",\\n    \\\"newscast-casual\\\": \\\"休闲广播\\\",\\n    \\\"narration-professional\\\": \\\"专业叙事\\\",\\n    \\\"narration-relaxed\\\": \\\"轻松叙事\\\",\\n    \\\"poetry-reading\\\": \\\"诗歌朗诵\\\",\\n    \\\"advertisement_upbeat\\\": \\\"欢快的广告\\\",\\n    \\\"sports_commentary\\\": \\\"体育解说\\\",\\n    \\\"sports_commentary_excited\\\": \\\"激动的解说\\\",\\n    \\\"documentary-narration\\\": \\\"纪录片叙事\\\"\\n}\\nlet 风格原组 = request('hiker://files/cache/微软语音风格.json') || '[]'\\n风格原组 = JSON.parse(风格原组)\\nlet 风格翻译 = 风格原组.map((f) => 翻译[f])\\nwriteFile('hiker://files/cache/微软语音风格翻译.json', JSON.stringify(风格翻译))\"},{\"col_type\":\"movie_3\",\"name\":\"初用提示\",\"path\":\"初用\",\"rule\":\"if (!getItem(\\\"TTSstartUse\\\",false)) {\\n    toast(\\\":-)初次见面，请多关照\\\");\\n    confirm({\\n        title: \\\"使用须知\\\",\\n        content: \\\"1.此小程序主要为视频创作者提供语音合成等功能\\\\n\\\\n2.外调朗读在当前页面未刷新的情况下，再次点击朗读按钮可将合成文件保存，为书单号创作带来福利\\\\n\\\\n3.非专业人事，不需要盲目保留此小程序\\\",\\n        confirm: \\\"setItem('TTSstartUse','1');refreshPage();'toast://感谢您的支持'\\\",\\n        cancel: \\\"setItem('TTSstartUse','1');refreshPage();'toast://感谢您的支持'\\\"\\n    });\\n}\"},{\"col_type\":\"movie_3\",\"name\":\"解锁新角色\",\"path\":\"新角色\",\"rule\":\"let 新角色 = {\\t\\\"zh-CN-XiaomengNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"晓梦\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-XiaomengNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"chat\\\"]\\t},\\t\\\"zh-CN-XiaoyiNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"晓伊\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-XiaoyiNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"angry\\\",\\\"depressed\\\",\\\"affectionate\\\",\\\"cheerful\\\",\\\"fearful\\\",\\\"sad\\\",\\\"embarrassed\\\",\\\"serious\\\",\\\"gentle\\\"]\\t},\\t\\\"zh-CN-XiaozhenNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"晓甄\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-XiaozhenNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"angry\\\",\\\"disgruntled\\\",\\\"cheerful\\\",\\\"fearful\\\",\\\"sad\\\",\\\"serious\\\"]\\t},\\t\\\"zh-CN-YunfengNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"云枫\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-YunfengNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"angry\\\",\\\"disgruntled\\\",\\\"cheerful\\\",\\\"fearful\\\",\\\"sad\\\",\\\"serious\\\",\\\"depressed\\\"]\\t},\\t\\\"zh-CN-YunhaoNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"云皓\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-YunhaoNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"advertisement_upbeat\\\"]\\t},\\t\\\"zh-CN-YunjianNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"云健\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-YunjianNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"narration-relaxed\\\",\\\"sports_commentary\\\",\\\"sports_commentary_excited\\\"]\\t},\\t\\\"zh-CN-YunxiaNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"云夏\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-YunxiaNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"narration-relaxed\\\",\\\"calm\\\",\\\"fearful\\\",\\\"cheerful\\\",\\\"angry\\\",\\\"sad\\\"]\\t},\\t\\\"zh-CN-YunzeNeural\\\": {\\t\\t\\\"LocalName\\\": \\\"云泽\\\",\\t\\t\\\"ShortName\\\": \\\"zh-CN-YunzeNeural\\\",\\t\\t\\\"Locale\\\": \\\"zh-CN\\\",\\t\\t\\\"StyleList\\\": [\\\"calm\\\",\\\"fearful\\\",\\\"cheerful\\\",\\\"disgruntled\\\",\\\"serious\\\",\\\"angry\\\",\\\"sad\\\",\\\"depressed\\\",\\\"documentary-narration\\\"]\\t}}\"}]","icon":"https://appimg.dbankcdn.com/application/icon144/e924c0d347474528a684bd9850707b58.png","proxy":""}
Add Comment
Please, Sign In to add comment