小程序mpvue图片绘制水印_开发笔记:使用 mpvue 开发斗图小程序

之前用过 wepy 框架写了个小程序 GitHub - yshkk/shanbay-mina: 基于 wepy 框架的 “扇贝阅读” 微信小程序 ,感觉写法上类似 vue,但不那么彻底。现在美团点评发布的 mpvue 支持开发者可以用 vue 的语法开发微信小程序,正好有强需求需要一个斗图小程序,所以就尝试了下。

扫码体验

截图

开发细节和坑

使用 iView Weapp 组件库

相关代码 pages/index/main.js 第 8 行

将组件库的 dist 目录拷贝到自己项目 static 目录,然后在需要用到组件的页面配置 usingComponents 即可。开发期间可能对组件的样式不太满意,或者一些蜜汁问题(比如 input 下边框突然消失 issue ),要改的话方式非常诡异 相关 issue ,所以粗暴点的方式就是直接改组件库里的 wxss 文件。

v-show 和 v-model 不好使

相关代码 pages/index/index.vue 第 4 行

关于 v-show 相关 issue ,所以只能用 v-if 替代。使用 v-if 会销毁不显示的组件,但有个场景是期望保留原来的组件,因此只能曲线救国在组件外层包一个 < view > 使用 :style="{display?condition?'block':'none'}" 的方式(其实最好是用 keep-alive 的方法,可惜 mpvue 不支持)。

v-model 就很奇怪了,好像 input 不能双向绑定,原因是自定义组件就没有支持 v-model ,所以得手动 update data。同理使用组件库 input 后不能使用 v-focus 。(相关 issue )

模板语法里不能调用 methods 方法

相关代码 components/homppage.vue 第 52 行

可以说是血坑了,一直以为我使用姿势有误,费了好长时间。后来才从 articles / 美团小程序框架 mpvue 蹲坑指南. md at master · noahlam/articles · GitHub 看到原来这是 mpvue 不支持。 当时的场景是这样的: 在图片列表里,给被用户 “收藏” 过的图片加个额外的 className,该 className 可以给图片加个粉色边框,这样就能在图片列表中一眼看到哪些是被收藏过的。data 里有一个表示所有图片的数组 imageList 和一个表示收藏列表的数组 favoriteList 。起初的写法是

复制代码

其中 isFavorite 是在 methods 里的一个方法,判断当前图片 url 是否在 favoriteList 里。然而这样写一直不 work,后来只能换个方案:在 computed 里跟据 imageList 和 favoriteList计算出 一个叫 imageListWithFavorite 的数组,遍历这个数据即可:joy: 虽然很丑陋但是还能用。

将用户收藏同步到本地存储

相关代码 components/homppage.vue 第 63 行

用户收藏的表情会放到微信提供的 storage,类似浏览器的 localstorage,这样在关闭小程序以后下次来还能看到自己的收藏,因此在组件需要 watch favoriteList 的变更并调用 wx.setStorage 方法。但是不知为何直接 watch favoriteList 并不会触发相应函数,而 watch ‘favoriteList.length’就能触发,希望有大佬能指点下。

watch: {

'favoriteList.length': {

// 将变化更新到本地存储

handler: function (val, oldval) {

this.updateStorage({method: val > oldval ? 'ADD' : 'DELETE'})

}

}

}

复制代码

表情包图片制作

相关代码 pages/maker/index.vue

思路是初始化一个 canvas,将表情模版(一张图片,url 从跳转过来的页面的 query 里取得)绘制到 canvas 上,用户打字 / 设置颜色字体 的时候调用 updateCanvas 。最后调用 wx.canvasToTempFilePath 方法输出成图片。 关键代码如下

ctx = wx.createCanvasContext('maker') // 选择当前 canvas

...

updateCanvas () {

ctx.drawImage(this.path, 0, 0, 300, 300) //path 为当前表情包的路径

ctx.setTextAlign('center') // 必须每次在 updateCanvas 重新设置,否则模拟器上生效但真机下不会生效

ctx.setFontSize(this.fontSize)

ctx.setFillStyle(this.currentColor)

ctx.fillText(this.txt, this.x, this.y)

ctx.draw()

},

复制代码

有几个小坑:

将图片绘制到 canvas 时指定的图片不能是一个远端图床的链接,必须先本地下载下来(调用 wx.getImageInfo 获取图片,得到本地一个临时 path)才能绘制。

canvas 指定的大小单位是 px,而用 css 控制的单位是 rpx(mpvue 用了 px2rpx-loader ,就算在 css 里写成 px 也会被编译成 rpx)。

小程序 canvas 的 save 和 restore 功能在这里很鸡肋,每次都需要完全重绘一次。特别是用户拖动文字更新文字坐标的功能, touchmove 事件一直触发,就一直更新 canvas,小程序里没有 requestAnimationFrame 的方法,所以就自己得~~ 从网上找~~ 封装一个,在拖动时起到节流的效果。

canvas 输出的图片只支持 jpg 或者 png,因此即使用 gif 图的模版也只能生成静态的表情包,残念。

总结

大体上使用 mpvue 的体验还是挺好的。mpvue 和 wepy 的写法上比较类似,mpvue 对 vue 开发者来说更友好容易上手,wepy 更接近于原生小程序。虽然框架的出现屏蔽了一些原生小程序写起来很丑陋的地方, 但是不管用什么框架,原生小程序的文档还是需要掌握的 ,有一大堆的坑等着要踩,有时候不得不从编译出的文件里面找原因。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/457495.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql int类型的长度值

整数类型的存储和范围(来自mysql手册) 类型字节最小值最大值(带符号的/无符号的)(带符号的/无符号的)TINYINT1-1281270255SMALLINT2-3276832767065535MEDIUMINT3-83886088388607016777215INT4-2147483648214748364704294967295BIGINT8-92233720368547758089223372036854775807…

龙王我当定了(一个在QQ刷龙王的脚本)

自从学了python&#xff0c;龙王再也没丢过&#xff0c;就是经常被打, QQ 和 TIM 都可以&#xff0c;发送时要把聊天窗口打开。 # 如果import报错&#xff0c;那可以pip下载这几个模块试一试 import win32gui import win32con import win32clipboard as w import random from…

时序数据合并场景加速分析和实现 - 复合索引,窗口分组查询加速,变态递归加速...

时序数据合并场景加速分析和实现 - 复合索引&#xff0c;窗口分组查询加速&#xff0c;变态递归加速 作者 digoal 日期 2016-11-28 标签 PostgreSQL , 数据合并 , 时序数据 , 复合索引 , 窗口查询 背景 在很多场景中&#xff0c;都会有数据合并的需求。 例如记录了表的变更明细…

navicat for mysql 数据库备份与还原

一, 首先设置, 备份保存路径 工具 -> 选项 点开 其他 -> 日志文件保存路径 二. 开始备份 备份分两种, 一种是以sql保存, 一种是保存为备份 SQL保存 右键点击你要备份的数据库, -> 转储SQL文件 选择位置和文件名 开始转储 导入 建议 删除所有表 或 重新建数据库 同导出…

DES的原理及python实现

DES加密算法原理及实现 DES是一种对称加密算法【即发送者与接收者持有相同的密钥】&#xff0c;它的基本原理是将要加密的数据划分为n个64位的块&#xff0c;然后使用一个56位的密钥逐个加密每一个64位的块&#xff0c;得到n个64位的密文块&#xff0c;最后将密文块拼接起来得…

python按身高体重排队_LeetCode-python 406.根据身高重建队列

题目链接难度&#xff1a;中等 类型&#xff1a; 数组假设有打乱顺序的一群人站成一个队列。 每个人由一个整数对(h, k)表示&#xff0c;其中h是这个人的身高&#xff0c;k是排在这个人前面且身高大于或等于h的人数。 编写一个算法来重建这个队列。注意&#xff1a;总人数…

远程连接mysql数据库,1130问题

远程或使用非127.0.0.1和localhost地址连接时&#xff0c;出现代号为1130问题&#xff0c; ERROR 1130: Host 192.168.2.159 is not allowed to connect to this MySQL server 猜想这是没有授权&#xff0c;将mysql数据库中user表中host列的localhost改为%&#xff0c;重新启动…

华为手机充满有提醒吗_2020手机充电速度排名:最快21分钟充满,华为第15名

5G手机扎堆出现&#xff0c;中国5G基站数量也是不断增多&#xff0c;中国移动曾经表态&#xff0c;2020年底将会在全国地级市覆盖5G网络&#xff0c;全民5G时代终于到来&#xff01;从目前国内手机出货量数据来看&#xff0c;5G手机占比已经达到了六成以上&#xff0c;国产5G手…

关于移动手机端富文本编辑器qeditor图片上传改造

日前项目需要在移动端增加富文本编辑&#xff0c;上网找了下&#xff0c;大多数都是针对pc版的&#xff0c;不太兼容手机&#xff0c;当然由于手机屏幕小等原因也限制富文本编辑器的众多强大功能&#xff0c;所以要找的编辑器功能必须是精简的。 找了好久&#xff0c;发现qedit…

【python】生成器

生成器 直接总结 创建生成器的方法 生成器表达式&#xff1a;(i for i in [1, 2])yield: 函数中出现yield这个函数就是生成器&#xff0c;函数&#xff08;生成器&#xff09;执行到yield时会返回yield后面的值&#xff0c;并暂停&#xff0c;知道下次被唤醒后会从暂停处接着…

python redis 性能测试台_Redis性能测试

Redis 性能测试Redis 性能测试是通过同时执行多个命令实现的。Redis性能测试主要是通过src文件夹下的redis-benchmark来实现(Linux系统下)语法redis 性能测试的基本命令如下&#xff1a;redis-benchmark [option] [option value]实例以下实例同时执行 10000 个请求来检测性能&a…

Java IO 系统

Java IO系统 File类 用来处理文件目录&#xff0c;既可以代表一个特定文件的名称&#xff0c;也可以代表一组文件的名称&#xff0c;如果代表的是一个文件组&#xff0c;可以调用File.list()方法返回一个字符数组。 list()不传递任何参数时返回该目录下所有文件或文件名的字…

Linux Crontab 任务管理工具命令以及示例

Crontab 是 Linux 平台下的一款用于循环执行例行任务的工具,Linux 系统由 cron (crond) 这个系统服务来控制任务 , Linux系统本来就有很多的计划任务需要启动 , 所以这个系统服务是默认开机启动的 。 Linux 为使用者提供的计划任务的命令就是 Crontab Crontab 是 Linux 下用来周…

Linux 网络编程详解一(IP套接字结构体、网络字节序,地址转换函数)

IPv4套接字地址结构 struct sockaddr_in {uint8_t sinlen;&#xff08;4个字节&#xff09;sa_family_t sin_family;&#xff08;4个字节&#xff09;in_port_t sin_port;&#xff08;2个字节&#xff09;struct in_addr sin_addr;&#xff08;4个字节&#xff09;char sin_zer…

地籍cad的lisp程序大集合_AutoCAD-LISP程序100例

{:soso_e179:}AutoCAD-LISP程序100例.JPG (143.82 KB, 下载次数: 28)2011-10-18 14:42 上传有说明很好&#xff01;顶如果您使用 AutoCAD,下面的内容对您一定有帮助。在某些方面能大大提高您的工作效率。下面的程序均以源程序方式给出&#xff0c;您可以使用、参考、修改它。bg…

javascript中数组的22种方法

前面的话数组总共有22种方法&#xff0c;本文将其分为对象继承方法、数组转换方法、栈和队列方法、数组排序方法、数组拼接方法、创建子数组方法、数组删改方法、数组位置方法、数组归并方法和数组迭代方法共10类来进行详细介绍对象继承方法数组是一种特殊的对象&#xff0c;继…

javascript/jquery高度宽度详情解说分析

为什么80%的码农都做不了架构师&#xff1f;>>> 一、window对象表示浏览器中打开的窗口 二、window对象可以省略 一、document对象是window对象的一部分 二、浏览器的HTML文档成为Document对象 window.location和document.location window对象的location属性引用的…

农用地包括哪些地类_土地地类一览表

一级类二级类三级类含义编号三大类名称编号名称编号名称1农用地指直接用于农业生产的土地&#xff0c;包括耕地&#xff0c;园地&#xff0c;林地&#xff0c;牧草地及其他的农业用地11耕地指种植农作物、土地&#xff0c;包括熟地、新开发复垦整理地&#xff0c;休闲地、轮歇地…

红黑树插入时的自平衡

红黑树插入时的自平衡 红黑树实质上是一棵自平衡的二叉查找树&#xff0c;引入带颜色的节点也是为了方便在进行插入或删除操作时&#xff0c;如果破坏了二叉查找树的平衡性能通过一系列变换保持平衡。 红黑树的性质 每个节点要么是红色&#xff0c;要么是黑色根节点必须是黑…

说一下自己对于 Linux 哲学的理解

查阅了一些资料&#xff0c;官方的哲学思想貌似是&#xff1a; 一切皆文件由众多单一目的的小程序&#xff0c;一个程序只实现一个功能&#xff0c;多个程序组合完成复杂任务文本文件保存配置信息尽量避免与用户交互什么&#xff0c;你问我的理解&#xff1f;哲学思想&#xff…