Fixed libwebpjs memmove problem

This commit is contained in:
Igor Zhukov 2015-06-29 22:55:11 +03:00
parent 97f0f80808
commit 4b0bd16aab
6 changed files with 4102 additions and 38 deletions

View File

@ -64,8 +64,7 @@
<script type="text/javascript" src="vendor/zlib/gunzip.min.js"></script>
<script type="text/javascript" src="vendor/closure/long.js"></script>
<script type="text/javascript" src="vendor/leemon_bigint/bigint.js"></script>
<!--script type="text/javascript" src="vendor/libwebpjs/libwebp-0.2.0.min.js"></script-->
<script type="text/javascript" src="vendor/libwebpjs/libwebp-0.1.13.js"></script>
<script type="text/javascript" src="vendor/libwebpjs/libwebp-0.2.0.js"></script>
<script type="text/javascript" src="js/lib/utils.js"></script>

View File

@ -205,6 +205,19 @@ angular.module('izhukov.utils', [])
return $q.reject(e);
}
}
else if (fileData.file) {
var deferred = $q.defer();
fileData.file(function (blob) {
getByteArray(blob).then(function (result) {
deferred.resolve(result);
}, function (error) {
deferred.reject(error);
})
}, function (error) {
deferred.reject(error);
});
return deferred.promise;
}
return $q.when(fileData);
}

View File

@ -463,30 +463,17 @@ function versionCompare (ver1, ver2) {
image.onerror = function () {
nativeWebpSupport = false;
};
// image.src = '';
image.src = '';
var canvas, context;
function convertBinaryToArray (a) {
var b = new Array();
var c = a.length;
for (i = 0; i < c; ++i) b.push(a.charCodeAt(i));
return b
}
function getPngUrlFromData(data) {
console.log(data);
data = convertBinaryToArray(data);
var start = tsNow();
var decoder = new WebPDecoder();
var config = decoder.WebPDecoderConfig;
var buffer = config.output;
// var buffer = config.j;
var buffer = config.j || config.output;
var bitstream = config.input;
if (!decoder.WebPInitDecoderConfig(config)) {
@ -495,10 +482,11 @@ function versionCompare (ver1, ver2) {
}
// console.log('[webpjs] status code', decoder.VP8StatusCode);
var StatusCode = decoder.VP8StatusCode;
status = decoder.WebPGetFeatures(data, data.length, bitstream);
if (status != 0) {
console.error('[webpjs] status error', status);
if (status != (StatusCode.VP8_STATUS_OK || 0)) {
console.error('[webpjs] status error', status, StatusCode);
}
var mode = decoder.WEBP_CSP_MODE;

View File

@ -3792,25 +3792,10 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
}
return FileManager.getByteArray(blob).then(function (bytes) {
var deferred = $q.defer();
var freader = new FileReader();
freader.onload = function (evt) {
return {
id: doc.id,
src: WebpManager.getPngUrlFromData(evt.target.result)
};
// WebPDecodeAndDraw(evt.target.result)
return {
id: doc.id,
src: WebpManager.getPngUrlFromData(bytes)
};
freader.readAsBinaryString(bytes);
return deferred.promise;
// return {
// id: doc.id,
// src: WebpManager.getPngUrlFromData(bytes)
// };
});
});
}

4079
app/vendor/libwebpjs/libwebp-0.2.0.js vendored Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
CACHE MANIFEST
# 63
# 61
NETWORK:
*