Javascript/Sencha
Sencha 이미지 사이즈 변경 후 업로드하기
바리새인
2025. 1. 6. 21:54
이미지 사이즈 변경 및 rotation 처리
function resizeImage(file, callback) {
const reader = new FileReader();
reader.onload = function(e) {
const img = new Image();
img.src = e.target.result;
img.onload = function() {
let width = img.width;
let height = img.height;
let orientation = -1;
EXIF.getData(img, function() {
const exifOrientation = EXIF.getTag(this, "Orientation");
if(exifOrientation) {
orientation = exifOrientation;
}
const maxWidth = 1024;
const maxHeight = 768;
if(width > maxWidth || height > maxHeight) {
const aspectRatio = width / height;
if(width > height) {
width = maxWidth;
height = Math.floor(width /aspectRation);
} else {
height = maxHeight;
width = Math.floor(height * aspectRatio);
}
}
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
if(orientation === 6) { // 90° rotated
canvas.width = height;
canvas.height = width;
ctx.rotate(90 * Math.PI / 180);
ctx.translate(0, -height);
} else if(orientation === 8) { // 270° rotated
canvas.width = height;
canvas.height = width;
ctx.rotate(-90 * Math.PI / 180);
ctx.translate(-width, 0);
} else if (orientation === 3) { // 180° rotated
canvas.width = width;
canvas.height = height;
ctx.rotate(180 * Math.PI / 180);
ctx.translate(-width, -height);
} else {
canvas.width = width;
canvas.height = height;
}
ctx.drawImage(img, 0, 0, width, height);
canvas.toBlob((blob) => {
const resizedFile = new File([blob], file.name, { type: file.type });
callback(resizedFile);
}, file.tyupe, 0.9);
});
};
};
reader.readAsDataURL(file);
}
팝업 처리
function uploadPopup() {
const popupImage = Ext.create('Ext.window.Window', {
title: '업로드 팝업',
width: 400,
height: 300,
floating: true,
constrain: false,
modal: false,
layout: 'fit',
items: {
xtype: 'form',
bodyPadding: 10,
frame: true,
items: [
{
xtype: 'textfield',
name: 'id',
readOnly: true,
hidden: true,
value: id,
},
{
xtype: 'filefield',
name: 'file',
fieldLabel: 'File',
labelWidth: 50,
allowBlank: false,
buttonText: 'Browse...',
},
],
buttons: [
{
text: 'Upload',
handler: function() {
const form = this.up('form').getForm();
const fileInput = form.findField('file').fileInputEl.dom.files[0];
const idHidden = form.findField('id').getValue();
resizeImage(fileInput, (resizedFile) => {
if(form.isValid()) {
const formData = new FormData();
formData.append('file', resizedFile);
formData.append('id', idHidden);
formData.append('_csrf', document.getElementById('_csrf').innerText);
Ext.getBody().mask('Uploading file...');
popupImage.setLoading('Uploading file...');
Ext.Ajax.request({
url: '/test/insert',
rawData: formData,
headers: {
'Content-Type': undefined
},
success: function(response) {
Ext.getBody().unmask(); // Remove loading mask on success
popupImage.setLoading(false); // Remove loading mask on success
const result = Ext.decode(response.responseText);
popupImage.close();
},
failure: function(response) {
Ext.getBody().unmask(); // Remove loading mask on success
popupImage.setLoading(false); // Remove loading mask on success
const result = Ext.decode(response.responseText);
console.log(result);
Ext.Msg.alert('Failure', 'File upload failed.');
}
});
} else {
Ext.Msg.alert('Validation Error', 'Please select a file before uploading.');
}
});
}
}
]
}
});
popupImage.show();
}