android 短信添加附件
来源:互联网 发布:德哈维兰 知乎 编辑:程序博客网 时间:2024/06/04 18:35
添加附件。
在ComposeMessageActivity里
addAttachment(int type) 函数
根据type的不同,分成6个case
case A:
MediaSelectListActivity.ADD_IMAGE 用gallery选图片:
MessageUtils.selectImage(this, REQUEST_CODE_ATTACH_IMAGE);
起一个intent:
createChooser 函数new 一个 Intent intent = new Intent(ACTION_CHOOSER);
也就是起来一个ACTION_CHOOSER的 activity
case B:
MediaSelectListActivity.TAKE_PICTURE起一个照相机来拍照了,
case C:
MediaSelectListActivity.ADD_VIDEO
很像case A
只有在type那里,从image换成video
case D:
MediaSelectListActivity.RECORD_VIDEO
和case B一样起一个录像机,不过这次有空间大小计算:给文本留1024Byte。
按一条彩信300k算,录像最多使用299k。也即299*1024bytecase E:
MediaSelectListActivity.ADD_SOUNDcase F:
MediaSelectListActivity.RECORD_SOUND
像B那样,七个录音机。 这次type是autioncase G:
MediaSelectListActivity.ADD_SLIDESHOW
幻灯片slideshow比较尴尬。因为整个彩信附件也叫slideshow,而这里的slideshow是多张图片拼凑在一起的意思。彩信的附件也经常是若干张图片。。。 这里从起名开始就绕的要死了。saveAsMms函数里面有几个事情:首先把短信强制变成彩信,把短信的内容封装到PduPersister中(可以理解为彩信body)去,new一个SendReq也就是彩信头。生成包含彩信头和body的uri。
最后起一个尴尬的SlideshowEditActivity。 这个东西太麻烦。不看。。
然后是到了onActivityResult函数。 那些从外面的activity读取媒体数据的应用返回的时候都回到这里。
A。图片
图片在onActivityReuslt会得到uri,调用 addImage(uri, false); 这个函数会调用mWorkingMessage.setAttachment(WorkingMessage.IMAGE, uri,
false);也就是非append模式添加图片。
如果图片太大,会启用异步的图片压缩函数。
B 拍照片
也是返回一个uri到onActivityReuslt函数。也是调用 addImage(uri, false),同上。
C 选录像文件 D 拍录像
都是调用addVideo(data.getData(), false);
data.getData()也是得到uri,addVideo调用mWorkingMessage.setAttachment(WorkingMessage.VIDEO,
uri, append);
跟图片处理一样的。
E 选录音文件 F 录音
都是addAudio -->
mWorkingMessage.setAttachment(WorkingMessage.AUDIO, uri,
false);
不多说
删除附件
AttachmentEditor里面有个handler,用来给composeMessageActivity传消息。
所有删除附件操作的按钮都在AttachmentEditor上。对不同的媒体类型有不同的按钮,但是按下之后出口是一样的:就是这么个操作。
之所以一样是因为所有的附近都存在SlideshowModel里,而这个SlideshowModel是:
ArrayList<SlideModel> mSlides; 一列儿slide组成的。
每个slide可以包含video,image,audio,text, 其中前三者一般不能两两同时存在,唯一的例外是image和audio。
(其实我觉得如果,如果每个slide只能包含三者中的一种,即不处理上面那个例外,逻辑可能更清晰)
说回到那个remove操作。。
composeMessageActivity的Handler里的handleMessage函数,接到这个删除msg之后的操作是:
最后一位false表示非append模式,即从新修改附件。
mWorkingMessage是什么呢?
是短信(包括彩信)的所有的状态所有操作所有数据的现状,主要有几个成员:
mMmsState 彩信状态,是不是彩信,为啥是彩信,是有附件有标题,或者强制彩信等
mAttachmentType 附件类型。如果mSlideshow是多页:slide类型。 单页:图片|声音|录像|文本。 如果mSlideshow是空,就是文本类型。
mSlideshow 附件数据数组。就是那个ArrayList<SlideModel> mSlides。
现在回头看那个删除操作。
setAttachment里面最主要的函数是changeMedia(type, dataUri),这里传入的参数type是TEXT,dataUri是null。
这个函数进去:看到第一个return我们就可以return了。。
多干净利落!直接把彩信原来的附件看都不堪直接一刀删完,类型回归到WorkingMessage.TEXT,把uri置空。
另外,说一些题外的。
这个changeMedia函数,来来回回,都是改的mSlideshow.get(0)那个
在setAttachment的时候,如果是用的append模式,到时候就会用appendMedia而不是changeMedia函数。
对于append模式,
如果最后一页包含了图片image或者录像vedio, 那么append的时候必须加到下一张。
感觉源码里这个判断有点写复杂了。。你看我一句话就能归纳出来的,他代码写半天~
不过我写不出更好的~~
还有SlideModel的add函数。 很多情况叠在一起了,所以有点复杂。
添加的关键函数是下面这个,第一个参数是对应格式的原来媒体(比如你想添加录像,那这个就是原来的录像,可以是null),第二个是添加的新媒体还有个附件太大时的异步缩小功能,是下面这个函数图片被缩放到最大640*480,如果还是大于300*1024-5000字节(差不多295k),那么缩放到295k。
这个大小是源码编写程序员凭感觉写死的。
这里的cb.onResizeResult是调用的ComposeMessageActivity的ResizeImageResultCallback里的函数。
处理大小结束后,会拿新的图片去再次setAttachment,
也就更新了附件
在ComposeMessageActivity里
addAttachment(int type) 函数
根据type的不同,分成6个case
case A:
MediaSelectListActivity.ADD_IMAGE 用gallery选图片:
MessageUtils.selectImage(this, REQUEST_CODE_ATTACH_IMAGE);
起一个intent:
createChooser 函数new 一个 Intent intent = new Intent(ACTION_CHOOSER);
也就是起来一个ACTION_CHOOSER的 activity
case B:
MediaSelectListActivity.TAKE_PICTURE起一个照相机来拍照了,
case C:
MediaSelectListActivity.ADD_VIDEO
很像case A
只有在type那里,从image换成video
case D:
MediaSelectListActivity.RECORD_VIDEO
和case B一样起一个录像机,不过这次有空间大小计算:给文本留1024Byte。
按一条彩信300k算,录像最多使用299k。也即299*1024bytecase E:
MediaSelectListActivity.ADD_SOUNDcase F:
MediaSelectListActivity.RECORD_SOUND
像B那样,七个录音机。 这次type是autioncase G:
MediaSelectListActivity.ADD_SLIDESHOW
幻灯片slideshow比较尴尬。因为整个彩信附件也叫slideshow,而这里的slideshow是多张图片拼凑在一起的意思。彩信的附件也经常是若干张图片。。。 这里从起名开始就绕的要死了。saveAsMms函数里面有几个事情:首先把短信强制变成彩信,把短信的内容封装到PduPersister中(可以理解为彩信body)去,new一个SendReq也就是彩信头。生成包含彩信头和body的uri。
最后起一个尴尬的SlideshowEditActivity。 这个东西太麻烦。不看。。
然后是到了onActivityResult函数。 那些从外面的activity读取媒体数据的应用返回的时候都回到这里。
A。图片
图片在onActivityReuslt会得到uri,调用 addImage(uri, false); 这个函数会调用mWorkingMessage.setAttachment(WorkingMessage.IMAGE, uri,
false);也就是非append模式添加图片。
如果图片太大,会启用异步的图片压缩函数。
B 拍照片
也是返回一个uri到onActivityReuslt函数。也是调用 addImage(uri, false),同上。
C 选录像文件 D 拍录像
都是调用addVideo(data.getData(), false);
data.getData()也是得到uri,addVideo调用mWorkingMessage.setAttachment(WorkingMessage.VIDEO,
uri, append);
跟图片处理一样的。
E 选录音文件 F 录音
都是addAudio -->
mWorkingMessage.setAttachment(WorkingMessage.AUDIO, uri,
false);
不多说
删除附件
AttachmentEditor里面有个handler,用来给composeMessageActivity传消息。
所有删除附件操作的按钮都在AttachmentEditor上。对不同的媒体类型有不同的按钮,但是按下之后出口是一样的:就是这么个操作。
之所以一样是因为所有的附近都存在SlideshowModel里,而这个SlideshowModel是:
ArrayList<SlideModel> mSlides; 一列儿slide组成的。
每个slide可以包含video,image,audio,text, 其中前三者一般不能两两同时存在,唯一的例外是image和audio。
(其实我觉得如果,如果每个slide只能包含三者中的一种,即不处理上面那个例外,逻辑可能更清晰)
说回到那个remove操作。。
composeMessageActivity的Handler里的handleMessage函数,接到这个删除msg之后的操作是:
最后一位false表示非append模式,即从新修改附件。
mWorkingMessage是什么呢?
是短信(包括彩信)的所有的状态所有操作所有数据的现状,主要有几个成员:
mMmsState 彩信状态,是不是彩信,为啥是彩信,是有附件有标题,或者强制彩信等
mAttachmentType 附件类型。如果mSlideshow是多页:slide类型。 单页:图片|声音|录像|文本。 如果mSlideshow是空,就是文本类型。
mSlideshow 附件数据数组。就是那个ArrayList<SlideModel> mSlides。
现在回头看那个删除操作。
setAttachment里面最主要的函数是changeMedia(type, dataUri),这里传入的参数type是TEXT,dataUri是null。
这个函数进去:看到第一个return我们就可以return了。。
多干净利落!直接把彩信原来的附件看都不堪直接一刀删完,类型回归到WorkingMessage.TEXT,把uri置空。
另外,说一些题外的。
这个changeMedia函数,来来回回,都是改的mSlideshow.get(0)那个
在setAttachment的时候,如果是用的append模式,到时候就会用appendMedia而不是changeMedia函数。
对于append模式,
如果最后一页包含了图片image或者录像vedio, 那么append的时候必须加到下一张。
感觉源码里这个判断有点写复杂了。。你看我一句话就能归纳出来的,他代码写半天~
不过我写不出更好的~~
还有SlideModel的add函数。 很多情况叠在一起了,所以有点复杂。
添加的关键函数是下面这个,第一个参数是对应格式的原来媒体(比如你想添加录像,那这个就是原来的录像,可以是null),第二个是添加的新媒体还有个附件太大时的异步缩小功能,是下面这个函数图片被缩放到最大640*480,如果还是大于300*1024-5000字节(差不多295k),那么缩放到295k。
这个大小是源码编写程序员凭感觉写死的。
这里的cb.onResizeResult是调用的ComposeMessageActivity的ResizeImageResultCallback里的函数。
处理大小结束后,会拿新的图片去再次setAttachment,
也就更新了附件
0 0
- android 短信添加附件
- android 彩信附件添加删除
- 添加附件、删除附件
- android gmail 添加附件(转载)
- android添加一条短信记录
- Android短信自动添加功能
- 添加附件
- 添加附件
- 添加附件
- IOS发送短信附件
- Android(SpreadTurm) 信息添加录音附件显示错误
- Android 短信模块分析(六) 接收Wappush信息及彩信附件增加删除
- android 应用组件[通用 Intent---撰写带附件的短信/彩信] 二十一
- 解决:短信添加录音附件,录音,没有录音时间限制,超出彩信最大限制也正常录音
- 动态添加、删除附件
- 添加附件示例
- 添加&移除附件
- js添加附件
- Dropout原理介绍
- 标题和图片的兼容性
- flyway初始化脚本存在默认特殊字符的问题处理
- Python——debug
- 小米push
- android 短信添加附件
- 后台post发送XML
- jquery validation 小结1
- Win10/UWP开发—凭据保险箱PasswordVault
- 本地保存图片的几种思路
- JAVA+Selenium 开发环境搭建
- HDU 1864 —— 最大报销额 01背包
- 杭电ACM5512
- IOS8 AutoLayout和size classes 详解