APNG在QT中的使用-代码篇(二)

代码

apng-canvas.js库文件已上传,经过修改后可在QT,浏览器上正常使用。【点击此处下载apng-canvas.js】

function convertImgDataToBlob(base64Data) {  
      var format = "image/png";  
      var code = window.atob(base64Data);;  
      var aBuffer = new window.ArrayBuffer(code.length);  
      var uBuffer = new window.Uint8Array(aBuffer);  
      for(var i = 0; i < code.length; i++){  
          uBuffer[i] = code.charCodeAt(i) & 0xff ;  
      }  

      var blob=null;  
      try{  
          blob = new Blob([uBuffer], {type : format});  
      }  
      catch(e){  
          window.BlobBuilder = window.BlobBuilder ||  
          window.WebKitBlobBuilder ||  
          window.MozBlobBuilder ||  
          window.MSBlobBuilder;  
          if(e.name == 'TypeError' && window.BlobBuilder){  
              var bb = new window.BlobBuilder();  
              bb.append(uBuffer.buffer);  
              blob = bb.getBlob("image/png");  

          }  
          else if(e.name == "InvalidStateError"){  
              blob = new Blob([aBuffer], {type : format});  
          }  
          else{  

          }  
      }  
      return blob;     
};  

function replaceAnmiationEmotion()
{
    $('#apng').find('.apng_image').each(function(){    
        var imgObj = $(this);
        var emotionPath = imgObj.attr("src");
        //getImageBase64从QT上获取图片数据
        var baseData64 = external.getImageBase64(emotionPath);
        var reader = new FileReader();  
        var blob = convertImgDataToBlob(baseData64);
        reader.readAsBinaryString(blob);
        reader.onload=function(file){
            var url=file.target.result;
            url=encodeURI(url);
            imgObj.attr("data-src",url);
            APNG.animateImage(imgObj[0]);
        }
    });
}
QString getImageBase64(QString filePath)
{
    QFile file(filePath);
    bool ret = file.open(QIODevice::ReadOnly);
    QString data= file.readAll().toBase64();
    file.close();
    return data;
}

效果图

这里写图片描述

参考链接

APNG在QT中的使用(一)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雨田哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值