Fixed libwebpjs memmove problem
This commit is contained in:
parent
97f0f80808
commit
4b0bd16aab
@ -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>
|
||||
|
@ -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);
|
||||
}
|
||||
|
||||
|
@ -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;
|
||||
|
@ -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
4079
app/vendor/libwebpjs/libwebp-0.2.0.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,6 @@
|
||||
CACHE MANIFEST
|
||||
|
||||
# 63
|
||||
# 61
|
||||
|
||||
NETWORK:
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user