欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IM聊天教程之發(fā)送圖片/視頻/語音/表情

 更新時間:2020年05月19日 11:56:20   投稿:mrr  
朋友在問如何在IM即時通訊中實現(xiàn)發(fā)送圖片視頻語音和表情呢,今天小編通過本文給大家詳細(xì)介紹下,感興趣的朋友一起看看吧

經(jīng)常有朋友問起,如何在IM即時通訊中實現(xiàn)發(fā)送圖片、視頻、語音和表情?

為此,小編特意寫了一個vue版本的Demo,實現(xiàn)了圖片視頻文件和表情的的發(fā)送,參考這個Demo源代碼,相信你就可以輕松的用Uniapp和小程序完成類似的功能。

一、圖片/視頻/語音發(fā)送

對于語音、視頻和圖片的發(fā)送,您如果有注意的話,在使用QQ或者微信的時候,當(dāng)有朋友發(fā)送圖片和視頻給您時,收到后,需要等一會兒才能顯示出來。就是因為在發(fā)送的時候,只發(fā)送了文件的路徑,您收到后,需要加載才能顯示出來。因為當(dāng)前主流的IM包括微信,QQ等對于圖片和視頻的發(fā)送,通常的做法都是:

  • 上傳文件到文件服務(wù)器
  • 推送文件路徑
  • 收到文件路徑
  • 加載文件

并不會通過網(wǎng)絡(luò)直接傳送源文件,因為對于大文件的傳輸,會影響消息的即時性。

對于文件的上傳,您可以選擇直接上傳到您自己的服務(wù)器,也可以選擇上傳到各種云服務(wù)的對象存儲服務(wù),也就是OSS上。

參考源碼:

DemoService.prototype.sendFileMessage = function (type,content) {
  let uploadResult = restapi.uploadFile(content);
  let message = new Message(type, uploadResult.url);
  uploadResult.promise.then(() => {
    this.publish(message);
  },() => {
    var error = new Message(MessageType.TEXT, "文件上傳失敗.");
    this.messages.unshift(error)
  });
  return uploadResult.promise;
};

云服務(wù)的OSS具有更好的穩(wěn)定性和高可用性,上傳的速度也有保證,另外也可以和CDN配合,所以我們建議用GoEasy配合OSS服務(wù)來實現(xiàn)圖片和視頻的發(fā)送。

在本文的源碼里,選擇了使用阿里云的OSS作為文件上傳服務(wù)器,您也可以切換為您自己實現(xiàn)的文件上傳服務(wù)器,或者選擇其他云服務(wù)的OSS,原理都是一樣的。

二、發(fā)送表情

表情的發(fā)送也是非常簡單的,只是對于一些第一次實現(xiàn)表情發(fā)送的同學(xué)來說,需要一個思路而已。

細(xì)心點的朋友,肯定有發(fā)現(xiàn),當(dāng)我們在QQ上聊天的時候,我們輸入一個反斜杠+“cy”, 就像這樣:/cy ,QQ就會立即顯示為一個呲牙的表情,就像下圖一樣:

哈哈哈,相信你已經(jīng)心里已經(jīng)明白了十之八九了,對吧?

沒錯,表情在發(fā)送的過程中其實就是發(fā)一個像“/cy”這樣定義好的的字符串,在對方收到后“翻譯”成表情而已。

那為什么不直接發(fā)圖片,而要進(jìn)行這么復(fù)雜的“翻譯”呢?

因為字符串比圖片更小,發(fā)送的速度更快,用戶體驗更好。一個系統(tǒng)中的用戶成千上萬,用字符串可以節(jié)約大量的帶寬,節(jié)約系統(tǒng)資源。

原理講明白了,我們就開始干活兒吧:

第一步、定義表情

定義一個key value的對象,key作為表情標(biāo)簽,value則為每個表情標(biāo)簽對應(yīng)的圖片:

let expressions = {
  "[risus]": './images/risus.png',
  "[kiss]": './images/kiss.png',
  "[cry]": './images/cry.png',
  "[die]": './images/die.png',
  "[anger]": './images/anger.png',
}

然后畫一個表情選擇的界面:

第二步、選擇表情

為每個圖片的onclick事件中傳入這個表情的字符串標(biāo)簽,當(dāng)用戶點擊的時候,將表情的標(biāo)簽寫入輸入框,就成為了一個普通的字符串。在發(fā)送的時候,發(fā)送的其實就是這個表情的標(biāo)簽,也就是一個字符串。

<div class="goeasy-expression">
      <div :class="[appearanceClass, 'goeasy-appearance']" @click="show = true">{{text}}</div>
      <div class="expression-container" v-show="show">
        <div class="expression-icon-content">
          <div class="expression-icon__item"
             v-for="expression in list"
             :key="expression.id"
             @click="selectExpression(expression)">
            <img :src="expressions[expression.tag]">
          </div>

        </div>
        <div class="close-expression" @click="show = false"></div>
      </div>
    </div>

第三步、收到表情和展示表情

當(dāng)對方收到一個字符串后,跟第一步定義的key-value列表去匹配,如果能找到對應(yīng)的表情,就在頁面上展示對應(yīng)的表情圖片,如果找不到,就是一個普通的文本信息。

原理講清楚了后,具體實現(xiàn)是不是很簡單了?

參考我們提供的Demo源代碼,相信你很快就能掌握實現(xiàn)方法。

Demo源碼:https://gitee.com/goeasy-io/GoEasyDemo-vue-AudioPictureVideo

總結(jié)

到此這篇關(guān)于IM聊天教程之發(fā)送圖片/視頻/語音/表情的文章就介紹到這了,更多相關(guān)IM聊天發(fā)送視頻內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解文法的定義與分類(編譯原理)

    詳解文法的定義與分類(編譯原理)

    計算機(jī)的語言具有嚴(yán)格的語法、語義,易于形式化的特征,這篇文章主要介紹了詳解文法的定義與分類(編譯原理),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • 永久解決VSCode終端中文亂碼問題

    永久解決VSCode終端中文亂碼問題

    這篇文章主要介紹了永久解決VSCode終端中文亂碼問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 分享10個免費超棒的編程用等寬字體

    分享10個免費超棒的編程用等寬字體

    本文介紹 10 個適合在編程時使用的等寬字體,它們都是免費的,效果很好
    2013-07-07
  • 常用VsCode 快捷鍵(Window & Mac)GIF演示

    常用VsCode 快捷鍵(Window & Mac)GIF演示

    本文給大家分享了23個常用VsCode 快捷鍵(Window & Mac)的GIF動圖演示,非常的實用,有需要的小伙伴可以拿走參考
    2020-02-02
  • 算法系列15天速成 第十天 棧

    算法系列15天速成 第十天 棧

    今天跟大家聊聊棧,在程序設(shè)計中,棧的使用還是非常廣泛的,比如有“括號匹配問題“,”html結(jié)構(gòu)匹配問題“。所以說掌握了”?!暗氖褂茫瑢ξ覀儗W(xué)習(xí)算法還是很有幫助的
    2013-11-11
  • git stash的正確用法詳解

    git stash的正確用法詳解

    這篇文章主要為大家介紹了git stash的正確用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • 如何使用?Merklized?抽象語法樹壓縮智能合約

    如何使用?Merklized?抽象語法樹壓縮智能合約

    Merklized?抽象語法樹?MAST(又名?Merklized?替代腳本樹)是一種使用?Merkle?樹壓縮比特幣智能合約的技術(shù),這篇文章主要介紹了使用?Merklized?抽象語法樹壓縮智能合約,需要的朋友可以參考下
    2023-12-12
  • Git 教程之工作區(qū)、暫存區(qū)和版本庫詳解

    Git 教程之工作區(qū)、暫存區(qū)和版本庫詳解

    本文主要介紹Git 工作區(qū)、暫存區(qū)和版本庫的知識,這里整理了詳細(xì)的資料,有需要的小伙伴可以參考下
    2016-09-09
  • 自定義?Github?Action?庫實戰(zhàn)詳解

    自定義?Github?Action?庫實戰(zhàn)詳解

    這篇文章主要為大家介紹了自定義?Github?Action?庫實戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 代碼中到底應(yīng)不應(yīng)當(dāng)寫注釋?

    代碼中到底應(yīng)不應(yīng)當(dāng)寫注釋?

    注釋的確有其用途,但大部分情況下,程序員在濫用注釋。我是反對夾雜在代碼間的注釋的,我認(rèn)為注釋應(yīng)當(dāng)從代碼中獨立出來——通常被稱為文檔。
    2014-10-10

最新評論