随着 APP 的使用,越来越多的图文信息出现在了移动网络中,用户对图文信息的查看也提出了更高的要求。而如何更好的将图文信息在用户面前呈现也成为了困扰很多 APP 的难题。
同时,仅仅图文信息的展示并不足以留住挑剔的用户,我们还需要提供炫酷的交互体验、分享、评论、点赞等功能。
photoBrowserWeiBo 插件封装了新浪微博客户端内相册浏览器功能,是由原生代码开发,为开发者封装了图文信息的最新主流展示界面,开发者只需要简单设置图片、颜色等即可让 APP 拥有完整的、高体验的图文信息展示界面,大大降低开发难度,节约开发成本,提高用户体验。
对于网络图片的展示,插件内部会做缓存处理,第一次加载网络图片时,插件会根据其路径生成一个 md5 加密的图片名,并缓存在缓存文件夹里。当用户下次打开同路径的图片时,插件直接从缓存文件内读取该图片,从而大大节省了用户流量。开发者可以通过调用 clearCache 接口清楚本插件在本地缓存的图片资源,调用 api.clearCache 接口会清除本 APP 在本地缓存的所有文件。由于原生代码相对前端代码的高效性,本插件相对于前端实现的图片切换更加流畅,内存管理更加优化。当展示多张图片时,其内存中只会保留最多三张图片,然后来回切换图片内容,从而降低了整个 app 内存占用率。
示例图片如下:
打开图文信息插件
open(callback(ret))
ret:
{
eventType: 'show', //字符串类型;交互事件类型,
//取值范围:
//show(插件打开成功)
//appendData(插件数据追加完成)
//save(保存按钮被点击时触发)
//comment(评论按钮被点击时触发)
//like(点赞按钮被点击时触发)
//text(文本区域被点击时触发)
//lastImage(显示最后一张图片的事件,此时可使用 appendData 接口追加数据,供用户继续浏览)
id:'1', //字符串类型;appndData 接口标识
status:true, //布尔类型:表示按钮的选中状态,只有点赞按钮触发事件时有该字段
savePath: '' //图片保存到相册的路径,当 eventType 为 save 时有效
index:0 //数字类型:表示当前预览图片的index,只有 save 事件返回该字段
}
var photoBS_wb = api.require('photoBrowserWeiBo');
photoBS_wb.open(function(ret) {
if (ret) {
api.alert({msg: JSON.stringify(ret)});
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
设置插件数据
appendData({params})
id:
images:
[
'http://www.x.com/image1.png', //字符串类型;图片路径,支持 widget://,fs://,以及网络路径 http://,https://
]
text:
comments:
like:
likes:
var photoBS_wb = api.require('photoBrowserWeiBo');
photoBS_wb.open(function(ret, err) {
if (ret.eventType == 'show') {
photoBS_wb.appendData({
id: '1',
images: [
'http://www.x.com/image1.png',
'http://www.x.com/image2.png',
'http://www.x.com/image3.png',
'http://www.x.com/image4.png'
],
text: '描述 1',
comments: 520,
like: false,
likes: 10
});
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
清除缓存到本地的网络图片,本接口只清除本插件缓存的数据,若要清除本 app 缓存的所有数据则调用 api.clearCache
clearCache()
var photoBS_wb = api.require('photoBrowserWeiBo');
photoBS_wb.clearCache();
iOS系统,Android系统
可提供的1.0.0及更高版本