小程序简单绘图,通过 json 方式绘制一张朋友圈分享图

网友投稿 590 2022-10-13

小程序简单绘图,通过 json 方式绘制一张朋友圈分享图

小程序简单绘图,通过 json 方式绘制一张朋友圈分享图

easy-canvas

开发者工具请打开不校验合法域名,真机调试时请打开调试,真机无法绘制多半是微信安全域名的问题。

新增更新图片透明度

新增功能矩形、圆角矩形绘制阴影效果

新增 easy-canvas。之后同步更新。

做微信小程序中最好用的 canvas 绘图组件之一。

当前环境下,大家都非常需要分享到朋友圈这个功能,但是实现起来各有心酸(坑比较多),所以才有了如下的 canvas 绘图工具。

具有如下特性:

简单易用 —— 一个 json 搞定绘制图片功能全 —— 满足 90% 的使用场景 绘制文本(换行、超出内容省略号、中划线、下划线、文本加粗)绘制图片绘制矩形保存图片多图绘制圆形图片绘制圆角矩形... 代码量小

体验

git clone https://github.com/AfanSama/easy-canvas

想在手机上使用配置自己的 appid 即可。

编译模式中已经为你配置好比较常用的两种模式:

普通绘制,绘制单张分享图。多图绘制,连续绘制分享图

使用

API

对象结构一览{ width: 375, height: 555, views: [ { type: 'image', url: 'url', top: 0, left: 0, width: 375, height: 555, borderRadius: true }, { type: 'text', content: 'content', fontSize: 16, color: '#402D16', textAlign: 'left', top: 33, left: 96, bolder: true }, { type: 'rect', background: 'color', top: 0, left: 0, width: 375, height: 555, shadowBlur: 10, shadowColor: "rgba(255,255,255,1)" }, { type: 'roundrect', background: "#fff", y: 57.5, x: 88, width: 280, height: 25, radius:10, shadowBlur: 10, shadowColor: "rgba(255,255,255,1)" } ]}

数据对象的第一层需要三个参数: width、height、mode、views。配置中所有的数字都是没有单位的。这就意味着 canvas 绘制的是一个比例图。具体显示的大小直接把返回的图片路径放置到 image 标签中即可。

mode 可选值有 same, 默认值为空,常规下尽量不要使用。如要使用请看 Q&A的第1点。

当前可以绘制3种类型的配置: image、text、rect、roundrect。配置的属性基本上使用的都是 css 的驼峰名称,还是比较好理解的。

image(图片)

属性含义默认值可选值
url绘制的图片地址,可以是本地图片,如:/images/1.jpeg
top左上角距离画板顶部的距离
left左上角距离画板左侧的距离
width要画多宽0
height要画多高0
borderRadius是否圆形0true
opacity图片透明度1001-100(对应百分比)

text(文本)

属性含义默认值可选值
content绘制文本''(空字符串)
color颜色black
fontSize字体大小16
textAlign文字对齐方式leftcenter、right
lineHeight行高,只有在多行文本中才有用20
top文本左上角距离画板顶部的距离0
left文本左上角距离画板左侧的距离0
breakWord是否需要换行falsetrue
MaxLineNumber最大行数,只有设置 breakWord: true ,当前属性才有效,超出行数内容的显示为...2
widthMaxLineNumber 属性配套使用,width 就是达到换行的宽度
bolder是否加粗falsetrue
textDecoration显示中划线、下划线效果noneunderline(下划线)、line-through(中划线)

rect (矩形,线条)

属性含义默认值可选值
background背景颜色black
top左上角距离画板顶部的距离
left左上角距离画板左侧的距离
width要画多宽0
height要画多高0
shadowBlur阴影模糊0
shadowColor阴影颜色

roundrect(圆角矩形)

属性含义默认值可选值
background背景颜色black
top左上角距离画板顶部的距离
left左上角距离画板左侧的距离
width要画多宽0
height要画多高0
radius圆角度数0
shadowBlur阴影模糊0
shadowColor阴影颜色

Q&A

他们都在用 esay-canvas

TIPS

如果有什么疑问,欢迎 issues。 如果觉得不错,能不能送我小 ✨ ✨ ,让我有更多的动力。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:C++核心准则T.13:对于简单的,单类型参数概念,使用缩略记法更好
下一篇:C++核心准则T.150:用static_assert检查类和概念的匹配性
相关文章

 发表评论

暂时没有评论,来抢沙发吧~