mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-07 11:57:44 -08:00
182 lines
5.2 KiB
JavaScript
182 lines
5.2 KiB
JavaScript
|
/*
|
||
|
* JavaScript Load Image Orientation
|
||
|
* https://github.com/blueimp/JavaScript-Load-Image
|
||
|
*
|
||
|
* Copyright 2013, Sebastian Tschan
|
||
|
* https://blueimp.net
|
||
|
*
|
||
|
* Licensed under the MIT license:
|
||
|
* http://www.opensource.org/licenses/MIT
|
||
|
*/
|
||
|
|
||
|
/* global define */
|
||
|
|
||
|
;(function (factory) {
|
||
|
'use strict'
|
||
|
if (typeof define === 'function' && define.amd) {
|
||
|
// Register as an anonymous AMD module:
|
||
|
define(['./load-image'], factory)
|
||
|
} else if (typeof module === 'object' && module.exports) {
|
||
|
factory(require('./load-image'))
|
||
|
} else {
|
||
|
// Browser globals:
|
||
|
factory(window.loadImage)
|
||
|
}
|
||
|
}(function (loadImage) {
|
||
|
'use strict'
|
||
|
|
||
|
var originalHasCanvasOption = loadImage.hasCanvasOption
|
||
|
var originalHasMetaOption = loadImage.hasMetaOption
|
||
|
var originalTransformCoordinates = loadImage.transformCoordinates
|
||
|
var originalGetTransformedOptions = loadImage.getTransformedOptions
|
||
|
|
||
|
// Determines if the target image should be a canvas element:
|
||
|
loadImage.hasCanvasOption = function (options) {
|
||
|
return !!options.orientation ||
|
||
|
originalHasCanvasOption.call(loadImage, options)
|
||
|
}
|
||
|
|
||
|
// Determines if meta data should be loaded automatically:
|
||
|
loadImage.hasMetaOption = function (options) {
|
||
|
return options.orientation === true ||
|
||
|
originalHasMetaOption.call(loadImage, options)
|
||
|
}
|
||
|
|
||
|
// Transform image orientation based on
|
||
|
// the given EXIF orientation option:
|
||
|
loadImage.transformCoordinates = function (canvas, options) {
|
||
|
originalTransformCoordinates.call(loadImage, canvas, options)
|
||
|
var ctx = canvas.getContext('2d')
|
||
|
var width = canvas.width
|
||
|
var height = canvas.height
|
||
|
var styleWidth = canvas.style.width
|
||
|
var styleHeight = canvas.style.height
|
||
|
var orientation = options.orientation
|
||
|
if (!orientation || orientation > 8) {
|
||
|
return
|
||
|
}
|
||
|
if (orientation > 4) {
|
||
|
canvas.width = height
|
||
|
canvas.height = width
|
||
|
canvas.style.width = styleHeight
|
||
|
canvas.style.height = styleWidth
|
||
|
}
|
||
|
switch (orientation) {
|
||
|
case 2:
|
||
|
// horizontal flip
|
||
|
ctx.translate(width, 0)
|
||
|
ctx.scale(-1, 1)
|
||
|
break
|
||
|
case 3:
|
||
|
// 180° rotate left
|
||
|
ctx.translate(width, height)
|
||
|
ctx.rotate(Math.PI)
|
||
|
break
|
||
|
case 4:
|
||
|
// vertical flip
|
||
|
ctx.translate(0, height)
|
||
|
ctx.scale(1, -1)
|
||
|
break
|
||
|
case 5:
|
||
|
// vertical flip + 90 rotate right
|
||
|
ctx.rotate(0.5 * Math.PI)
|
||
|
ctx.scale(1, -1)
|
||
|
break
|
||
|
case 6:
|
||
|
// 90° rotate right
|
||
|
ctx.rotate(0.5 * Math.PI)
|
||
|
ctx.translate(0, -height)
|
||
|
break
|
||
|
case 7:
|
||
|
// horizontal flip + 90 rotate right
|
||
|
ctx.rotate(0.5 * Math.PI)
|
||
|
ctx.translate(width, -height)
|
||
|
ctx.scale(-1, 1)
|
||
|
break
|
||
|
case 8:
|
||
|
// 90° rotate left
|
||
|
ctx.rotate(-0.5 * Math.PI)
|
||
|
ctx.translate(-width, 0)
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Transforms coordinate and dimension options
|
||
|
// based on the given orientation option:
|
||
|
loadImage.getTransformedOptions = function (img, opts, data) {
|
||
|
var options = originalGetTransformedOptions.call(loadImage, img, opts)
|
||
|
var orientation = options.orientation
|
||
|
var newOptions
|
||
|
var i
|
||
|
if (orientation === true && data && data.exif) {
|
||
|
orientation = data.exif.get('Orientation')
|
||
|
}
|
||
|
if (!orientation || orientation > 8 || orientation === 1) {
|
||
|
return options
|
||
|
}
|
||
|
newOptions = {}
|
||
|
for (i in options) {
|
||
|
if (options.hasOwnProperty(i)) {
|
||
|
newOptions[i] = options[i]
|
||
|
}
|
||
|
}
|
||
|
newOptions.orientation = orientation
|
||
|
switch (orientation) {
|
||
|
case 2:
|
||
|
// horizontal flip
|
||
|
newOptions.left = options.right
|
||
|
newOptions.right = options.left
|
||
|
break
|
||
|
case 3:
|
||
|
// 180° rotate left
|
||
|
newOptions.left = options.right
|
||
|
newOptions.top = options.bottom
|
||
|
newOptions.right = options.left
|
||
|
newOptions.bottom = options.top
|
||
|
break
|
||
|
case 4:
|
||
|
// vertical flip
|
||
|
newOptions.top = options.bottom
|
||
|
newOptions.bottom = options.top
|
||
|
break
|
||
|
case 5:
|
||
|
// vertical flip + 90 rotate right
|
||
|
newOptions.left = options.top
|
||
|
newOptions.top = options.left
|
||
|
newOptions.right = options.bottom
|
||
|
newOptions.bottom = options.right
|
||
|
break
|
||
|
case 6:
|
||
|
// 90° rotate right
|
||
|
newOptions.left = options.top
|
||
|
newOptions.top = options.right
|
||
|
newOptions.right = options.bottom
|
||
|
newOptions.bottom = options.left
|
||
|
break
|
||
|
case 7:
|
||
|
// horizontal flip + 90 rotate right
|
||
|
newOptions.left = options.bottom
|
||
|
newOptions.top = options.right
|
||
|
newOptions.right = options.top
|
||
|
newOptions.bottom = options.left
|
||
|
break
|
||
|
case 8:
|
||
|
// 90° rotate left
|
||
|
newOptions.left = options.bottom
|
||
|
newOptions.top = options.left
|
||
|
newOptions.right = options.top
|
||
|
newOptions.bottom = options.right
|
||
|
break
|
||
|
}
|
||
|
if (newOptions.orientation > 4) {
|
||
|
newOptions.maxWidth = options.maxHeight
|
||
|
newOptions.maxHeight = options.maxWidth
|
||
|
newOptions.minWidth = options.minHeight
|
||
|
newOptions.minHeight = options.minWidth
|
||
|
newOptions.sourceWidth = options.sourceHeight
|
||
|
newOptions.sourceHeight = options.sourceWidth
|
||
|
}
|
||
|
return newOptions
|
||
|
}
|
||
|
}))
|