工具地址 点我直达>>painter-custom-poster
因为挂载在github page上,打开速度会慢一些,请耐心等待或自行解决git网速问题css
在作小程序时候,咱们常常会有一个需求,须要将小程序分享到朋友圈,可是朋友圈是不容许直接分享小程序,那咱们还有其余的办法解决吗?答案确定是有的,即 canvas 生成个性化海报分享图片到朋友圈html
那可不能够开发一款生成海报的插件库呢?git
以上的要求固然是能够的,曾经的我也想尝试开发一款出来,可是后来尝试了几款现成的工具以后就放弃了,毕竟轮子这个东西,是须要不断维护更新的,另外已经有这么多优秀现成的插件了,我为什么还要费力去写呢,贡献代码岂不更美哉,如下是我收集的几款github
唠了这么多,好像提供给你们插件就没我什么事情了...想走是不可能的
为了可以制做出更酷炫的海报,我思考了许久
虽然有了插件后,只须要提供配置代码就可以制做出一款海报来,可是我发现仍是有些许问题json
那我须要怎么作呢,请点击这个连接体验>>painter-custom-poster
点击左侧例子展现中的任意一个例子,而后导入代码就能看到效果图,这下你应该能猜到了个人想法了canvas
目前工具一共分红4部分小程序
用来将一些用户设计的精美海报显示出来,经过点击对应的例子并将代码导入画布中微信小程序
显示真实的海报效果,画布里添加的元素,均可以直接用鼠标进行拖动,旋转,缩放操做api
第一排四个按钮跨域
第二排五个按钮
第三排
各类元素的详细设置参数
激活对象是指鼠标点击画布上的元素,该对象会被蓝色的边框覆盖,此时该对象被激活,能够执行拖动 旋转 缩放等操做
激活区只有对象被激活才会出来,用来设置激活对象的各类配置参数,修改value值后,实时更新当前激活对象的对应状态,点击其余区域,此模块将隐藏
属性 | 说明 | 默认 |
---|---|---|
rotate | 旋转,按照顺时针旋转的度数 | 0 |
width、height | view 的宽度和高度 | |
top、left | 如 css 中为 absolute 布局时的做用 | 0 |
background | 背景颜色 | rgba(0,0,0,0) |
borderRadius | 边框圆角 | 0 |
borderWidth | 边框宽 | 0 |
borderColor | 边框颜色 | #000000 |
shadow | 阴影 | '' |
能够同时修饰 image、rect、text 等 。在修饰 text 时则至关于 text-shadow;修饰 image 和 rect 时至关于 box-shadow
使用方法:
shadow: 'h-shadow v-shadow blur color'; h-shadow: 必需。水平阴影的位置。容许负值。 v-shadow: 必需。垂直阴影的位置。容许负值。 blur: 必需。模糊的距离。 color: 必需。阴影的颜色。 举例: shadow:10 10 5 #888888
你能够在画布的 background 属性中使用如下方式实现 css 3 的渐变色,其中 radial-gradient 渐变的圆心为 中点,半径为最长边,目前不支持本身设置。
linear-gradient(-135deg, blue 0%, rgba(18, 52, 86, 1) 20%, #987 80%) radial-gradient(rgba(0, 0, 0, 0) 5%, #0ff 15%, #f0f 60%)
!!!注意:颜色后面的百分比必定得写。
属性 | 说明 | 默认 |
---|---|---|
times | 控制生成插件代码的宽度大小,好比画布宽100,times为2,生成的值为200 | 1 |
属性名称 | 说明 | 默认值 |
---|---|---|
text | 字体内容 | 别跟我谈感情,谈感情伤钱 |
maxLines | 最大行数 | 不限,根据 width 来 |
lineHeight | 行高(上下两行文字baseline的距离) | 1.3 |
fontSize | 字体大小 | 30 |
color | 字体颜色 | #000000 |
fontWeight | 字体粗细。仅支持 normal, bold | normal |
textDecoration | 文本修饰,支持none underline、 overline、 linethrough | none |
textStyle | fill: 填充样式,stroke:镂空样式 | fill |
fontFamily | 字体 | sans-serif |
textAlign | 文字的对齐方式,分为 left, center, right | left |
备注:
属性 | 说明 | 默认 |
---|---|---|
url | 图片路径 | |
mode | 图片裁剪、缩放的模式 | aspectFill |
mode参数详解
若是你设计的海报很好看,而且愿意开源贡献,能够贡献你的海报代码和缩略图,例子代码文件在example中,按顺序排列,例如如今库里例子是example2.js,那你添加example3.js和example3.jpg图片,事例能够参考一下文件夹中源码,而后在index.js中导出一下
代码不要格式化,会报错,请原模原样复制到json字段里
saveImgToLocal() { const that = this; setTimeout(() => { wx.canvasToTempFilePath( { canvasId: 'k-canvas', fileType: 'jpg', quality: 0.2, success: function(res) { that.getImageInfo(res.tempFilePath); }, fail: function(error) { console.error(`canvasToTempFilePath failed, ${JSON.stringify(error)}`); that.triggerEvent('imgErr', { error: error }); } }, this ); }, 300); }
~创做不易,若是对你有帮助,请给个星星 star✨✨ 谢谢~