Commit e9938482 authored by Romain Courteaud's avatar Romain Courteaud

erp5_document_scanner: use load-image library to bypass chrome canvas transformation issue

parent f0c8f016
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
<script type="text/javascript" src="domsugar.js"></script> <script type="text/javascript" src="domsugar.js"></script>
<script type="text/javascript" src="caman.full.min.js"></script> <script type="text/javascript" src="caman.full.min.js"></script>
<script type="text/javascript" src="glfx.js"></script> <script type="text/javascript" src="glfx.js"></script>
<script type="text/javascript" src="load-image.all.min.js"></script>
<script type="text/javascript" src="gadget_document_scanner.js"></script> <script type="text/javascript" src="gadget_document_scanner.js"></script>
<title>Gadget Document Scanner</title> <title>Gadget Document Scanner</title>
</head> </head>
......
...@@ -242,7 +242,7 @@ ...@@ -242,7 +242,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>982.61373.37397.17954</string> </value> <value> <string>983.7362.49324.10547</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -260,7 +260,7 @@ ...@@ -260,7 +260,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1585899899.78</float> <float>1599236057.62</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
/*jslint indent: 2, unparam: true, bitwise: true */ /*jslint indent: 2, unparam: true, bitwise: true */
/*global rJS, RSVP, window, document, navigator, Cropper, Promise, JSON, jIO, /*global rJS, RSVP, window, document, navigator, Cropper, Promise, JSON, jIO,
promiseEventListener, domsugar, createImageBitmap, FormData, Caman, promiseEventListener, domsugar, createImageBitmap, FormData, Caman,
FileReader, DataView, URL, fx*/ FileReader, DataView, URL, fx, loadImage */
(function (rJS, RSVP, window, document, navigator, Cropper, Promise, JSON, jIO, (function (rJS, RSVP, window, document, navigator, Cropper, Promise, JSON, jIO,
promiseEventListener, domsugar, createImageBitmap, FormData, caman, promiseEventListener, domsugar, createImageBitmap, FormData, caman,
FileReader, DataView, URL, fx) { FileReader, DataView, URL, fx) {
...@@ -528,8 +528,7 @@ ...@@ -528,8 +528,7 @@
.push(function (result) { .push(function (result) {
orientation = result; orientation = result;
var expected_width = settings.maximum_width, var expected_width = settings.maximum_width;
bitmap_options;
// If orientation is correct, return the original blob // If orientation is correct, return the original blob
// and size is small // and size is small
// and no color correction is expected // and no color correction is expected
...@@ -550,13 +549,19 @@ ...@@ -550,13 +549,19 @@
var canvas, var canvas,
webgl_context, webgl_context,
higher_dimension_key, higher_dimension_key,
higher_dimension_value; higher_dimension_value,
load_image_options = {
meta: false,
orientation: true,
canvas: true,
imageSmoothingQuality: 'high'
};
if (bitmap.width < bitmap.height) { if (bitmap.width < bitmap.height) {
higher_dimension_key = 'resizeHeight'; higher_dimension_key = 'maxHeight';
higher_dimension_value = bitmap.height; higher_dimension_value = bitmap.height;
} else { } else {
higher_dimension_key = 'resizeWidth'; higher_dimension_key = 'maxWidth';
higher_dimension_value = bitmap.width; higher_dimension_value = bitmap.width;
} }
...@@ -569,64 +574,14 @@ ...@@ -569,64 +574,14 @@
); );
if ((!!expected_width) && (expected_width < higher_dimension_value)) { if ((!!expected_width) && (expected_width < higher_dimension_value)) {
bitmap_options = { load_image_options[higher_dimension_key] = expected_width;
resizeQuality: 'high'
};
bitmap_options[higher_dimension_key] = expected_width;
return createImageBitmap(blob, bitmap_options);
} }
return bitmap; return loadImage(blob, load_image_options);
}) })
.push(function (bitmap) { .push(function (data) {
var height = bitmap.height, var canvas = data.image;
width = bitmap.width,
canvas = domsugar('canvas'),
ctx;
// Caman expect the canvas to be in a container
// in order to replace it when resizing
domsugar('div', [canvas]);
if ((4 < orientation) && (orientation < 9)) {
canvas.width = height;
canvas.height = width;
} else {
canvas.width = width;
canvas.height = height;
}
ctx = canvas.getContext('2d');
// transform context before drawing image
switch (orientation) {
case 2:
ctx.transform(-1, 0, 0, 1, width, 0);
break;
case 3:
ctx.transform(-1, 0, 0, -1, width, height);
break;
case 4:
ctx.transform(1, 0, 0, -1, 0, height);
break;
case 5:
ctx.transform(0, 1, 1, 0, 0, 0);
break;
case 6:
ctx.transform(0, 1, -1, 0, height, 0);
break;
case 7:
ctx.transform(0, -1, -1, 0, height, width);
break;
case 8:
ctx.transform(0, -1, 1, 0, 0, width);
break;
default:
break;
}
ctx.drawImage(bitmap, 0, 0);
if (settings.brightness || settings.contrast || settings.enable_greyscale) { if (settings.brightness || settings.contrast || settings.enable_greyscale) {
return handleGfx(canvas, settings); return handleGfx(canvas, settings);
// return handleCaman(canvas, settings); // return handleCaman(canvas, settings);
......
...@@ -244,7 +244,7 @@ ...@@ -244,7 +244,7 @@
</item> </item>
<item> <item>
<key> <string>serial</string> </key> <key> <string>serial</string> </key>
<value> <string>983.14351.3372.41932</string> </value> <value> <string>986.29418.46329.12509</string> </value>
</item> </item>
<item> <item>
<key> <string>state</string> </key> <key> <string>state</string> </key>
...@@ -262,7 +262,7 @@ ...@@ -262,7 +262,7 @@
</tuple> </tuple>
<state> <state>
<tuple> <tuple>
<float>1586942462.17</float> <float>1599470361.92</float>
<string>UTC</string> <string>UTC</string>
</tuple> </tuple>
</state> </state>
......
...@@ -7,7 +7,8 @@ url_list = [ ...@@ -7,7 +7,8 @@ url_list = [
"cropper.css", "cropper.css",
"cropper.js", "cropper.js",
"caman.full.min.js", "caman.full.min.js",
"glfx.js" "glfx.js",
"load-image.all.min.js"
] ]
return url_list return url_list
<?xml version="1.0"?>
<ZopeData>
<record id="1" aka="AAAAAAAAAAE=">
<pickle>
<global name="File" module="OFS.Image"/>
</pickle>
<pickle>
<dictionary>
<item>
<key> <string>_Cacheable__manager_id</string> </key>
<value> <string>must_revalidate_http_cache</string> </value>
</item>
<item>
<key> <string>__name__</string> </key>
<value> <string>load-image.all.min.js</string> </value>
</item>
<item>
<key> <string>content_type</string> </key>
<value> <string>text/javascript</string> </value>
</item>
<item>
<key> <string>precondition</string> </key>
<value> <string></string> </value>
</item>
<item>
<key> <string>title</string> </key>
<value> <string>load-image.all.min.js</string> </value>
</item>
</dictionary>
</pickle>
</record>
</ZopeData>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment