mirror of
https://github.com/stevenjoezhang/live2d-widget.git
synced 2024-11-22 20:59:59 +08:00
2 lines
14 KiB
JavaScript
2 lines
14 KiB
JavaScript
(function(){"use strict";var fa_comment='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M512 240c0 114.9-114.6 208-256 208c-37.1 0-72.3-6.4-104.1-17.9c-11.9 8.7-31.3 20.6-54.3 30.6C73.6 471.1 44.7 480 16 480c-6.5 0-12.3-3.9-14.8-9.9c-2.5-6-1.1-12.8 3.4-17.4l0 0 0 0 0 0 0 0 .3-.3c.3-.3 .7-.7 1.3-1.4c1.1-1.2 2.8-3.1 4.9-5.7c4.1-5 9.6-12.4 15.2-21.6c10-16.6 19.5-38.4 21.4-62.9C17.7 326.8 0 285.1 0 240C0 125.1 114.6 32 256 32s256 93.1 256 208z"/></svg>';var fa_paper_plane='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M498.1 5.6c10.1 7 15.4 19.1 13.5 31.2l-64 416c-1.5 9.7-7.4 18.2-16 23s-18.9 5.4-28 1.6L277.3 424.9l-40.1 74.5c-5.2 9.7-16.3 14.6-27 11.9S192 499 192 488V392c0-5.3 1.8-10.5 5.1-14.7L362.4 164.7c2.5-7.1-6.5-14.3-13-8.4L170.4 318.2l-32 28.9 0 0c-9.2 8.3-22.3 10.6-33.8 5.8l-85-35.4C8.4 312.8 .8 302.2 .1 290s5.5-23.7 16.1-29.8l448-256c10.7-6.1 23.9-5.5 34 1.4z"/></svg>';var fa_user_circle='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M399 384.2C376.9 345.8 335.4 320 288 320H224c-47.4 0-88.9 25.8-111 64.2c35.2 39.2 86.2 63.8 143 63.8s107.8-24.7 143-63.8zM512 256c0 141.4-114.6 256-256 256S0 397.4 0 256S114.6 0 256 0S512 114.6 512 256zM256 272c39.8 0 72-32.2 72-72s-32.2-72-72-72s-72 32.2-72 72s32.2 72 72 72z"/></svg>';var fa_street_view='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M320 64c0-35.3-28.7-64-64-64s-64 28.7-64 64s28.7 64 64 64s64-28.7 64-64zm-96 96c-35.3 0-64 28.7-64 64v48c0 17.7 14.3 32 32 32h1.8l11.1 99.5c1.8 16.2 15.5 28.5 31.8 28.5h38.7c16.3 0 30-12.3 31.8-28.5L318.2 304H320c17.7 0 32-14.3 32-32V224c0-35.3-28.7-64-64-64H224zM132.3 394.2c13-2.4 21.7-14.9 19.3-27.9s-14.9-21.7-27.9-19.3c-32.4 5.9-60.9 14.2-82 24.8c-10.5 5.3-20.3 11.7-27.8 19.6C6.4 399.5 0 410.5 0 424c0 21.4 15.5 36.1 29.1 45c14.7 9.6 34.3 17.3 56.4 23.4C130.2 504.7 190.4 512 256 512s125.8-7.3 170.4-19.6c22.1-6.1 41.8-13.8 56.4-23.4c13.7-8.9 29.1-23.6 29.1-45c0-13.5-6.4-24.5-14-32.6c-7.5-7.9-17.3-14.3-27.8-19.6c-21-10.6-49.5-18.9-82-24.8c-13-2.4-25.5 6.3-27.9 19.3s6.3 25.5 19.3 27.9c30.2 5.5 53.7 12.8 69 20.5c3.2 1.6 5.8 3.1 7.9 4.5c3.6 2.4 3.6 7.2 0 9.6c-8.8 5.7-23.1 11.8-43 17.3C374.3 457 318.5 464 256 464s-118.3-7-157.7-17.9c-19.9-5.5-34.2-11.6-43-17.3c-3.6-2.4-3.6-7.2 0-9.6c2.1-1.4 4.8-2.9 7.9-4.5c15.3-7.7 38.8-14.9 69-20.5z"/></svg>';var fa_camera_retro='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M220.6 121.2L271.1 96 448 96v96H333.2c-21.9-15.1-48.5-24-77.2-24s-55.2 8.9-77.2 24H64V128H192c9.9 0 19.7-2.3 28.6-6.8zM0 128V416c0 35.3 28.7 64 64 64H448c35.3 0 64-28.7 64-64V96c0-35.3-28.7-64-64-64H271.1c-9.9 0-19.7 2.3-28.6 6.8L192 64H160V48c0-8.8-7.2-16-16-16H80c-8.8 0-16 7.2-16 16l0 16C28.7 64 0 92.7 0 128zM344 304c0 48.6-39.4 88-88 88s-88-39.4-88-88s39.4-88 88-88s88 39.4 88 88z"/></svg>';var fa_info_circle='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512zM216 336h24V272H216c-13.3 0-24-10.7-24-24s10.7-24 24-24h48c13.3 0 24 10.7 24 24v88h8c13.3 0 24 10.7 24 24s-10.7 24-24 24H216c-13.3 0-24-10.7-24-24s10.7-24 24-24zm40-144c-17.7 0-32-14.3-32-32s14.3-32 32-32s32 14.3 32 32s-14.3 32-32 32z"/></svg>';var fa_xmark='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512">\x3c!--! Font Awesome Free 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2022 Fonticons, Inc. --\x3e<path d="M310.6 150.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L160 210.7 54.6 105.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L114.7 256 9.4 361.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L160 301.3 265.4 406.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L205.3 256 310.6 150.6z"/></svg>';function loadWidget(config){let{apiPath:apiPath,cdnPath:cdnPath}=config;let useCDN=false,modelList;if(typeof cdnPath==="string"){useCDN=true;if(!cdnPath.endsWith("/"))cdnPath+="/"}else if(typeof apiPath==="string"){if(!apiPath.endsWith("/"))apiPath+="/"}else{console.error("Invalid initWidget argument!");return}localStorage.removeItem("waifu-display");sessionStorage.removeItem("waifu-text");document.body.insertAdjacentHTML("beforeend",`<div id="waifu">\n\t\t\t<div id="waifu-tips"></div>\n\t\t\t<canvas id="live2d" width="800" height="800"></canvas>\n\t\t\t<div id="waifu-tool"></div>\n\t\t</div>`);setTimeout((()=>{document.getElementById("waifu").style.bottom=0}),0);function randomSelection(obj){return Array.isArray(obj)?obj[Math.floor(Math.random()*obj.length)]:obj}let userAction=false,userActionTimer,messageTimer,messageArray=["好久不见,日子过得好快呢……","大坏蛋!你都多久没理人家了呀,嘤嘤嘤~","嗨~快来逗我玩吧!","拿小拳拳锤你胸口!","记得把小家加入 Adblock 白名单哦!"];window.addEventListener("mousemove",(()=>userAction=true));window.addEventListener("keydown",(()=>userAction=true));setInterval((()=>{if(userAction){userAction=false;clearInterval(userActionTimer);userActionTimer=null}else if(!userActionTimer){userActionTimer=setInterval((()=>{showMessage(randomSelection(messageArray),6e3,9)}),2e4)}}),1e3);(function registerEventListener(){const tools={hitokoto:{icon:fa_comment,callback:showHitokoto},asteroids:{icon:fa_paper_plane,callback:()=>{if(window.Asteroids){if(!window.ASTEROIDSPLAYERS)window.ASTEROIDSPLAYERS=[];window.ASTEROIDSPLAYERS.push(new Asteroids)}else{const script=document.createElement("script");script.src="https://fastly.jsdelivr.net/gh/stevenjoezhang/asteroids/asteroids.js";document.head.appendChild(script)}}},"switch-model":{icon:fa_user_circle,callback:loadOtherModel},"switch-texture":{icon:fa_street_view,callback:loadRandModel},photo:{icon:fa_camera_retro,callback:()=>{showMessage("照好了嘛,是不是很可爱呢?",6e3,9);Live2D.captureName="photo.png";Live2D.captureFrame=true}},info:{icon:fa_info_circle,callback:()=>{open("https://github.com/stevenjoezhang/live2d-widget")}},quit:{icon:fa_xmark,callback:()=>{localStorage.setItem("waifu-display",Date.now());showMessage("愿你有一天能与重要的人重逢。",2e3,11);document.getElementById("waifu").style.bottom="-500px";setTimeout((()=>{document.getElementById("waifu").style.display="none";document.getElementById("waifu-toggle").classList.add("waifu-toggle-active")}),3e3)}}};if(!Array.isArray(config.tools)){config.tools=Object.keys(tools)}for(let tool of config.tools){if(tools[tool]){const{icon:icon,callback:callback}=tools[tool];document.getElementById("waifu-tool").insertAdjacentHTML("beforeend",`<span id="waifu-tool-${tool}">${icon}</span>`);document.getElementById(`waifu-tool-${tool}`).addEventListener("click",callback)}}const devtools=()=>{};console.log("%c",devtools);devtools.toString=()=>{showMessage("哈哈,你打开了控制台,是想要看看我的小秘密吗?",6e3,9)};window.addEventListener("copy",(()=>{showMessage("你都复制了些什么呀,转载要记得加上出处哦!",6e3,9)}));window.addEventListener("visibilitychange",(()=>{if(!document.hidden)showMessage("哇,你终于回来了~",6e3,9)}))})();function welcomeMessage(){const message=`欢迎阅读<span>「${document.title.split(" - ")[0]}」</span>`;let text;if(location.pathname==="/"){const now=(new Date).getHours();if(now>5&&now<=7)text="早上好!一日之计在于晨,美好的一天就要开始了。";else if(now>7&&now<=11)text="上午好!工作顺利嘛,不要久坐,多起来走动走动哦!";else if(now>11&&now<=13)text="中午了,工作了一个上午,现在是午餐时间!";else if(now>13&&now<=17)text="午后很容易犯困呢,今天的运动目标完成了吗?";else if(now>17&&now<=19)text="傍晚了!窗外夕阳的景色很美丽呢,最美不过夕阳红~";else if(now>19&&now<=21)text="晚上好,今天过得怎么样?";else if(now>21&&now<=23)text=["已经这么晚了呀,早点休息吧,晚安~","深夜时要爱护眼睛呀!"];else text="你是夜猫子呀?这么晚还不睡觉,明天起的来嘛?";return text}else if(document.referrer!==""){const referrer=new URL(document.referrer),domain=referrer.hostname.split(".")[1];const domains={baidu:"百度",so:"360搜索",google:"谷歌搜索"};if(location.hostname===referrer.hostname)return message;if(domain in domains)text=domains[domain];else text=referrer.hostname;return`Hello!来自 <span>${text}</span> 的朋友<br>${message}`}else{return message}}showMessage(welcomeMessage(),7e3,8);function showHitokoto(){fetch("https://v1.hitokoto.cn").then((response=>response.json())).then((result=>{const text=`这句一言来自 <span>「${result.from}」</span>,是 <span>${result.creator}</span> 在 hitokoto.cn 投稿的。`;showMessage(result.hitokoto,6e3,9);setTimeout((()=>{showMessage(text,4e3,9)}),6e3)}))}function showMessage(text,timeout,priority){if(!text||sessionStorage.getItem("waifu-text")&&sessionStorage.getItem("waifu-text")>priority)return;if(messageTimer){clearTimeout(messageTimer);messageTimer=null}text=randomSelection(text);sessionStorage.setItem("waifu-text",priority);const tips=document.getElementById("waifu-tips");tips.innerHTML=text;tips.classList.add("waifu-tips-active");messageTimer=setTimeout((()=>{sessionStorage.removeItem("waifu-text");tips.classList.remove("waifu-tips-active")}),timeout)}(function initModel(){let modelId=localStorage.getItem("modelId"),modelTexturesId=localStorage.getItem("modelTexturesId");if(modelId===null){modelId=1;modelTexturesId=53}loadModel(modelId,modelTexturesId);fetch(config.waifuPath).then((response=>response.json())).then((result=>{window.addEventListener("mouseover",(event=>{for(let{selector:selector,text:text}of result.mouseover){if(!event.target.matches(selector))continue;text=randomSelection(text);text=text.replace("{text}",event.target.innerText);showMessage(text,4e3,8);return}}));window.addEventListener("click",(event=>{for(let{selector:selector,text:text}of result.click){if(!event.target.matches(selector))continue;text=randomSelection(text);text=text.replace("{text}",event.target.innerText);showMessage(text,4e3,8);return}}));result.seasons.forEach((({date:date,text:text})=>{const now=new Date,after=date.split("-")[0],before=date.split("-")[1]||after;if(after.split("/")[0]<=now.getMonth()+1&&now.getMonth()+1<=before.split("/")[0]&&(after.split("/")[1]<=now.getDate()&&now.getDate()<=before.split("/")[1])){text=randomSelection(text);text=text.replace("{year}",now.getFullYear());messageArray.push(text)}}))}))})();async function loadModelList(){const response=await fetch(`${cdnPath}model_list.json`);modelList=await response.json()}async function loadModel(modelId,modelTexturesId,message){localStorage.setItem("modelId",modelId);localStorage.setItem("modelTexturesId",modelTexturesId);showMessage(message,4e3,10);if(useCDN){if(!modelList)await loadModelList();const target=randomSelection(modelList.models[modelId]);loadlive2d("live2d",`${cdnPath}model/${target}/index.json`)}else{loadlive2d("live2d",`${apiPath}get/?id=${modelId}-${modelTexturesId}`);console.log(`Live2D 模型 ${modelId}-${modelTexturesId} 加载完成`)}}async function loadRandModel(){const modelId=localStorage.getItem("modelId"),modelTexturesId=localStorage.getItem("modelTexturesId");if(useCDN){if(!modelList)await loadModelList();const target=randomSelection(modelList.models[modelId]);loadlive2d("live2d",`${cdnPath}model/${target}/index.json`);showMessage("我的新衣服好看嘛?",4e3,10)}else{fetch(`${apiPath}rand_textures/?id=${modelId}-${modelTexturesId}`).then((response=>response.json())).then((result=>{if(result.textures.id===1&&(modelTexturesId===1||modelTexturesId===0))showMessage("我还没有其他衣服呢!",4e3,10);else loadModel(modelId,result.textures.id,"我的新衣服好看嘛?")}))}}async function loadOtherModel(){let modelId=localStorage.getItem("modelId");if(useCDN){if(!modelList)await loadModelList();const index=++modelId>=modelList.models.length?0:modelId;loadModel(index,0,modelList.messages[index])}else{fetch(`${apiPath}switch/?id=${modelId}`).then((response=>response.json())).then((result=>{loadModel(result.model.id,0,result.model.message)}))}}}function initWidget(config,apiPath){if(typeof config==="string"){config={waifuPath:config,apiPath:apiPath}}document.body.insertAdjacentHTML("beforeend",`<div id="waifu-toggle">\n\t\t\t<span>看板娘</span>\n\t\t</div>`);const toggle=document.getElementById("waifu-toggle");toggle.addEventListener("click",(()=>{toggle.classList.remove("waifu-toggle-active");if(toggle.getAttribute("first-time")){loadWidget(config);toggle.removeAttribute("first-time")}else{localStorage.removeItem("waifu-display");document.getElementById("waifu").style.display="";setTimeout((()=>{document.getElementById("waifu").style.bottom=0}),0)}}));if(localStorage.getItem("waifu-display")&&Date.now()-localStorage.getItem("waifu-display")<=864e5){toggle.setAttribute("first-time",true);setTimeout((()=>{toggle.classList.add("waifu-toggle-active")}),0)}else{loadWidget(config)}}window.initWidget=initWidget})();
|