3 回答

TA貢獻1840條經(jīng)驗 獲得超5個贊
github項目JavaScript-Load-Image為EXIF方向問題提供了一個完整的解決方案,正確旋轉(zhuǎn)/鏡像所有8個exif方向的圖像。查看javascript exif方向的在線演示
圖像被繪制到HTML5畫布上。它的正確渲染是通過canvas操作在js / load-image-orientation.js中實現(xiàn)的。
希望這能節(jié)省一些時間,并教導(dǎo)搜索引擎關(guān)于這個開源寶石:)

TA貢獻1993條經(jīng)驗 獲得超6個贊
Mederr的上下文轉(zhuǎn)換非常有效。如果您需要提取方向,請僅使用此功能 - 您不需要任何EXIF讀取庫。以下是在base64圖像中重新設(shè)置方向的功能。 這是一個小提琴。我還準備了一個方向提取演示的小提琴。
function resetOrientation(srcBase64, srcOrientation, callback) { var img = new Image(); img.onload = function() { var width = img.width, height = img.height, canvas = document.createElement('canvas'), ctx = canvas.getContext("2d"); // set proper canvas dimensions before transform & export if (4 < srcOrientation && srcOrientation < 9) { canvas.width = height; canvas.height = width; } else { canvas.width = width; canvas.height = height; } // transform context before drawing image switch (srcOrientation) { 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; } // draw image ctx.drawImage(img, 0, 0); // export base64 callback(canvas.toDataURL()); }; img.src = srcBase64;};

TA貢獻1862條經(jīng)驗 獲得超6個贊
如果
width = img.width;height = img.height;var ctx = canvas.getContext('2d');
然后,您可以使用這些轉(zhuǎn)換將圖像轉(zhuǎn)換為方向1
從方向:
ctx.transform(1, 0, 0, 1, 0, 0);
ctx.transform(-1, 0, 0, 1, width, 0);
ctx.transform(-1, 0, 0, -1, width, height);
ctx.transform(1, 0, 0, -1, 0, height);
ctx.transform(0, 1, 1, 0, 0, 0);
ctx.transform(0, 1, -1, 0, height, 0);
ctx.transform(0, -1, -1, 0, height, width);
ctx.transform(0, -1, 1, 0, 0, width);
在ctx上繪制圖像之前
添加回答
舉報