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

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

备份:html5 canvas cheat sheet

纯备份资料,HTML5的canvas资料
大小: 88.14 K
尺寸: 500 x 370
浏览: 2616 次
点击打开新窗口浏览全图

Tags: html5, canvas, cheat sheet

JS实现的街头霸王

自从canvas越来越被大多数人接受后,基于它的游戏也越来越多了。。。
而这个,居然没用canvas也能实现这样的效果,看这里:http://www.cnblogs.com/Random/archive/2011/04/11/2011962.html

作者这么说了:
《天机》 之后,这次又山寨了个名为《街斗霸主》的经典格式游戏《街头霸王》的模仿版Demo,花了几个月的业余时间写了这么个东西,算是对目前的技术学习的一种练习吧。

其实这种练习的结果不是很重要,主要是体会其中的过程,虽然大部分的时间是在痛苦中渡过,但也是有很多收获的,同时也暴露出很多技术方面的不足,也为以后的学习明确了一些目标。

技术方面因为考虑到大部分IE用户(而且是非IE9),所以没有用HTML5的canvas,用的div的方式处理的,这样挑战也相对大了一些,

不过确实,性能上还是不理想,IE下的表现还是比较糟糕(特别是IE6。。。恩。。。- -!)。
目前兼容IE6/7/8(理论上也兼容IE9,只是没有测试),safari,FF3.5+(因为FF2.0/3.0不支持水平翻转的样式。。- -!),Chrome,Opera。
自己写了一个小型框架,包括了开发流程和js类库,类库用了OOP Like的方式包了个语法糖衣,看上去还算是像个OOP的样子,不过因为为了追求“优雅”,直接扩展了function的prototype,所以不建议在其它地方使用。
框架开发的整体思路就是用PHP作后端代码合并输出,js代码里用$import去建立了各个代码文件之间的关系,然后页面引用合并js的PHP文件,该模式需要在本地建立一个web服务器才能作测试,并且需要设置hosts为 127.0.0.1 aralork

  游戏说明

 

    游戏是一个Demo版本,实现了核心的整体流程。游戏分为“单人游戏”模式、“双人对战”模式和“练习模式”三种玩法,不过其实实现都是一样,只是改改初始化的参数而已,挺坑爹的。。。

    游戏只需要键盘操作,不需要鼠标,

    菜单的操作是方向键移动,Enter键选择,ESC键取消;

    玩家1的操作:

       上:W,下:S,左:A,右:D,拳:J / K / L,腿:U / I / O

     玩家2的操作:

      上:↑,下:↓,左:←,右:→,拳:小键盘 1 / 2 / 3,腿:小键盘 4 / 5 / 6

    这里的 ↑ ↓ ← → 代表方向键。

    游戏演示地址

     完整源代码下载

Tags: js, 街霸, div, canvas