cocoscreator 下载图片保存本地

该博客介绍如何在CocosCreator中实现从远程URL下载图片,并将其保存到本地文件系统。通过使用jsb.fileUtils的方法检查文件是否存在,创建目录,以及使用XMLHttpRequest进行异步GET请求来获取图片数据。当图片数据获取成功后,将其写入本地文件并加载到纹理中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

test:function (url, callback) {
    console.log('remote test');
var dirpath =  jsb.fileUtils.getWritablePath() + 'img/';
var filepath = dirpath + 'picture' + '.png';
console.log('remote filepath: ' + filepath);
function loadEnd(){
            cc.loader.load(filepath, function(err, tex){
                if( err ){
                    cc.error(err);
}else{
                    var spriteFrame = new cc.SpriteFrame(tex);
if( spriteFrame ){
                        spriteFrame.retain();
callback(spriteFrame);
}
                }
            });
}

        if( jsb.fileUtils.isFileExist(filepath) ){
            console.log('Remote is find' + filepath);
loadEnd();
return;
}

        var saveFile = function(data){
            if( typeof data !== 'undefined' ){
                if( !jsb.fileUtils.isDirectoryExist(dirpath) ){
                    jsb.fileUtils.createDirectory(dirpath);
}

                if( jsb.fileUtils.writeDataToFile(  new Uint8Array(data) , filepath) ){
                    console.log('Remote write file succeed.');
loadEnd();
}else{
                    console.log('Remote write file failed.');
}
            }else{
                console.log('Remote download file failed.');
}
        };

var xhr = new XMLHttpRequest();

xhr.onreadystatechange = function () {
            console.log("Remote xhr.readyState  " +xhr.readyState);
console.log("Remote xhr.status  " +xhr.status);
if (xhr.readyState === 4 ) {
                if(xhr.status === 200){
                    xhr.responseType = 'arraybuffer';
saveFile(xhr.response);
}else{
                    saveFile(null);
}
            }
        }.bind(this);
xhr.open("GET", url, true);
xhr.send();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值