前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微信小程序开发实战(24):选择图像

微信小程序开发实战(24):选择图像

作者头像
蒙娜丽宁
发布2020-08-28 10:46:24
6860
发布2020-08-28 10:46:24
举报
文章被收录于专栏:极客起源极客起源

wx:chooseImage方法用于从相册选择若干图像文件(1到n),或从相机拍摄图像,并返回被选中图像的临时路径,以便以后处理。

wx:chooseImage方法有一个Object类型的参数,该参数值的属性用于指定与图像相关的各种信息,下面是这些属性的描述。

  • count:Number类型,可选属性,表示最多可以选择的图片张数,默认是9。
  • sizeType:StringArray类型,可选属性,表示图像尺寸类型,可设置的值是original和compressed。前者表示原图,后者表示压缩图。默认二者都有,也就是允许用户选择是打开原图还是压缩图
  • sourceType:StringArray类型,可选属性,表示图像来源,可设置的值是album和camera,前者表示从相册选图,后者表示用相机拍摄,默认二者都有,也就是允许用户选择图像来源
  • success:Function类型,必须属性,成功则返回图片的本地文件路径列表 tempFilePaths
  • fail:Function类型,可选属性,接口调用失败的回调函数
  • complete:Function类型,可选属性,接口调用结束的回调函数(调用成功、失败都会执行)

下面的例子给出了一个简单的演示,该程序通过点击按钮,执行wx:chooseImage方法来选取图像,然后,将选取的图像显示在<image>组件中。

index.wxml

代码语言:javascript
复制
<view style="margin:20px">
<button bindtap="onClick">选择图像</button>
<image src="{{imageSrc}}" mode="aspectFit" style="margin-top:10px;width: 300px; height: 300px; background-color: #eeeeee;" />
</view>

index.js

代码语言:javascript
复制
var app = getApp()
Page({
data: {
imageSrc: ''   //  该变量与<image>组件绑定
  },
//选择图像
  onClick: function () {
var that = this;
    wx.chooseImage({
count: 1, // 最多只允许选择一个图像
      sizeType: ['original', 'compressed'],
sourceType: ['album', 'camera'],
success: function (res) {

        that.setData(
          {
imageSrc: res.tempFilePaths[0]    //  显示选中的第一个图像
          }
        )
//  输出返回的路径个数
console.log(res.tempFilePaths.length)
      }
    })
  }
})

由于小程序模拟器和真机的差异,在模拟器和真机上测试wx:chooseImage方法的效果是不一样的。例如,在模拟器上,不管sourceType属性的值是什么,都只会显示一个图像选择对话框,允许从本地选取一个或若干图像文件。而在真机上进行测试,根据sourceType属性值的不同,会允许用户有不同的选择。

我们现在模拟器上测试,点击“选择图像”按钮,会弹出一个如图1所示的图像选择对话框(这是Mac OS X的对话框,Windows风格对话框请在Windows下测试)。不管count属性的值是多少,该对话框都允许同时选择多个图像文件。不过,wx:chooseImage方法会根据count属性的值,选择前count个图像文件。例如,count属性值为1,不管选择了多少图像文件,wx:chooseImage方法都只会选取第一个图像文件,其他的图像文件被忽略。

图1  图像选择对话框
图1 图像选择对话框

本例中,sourceType属性的值为['album', 'camera'],也就是允许用户决定从相册选择图像,还是从相机拍摄图像。不过小程序模拟器目前不支持相机,所以在模拟器中只会显示图像选择对话框。不过在真机上就不一样了。在iPhone上测试,在屏幕的下方会出现如图2的图像源选择菜单。

图2  iPhone中图像源选择菜单
图2 iPhone中图像源选择菜单

在Android手机上测试,会看到如图3所示的图像源选择窗口,第一项是“拍摄照片”,其他的是相册中的图像。

图3  Android中的图像源选择窗口
图3 Android中的图像源选择窗口

如果sizeType属性的值是['original', 'compressed'],在从相册中选择图像后,点击屏幕下方的“预览”,会允许用户选择是否从原图打开。iPhone的效果如图4所示,Android的效果如图4所示。

图4  iPhone中选择原图的窗口
图4 iPhone中选择原图的窗口

图5  Android中选择原图的窗口
图5 Android中选择原图的窗口

如果不选择原图,系统会对原图进行压缩(图像尺寸缩小处理),以减少对资源的消耗。当sizeType属性的值是['original']或['compressed']时,在“预览”窗口就不会出现“原图”的选项,直接采用压缩或原图的方式处理图像文件。

选择图像后,会在<image>组件中显示已经选择的图像,效果如图6所示。

图6  在<image>组件中显示图像
图6 在<image>组件中显示图像
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-08-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 极客起源 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档