溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MMS之如何添加附件setattachment

發(fā)布時間:2021-12-17 09:14:36 來源:億速云 閱讀:84 作者:小新 欄目:移動開發(fā)

這篇文章給大家分享的是有關MMS之如何添加附件setattachment的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

MMS 在Android Mms應用里面的具體實現(xiàn)形式,或數(shù)據(jù)結構是SlideshowModel,它是一個每個節(jié)點為SlideModel的 ArrayList,SlideModel是一個Model的List,也就是它可以接收任何Model的子類,Audio,Video,Image和 Text都可以放到SlideModel上面。SlideModel主要用于管理其上面的各個媒體,比如它們的布局,它們的播放控制,而 SlideshowModel主要用于管理所有的附件,比如把所有的附件轉化成為Android的MMS協(xié)議的數(shù)據(jù)類型Pdu,以及從Pdu轉化成為 SlideshowModel。

Pdu 是實現(xiàn)了MMS協(xié)議的標準格式,它可以直接的發(fā)送給MMSC,從MMSC取回來的也是一個Pdu格式的數(shù)據(jù)。應用層Mms不需要關心Pdu的具體實現(xiàn)方式,Android中有一個內部的包com.google.android.mms.*下面的類都是專門用于處理Android平臺上的MMS。里面提供了工作可以把應用層的數(shù)據(jù),比如媒體文件等,進行包裝成Pdu,再把Pdu分解成為媒體文件。Pdu的數(shù)據(jù)結構包括PduBody,這個是用于存放多媒體文件的地方,其里面是PduPart的集合,每個PduPart代表一個文件。PduPersister用于操作這些數(shù)據(jù)結構,包括寫入數(shù)據(jù)庫,從數(shù)據(jù)庫中讀取等。

SlideshowModel或俗稱幻燈片是應用層的MMS的實現(xiàn)形式,或者它是應用層MMS用來創(chuàng)建,編輯,顯示和管理多媒體的一個數(shù)據(jù)結構。創(chuàng)建和發(fā)送MMS的時候,就是創(chuàng)建一個SlideshowModel,構建MediaModel,TextModel等加入到 SlideshowModel中。在發(fā)送時,SlideshowModel會把其內的媒體文件取出來,轉化為PduPart放入PduBody中。收到信息后從PduBody中取出PduPart,還原成媒體文件,生成MediaModel,加入到SlideshowModel中,也就是還原為幻燈片。應用拿到幻燈片后可以做顯示和播放。

附件類型

關于附件類型,Mms應用中所有的MMS都有一個幻燈片,其內含有所有的附件文件。但是Mms做了一些特殊的處理,對于一個MMS信息,它的附件類型分為 IMAGE, AUDIO, VIDEO,和SLIDESHOW,這些從添加附件對話框的列表中可以看出,而且展現(xiàn)方式也有所不同。但是實際的實現(xiàn)上面并沒有這么多的類型,只有一個 SlideshowModel,所有的附件都在里面。它處理的規(guī)則是這樣的,如果只添加了一個媒體(image, audio和video)時,會把類型設置為相應的媒體類型,而只有在附件對話框中明確選擇添加幻燈片時并且添加了多張幻燈片后,附件類型才會是幻燈片。這個附件類型只在給MMS添加附件時和發(fā)送MMS前有效,主要用于在消息列表中如何展示媒體文件,如果是具體媒體類型,就直接顯示,否則顯示為幻燈片,這個附件類型僅存在于應用中顯示媒體所用,并不會在發(fā)送出去的Pdu中有痕跡。當收到MMS后,也是根據(jù)轉化后的SlideshowModel里面的內容來推測出附件類型,然后再做顯示。所以,對于一個MMS來說它始終都有一個SlideshowModel,用戶所感受到的附件類型僅是附件媒體顯示上面的一個處理而已。

創(chuàng)建和編輯MMS

與傳統(tǒng)手機不同,創(chuàng)建MMS并不需要特殊的方式。因為Mms應用對MMS和SMS并不做嚴格的區(qū)分,而是以統(tǒng)一的對話中的一個消息來對待,所以MMS與 SMS的區(qū)別也很簡單,就看一個消息中只否有附件(WorkingMessage.hasAttachment())。創(chuàng)建MMS也十分簡單,只需點擊 Composer而的Attach菜單添加媒體即可。在列表中選擇image, audio和video后就只有一個媒體文件,都會跑到其他的Activity去選擇文件,然后會返回其Uri給Composer,Composer會調用WorkingMessage.setAttachment()來做具體的添加,用Uri創(chuàng)建MediaModel然后加入到 SlideshowModel中,并設置類型。另外,如果選擇了Attach幻燈片,就會直接進入編輯幻燈片的而面,可以添加刪除幻燈片頁,給幻燈片頁加媒體文件,設置布局等,之后Composer會把SlideshowModel顯示出來,此時的附件類型也是SLIDESHOW,這些都是通過 WorkingMessage.load()來完成的。

WorkingMessage在把媒體加到幻燈片里以后,就會回調一個接口 onAttachmentChanged(),Composer實現(xiàn)了此接口,這個接口主要用于通知Composer附件已發(fā)生變化,刷新UI以正確顯示附件。Composer會創(chuàng)建AttachmentEditor來顯示附件的內容,因為所有的附件都放在Slideshow里面這個Slideshow在 WorkingMessage中,可以通過WorkingMessage.getSlideshow()來獲取。AttachmentEditor會根據(jù) Slideshow里面的內容來創(chuàng)建不同的View以展示不同的附件,如果Slideshow中只有一個Video,Audio或Image,就直接創(chuàng)建 VideoAttachmentView,AudioAttachmentView或ImageAttachmentView,而對于幻燈片中頁數(shù)大于1 時就會創(chuàng)建SlideshowAttachmentView。還有相應的按扭可以用來編輯,替換或刪除,對于單個媒體有查看/播放,選擇后可以查看原圖和播放音頻視頻,替換可以重新重選擇一個附件,刪除會移除掉附件;對于Slideshow有編輯和刪除,編輯會直接進入幻燈片的編輯頁面,那里可以一頁一頁的對每頁幻燈片進行詳細的編輯,刪除會移除掉附件。

編輯完附件后有三種處理方式,一個是發(fā)送信息,一個是保存為草稿另一個就是放棄信息。發(fā)送信息和保存草稿都會對幻燈片進行打包,轉成Pdu,并保存到數(shù)據(jù)庫,之后的幻燈片都需要從數(shù)據(jù)庫加載并把Pdu解包成為SlidehshowModel。

Packaging and unpackaging MMS

要發(fā)送信息前,或是保存草稿時,都需要把SlideshowModel進行打包生成Pdu格式,并保存至數(shù)據(jù)庫。這個稱為MMS的打包(Packaging),是由SlideshowModel.makePduBody()方法來完成,它會把幻燈片里面的內容一個一個的取出來,轉成一個 PduPart,再放入PduBody中,以生成PduBody,一個媒體對應一個PduPart,同時還可以設置PduPart的屬性以描述媒體的文件,比如 ContentType,這是一個用于標識媒體MIME類型的字串;Filename文件的名字; ContentLocation文件的路徑。這些信息都用于描述PduPart中數(shù)據(jù)的元信息(MetaData),也就是數(shù)據(jù)具體是什么,以便讓解包的時候對數(shù)據(jù)進行正確的處理。

之后PduPersister會通過其persist()方法把PduBody存入到數(shù)據(jù)庫中,它會把PduPart 中的描述性信息作數(shù)據(jù)庫字段寫入,把文件存儲在TelephonyProvider文件夾下面(/data/data /android.providers.telephony/app_parts),并把存儲后的路徑作為_data字段寫入數(shù)據(jù)庫,這樣一條MMS的數(shù)據(jù)就都寫入了數(shù)據(jù)庫中。這以后,MMS的數(shù)據(jù)都是從數(shù)據(jù)庫中加載,所以原SlideshowModel中的數(shù)據(jù)庫不再有效,如Uri在原 SlideshowModel中可能指向一個文件,或是其他數(shù)據(jù)庫,在PduPersister.persist()之后就不再有效了。

當 PduPersister.persist()之后,MMS的附件就都從數(shù)據(jù)中加載,PduPersister.load()會從數(shù)據(jù)庫把數(shù)據(jù)加載成為一個PduBody,SlideshowModel的方法createFromPduBody()就是用于把PduBody轉化成為一個 SlideshowModel,從PduPart取出媒體信息以得到正確的媒體格式,和相關信息,可以通過Uri來獲取具體文件(流)。

接收到的 MMS過程也差不多當NotificationTransaction或RetrieveTransaction用HttpUtils從MMSC獲取到 MMS數(shù)據(jù)后會用PduParser來解析數(shù)據(jù)生成Pdu,再用PduPersister.persist()把其寫入數(shù)據(jù)庫,之后會再從數(shù)據(jù)庫中加載。

SMIL語言支持

對于每條MMS還有一個很重要的數(shù)據(jù)就是SMIL語言,SMIL是同步多媒體集成語言的簡稱(Synchronized Multimedia Integration Language),它與HTML文檔很類似,是W3C(World Wide Web Consortium)組織規(guī)定的多媒體操縱標準語言。MMS也是用它來管理和播放多媒體。來看一個具體的SMIL語言實例:

<smil xmlns="http://www.w3.org/2000/SMIL20/CR/Language">           <head>                   <layout>                           <root-layout width="360" height="615"/>                           <region id="Image" width="347" height="260" top="14" left="7" fit="meet"/>                                                          <region id="Text" width="326" height="320" top="281" left="7" fit="scroll"/>                   </layout>           </head>           <body>                   <par dur="60s">                           <img src="0.jpg" region="Image"/>                           <text src ="0.txt" region="Text"/>                   </par>                   <par dur="60s">                           <text src ="1.txt" region="Text"/>                   </par>                   <par dur="60s">                           <text src ="2.txt" region="Text"/>                   </par>                   <par dur="60s">                           <text src ="3.txt" region="Text"/>                   </par>                   <par dur="60s">                           <text src ="4.txt" region="Text"/>                   </par>           </body>   </smil>

SMIL 語言播放多媒體時通常是一頁頁的,與幻為播放十分類似,因為很多SMIL播放器都會做成幻燈片形式。因為MMS用SMIL來傳送多媒體,所以Mms終端應 用都會以幻燈片的方式來播放MMS。這也就是為什么Mms應用中會出來SlideshowModel的原因?;脽羝绞斤@示彩信是一種常用的方法,即使某 些終端應用沒有用幻燈片放映的方式顯示彩信,但是對于運營商或彩信平臺發(fā)出來彩信都有頁碼標識,另外其他的一些手機,比如非智能手機查看彩信的方式也是以 幻燈片一頁一頁的放映。

它主要記載著用于幻燈片的布局信息。這個SMIL語言就是用于幻燈片布局的,也就是說SMIL會像HTML文檔布局網(wǎng)頁那 樣來說明如何布局幻燈片,它有這些TAG:head, layout, body, par,head是頭信息,里面有TAG layout用來說明這個幻燈片是如何布局的,具體的它用一些子TAG如root-layout, region等來說明幻燈片中的每一個元素如Image或Text如何布局。TAG body中列出了幻燈片的所有媒體元素和詳細內容,比如image, audio, text等,每一par是一頁,它的子TAG說明這一頁有哪些內容,當然SMIL語言還有很多內容可以參考Wikipedia上的講解。

當 打包幻燈片時,也就是把SlideshowModel轉化為Pdu時,會根據(jù)SlideshowModel的內容生成一個SMIL語言,通過 SmilHelper.getDocument()來生成SMIL文檔,把其加入到PduBody中并作為***個PduPart,它的 ContentType(MIME)是application/smil,它的內容就是SMIL文檔。需要注意的是SMIL文檔總是會在PduBody的 ***個Part,并且它直接把文檔內容寫到PduPart中,而不是以文件的形式存在。

當解包的時候,會先取出SMIL文檔,對其進行解析,生成幻燈片。

因 為SMIL是一個標準的文檔,所以W3C有其相應的規(guī)范,也有相應的庫來解析和生成。在Mms應用中可以看到這樣的二個Package: org.w3c.dom.*和com.android.mms.dom.*;其中org.w3c.dom是SMIL語言的一些標準庫,而 com.android.mms.dom.*;是對org.w3c.dom一些標準接口的實現(xiàn),或者說是為了Mms應用而做的一些適配。那么在 com.android.mms.model.*里面的一些類也是根據(jù)SMIL標準而寫的,比如SmilHelper就是專門用于解析SMIL文檔和生成 SMIL文檔,當然它會用到前面提到的二個Package里面的東西。還有如ImageModel,TextModel和RegionModel也都是基 于SMIL標準的,比如它們分別 對應SMIL文檔中的標簽img, text和region。

當然,這都是具體的終端應用的實現(xiàn),可能不同的應用會有不同的方式,但發(fā)送出去的和接收到的都應該是標準的Pdu,而SMIL文檔僅是一個其中一個PduPart而已。

感謝各位的閱讀!關于“MMS之如何添加附件setattachment”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

mms
AI