1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/pipes/FixOrientationPipe.ts

92 lines
2.8 KiB
TypeScript
Raw Normal View History

2018-11-02 17:40:09 +08:00
import {Pipe, PipeTransform} from '@angular/core';
import {OrientationTypes} from 'ts-exif-parser';
/**
2018-11-05 02:28:32 +08:00
* This pipe is used to fix thumbnail and media orientation based on their exif orientation tag
2018-11-02 17:40:09 +08:00
*/
@Pipe({name: 'fixOrientation'})
export class FixOrientationPipe implements PipeTransform {
public static transform(imageSrc: string, orientation: OrientationTypes): Promise<string> {
if (orientation === OrientationTypes.TOP_LEFT) {
return Promise.resolve(imageSrc);
}
return new Promise((resolve) => {
const img = new Image();
// noinspection SpellCheckingInspection
img.onload = () => {
const width = img.width,
height = img.height,
canvas = document.createElement('canvas'),
ctx = canvas.getContext('2d');
// set proper canvas dimensions before transform & export
if (OrientationTypes.BOTTOM_LEFT < orientation &&
2018-12-20 05:28:20 +08:00
orientation <= OrientationTypes.LEFT_BOTTOM) {
2018-11-02 17:40:09 +08:00
// noinspection JSSuspiciousNameCombination
canvas.width = height;
// noinspection JSSuspiciousNameCombination
canvas.height = width;
} else {
canvas.width = width;
canvas.height = height;
}
// transform context before drawing image
2019-02-05 06:46:27 +08:00
// transform function parameters:
// a Horizontal scaling
// b Horizontal skewing
// c Vertical skewing
// d Vertical scaling
// e Horizontal moving
// f Vertical moving
2018-11-02 17:40:09 +08:00
switch (orientation) {
case OrientationTypes.TOP_RIGHT: // 2
ctx.transform(-1, 0, 0, 1, width, 0);
break;
case OrientationTypes.BOTTOM_RIGHT: // 3
ctx.transform(-1, 0, 0, -1, width, height);
break;
case OrientationTypes.BOTTOM_LEFT: // 4
ctx.transform(1, 0, 0, -1, 0, height);
break;
case OrientationTypes.LEFT_TOP: // 5
ctx.transform(0, 1, 1, 0, 0, 0);
break;
case OrientationTypes.RIGHT_TOP: // 6
ctx.transform(0, 1, -1, 0, height, 0);
break;
case OrientationTypes.RIGHT_BOTTOM: // 7
ctx.transform(0, -1, -1, 0, height, width);
break;
case OrientationTypes.LEFT_BOTTOM: // 8
ctx.transform(0, -1, 1, 0, 0, width);
break;
default:
break;
}
// draw image
ctx.drawImage(img, 0, 0);
// export base64
resolve(canvas.toDataURL());
};
img.onerror = () => {
resolve(imageSrc);
};
img.src = imageSrc;
});
}
transform(imageSrc: string, orientation: OrientationTypes): Promise<string> {
return FixOrientationPipe.transform(imageSrc, orientation);
}
}