Mms 杂项与彩信附件加载

  Android4.2

MmsApp继承Application,在onCreate方法中初始化了一系列对象。

Conversation.init(this):

Uri =  Threads.CONTENT_URI.buildUpon().appendQueryParameter("simple", "true").build();

查询“threads”表中的所有项,生成Conversation对象存到内部类Cache的HashSet<Conversation>中,HashSet大小限制为10条。


Contact.init(this):

初始化ContactsCache对象。

调用Contact.init(this):

Uri = Uri.parse("content://mms-sms/canonical-addresses");

查询canonical_addresses表,把结果存到Map<Long, String>中,键为id。


1.短彩信的Application是MmsApp,在onCreate中 Contact.init(this);,而在Contact的init方法中又调用了RecipientIdCache.init(context);,并初始化了ContactsCache。在RecipientIdCache的init方法中构建单例RecipientIdCache对象,并启用线程调用fill方法,fill方法中查询mms-sms数据库的“canonical_addresses”表,并把查到的结果以id为键,number为值存到RecipientIdCache的hashmap中。

从Conversation中的fillFromCursor--->ContactList.getByIds ---- >RecipientIdCache.getAddresses可以看出:"canonical_addresses"表的id存到了“threads”表的recipient_ids字段中,多个id以空格隔开。



1、图片与视频附件的缩略图加载
当选择附件后,AttachmentEditor的update方法被调用,此方法构造Presenter的子类MmsThumbnailPresenter,在mPresenter.present(null);方法里开始加载。
present方法里判断附件类型,做不同处理(set),视频与图库会调用到ThumbnailManager的getThumbnail方法,此方法中获取图片后调用传过来的接口callback.onItemLoaded(imageLoaded, null);
在MmsThumbnailPresenter里面定义了这个接口的处理。

2.ThreadId的创建

在MsmSmsProvider里面查询"content://mms-sms/threadID"判断是否有

 List<String> recipients = uri.getQueryParameters("recipient");

联系人的信息,有就查询threadId,没有就把联系人信息等插入threads表,接着查询返回。

3.WorkingMessage的saveAsMms方法把当前信息存为彩信,在PduPersister的persist方法中,如果联系人栏为空,则把threadid存为0.

            long threadId = 0;
            if (createThreadId && !recipients.isEmpty()) {
                // Given all the recipients associated with this message, find (or create) the
                // correct thread.
                threadId = Threads.getOrCreateThreadId(mContext, recipients);
            }
            values.put(Mms.THREAD_ID, threadId);

但是discard方法中删除的条件却是

String where = Mms.THREAD_ID +  (threadId > 0 ? " = " + threadId : " IS NULL");

这就导致了可能出现threadId == 0的数据。最佳的方法为改PduPersister的persist方法。

4.彩信草稿附件的加载

按着流程走会调用到loadMessagesAndDraft方法,此方法会调用loadDraft()方法,接着调用WorkingMessage.loadDraft,需要参数mConversation。

        mWorkingMessage = WorkingMessage.loadDraft(this, mConversation,
                new Runnable() {
                    @Override
                    public void run() {
                        drawTopPanel(false);
                        drawBottomPanel();
                        updateSendButtonState();
                    }
                });

接着读取Sms的信息msg.readDraftSmsMessage(conv),如果是彩信,则读不到返回null,接着判断是否为空字符,如果是空字符,

Uri uri = readDraftMmsMessage(msg.mActivity, conv, sb);
获取uri,利用uri获取附件与文本的信息
msg.loadFromUri(uri)
彩信内容信息存储在SlideshowModel的mSlideshow对象中,利用uri构建对象
mSlideshow = SlideshowModel.createFromMessageUri(mActivity, uri);
接着syncTextFromSlideshow()同步显示的文本,
    private void syncTextFromSlideshow() {
        // Don't sync text for real slideshows.
        if (mSlideshow.size() != 1) {
            return;
        }

        SlideModel slide = mSlideshow.get(0);
        if (slide == null || !slide.hasText()) {
            return;
        }

        mText = slide.getText().getText();
    }
方法drawTopPanel(boolean showSubjectEditor)会在WorkMessage中的方法执行完后被调用,
        boolean showingAttachment = mAttachmentEditor.update(mWorkingMessage);
用于显示附件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值