開発環境:Monaca(OnsenUI JS Tabbar)
仕様デバイス:iPhone XS
iPhoneで写真をとった一部のデータがJPEG画像としてアップロードできません。(できる画像とできない画像があります。)
サイズの問題なのかと思い調べたところ、
写真1 ← アップロードできるJPEG
・容量:2,225,709Byte
・拡張子:JPEG
・base64形式: 1~27行まで : data:image/jpeg;base64,/9j/4
・type: image/jpeg
写真2 ← アップロードできないJPEG
・容量:7,540,589Byte
・拡張子:JPEG
・base64形式: 1~27行まで : data:image/jpeg;base64,/9j/4
・type: image/jpeg
ncmbには一度にアップロードされる容量制限があるのでしょうか?容量制限の最大値を教えてくれると助かります。
HTML
<ons-template id="tab2.html"> <ons-page id="second-page"> <p style="text-align: center;"> input fileを使用 </p> <div style="text-align:center;"> <input type="file" id="file" accept="image/*" onchange="OnFileSelect( this );" /> <br> <img id="image" width="80%" style="max-height: 500px;"/> </div> </ons-page> </ons-template>
Javascript
function toBlob(base64) { var bin = atob(base64.replace(/^.*,/, "")); var buffer = new Uint8Array(bin.length); for (var i = 0; i < bin.length; i++) { buffer[i] = bin.charCodeAt(i); } try { var blob = new Blob([buffer.buffer], { type: "image/jpeg" }); } catch (e) { return false; } return blob; } // 要素を取得 function OnFileSelect( inputElement ){ var fileList = inputElement.files; // FileReaderを生成 var fileReader = new FileReader(); // ファイルを取得 var file = fileList[0]; // 読み込み完了時の処理を追加 fileReader.onload = function() { document.getElementById("image").src = this.result; var imagData = toBlob(this.result); ncmb.File.upload("sample.jpeg", imageData) .then(function(data){ alert("保存が完了しました"); }) .catch(function(err){ alert("予期せぬエラー:" + err); }); }; // ファイルの読み込み(Data URI Schemeの取得) fileReader.readAsDataURL( file ); return {imageName: imageName}; }
あなたの回答
tips
プレビュー