使用uploadifive在客户端调整图像大小

时间:2014-04-04 04:44:55

标签: jquery image-uploading uploadifive

我使用uploadifive实现了图片上传页面。有没有办法在客户端重新调整图像大小而不是在服务器端进行调整?如果图像可以在客户端重新调整大小,则会减少上传图像的时间。

任何人都可以举一些例子来做这件事。

1 个答案:

答案 0 :(得分:2)

最后,我实现了图像调整大小功能,并包含在uploadifive js中。

我修改了$ data.uploadFile方法(第363行)

$data.uploadFile = function(file, uploadAll) {
    if (!file.skip && !file.complete && !file.uploading) {
        file.uploading = true;
        $data.uploads.current++;
        $data.uploads.attempted++;

        // Create a new AJAX request
        xhr = file.xhr = new XMLHttpRequest();

        // Start the upload
        // Use the faster FormData if it exists
        if (typeof FormData === 'function' || typeof FormData === 'object') {
            // Resizing starts
            var readerResize = new FileReader();
            readerResize.onload = function() {
                // Create a new FormData object
                var formData = new FormData();

                var dataURL = methods.getResizedDataULR(readerResize, file.type);

                // Convert resize dataURL into a blob again
                var blob = methods.dataURItoBlob(dataURL);

                // Append resized blob into form data with file name
                formData.append(settings.fileObjName, blob, file.name);

                // Add the rest of the formData
                for (i in settings.formData) {
                    formData.append(i, settings.formData[i]);
                }

                // Open the AJAX call
                xhr.open(settings.method, settings.uploadScript, true);

                // On progress function
                xhr.upload.addEventListener('progress', function(e) {
                    if (e.lengthComputable) {
                        $data.progress(e, file);
                    }
                }, false);

                // On complete function
                xhr.addEventListener('load', function(e) {
                    if (this.readyState == 4) {
                        file.uploading = false;
                        if (this.status == 200) {
                            if (file.xhr.responseText !== 'Invalid file type.') {
                                $data.uploadComplete(e, file, uploadAll);
                            } else {
                                $data.error(file.xhr.responseText, file, uploadAll);
                            }
                        } else if (this.status == 404) {
                            $data.error('404_FILE_NOT_FOUND', file, uploadAll);
                        } else if (this.status == 403) {
                            $data.error('403_FORBIDDEN', file, uploadAll);
                        } else {
                            $data.error('Unknown Error', file, uploadAll);
                        }
                    }
                });

                // Send the form data (multipart/form-data)
                xhr.send(formData);
            };

            readerResize.readAsDataURL(file);

            // Resizing ends
        } else {

            // Send as binary
            // Don't change this else block

        }
    }
}  

并添加了如下的辅助方法

var methods = {
    .....
    // appended below new methods for resizing purpose

    dataURItoBlob: function (dataURI) {
        var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
        var binary = atob(dataURI.split(',')[1]), array = [];
        for (var i = 0; i < binary.length; i++) array.push(binary.charCodeAt(i));
        return new Blob([new Uint8Array(array)], { type: mimeString });
    },

    getResizedDataULR: function (reader, fileType) {
        var tempImg = new Image();
        tempImg.src = reader.result;

        var MAX_WIDTH = 800;
        var MAX_HEIGHT = 600;
        var tempW = tempImg.width;
        var tempH = tempImg.height;
        if (tempW > tempH) {
            if (tempW > MAX_WIDTH) {
                tempH *= MAX_WIDTH / tempW;
                tempW = MAX_WIDTH;
            }
        } else {
            if (tempH > MAX_HEIGHT) {
                tempW *= MAX_HEIGHT / tempH;
                tempH = MAX_HEIGHT;
            }
        }

        var canvas = document.createElement('canvas');
        canvas.width = tempW;
        canvas.height = tempH;
        var ctx = canvas.getContext("2d");
        ctx.drawImage(tempImg, 0, 0, tempW, tempH);
        return canvas.toDataURL(fileType);
    }
}