微信小程序实现点击保存图片

微信小程序实现点击保存图片

wxml代码

<view class='title'>点击图片保存图片</view>
<image class='img' data-src="http://img2.imgtn.bdimg.com/it/u=3507713655,931555131&fm=26&gp=0.jpg" bindtap="downLoadImage" src='http://img2.imgtn.bdimg.com/it/u=3507713655,931555131&fm=26&gp=0.jpg'></image>

  <i-message id="message" />

js代码

//index.js
//获取应用实例
const app = getApp()
const { $Message } = require('../../components/iview-weapp/base/index');
Page({
  data: {
    
  },

  onLoad: function () {
  
  },
  //点击事件
  downLoadImage(e){
    this.downloadFileImages(e.target.dataset.src);
  },
  //是否授权
  downloadFileImages(images) {
    let t = this;
    wx.getSetting({
      success(res) {
        if (res.authSetting['scope.writePhotosAlbum'] == true) {
            t.retrundownloadFileImage(images);
        } else {
          if (res.authSetting['scope.writePhotosAlbum'] == false) {
            $Message({
              content: '您拒绝访问相册,请在小程序授权页面重新授权。',
            });
            return;
          }
          wx.authorize({
            scope: 'scope.writePhotosAlbum',
            success() {
                t.retrundownloadFileImage(images);
            }
          })
        }
      }
    })
  },
  //保存图片
  retrundownloadFileImage(images) {
      wx.downloadFile({
        url: images,
        header: {},
        success: function (res) {
          wx.saveImageToPhotosAlbum({
            filePath: res.tempFilePath,
            success: function (res) {
              $Message({
                content: '保存成功,请前往相册查看。',
              });
            }.bind(this),
            fail: function (res) {
              $Message({
                content: '保存失败。',
              });
            }.bind(this),
            complete: function (res) { console.log(321);},
          })
        }.bind(this),
        fail: function (res) { },
        complete: function (res) {
          console.log(123);
        }.bind(this),
      });
  },
})

微信小程序实现保存图片功能的基本步骤如下: 1. 在小程序的页面中,首先需要引入 `wx.canvas` 用于绘制和保存图片。 2. 在页面中创建一个 `<canvas>` 标签,设置宽高和唯一的 `canvas-id`。 3. 在 `<canvas>` 中使用 `wx.createContext` 创建绘图上下文对象。 4. 使用绘图上下文对象的 `drawImage` 方法将图片绘制到 `<canvas>` 中。 5. 创建一个按钮或其他触发保存操作的交互元素,并在点击事件中编写保存图片的逻辑。 6. 在点击事件中,使用 `wx.canvasToTempFilePath` 方法将 `<canvas>` 中的内容保存为临时文件路径。 7. 使用 `wx.saveImageToPhotosAlbum` 方法将临时文件保存到用户相册中。 下面是一个实现保存图片功能的示例代码: ```javascript // 在页面中的 js 文件中 Page({ saveImage: function() { const ctx = wx.createCanvasContext('myCanvas', this); // 绘制图片到 canvas ctx.drawImage('/path/to/image.jpg', 0, 0, 300, 200); // 绘制完成后调用 draw 方法 ctx.draw(false, () => { // 将 canvas 中的内容保存为临时文件 wx.canvasToTempFilePath({ canvasId: 'myCanvas', success: (res) => { // 保存临时文件到用户相册 wx.saveImageToPhotosAlbum({ filePath: res.tempFilePath, success: (res) => { wx.showToast({ title: '保存成功', icon: 'success', duration: 2000 }); }, fail: (err) => { console.error(err); } }); }, fail: (err) => { console.error(err); } }, this); }); } }); ``` 在上述代码中,点击 `saveImage` 按钮会执行保存图片的逻辑,将图片绘制到 `<canvas>` 中,然后将 `<canvas>` 中的内容保存为临时文件,并最终保存到用户的相册中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值