xiaomianao666

小程序:微软语音

Aug 2nd, 2022
111
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":20220803,"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 = [];\nd.push({\n    col_type: 'x5_webview_single',\n    desc: '0&&float'\n}, {\n    col_type: \"input\",\n    desc: \"请输入要转换的文本\",\n    extra: {\n        type: \"textarea\",\n        height: 5,\n        highlight: true,\n        onChange: $.toString(() => {\n            putMyVar(\"文字\", input.replace(/<|>/g,''));\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});\nlet ln = 'hiker://files/cache/';\nlet list = request(ln + '微软声音选择列表.json')\nif (!list) {\n    let load_list = fetch('https://ms-ra-forwarder-fawn-siX.Vercel.app/api/azure');\n    writeFile(ln + '微软声音选择列表.json', load_list);\n    list = request(ln + '微软声音选择列表.json')\n}\nlet voices = {};\nvar 名组 = ln + '微软语音中文名组.json';\nJSON.parse(list).forEach(item => {\n    if (['zh-CN', 'zh-TW', 'zh-HK'].includes(item['Locale'])) {\n        let 真名 = item['ShortName'];\n        let 显示名 = item['LocalName'] + '（' + item['Locale'] + '）';\n        voices[item['ShortName']] = item;\n\n        let 名字组 = request(名组) || '{}'\n        if (名字组.indexOf(显示名) == -1) {\n            名字组 = JSON.parse(名字组);\n            名字组[显示名] = 真名;\n            writeFile(名组, JSON.stringify(名字组));\n        }\n    }\n});\n\nvar 新名组 = JSON.parse(request(名组))\nlet 选名组 = Object.keys(新名组)\nlet 真名组 = Object.values(新名组)\nvar 角色名 = getItem(\"角色名\", '晓晓（zh-CN）');\nlet 缓存选名组 = request(ln + '缓存选名组.json');\nif (!缓存选名组) writeFile(ln + '缓存选名组.json', JSON.stringify(选名组));\n\nd.push({\n    title: \"语音（\" + 角色名.split('（')[0] + \"）\",\n    url: eval(JSON.parse(fetch(\"hiker://page/角色选框\")).rule),\n    col_type: \"text_3\",\n    extra: {\n        id: \"角色\"\n    }\n});\n\nd.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        updateItem(\"语速\", {\n            \"title\": \"语速（\" + input + \"）\"\n        });\n        updateItem(\"试听\", {\n            \"url\": eval(JSON.parse(fetch(\"hiker://page/试听\")).rule)\n        })\n        updateItem(\"语速\", {\n            'url': $(input, \"语速 0.00 到 3\").input(arguments.callee, 真名组)\n        });\n        return \"toast://已设置语速为\" + input\n    }, 真名组),\n    col_type: \"text_3\",\n    extra: {\n        id: \"语速\"\n    }\n})\nd.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        updateItem(\"音调\", {\n            \"title\": \"音调（\" + input + \"）\"\n        });\n        updateItem(\"试听\", {\n            \"url\": eval(JSON.parse(fetch(\"hiker://page/试听\")).rule)\n        });\n        updateItem(\"音调\", {\n            'url': $(input, \"音调 0.00 到 2\").input(arguments.callee, 真名组)\n        });\n        return \"toast://已设置音调为\" + input\n    }, 真名组),\n    col_type: \"text_3\",\n    extra: {\n        id: \"音调\"\n    }\n})\n\nd.push({\n    title: \"🔊 搭配效果\",\n    url: eval(JSON.parse(fetch(\"hiker://page/试听\")).rule),\n    col_type: \"text_2\",\n    extra: {\n        id: \"试听\"\n    }\n});\n/*\nd.push({\n    title: \"💬 文转语音\",\n    url: $('#noLoading#').lazyRule((真名组) => {\n        let 角色 = getItem(\"角色\", 'zh-CN-XiaoxiaoNeural');\n        let 文字 = getMyVar(\"文字\", \"\");\n        if (文字 == \"\") return \"toast://请输入文本\";\n        showLoading('语音合成中')\n        let 语速 = (getItem(\"语速\", '1') - 1) * 100 + '%';\n        let 音调 = ((getItem(\"音调\", '1') - 1) * 100) / 2 + '%';\n        eval(JSON.parse(fetch(\"hiker://page/合成朗读\")).rule)\n        hideLoading()\n        return 'toast://朗读中';\n    }, 真名组),\n    col_type: \"text_2\",\n});\n*/\n\neval(JSON.parse(fetch(\"hiker://page/文转语音\")).rule);\n\n/*\nd.push({\n    title: \"🫂 分享文件\",\n    url: $('#noLoading#').lazyRule(() => {\n        return 'share://hiker://files/cache/微软语音合成.mp3';\n    }),\n    col_type: \"text_2\",\n    extra: {\n        id: \"分享\"\n    }\n});\n*/\neval(JSON.parse(fetch(\"hiker://page/管理文件\")).rule)\n\nd.push({\n    title: \"📚 生成引擎\",\n    url: $('生成支持【阅读ledago】的语音引擎\\n\\n'+'♦️当前：'+ 角色名+'\\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});\n\n/* //风格还没写\nlet voiceName = 'zh-CN-XiaoxiaoNeural';\nlet voice = voices[voiceName];\nlet 已选 = voice['LocalName'];\nlet option = 'general';\nlet styleList = voice['StyleList']\nif (styleList) {\n    styleList.forEach(style => {\n        let 所有风格 = style;\n        log(所有风格)\n    });\n}\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\":\"let 风格 = 'general';\\nfunction 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=\\\"en-US\\\">\\\\\\n          <voice name=\\\"${voiceName}\\\">\\\\\\n            <mstts:express-as style=\\\"${styleName}\\\" role=\\\"\\\" styledegree=\\\"1\\\">\\\\\\n              <prosody rate=\\\"${rate}\\\" pitch=\\\"${pitch}\\\">\\\\\\n                  ${text}\\\\\\n              </prosody >\\\\\\n            </mstts:express-as>\\n          </voice >\\\\\\n        </speak > `\\n    return ssml;\\n};\\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 headers = {\\n        'Content-Type': 'text/plain',\\n        'Authorization': 'Bearer',\\n        'Format': 音频格式\\n    };\\n    let res = request('https://ms-ra-forwarder-fawn-siX.Vercel.app/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()\\nwriteHexFile(p, 文件);\\nrefreshX5WebView(getPath(p + '?t=' + JSON.stringify(new Date().getTime())))\\n//return的值请放在eval外面\"},{\"col_type\":\"movie_3\",\"name\":\"试听\",\"path\":\"试听\",\"rule\":\"$('#noLoading#').lazyRule((真名组) => {\\n    //refreshPage()\\n    let 文字 = '小棉袄除了帅，还啥都会，嘿嘿嘿嘿';\\n    let 角色 = getItem(\\\"角色\\\", 'zh-CN-XiaoxiaoNeural');\\n    let 语速 = (getItem(\\\"语速\\\", '1') - 1) * 100 + '%';\\nlet 音调 = ((getItem(\\\"音调\\\", '1') - 1) * 100) / 2 + '%';\\n    eval(JSON.parse(fetch(\\\"hiker://page/合成朗读\\\")).rule)\\n    return 'toast://角色试听';\\n}, 真名组)\"},{\"col_type\":\"movie_3\",\"name\":\"角色选框\",\"path\":\"角色选框\",\"rule\":\"$(JSON.parse(request(ln + '缓存选名组.json')), 2, \\\"选择角色\\\").select(function(ln, 选名组, 真名组) {\\n    let 选择 = []\\n    input = input.replace(/🔻/g, \\\"\\\")\\n    for (let i in 选名组) {\\n        var tss = new RegExp(input).test(选名组[i]);\\n        if (tss == true) {\\n            var nn = 真名组[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    updateItem(\\\"角色\\\", {\\n        'title': \\\"语音（\\\" + input.split('（')[0] + \\\"）\\\",\\n        'url': $(选择, 2, \\\"选择角色\\\").select(arguments.callee, ln, 选名组, 真名组)\\n    });\\n    updateItem(\\\"阅读\\\", {\\n        url: $('生成支持【阅读ledago】的语音引擎\\\\n\\\\n'+'♦️当前：'+ input+'\\\\n\\\\n请在阅读朗读设置中点添加，粘贴源').confirm(() => {\\n            eval(JSON.parse(fetch(\\\"hiker://page/导入到阅读\\\")).rule)\\n            return 'hiker://empty';\\n        }),\\n    });\\n    let 文字 = '哈哈哈哈哈，实话告诉你，小棉袄是真的帅';\\n    let 角色 = nn;\\n    setItem(\\\"角色\\\", nn);\\n    setItem(\\\"角色名\\\", input);\\n    let 语速 = '0%'; //-100%到200%\\n    let 音调 = '0%'; //-50%到50%\\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, 选名组, 真名组)\"},{\"col_type\":\"movie_3\",\"name\":\"导入到阅读\",\"path\":\"导入到阅读\",\"rule\":\"let 角色 = getItem(\\\"角色\\\",'zh-CN-XiaoxiaoNeural')\\nlet 角色名 = getItem(\\\"角色名\\\",'晓晓（zh-CN）')\\n//log(角色名+' : '+角色)\\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-forwarder-fawn-siX.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=\\\\\\\\\\\\\\\"en-US\\\\\\\\\\\\\\\"><voice name=\\\\\\\\\\\\\\\"${角色}\\\\\\\\\\\\\\\"><mstts:express-as style=\\\\\\\\\\\\\\\"general\\\\\\\\\\\\\\\" styledegree=\\\\\\\\\\\\\\\"1.0\\\\\\\\\\\\\\\"><prosody rate=\\\\\\\\\\\\\\\"{{(speakSpeed - 10) * 2}}%\\\\\\\\\\\\\\\" pitch=\\\\\\\\\\\\\\\"+0Hz\\\\\\\\\\\\\\\">{{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\":\"var date = new Date(); \\nvar 年 = date.getFullYear(); \\nvar 月 = date.getMonth() + 1; \\nvar 日 = date.getDate(); \\nvar 时 = date.getHours();\\nvar 秒 = date.getSeconds();\\nif (月 >= 1 && 月 <= 9) { \\n    月 = \\\"0\\\" + 月; \\n} \\nif (日 >= 0 && 日 <= 9) { \\n    日 = \\\"0\\\" + 日; \\n} \\neval(JSON.parse(fetch(\\\"hiker://page/合成朗读\\\")).rule); \\nvar saveF = \\\"hiker://files/cache/微软tts/\\\";\\nvar 文件名 = getMyVar('文件名', '');\\nif (文件名 == ''){\\n   文件名 = '微软tts'+年+月+日+时+秒+'.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            //log(TYPE);\\n            //log(PATH)\\n            setPageTitle('文件列表')\\n            return $(['📝 重命名', '🗑️ 删   除', '💽 播   放', '🌀 分   享'], 2, \\\"选择操作\\\").select((PATH,TYPE) => {\\n                if (input == '🌀 分   享') {\\n                    return 'share://file://' + PATH\\n                } else if (input == '🗑️ 删   除') {\\n                    return $('⛔ 确定删除吗?').confirm((PATH) => {\\n                        deleteFile('file://' + PATH)\\n                        refreshPage(false)\\n                        return \\\"toast://已删除\\\"\\n                    }, PATH)\\n                } else if (input == '💽 播   放') {\\n                    return '#isMusic=true#' + 'file://' + PATH\\n                } else {\\n                    //重命名\\n                    return $(PATH.substring((PATH.lastIndexOf(\\\"/\\\") + 1), PATH.lastIndexOf(\\\".\\\")), \\\"重新命名\\\").input(function(PATH,TYPE) {\\n                        input = input + TYPE\\n                        let re = request('file://' + PATH, {\\n                            toHex: true\\n                        })\\n                        writeHexFile('file://'+ PATH.substring(0,(PATH.lastIndexOf(\\\"/\\\") + 1))+ input, re)\\n                        deleteFile('file://' + PATH)\\n                        refreshPage(false)\\n                        return \\\"toast://已重命名\\\"\\n                    }, PATH,TYPE)\\n                }\\n            }, PATH,TYPE)\\n        }),\\n        fileType: \\\"\\\",\\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        pattern: 0,\\n        onClickType: \\\"lazyRule\\\",\\n        requireUrl: \\\"http://hiker.nokia.press/hikerule/rulelist.json?id=5099\\\",\\n        // cHomeTips: \\\"转发分享[${name}] ?\\\",\\n        // cSearchTips: \\\"转发分享[${path}] ?\\\"\\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 文字 = 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    },真名组),\\n    col_type: \\\"text_2\\\",\\n});\"}]","icon":"https://appimg.dbankcdn.com/application/icon144/e924c0d347474528a684bd9850707b58.png","proxy":""}
Add Comment
Please, Sign In to add comment