首頁 >web前端 >css教學 >帶你使用CSS+jQuery實現一個文字轉語音機器人

帶你使用CSS+jQuery實現一個文字轉語音機器人

青灯夜游
青灯夜游轉載
2022-11-04 19:52:512572瀏覽

這篇文章手把手帶大家使用CSS jQuery實現一個文字轉語音機器人,希望對大家有幫助!

帶你使用CSS+jQuery實現一個文字轉語音機器人

素材

  • #機器眼睛

    帶你使用CSS+jQuery實現一個文字轉語音機器人

【推薦學習:css影片教學jQuery影片教學web前端影片

頁面佈局

機器人樣式參考了下圖,透過css拼造型的方式來實現。部分還原了設計圖

帶你使用CSS+jQuery實現一個文字轉語音機器人

  • #頭頂部分 頭頂部分是一個圓 偽類after實作白點
 <div class="tianxian"></div>
 .tianxian{
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background: #0e58cc;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
  }
  .tianxian::after{
    content: &#39;&#39;;
    display: block;
    width: 5px;
    height: 10px;
    border-radius: 12px;
    background: #fff;
    position: absolute;
    top: 10px;
    left: 5px;
    transform: rotateZ(20deg);
  }

整體佈局採用絕對定位佈局 利用整個頭部,實現耳朵和眼睛的定位

<div class="head">
      <div class="erduo"></div>
      <div class="erduo"></div>
      <div class="face">
        <div class="eye"></div>
        <div class="eye"></div>
      </div>
    </div>
  • 立體效果 透過box-shadow 的inset特性,透過適當偏移x,y軸,實現內陰影的立體效果
 box-shadow: -5px -5px 30px 1px #0075af inset;
  • 文字轉語音實現

基於瀏覽器提供的SpeechSynthesisUtterance Api進行實現

SpeechSynthesisUtterance基本屬性

  • SpeechSynthesisUtterance.lang 獲取並設定話語的語言
  • SpeechSynthesisUtterance.pitch 取得並設定話語的音調(值越大越尖銳,越低越低沉)
  • SpeechSynthesisUtterance.rate 取得並設定說話的速度(值越大語速越快,越小語速越慢)
  • SpeechSynthesisUtterance.text 取得並設定說話時的文字
  • SpeechSynthesisUtterance.voice  取得並設定說話的聲音
  • SpeechSynthesisUtterance.volume 取得並設定說話的音量

SpeechSynthesisUtterance.text基本方法

  • SpeechSynthesisUtterance.text基本方法
  • #SpeechSynthesisUtterance.text基本方法
  • speak() 將對應的實例加入語音佇列中
  • #cancel() 刪除佇列中所有的語音.如果正在播放,則直接停止

pause()

 暫停語音

resume() 恢復暫停的語音

為按鈕新增點擊事件,取得input輸入框的值,並進行播放,新增眼睛動畫,並在播放結束的回呼移除眼睛動畫

$(&#39;#btn&#39;).click(function () {
      let text = $(&#39;#input&#39;).val()
      if (text) {
        $(&#39;.eye&#39;).addClass(&#39;shine&#39;)
      }
      let u = new window.SpeechSynthesisUtterance()
      u.text = text
      u.lang = &#39;zh&#39;
      u.rate = 0.7
      u.onend = function () {
        $(&#39;.eye&#39;).removeClass(&#39;shine&#39;)
      }
      speechSynthesis.speak(u)
    })

動畫類別:

 .shine {
    animation: shine 1s linear infinite;
  }
  @keyframes shine {
    0%{
      height: 100px;
    }
    100%{
      height: 0px;
    }
  }

完整程式碼:

HTML CSS###


 
  
<div class="head"> <div class="erduo"></div> <div class="erduo"></div> <div class="face"> <div class="eye"></div> <div class="eye"></div> </div> </div>
点击朗读
###js######
 $(function () {
    $(&#39;#btn&#39;).click(function () {
      let text = $(&#39;#input&#39;).val()
      if (text) {
        $(&#39;.eye&#39;).addClass(&#39;shine&#39;)
      }
      let u = new window.SpeechSynthesisUtterance()
      u.text = text
      u.lang = &#39;zh&#39;
      u.rate = 0.7
      u.onend = function () {
        $(&#39;.eye&#39;).removeClass(&#39;shine&#39;)
      }
      speechSynthesis.speak(u)
    })
  })
###更多程式相關知識,請造訪:###程式設計教學###! ! ###

以上是帶你使用CSS+jQuery實現一個文字轉語音機器人的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除