怎样加载base64的图片?

因为没有3d的label,所以我想通过canvas生成输出base64的文字图片,然后场景中通过base64加载图片,在creator中可以通过以下方式加载,但在creator3d中没有对应的方法,我应该怎样做。
let strImg = “data:image/jpeg;base64,” + strQR;
let img = new Image();
img.src = strImg
let texture = new cc.Texture2D();
texture.initWithElement(img);
texture.handleLoadedTexture();
this.aSprite.spriteFrame = new cc.SpriteFrame(texture);

1赞

自己顶顶:sob:

你这个问题提的让我想了半天,最后一拍大腿想起来canvas可以直接扔到Texture2D里渲染的。这个变量名是creator2d里用的renderTexture,懒得改了。

1赞

const img = new Image();
img.src =
“”;
const tex = new Texture2D();

img.onload = function () {
  tex.reset({
    width: img.width,
    height: img.height,
  });
  tex.uploadData(img, 0, 0);
  tex.loaded = true;
  const sp = new SpriteFrame();
  sp.texture = tex;
  self.sp.spriteFrame = sp;
};
3赞

感谢感谢。

请教下:我使用了你这个方法,但是又报错,图片没加载出来。

431:  Request Header Fields Too Large

读取的data数据也没有 “data:image/png;base64, 只有后面的字节。

请教下,这个方法是不是只能在web端使用呢?