鍓嶈█鏈€杩戠數瑙嗗墽銆婄偣鐕冩垜锛屾俯鏆栦綘銆嬬殑涓€娈碉紝鏉庡鍐欑殑鐖辨儏瀵嗙爜璧扮孩鉂わ笍鈥嶐煍モ潳锔忊€嶐煍モ潳锔忊€嶐煍ワ紝绫讳技鐨勮〃鐧界鍣ㄦ瘡姣忓嚭鐜板勾鍦ㄧ壒瀹氭椂闂寸敾鍑犱釜鍦堬紙浣犵煡閬撹繖浜涙棩鏈熷悧锛夈€傚綋鍚勮矾澶т浆寮€濮嬩互鍚勭璇█銆佸悇绉嶇被鍨嬪彂甯冪埍鎯呬唬鐮佹椂锛屾垜杩欎釜椤剁骇CV宸ョ▼甯堣嚜鐒惰鍦ㄨ繖娴簛鐨勭幆澧冧腑鐐€€涓€鐣紝浜庢槸鍦ㄨ繖鑼尗浜烘捣涓粡鍘嗕簡鎴戠殑灞傚眰绛涢€塷cean锛岃繖涓埍鎯呭瘑鐮佹槸鎴戞寫鍑烘潵鐨勶紝瀵逛粬鍋氫簡涓€鐐瑰皬鏀瑰姩銆傛彃浠跺湴鍧€鍏充簬鎻掍欢锛氳繖涓彃浠朵綔鑰呬粠浠g爜鐨勮搴︽槸娌″姙娉曠爺绌剁殑锛岃阿璋㈠ぇ瀹剁鏍戙€備綔涓哄疄鐜扮埍浠g爜閰风偒鏁堟灉鐨勫墠绔紝灏ゅ叾鏄?D鏁堟灉鎵€鐢ㄧ殑鎶€鏈爤锛屽熀鏈兘鏄熀浜巘hree.js+ca鈥嬧€媙vas銆傝繖涓彃浠朵篃鏄娇鐢╰hree.js+canvas寮€鍙戠殑锛屽叿浣撳紑鍙戣繃绋嬪氨涓嶈繃澶氬垎鏋愪簡锛宑v宸ョ▼甯堝three.js涓嶆槸寰堝湪琛岋紝绗戞鎴戜簡馃槀鍏虫敞WebAudioAPI锛歐ebAudioAPI鎻愪緵涓€涓姛鑳藉己澶т笖閫氱敤鐨勭郴缁燂紝鐢ㄤ簬鎺у埗Web涓婄殑闊抽锛屽厑璁稿紑鍙戜汉鍛橀€夋嫨闊抽婧愬苟鍚戦煶棰戞坊鍔犳晥鏋溿€佸垱寤洪煶棰戝彲瑙嗗寲銆佸簲鐢ㄧ┖闂存晥鏋滐紙濡傚0鍍忥級绛夈€傚0闊宠窛绂汇€佸ぇ灏忋€佹尟鍔ㄧ瓑鏁堟灉鐨勫彲瑙嗗寲闇€瑕乄ebAudioAPI鐨勫府鍔╂帴鍙o細杩欓噷绠€鍗曞垪鍑哄嚑涓彃浠朵娇鐢ㄧ殑鎺ュ彛銆傛洿澶氭帴鍙e彲浠ュ幓MDN鏌ョ湅AudioListenerAudioListener鏄敤鍦烘櫙涓殑涓€涓櫄鎷熺洃鍚櫒琛ㄧず鐨勬墍鏈変綅缃拰闈炰綅缃煶鏁堛€倀hree.js绋嬪簭閫氬父浼氬垱寤轰竴涓狝udioListener銆傚畠鏄煶棰戝疄浣撴瀯閫犲嚱鏁扮殑蹇呴渶鍙傛暟锛屼緥濡侫udio鍜孭ositionalAudio銆傚湪澶у鏁版儏鍐典笅锛屼睛鍚櫒瀵硅薄鏄浉鏈虹殑瀛愬璞°€侰amera3D鍙樻崲琛ㄧず鍚€呯殑3D鍙樻崲銆侫udioLoader鐢ㄤ簬鍔犺浇涓€绫籄udioBuffer銆傞粯璁ゆ儏鍐典笅锛孎ileLoader>>鐢ㄤ簬鍐呴儴鍔犺浇鏂囦欢銆傦紙鐢ㄤ簬鍔犺浇宸ョ▼涓殑闊抽鏂囦欢锛堿udioAnalyser鍒涘缓涓€涓狝udioAnalyser瀵硅薄锛屼娇鐢ˋnalyserNode鏉ュ垎鏋愰煶棰戞暟鎹€傛彃浠剁殑鍔ㄧ敾鏁堟灉涓€寮€濮嬪氨寰堝畬缇庯紝婊¤冻瀹夎瑕佹眰銆傚幓鎺夎竟妗嗘洿鍔犲ぇ姘旓紱鎶奲gm褰撻搩澹版崲鎴愭垜鍛ㄦ澃浼︾殑鏇村姩浜猴紱鍛ㄦ澃浼︾湅涓嶆噦鍔犱釜姝岃瘝鏇存樉浜烘€у寲锛堝紑鐜╃瑧锛屾垜鍠滄杩欐牱锛夈€傚凡缁忔湁浜嗚窡闅忔棆寰嬪姩鐢绘晥鏋滅殑鎻掍欢銆備笉鏄幇鎴愮殑甯︽瓕璇嶇殑鎾斁鍣ㄥ悧锛熸€濊矾涓€锛氬疄鐜拌瘑鍒煶棰戞樉绀烘瓕璇嶇殑鏁堟灉锛岀被浼间簬瑙嗛鎾斁鏃舵樉绀哄瓧骞曠殑鏁堟灉銆傛槗閫氱櫨搴﹀緱鍒扮殑缁撴灉涓昏鍒嗕负涓ょ锛氫笂浼犺闊冲埌鏈嶅姟鍣紝鏈嶅姟鍣ㄤ娇鐢ˋPI鈥嬧€嬭В鏋愯闊筹紝杩斿洖鏂囨湰锛涗娇鐢ㄦ湰鏈篈PI鎴栧悇绉嶅簱璋冪敤娴忚鍣ㄩ害鍏嬮锛屽苟璇嗗埆璇煶杞枃鏈柟娉曘€傚湪鐜╃殑椤圭洰涓樉鐒朵笉閫傜敤锛屾柟娉?寤惰繜澶暱锛岃瘑鍒噯纭巼澶綆銆傛€濊矾浜岋細鈭氳幏鍙栨瓕璇嶏紝瀹炵幇姝岃瘝鍜岄煶棰戠殑鍚屾銆傝繖涓柟妗堟槸鍙鐨勩€傝幏鍙栨瓕璇嶏紝鍦ㄧ綉涓婃壘LRC鏍煎紡鐨勬瓕璇嶃€傚繀椤绘槸LRC鏍煎紡锛屾斁鍦ㄦ枃鏈閲岋紝璁剧疆涓洪殣钘?textareaid="lrc_content"cols="30"style="display:none">[ti:鑺辨捣][ar:鍛ㄦ澃浼[00:03.63]鑺辨捣[00:06.35]鍛ㄦ澃浼00:14.49]...[00:18.56]...[00:26.90]鑺卞紑渚濇棫[00:33.31]杩滄柟娓呮緢鐨勭埍[00:39.53]鎯呬荆鐩哥埍鍗存洿鍠滄[00:45.99]鎴戝綋鏃朵笉鎳傝繖浠界埍[00:51.55][00:52.50]浣犲枩娆㈢珯鍦ㄧ獥鍙颁笂[00:58.47]浣犳病鏈夊ソ涔呬笉鍥炴潵浜哰01:05.12]浜旈鍏壊鐨勪笘鐣岃鏌撴垚涓€鐗囩┖鐧絒01:12.18]妯$硦鐨勬槸浣犵殑鐪兼唱[01:16.14][01:17.26]涓嶈浣犵寮€杩滄柟[01:23.65]鎬濆康鍙樻垚绐楀鐨勫ぇ娴疯繘涓嶅幓[01:29.82]鍘熻皡鎴戣鐖卞お蹇垚浜嗛樆纰峓01:36.24]鎵嬩腑鐨勯绛濋寰楀お蹇垜鏉ヤ笉鍙婅繑鍥瀃01:42.22][01:42.74]鎴戜笉鎯充綘绂诲紑鐪兼唱鏃犳硶铻嶅寲[01:48.96]鎴戝凡缁忕┛杩囬殰纰嶆垜绛夊緟閲嶆柊寮€濮媅01:55.51]澶╃┖鏄痵tillbright濂圭埍澶ф捣[02:01.79]鎯呮瓕琚墦璐ョ埍涓嶅啀瀛樺湪[02:09.83][02:34.80]浣犲枩娆㈢珯鍦ㄧ獥鍙颁笂[02:01.79]:41.14]浣犺繕娌℃湁濂戒箙涓嶅洖鏉ヤ簡[02:47.40]浜旈鍏壊鐨勪笘鐣岃鏌撴垚涓€鐗囩┖鐧絒02:54.66]瑜幓鐨勬槸浣犵殑鐪兼唱[02:59.87][03:0]0.24]涓嶆兂浣犵寮€杩滄柟[03:05.75]鎬濆康鍙樻垚绐楀鐨勬捣鎴戣繘涓嶅幓[03:12.16]鍘熻皡鎴戝お鏃╃埍鎴愰殰纰峓03:18.56]鎵嬩腑鐨勯绛濋寰楀お蹇洖涓嶆潵浜哰03:24.53][03:25.07]涓嶆兂浣犺蛋鐪兼唱鏃犳硶鎰堝悎[03:31.37]鎴戝湪绛夋柊鐨勫紑濮媅03:37.81]澶╄繕浜潃濂圭埍娴穂03:44.12]鎯呮瓕缈绘秾鎵撹触鐖卞凡涓嶅瓨鍦╗03:54.85]js璇绘瓕璇峷arlrc=document.getElementById("lrc_content").innerHTML;灏哃RC姝岃瘝瑙f瀽鎴怞S瀵硅薄varoLRC={ti:"",//姝屾洸鍚嶇Оar:"",//姝屾墜al:"",//涓撹緫鍚嶇Оby:"",//姝岃瘝鍒朵綔浜簅ffset:0,//鏃堕棿琛ュ伩鍊硷紝鍗曚綅姣锛岀敤浜庤皟鏁存瓕璇嶇殑鏁翠綋浣嶇疆锛屽崟浣峬s:[]//姝岃瘝鏁扮粍{t:time,c:lyric}};functioncreateLrcObj(lrc){if(lrc.length==0)杩斿洖锛泇arlrcs=lrc.split('\n');//浣跨敤鍥炶溅鎷嗗垎鎴愭暟缁刦or(variinlrcs){//閬嶅巻姝岃瘝鏁扮粍lrcs[i]=lrcs[i].replace(/(^\s*)|(\s*$)/g,"");//鍘绘帀鍓嶅悗绌烘牸vart=lrcs[i].substring(lrcs[i].indexOf("[")+1,lrcs[i].indexOf("]"));//寰楀埌[]鐨刢ontentbetweenvars=t.split(":");//鍒嗛殧锛氬墠鍚庢枃鏈琲f(isNaN(parseInt(s[0]))){//涓嶆槸涓€涓€糵or(vari鍦╫LRC){if(i!="ms"&&i==s[0].toLowerCase()){oLRC[i]=s[1];}}}else{//鏄竴涓€紇ararr=lrcs[i].match(/[(\d+:.+?)]/g);//鎻愬彇鏃堕棿瀛楁锛屽彲鑳芥湁澶氫釜varstart=0;for(varkinarr){start+=arr[k].length;//璁$畻姝岃瘝浣嶇疆}varcontent=lrcs[i].substring(start);//鑾峰彇姝岃瘝鍐呭for(varkinarr){vart=arr[k].substring(1,arr[k].length-1);//鑾峰彇[]涔嬮棿鐨勫唴瀹箆ars=t.split(":");//Separate:beforeandaftertextoLRC.ms.push({//Object{t:time,c:Lyrics}鍔犲叆ms鏁扮粍t:(parseFloat(s[0])*60+parseFloat(s[1])).toFixed(3),c:content});}}}oLRC.ms.sort(function(a,b){//鎸夋椂闂撮『搴忔帓搴弐eturna.t-b.t;});}createLrcObj(lrc);灏嗚В鏋愬悗鐨勬瓕璇嶅憟鐜板湪椤甸潰涓婂垱寤轰竴涓鍣ㄦ潵灞曠ず姝岃瘝
