教材の内容に関係のない質問や教材とは異なる環境・バージョンで進めている場合のエラーなど、教材に関係しない質問は推奨していないため回答できない場合がございます。
その場合、teratailなどの外部サイトを利用して質問することをおすすめします。教材の誤字脱字や追記・改善の要望は「文章の間違いや改善点の指摘」からお願いします。
このパートでは画像アップロードするためにcarrierwaveとMiniMagickの導入を行います。
本パートでは、carrierwaveとMiniMagickの導入を行います。
今回のGemの導入に関しても、基本的に公式ドキュメントに沿って行っていくので、導入方法を覚える必要はないです。
では実際に進めていきましょう。
carrierwaveはファイルを簡単かつ柔軟にアップロードする方法を提供するライブラリです。
carrierwaveの公式ドキュメントを元にcarrierwaveを導入していきます。
まずは、Gemfileの最下部に以下のコードを追加します。
Copied!techpitgram
└── Gemfile
Gemfile1 Copied!gem 'carrierwave', '~> 2.0'
追加したら、bundle install
を実行してcarrierwaveをインストールします。
Copied!$ bundle install
次に、CarrierWaveのアップローダーを作成します。
以下のコマンドを実行してください。
Copied!$ rails g uploader image
上記のコマンドを実行すると以下のファイルが作成されます。
Copied!create app/uploaders/image_uploader.rb
Photoモデルのimageカラムと、先ほど作成したアップローダーImageUploader
と紐付けをします。(ImageUploader
はapp/uploaders/image_uploader.rb
のクラスの名前です。)
app/models/photo.rb
に以下のコードを追加してください。
app/models/photo.rb12345678 Copied!class Photo < ApplicationRecord
belongs_to :post
validates :image, presence: true
# ここを追加
mount_uploader :image, ImageUploader
end
MiniMagickは、CarrierWaveからImageMagickを使えるようにします。ImageMagickとは、画像処理ライブラリです。
MiniMagickを導入することで、画像をリサイズできます。
参考)MiniMagick
MiniMagickを使えるようにするにはimagemagick
を開発環境にインストールする必要があります。
まず開発環境がMacの方から説明していきます。
開発環境にimagemagick
があるかどうかは以下のコマンドで確認ができます。
Copied!$ brew list
上記のコマンドを実行して、imagemagick
があれば、既にインストールされています。
imagemagick
がなければ、以下のコマンドを実行して、imagemagick
をインストールしてください。
Copied!$ brew install imagemagick
Cloud9では、以下のコマンドでimagemagick
をインストールできます。
Copied!$ sudo yum update
$ sudo yum install -y ImageMagick
次に、Gemfileの最下部に以下のコードを追加します。
Copied!techpitgram
└── Gemfile
Gemfile1 Copied!gem "mini_magick"
上記のコードを追加できたらコマンドでbundle install
を実行します。
Copied!$ bundle install
次にapp/uploaders/image_uploader.rb
を修正します。
ここで修正するのは以下の3点です。
Copied!- 4行目のすでに生成されているコードのコメントを外す
- 「version :medium」というサイズを指定するコードを追加
- extension_whitelistメソッドのコメントアウトを外す
Copied!app
└── uploaders
└── image_uploader.rb
app/uploaders/image_uploader.rb12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 Copied!class ImageUploader < CarrierWave::Uploader::Base
# Include RMagick or MiniMagick support:
# include CarrierWave::RMagick
include CarrierWave::MiniMagick # ここのコメントアウトを外す
# Choose what kind of storage to use for this uploader:
storage :file
# storage :fog
# Override the directory where uploaded files will be stored.
# This is a sensible default for uploaders that are meant to be mounted:
def store_dir
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
end
# Provide a default URL as a default if there hasn't been a file uploaded:
# def default_url(*args)
# # For Rails 3.1+ asset pipeline compatibility:
# # ActionController::Base.helpers.asset_path("fallback/" + [version_name, "default.png"].compact.join('_'))
#
# "/images/fallback/" + [version_name, "default.png"].compact.join('_')
# end
# Process files as they are uploaded:
# process scale: [200, 300]
#
# def scale(width, height)
# # do something
# end
# Create different versions of your uploaded files:
# version :thumb do
# process resize_to_fit: [50, 50]
# end
# ==========ここから追加する==========
version :medium do
process resize_to_fill: [1080, 1080]
end
# ==========ここまで追加する==========
# Add a white list of extensions which are allowed to be uploaded.
# For images you might use something like this:
# ここのコメントアウトを外す
def extension_whitelist
%w(jpg jpeg gif png)
end
# Override the filename of the uploaded files:
# Avoid using model.id or version_name here, see uploader/store.rb for details.
# def filename
# "something.jpg" if original_filename
# end
end
ruby123 Copied!version :medium do
process resize_to_fill: [1080, 1080]
end
というコードでmedium
というバージョンが作成され、画像を1080 x 1080ピクセルにリサイズします。
以上で今回のパートは終了です。
お疲れさまでした。