小程序踩坑记录-上传图片及canvas裁剪图片后上传至服务器
2024-08-28 19:46:51
最近在写微信小程序的上传图片功能,趟过了一些坑记录一下。
想要满足的需求是,从手机端上传图片至服务器,为了避免图片过大影响传输效率,需要把图片裁剪至适当大小后再传输
主要思路是,通过wx.chooseImage()函数获得图片的文件路径,在canvas画板获得文件路径后,重新绘制成制定大小的图片。再通过canvasToTempFilePath(),生成新的文件路径。最后通过wx.uploadFile()上传到指定服务器
遇到的坑有三个
一,在canvas中绘制的单位都是px,但由于不同屏幕的像素比不同,在小程序中样式我们使用的单位是rpx,所以在canvas中就需要把rpx换成对应的px;由于rpx可以根据屏幕宽度进行自适应,规定屏幕宽为750rpx,所以rpx换算成px的公式是:
1rpx = 屏幕宽度 / 750
这一点在小程序的官方文档也有讲到:
屏幕宽度可以使用wx.getSystemInfoSync();获取;[][1]
所以例如在样式中你的canvas宽度650rpx,那么在canvas中绘制使用的宽度就是:(屏幕宽度 / 750)* 650 ;
最新文章
- selenium-webdriver(python) (十六) --unittest 框架
- cantor三分集
- windows下搭建学习objective-c 的运行环境【转载】
- shell随机写入指定文件
- NGUI自适应分辨率,黑边自动填充, 无黑边,等比例缩放
- 分页 page
- QQ宠物吹泡泡游戏小助手 VC++6.0代码分析
- Ajax实现动态的二级级联菜单
- ajax联动
- [CSS3]学习笔记-文字与字体相关样式
- C#基础加强(7)之ref与out
- [PA2014]Iloczyn
- Remove Element leetcode java
- [部署]VM11下CentOS7mini安装及配置
- Android:客户端和服务器之间传输数据加密
- 《软件定义网络:SDN与OpenFlow解析》
- 计蒜客 31451 - Ka Chang - [DFS序+树状数组][2018ICPC沈阳网络预赛J题]
- HashMap 的工作原理及代码实现,什么时候用到红黑树
- 【BZOJ-1194】潘多拉的盒子 拓扑排序 + DP
- Windows Azure Mobiles Services实现client的登录注冊