jquery-fileupload-rails gemを介して、Rails 3.2 アプリでblueimp jquery-file-uploadを使用しています。
アップロードする前にクライアント側で画像のサイズを変更しようとしていますが、ドキュメントに従うのに問題があります。私のコードは以下です。現在、アップロードは完全に機能していますが、画像のサイズは変更されていません。
jquery-file-upload を介して画像のサイズを変更する正しい構文は何ですか。
(これとこのドキュメントに基づいてコーヒースクリプトに示されている2つのアプローチ。どちらも私にはうまくいきません。)
#Coffeescript
jQuery ->
if $("#new_asset").length
$("#new_asset").fileupload
dataType: "script"
add: (e, data) ->
types = /(\.|\/)(jpe?g|png)$/i
file = data.files[0]
if types.test(file.type) || types.test(file.name)
data.context = $(tmpl("template-upload", file))
$('#progress-container').append(data.context)
jqXHR = data.submit()
$("button.cancel").click (e) ->
jqXHR.abort()
else
alert("#{file.name} is not a jpeg or png image file")
progress: (e, data) ->
if data.context
progress = parseInt(data.loaded / data.total * 100, 10)
data.context.find('.bar').css('width', progress + '%')
stop: (e, data) ->
$('.upload').hide()
process: [
action: "load"
fileTypes: /^image\/(gif|jp?g)$/
maxFileSize: 20000000 # 20MB
,
action: "resize"
imageMaxWidth: 1500
imageMaxHeight: 1500
,
action: "save"
]
dropZone: $(".dropzone")
sequentialUploads: true
disableImageResize: /Android(?!.*Chrome)|Opera/.test(window.navigator and navigator.userAgent)
imageMaxWidth: 1500
imageMaxHeight: 1500
downloadTemplateId: null
#application.js
//= require jquery-fileupload
編集
Matanza の回答によるとadd
、私のコードのコールバックは、処理関数が自動的に呼び出されるのを防ぎます。だから私は次のようなことをする必要があると思います
...
add: (e, data) ->
$.each data.result, (index, file) ->
// processing code goes here
しかし、正しい構文を理解したり、利用可能なガイドを理解するのに苦労しています。
add コールバックで各ファイルにサイズ変更処理を適用するにはどうすればよいですか?