如何将图片的base64数据转换成 ImageAsset 格式呢

var img = new ImageAsset();
let baseData = ‘’;
// img.reset();
// TODO
// 这里该怎么处理
//
img.onLoaded = () => {
var texture = new Texture2D();
texture.image = img;
var newframe = new SpriteFrame();
newframe.texture = texture;
this.sp_test.spriteFrame = newframe;
};

有没有大佬再Creator3.x 处理过这部分数据呢,base64数据是安卓传过来的数据。想把这个图片数据做展示到游戏中

    // let texture2D = new cc.Texture2D();
    // texture2D.initWithElement(img);

    // let spriteFrame = new cc.SpriteFrame();
    // spriteFrame.setTexture(texture2D);

    // let node = new cc.Node();
    // let sprite = node.addComponent(cc.Sprite);
    // sprite.spriteFrame = spriteFrame;

你这个是2.x上可以用的,3.x没有initWithElement了

var _img = new Image();
_ img.onload = () => {
var texture = new Texture2D();
// texture.image = img;
texture.reset({
width: _img.width,
height: _img.height,
});
texture.uploadData(_img, 0, 0);

  var newframe = new SpriteFrame();
  newframe.texture = texture;
  this.sp_test.spriteFrame = newframe;
  }
 img.src = baseData;

431 (Request Header Fields Too Large) ,cocos报 这个错误是怎么回事?base64太长?

代码:
let img = new Image();

var _img = new Image();

                    _img.onload = () => {

                        var texture = new Texture2D();

                        // texture.image = img;

                        texture.reset({

                            width: _img.width,

                            height: _img.height,

                        });

                        texture.uploadData(_img, 0, 0);

                        var newframe = new SpriteFrame();

                        newframe.texture = texture;

                        find("Canvas/bg1").getComponent(Sprite).spriteFrame = newframe;

                    }

                    img.src = dizhi;
1赞

https://blog.csdn.net/enthan809882/article/details/115796151
你尝试使用一张小的图片试试,如果可以那就这个问题喽

// let img = new Image();

                    // var _img = new Image();

                    // _img.onload = () => {

                    //     var texture = new Texture2D();

                    //     // texture.image = img;

                    //     texture.reset({

                    //         width: _img.width,

                    //         height: _img.height,

                    //     });

                    //     texture.uploadData(_img, 0, 0);

                    //     var newframe = new SpriteFrame();

                    //     newframe.texture = texture;

                    //     this.bj.spriteFrame = newframe;

                    // }

                    // img.src = t;

替换后,没有报错,也没有任何的图片被替换反应。

> 
> public setSprFrameByBase64Data(spr: Sprite, base64: string) {
>     var img = new Image();
>     console.log(base64);
>     img.onload = function () {
>         var texture = new Texture2D();
>         texture.reset({
>             width: img.width,
>             height: img.height,
>         });
>         texture.uploadData(img, 0, 0);
>         var newframe = new SpriteFrame();
>         newframe.texture = texture;
>         if (spr) spr.spriteFrame = newframe;
>     }
>     img.onerror = function (err) {
>         console.warn("------合成报错-----", err)
>     }
>     if ((<any>base64).startsWith !== undefined && (<any>base64).startsWith("data:image")) {
>         img.src = base64;
>     } else {
>         img.src = "data:image/png;base64," + base64;
>     }
> }

试试这个,我这边是没有问题的

3赞

我使用了你这里的diamante,在客户端不能用,onload根本不调用

你确定下自己的base64格式对不,是全的不