LoginSignup
2
0

ImageMagick で長方形画像のアスペクト比を変えずに正方形にリサイズする

Last updated at Posted at 2022-06-25

はじめに

矛盾したタイトルに対してトンチに近い対策の話で、
画像をリサイズする際に(元と異なる)特定の縦横アスペクト比の画像ファイルを作りたいシーンは結構あります。

ImageMagick を使い始めたばかりだと、例えば、正方形(200x200)の画像を得ようと以下の通り実行して、その結果にガッカリするかもしれませんが、実はここにヒントがあります。

% magick rose: rose.png  # サンプル画像
% magick convert rose.png -resize 200x200 rose0.jpg
% magick identify rose.png rose0.jpg
rose.png PNG 70x46 70x46+0+0 8-bit sRGB 6975B 0.000u 0:00.001
rose0.jpg JPEG 200x131 200x131+0+0 8-bit sRGB 8329B 0.000u 0:00.000
rose.png (70x46) rose0.jpg (200x131)
rose.png rose1.jpg

処理結果は 200x200 になりません。ImageMagick の "-resize 200x200" は、画像の縦横比を維持して 200x200 を超えない範囲でサイズ変更する指定です。

正方形でない画像を元に、正方形の画像ファイルをつくるとき。主に以下の選択肢が考えられます。

% magick convert rose.png -resize '200x200!' rose1.jpg
% magick convert rose.png -resize 200x200x -background white
               -gravity center -extent 200x200 rose2.jpg
% magick convert rose.png -resize '200x200^'  \
               -gravity center -crop 1:1 rose3.jpg
% magick identify rose[1-3].jpg
rose1.jpg JPEG 200x200 200x200+0+0 8-bit sRGB 10783B 0.000u 0:00.000
rose2.jpg JPEG 200x200 200x200+0+0 8-bit sRGB 9470B 0.000u 0:00.000
rose3.jpg JPEG 200x200 200x200+0+0 8-bit sRGB 9652B 0.000u 0:00.000

rose1.jpg (アスペクト無視) rose2.jpg (内接,パディング) rose3.jpg (外接,クロップ)
rose1.jpg rose2.jpg rose3.jpg

rose1.jpg は縦横比を維持せずに 200x200 に引き伸ばす方式です。特殊用途です。

大抵は、rose2.jpg、rose3.jpg のどちらかを選択すると思います。
考え方としては、額縁に大きさの合わない写真を嵌め込むイメージです。どこに隙間を許すか、または隙間は許せないのでいっそ写真の端っこを切り取るか。前者を内接、後者は外接と呼びます。

各々の説明

rose0.jpg

-resize オプションを使った普通のリサイズです。ImageMagick のリサイズは特別な事をしないと元画像のアスペクト比を維持します。ただ、これだと元が正方形でない限り、正方形の画像は作れません。

rose.png (70x46) rose0.jpg (200x131)
rose.png rose1.jpg

rose1.jpg

-resize に ! をつけると、アスペクト比を維持せずに指定されたサイズに引き伸ばします。

% magick convert rose.png -resize '200x200!' rose1.jpg

! は shell が特別な解釈をするので、'〜' で囲う事で防いでます。

rose.png (70x46) rose1.jpg (200x200)
rose.png rose1.jpg

rose2.jpg

内接と呼ばれるリサイズ方法です。適当な色で隙間をうめサイズを合わせます。

image.png

% magick convert rose.png -resize 200x200 -background white  \
               -gravity center -extent 200x200 rose2.jpg

2つの処理があります。まずは、アスペクト比を維持して、小さめに(200x200を上回らない大きさに)リサイズします。その後、上下、または左右に白で隙間を埋めます。

% magick convert rose.png -resize 200x200 rose2-1.jpg
% magick identify rose2-1.jpg
rose2-1.jpg JPEG 200x131 200x131+0+0 8-bit sRGB 8329B 0.000u 0:00.000
% magick convert rose2-1.jpg-background white  \
               -gravity center -extent 200x200 rose2.jpg
rose.png (70x46) rose2-1.jpg(200x131) rose2.jpg (200x200)
rose.png rose2-1.jpg rose2.jpg

x:y# 記法 (蛇足)

7.1.0-14 から x:y# 記法が追加されたので、もう少しシンプルに出来ます。

~/ImageMagick/7.1.0-14/bin/magick convert rose.png -resize 200x200  \
               -background white -gravity center -extent '1:1#' rose2.jpg

同じサイズ 200x200 を二度指定しなくて済みます。正直、バージョンを考えると使うのは慎重になる方が良いかもです。

参考までに、7.1.0-13 以前で実行した時のエラーです。

% ~/ImageMagick/7.1.0-13/bin/magick convert rose: -resize 200x200  \
                  -background white -gravity center -extent '1:1#' rose2.jpg
convert: invalid argument for option '-extent': 1:1# @ error/convert.c/ConvertImageCommand/1562.

rose3.jpg

こちらは外接と呼ばれるリサイズ方法です。

image.png

% magick convert rose.png -resize '200x200^'  \
               -gravity center -crop 1:1 rose3.jpg

2つの処理があります。まずは、アスペクト比を維持して、大きめに(200x200を下回らない大きさに)リサイズします。そこから真ん中を 200x200 でクロップします。

% magick convert rose.png -resize '200x200^' rose3-1.jpg
% magick identify  rose3-1.jpg
rose3-1.jpg JPEG 304x200 304x200+0+0 8-bit sRGB 14069B 0.000u 0:00.000
% magick convert rose3-1.jpg \
               -gravity center -crop 1:1 rose3.jpg
rose.png (70x46) rose3-1.jpg(304x200) rose3.jpg (200x200)
rose.png rose3-1.jpg rose3.jpg

参考

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0