skyfish-qc / pixi-miniprogram

一个可运行于微信小程序的PIXI引擎,通过模拟window环境,有些功能小程序无法模拟,就直接修改了PIXI引擎代码,最终使得PIXI引擎正常运行在小程序上

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Graphics 在真机上无法正常着色

lqloveball opened this issue · comments

初步判断是 pixi 的 canvas2d 绘制白色纹理失效

	function createWhiteTexture()
	{
	    var canvas = document.createElement('canvas2d');

	    canvas.width = 16;
	    canvas.height = 16;
		canvas.type='canvas';

	    var context = canvas.getContext('2d');

	    context.fillStyle = 'white';
		context.fillRect(0, 0, 16, 16);


	    return new Texture(new BaseTexture(new CanvasResource(canvas)));
	}

目前暂时解决方案,自己做一个白色图片纹理

PIXI.Texture.WHITE = PIXI.Texture.from("/static/color.png");

Graphics 绘制需要一个白色纹理,在 Graphics绘制前 直接使用PIXI.Texture.from 来创建 base64 白色纹理(只需要开始设置一次)


    PIXI.Texture.WHITE = PIXI.Texture.from("");

你这个应该是没有把那个canvas2d参数传进去,那个初始化PIXI那里,如果有需要用到graphics的,需要传入一个2d的canvas才能正常使用,看那个readme的说明就好

你这个应该是没有把那个canvas2d参数传进去,那个初始化PIXI那里,如果有需要用到graphics的,需要传入一个2d的canvas才能正常使用,看那个readme的说明就好

已经传递
createPIXI(_canvas, _stageWidth, _canvas2d)

但渲染出来的是黑色的,问题出在使用canvas 创建 BaseTexture纹理问题。目前绘制出来是黑色的。

今天试了一下,是新版微信的webgl渲染改动导致的,之前版本的微信是正常显示的,微信更新后不正常了。刚更新了一个版本,修改了webgl渲染canvas的机制,在真机上测试了可以正常显示了。

今天试了一下,是新版微信的webgl渲染改动导致的,之前版本的微信是正常显示的,微信更新后不正常了。刚更新了一个版本,修改了webgl渲染canvas的机制,在真机上测试了可以正常显示了。

太棒了!这个更新完美解决。

目前PIXI.Text 无法实现,主要还是由于canvas无法动态修改宽高。
但BitmapText 是无法做全量文本动态输入。PIXI.Text
我现在方式是使用一个 1000px*1000px的2d canvas来完成文本绘制后传递数据给PIXI.Text完成最终渲染。

canvas可以动态修改宽高的,主要是一个Text需要对应一个canvas,不能动态创建2d类型的canvas,你获取2d类型的canvas时候用上node,size参数就可以动态改宽高了,可以看看例子里面的获取方式

今天试了一下,是新版微信的webgl渲染改动导致的,之前版本的微信是正常显示的,微信更新后不正常了。刚更新了一个版本,修改了webgl渲染canvas的机制,在真机上测试了可以正常显示了。

太棒了!这个更新完美解决。

目前PIXI.Text 无法实现,主要还是由于canvas无法动态修改宽高。
但BitmapText 是无法做全量文本动态输入。PIXI.Text
我现在方式是使用一个 1000px*1000px的2d canvas来完成文本绘制后传递数据给PIXI.Text完成最终渲染。

重新改写了Text的渲染逻辑,新引入一个2d类型的canvas就可以正常显示了。具体可以参考例子的做法。

问题已修复