Railsの写真のプレビューでJavaScriptで写真を回転させないようにする方法
- 評価
- クリップ 0
- VIEW 546

退会済みユーザー
こんにちは!RubyとRailsを独学で勉強している者です。
今回はJavaScriptに関して質問があります。
RailsのWebアプリケーションを開発しておりますが、写真をアップロードする際にプレビュー表示を実装致しました。
その時に、iPhoneなどから撮った写真が横になるのを防ぐ方法を考えております。
以下のサイトの内容と全く同じことがしたいと思い、以下のサイトの通りに実装したのですが、JavaScriptが上手く動きません。
リンク内容
実装したコードは以下の通りです。(ライブラリはインストールしております。)
<script src="js/load-image.all.min.js"></script>
document.querySelector('input[type="file"]').addEventListener('change', function() {
var file = this.files[0];
loadImage.parseMetaData(file, (data) => {
var options = {
canvas: true
};
if (data.exif) {
options.orientation = data.exif.get('Orientation');
}
loadImage(file, (canvas) => {
var dataUri = canvas.toDataURL('image/jpeg');
// 画像を作成
var img = new Image();
img.src = dataUri;
document.body.appendChild(img);
}, options);
});
}
});
ちなみにサーバー側では以下のようにして写真が横になるのを防いでおります。
picture_uploader.rb
def fix_exif_rotation
manipulate! do |img|
img.auto_orient
img = yield(img) if block_given?
img
end
end
上の設定により、DBに保存後は正しい向きで写真が表示されます。
しかし、DBに保存する前のプレビュー画面では写真が横になってしまいます。
是非、アドバイスなどよろしくお願い致します。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
まだ回答がついていません
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.22%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正の依頼
m.ts10806
2018/09/24 14:50
同じ質問をあげられているようなので削除いらいを依頼を出しておいてくださいね
退会済みユーザー
2018/09/24 16:58 編集
すみません、次の質問は削除依頼を出しました。https://teratail.com/questions/148168