下载与展示媒体消息
SDK 提供多媒体文件的下载功能,支持通过媒体消息中的地址下载文件。
下载媒体消息中的媒体文件
如果消息 Message 对象中包含媒体消息内容(指 Message.content 为 MediaMessageContent 子类(如 FileMessage,ImageMessage, HQVoiceMessage 等),其中携带了媒体文件地址),可以使用 downloadMediaMessage 下载媒体文件。
提示
- 首次下载媒体消息,SDK 会将媒体数据保存到
localPath中返回。同一个媒体消息多次调用下载接口,SDK 只会下载一次。 - 1.3.0 废弃
downloadMediaMessage方法,使用downloadMediaMessageWithProgress替代。
示例代码
TypeScript
let messageId = 234;
IMEngine.getInstance().downloadMediaMessage(messageId).then(result => {
if (EngineError.Success === result.code) {
// 本地路径
let localPath = result.data as string;
}
});
下载媒体消息中的媒体文件(带下载进度)
1.3.0 支持该功能,包含下载进度。
提示
- 首次下载媒体消息,SDK 会将媒体数据保存到
localPath中返回。同一个媒体消息多次调用下载接口,SDK 只会下载一次。 - SDK 下载媒体过程中,调用了
cancelDownloadMediaMessage(),该方法会返回EngineError.RequestCanceled。
接口原型
TypeScript
public downloadMediaMessageWithProgress(messageId: number, progressListener: (messageId: number, progress: number) => void): Promise<IAsyncResult<string>>;
参数说明
| 参数名 | 类型 | 详细说明 |
|---|---|---|
| messageId | number | 要下载的媒体消息 ID(必须为有效的媒体消息) |
| progressListener | (messageId: number, progress: number) => void | 下载进度回调函数 |
示例代码
TypeScript
let messageId = 123;
IMEngine.getInstance().downloadMediaMessageWithProgress(messageId, (messageId: number, progress: number) => {
// 下载进度,取值范围 [0 , 100]
}).then(result => {
if (EngineError.Success === result.code) {
// 本地路径
let localPath = result.data as string;
}
});
使用自定义方法下载媒体消息
您可在下载媒体消息时使用 downloadMediaMessageWithDownloader 方法,自行管理媒体消息的如视频、图片资源文件。
提示
IMLib SDK 从 1.4.3 版本开始支持该功能。
示例代码
TypeScript
let messageId = 234;
IMEngine.getInstance().downloadMediaMessageWithDownloader(
messageId,
(messageId: number, progress: number) => {
// 下载进度,取值范围 [0 , 100]
},
(downloader: MediaMessageTransfer) => {
downloadImg(imgMsg.getPicFilePath(), new downloadListener() {
public onSuccess(localPath: string): void {
downloader.success(localPath);
}
}
}
).then(result => {
if (EngineError.Success === result.code) {
// 本地路径
let localPath = result.data as string;
}
});