小程序 — 保存图片到手机相册①

简介: 讲一下在微信小程序中,怎么把网络图片保存到本机相册中;这个功能其实在小程序开发中还是很常见的,比如保存海报之类的等等。GitHub:https://github.com/Ewall1106/miniProgramDemo1、保存图片(1)要保存图片到手机相册中,所以首先我们来看看保存图片的api方法是什么?我们使用的是wx.saveImageToPhotosAlbum(OBJECT)这个api方法,其中OBJECT的参数可以是:图片来源自小程序官网请注意我红框标记的部分, 不支持网络图片路径。

讲一下在微信小程序中,怎么把网络图片保存到本机相册中;这个功能其实在小程序开发中还是很常见的,比如保存海报之类的等等。
GitHub:https://github.com/Ewall1106/miniProgramDemo

1、保存图片

(1)要保存图片到手机相册中,所以首先我们来看看保存图片的api方法是什么?
我们使用的是wx.saveImageToPhotosAlbum(OBJECT)这个api方法,其中OBJECT的参数可以是:

img_65eb8c142bde3cc63fe83e88fc9cc499.png
图片来源自小程序官网

请注意我红框标记的部分, 不支持网络图片路径

(2)于是我们照猫画虎简单的写一下

img_437aca55dfbaffb46a15d56e8016842d.png
简单使用wx.saveImageToPhotosAlbum(OBJECT)

2、下载图片到本地

前面已经重点提到,由于wx.saveImageToPhotosAlbum(OBJECT)这个方法不支持网络图片,但是一般我们在项目中要下载的图片都是后端提供的,所以我们要把图片下载到本地。

(1)wx.downloadFile(OBJECT) 基本语法

  • OBJECT参数说明:

    img_25767bf03dea4517119fabbc196b63e2.png
    图片来源自小程序官网

  • success返回函数:

    img_ca71ae17c0bc895c0418be178559e47d.png
    图片来源自小程序官网

(2)代码示例基本用法
使用方法很简单,copy一下官网的示例代码就就ok了:

img_15252369ce968aedf6fb06a740bad4e8.png
wx.downloadFile(OBJECT)基本案例代码

3、实现保存图片到手机相册功能

于是,把下载图片后成功返回的tempFilePath临时路径赋给wx.saveImageToPhotosAlbum(OBJECT)filePath,就可以实现保存网络图片到本地了。

img_6b3796e7b2cad44a85d0715110757954.png
实现保存图片到手机相册功能代码
img_d3885442079626d27d8bf0643c290c72.png
保存成功

4、案例代码

添加操作提示弹窗,全部的案例代码:

saveImage() {
  wepy.showLoading({
    title: '保存中...', 
    mask: true,
  });
  wx.downloadFile({
    url:
'http://upload.jianshu.io/admin_banners/web_images/4435/c1d3ca63353c8bd527f0d781605516cb5b266d02.jpg?imageMogr2/auto-orient/strip|imageView2/1/w/1250/h/540',
    success: function(res) {
      if (res.statusCode === 200) {
        let img = res.tempFilePath;
        wx.saveImageToPhotosAlbum({
          filePath: img,
          success(res) {
            wepy.showToast({
              title: '保存成功',
              icon: 'success',
              duration: 2000
            });
          },
          fail(res) {
            wepy.showToast({
              title: '保存失败',
              icon: 'success',
              duration: 2000
            });
          }
        });
      }
    }
  });
}

5、问题及优化

其实到上面部分就可以基本实现保存图片到手机相册的功能了,但是还有这么几个问题:

  • 如果用户第一次点击的时候,对弹出来的微信授权弹窗点击了拒绝,那么之后点击保存图片就没用了。

    img_4e0d1040e64d1475e9d025df76741fd8.gif
    如果用户第一次点击了拒绝授权

  • 手机打开调试模式可以保存图片,但是关闭调试模式就不能保存图片了。

下一章节解决这几个问题。

参考学习
https://developers.weixin.qq.com/miniprogram/dev/api/network-file.html#wxdownloadfileobject
https://developers.weixin.qq.com/miniprogram/dev/api/media-picture.html#wxsaveimagetophotosalbumobject

目录
相关文章
|
27天前
Discuz! X3.5插件云诺-阿里云短信手机登录 会员登录后也无法查看附件图片的问题解决方法
Discuz! X3.5插件云诺-阿里云短信手机登录 会员登录后也无法查看附件图片的问题解决方法
36 2
|
1月前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
19 1
|
1月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
526 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
2月前
|
小程序
小程序消除图片下边距的三个方法
小程序消除图片下边距的三个方法
48 11
|
1月前
|
小程序
如何将CCBUPT全能墙小程序添加到手机桌面
如何将CCBUPT全能墙小程序添加到手机桌面
30 0
|
3月前
|
存储 小程序 数据可视化
小程序开发问题之使用小程序云服务开发个人相册小程序如何解决
小程序开发问题之使用小程序云服务开发个人相册小程序如何解决
|
3月前
|
小程序 前端开发
|
3月前
|
运维 小程序 前端开发
小程序开发问题之在小程序中调用my.chooseImage接口让用户选择图片如何解决
小程序开发问题之在小程序中调用my.chooseImage接口让用户选择图片如何解决
|
3月前
|
存储 小程序 JavaScript
|
5月前
|
网络协议 Android开发 数据安全/隐私保护
Android手机上使用Socks5全局代理-教程+软件
Android手机上使用Socks5全局代理-教程+软件
4626 2

热门文章

最新文章