手机浏览 RSS 2.0 订阅 膘叔的简单人生 , 腾讯云RDS购买 | 超便宜的Vultr , 注册 | 登陆
浏览模式: 标准 | 列表2020年10月的文章

Kujiale-Mobile/Painter 踩小坑以及处理方法

Kujiale-Mobile/Painter是一个优秀的JS生成canvas的库,如果配合https://lingxiaoyi.github.io/painter-custom-poster/,这个在生制作模板的工具,你会发现哇。原来做个二维码这么容易 。

优秀不代表没有缺点,至少我在使用的时候,真是踩了不少坑。网上的例子都是说直接使用"userComponents":{"painter":"path"}

然而我真的遇到了问题,先申明 ,我是在uniapp下面使用这个

1、各种例子说的组件位置都不一样,有说,放在根目录下:components目录,有说wxcomponents目录,甚至也有人说放在static目录下。我一个个都试了,结果 都是报app.json不正常。查了文档,都说路径不对。各种例子里的路径也是千奇百怪。有的路径用的"./components",有的用的是"/components",也有前面没有任何路径的。后面查到了官方,原来在某个版本的更新后,已经可以不用在前面加"./"或者"/"了。然而我还是不正常。最终我没有用这个办法,我是直接在main.js里采用import的方式解决了。【这个后面还要再提一下】

2、Painter 在网上的例子,都是<painter :palette="xxx" >类似这样,或者<painter palette="{{xxx}}" >这样的类似原生的调用方法。在官方的文档中有说:palette支持的是静态模板,也就是说这里的变量是先生成好的。而不是即时生成。。。。这个就很尴尬了,毕竟我不是做早安图之类的。在进页面前,可能不知道模板中的图片路径是不是确定好。再查的时候,就发现了,原来新版已经支持 dancePalette

3、采用dancePalette,果然是随时可以调用了,但又发生了一个问题,即原来canvas生成的时候,有ImgOK事件。但dancePalette没有ImgOK事件,确实,官方文档中有说,didShow事件是在使用dancePalette模板里触发。直接用最新版,会发现didShow方法报错。于是改代码,在didShow后加了个参数,现在只是不报错了,但还是没啥用。

于是猜想,是不是以前正常,现在不正常了呢?因为发现代码中有使用canvas2d,所以直接下载了canvas2d分支。结果下载后,我原来的import方式不能用了,但是那种:userComponents的方式又正常了。好吧,这不是大事。继续 测试didShow,果然这个分支的didShow输出N多内容。然而最重要的。detail节点没有任何内容,也就是说didShow没有生成Canvas的临时地址。这个事情就尴尬了。

当然我没放弃,我就一直在想,painter的palette静态模板调用,我是不是可以用呢。毕竟,uniapp采用的是vue(或者说是伪VUE),我可以利用v-if,先隐藏painter组件,等 palette的模板生成好了。我再加载painter组件,这时候不是就可以了吗?

说做就做,在<painter>外层加了一个view,默认v-if="templateGenerated == true",data()中先设置为false,然后请求完数据,赋值变量palette后,设置templateGenerate=true;

组件顺利调用,ImgOK方法也触发了。有了路径,什么长按保存,点击预览就都好办了。不是嘛~

至此,踩坑完毕,希望能够给同样踩坑的人有个小帮助。

或许有人说,为什么不看源码,提交PR?大哥,我只是画个太阳码,根本没心思看整个源码。。也没时间啊,先绕过去再说,如果有人能够提交PR,我也可以到时候再试试。

最后,感谢:

1、https://lingxiaoyi.github.io/painter-custom-poster/

2、https://github.com/Kujiale-Mobile/Painter/tree/canvas2d

Tags: painter, canvas

uni-app开发微信小程序如何授权(兼容iso和Android)保存图片到相册?

市面上开发小程序的工具有很多,如果你只是个人开发者,或者是小公司,前端技术没有那么精通的。还是用uniapp吧。确实比较简单,会一点vue就行了。就当开发一个网页就行了。非网页的地方用 #ifndef H5 之类的判断一下处理就OK,然后还能编译成APP。试了一下。在现代的机器下面,性能也确实可以

当然你要说什么ApiCloud/taro/mpvue等都支持,我也没话说。但从便捷性上来说。确实是uniapp更方便一点。而且可找的资料,别人写的代码、插件也确实更多。硬要说不爽的,那就是。。。。公司自己的编辑器HBuilderX实在太烂。连代码跳传都做不到(也可能是我姿势不对。)

这里贴一段别人的长按保存到相册,长按事件是小程序自带的longpress。所以uniapp里的事件就是:

JavaScript代码
  1. /** 
  2.  * @description 保存图片,保存到系统相册 
  3.  * @param {String}  imgSrc 图片路径  
  4.  * @param {String}  content 授权提示语句  
  5.  * @param {String}  failTip 无图片保存时失败提示  
  6.  * @param {String}  successTip 保存成功提示 
  7.  */  
  8. saveImage(imgSrc, content="是否允许获取保存相册权限", failTip='暂无图片', successTip="已保存到本地相册,请打开相册扫描") {  
  9.     uni.saveImageToPhotosAlbum({  
  10.         filePath: imgSrc,  
  11.         // 保存成功,直接给出提示  
  12.         success: (res) => {  
  13.             uni.showModal({  
  14.                 title: '提示',  
  15.                 content: successTip,  
  16.                 showCancel: false,  
  17.                 confirmText: "好的"  
  18.             })  
  19.         },  
  20.    
  21.         // 保存失败,判断是否授权,未授权则调用授权,否则弹出失败信息  
  22.         fail(err) {  
  23.             console.error(err);  
  24.             if (err.errMsg === "saveImageToPhotosAlbum:fail auth deny" || err.errMsg ===  
  25.                 "saveImageToPhotosAlbum:fail authorize no response" || err.errMsg === "saveImageToPhotosAlbum:fail auth denied") { // 没有授权,重新授权,兼容iso和Android  
  26.                 uni.showModal({  
  27.                     title: '授权提示',  
  28.                     content: content,  
  29.                     success: (res) => {  
  30.                         if (res.confirm) { // 点击确定,则调用相册授权  
  31.                             uni.openSetting({  
  32.                                 success(settingdata) {  
  33.                                     if (settingdata.authSetting["scope.writePhotosAlbum"]) {  
  34.                                         console.log("获取权限成功,再次点击图片保存到相册")  
  35.                                         uni.showToast({  
  36.                                             title: '授权成功,请重试哦~'  
  37.                                         });  
  38.                                     } else {  
  39.                                         console.log("获取权限失败")  
  40.                                         uni.showToast({  
  41.                                             title: '请确定已打开保存权限',  
  42.                                             icon: "none"  
  43.                                         });  
  44.                                     }  
  45.                                 }  
  46.                             })  
  47.                         }  
  48.                     }  
  49.                 })  
  50.             } else if (err.errMsg === "saveImageToPhotosAlbum:fail file not found" || err.errMsg ===  
  51.                 "saveImageToPhotosAlbum:fail file not exists" || err.errMsg ===  
  52.                 "saveImageToPhotosAlbum:fail get file data fail"  
  53.             ) { // 无图片,则提示  
  54.                 uni.showToast({  
  55.                     title: failTip,  
  56.                     icon: "none"  
  57.                 });  
  58.             }  
  59.         }  
  60.     })  
  61. },  

原文地址在这里:https://blog.csdn.net/liuxin00020/article/details/104843960,如果保存还是失败,那就先用uni.getImageInfo(),会自动调用图片下载的(特别是微信小程序,还要设置downloadFilePath,否则也不能下载图片,这其实就是很多生成canvas失败的原因之一)

 

1024,爱码士,节日快乐

如题吧,祈福所有从事编程现在还在编程的人,节日快乐,毕竟你有也有一个好名字:爱码士。