Я погоджуюся з прийнятою відповіддю -geometry +0+0
на видалення зайвого простору плитки, і я додам -mode Concatenate
(за певних умов).
Крім того, після того, як ви маєте різні розміри montage
, вам стає важко розрізнити, що таке "фон плитки" (плитковий простір) проти "рамка" та "межа" - я часто втрачаю інформацію про себе, тому ось невеликий тестовий випадок із (кнопки) зображення:
#$ montage --version # done on:
#Version: ImageMagick 6.6.2-6 2012-08-17 Q16 http://www.imagemagick.org
# pipe to `display` (for preview):
# montage img1.png img3.png img2.png img4.png bmp:- | display
# generate images first
convert -size 200x100 xc:red img1.png
convert -size 300x200 xc:blue img2.png
convert -size 400x300 xc:green img3.png
convert -size 500x400 xc:orange img4.png
# #01: direct montage (-tile 2x2 automatic for four images)
# note: mont01.png is 256x252 pixels!
montage img1.png img3.png img2.png img4.png \
mont01.png
data:image/s3,"s3://crabby-images/d9e03/d9e03ea8aa6c97f5e33c8ae2675ef87b99a286be" alt="mont01"
# "The 'tile' size is then set to the largest dimentions
# of all the resized images, and the size actually specified."
# "by removing the 'size' component, non of the images will
# be resized, and the 'tile' size will be set to the largest
# dimensions of all the images given"
# #02: specify -geometry offset (tile spacing)
# note: mont02.png is 1008x808 pixels now!
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 \
mont02.png
data:image/s3,"s3://crabby-images/130db/130db6d8d6fc4b61e51101998d2f5113fbf05bce" alt="mont02"
# #03: add border to command #02:
# border sticks around images themselves
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -border 5 \
mont03.png
data:image/s3,"s3://crabby-images/daf13/daf1347a2de508011b056212a5b1610f2642bef1" alt="mont03"
# #04: add frame to command #02:
# frame is around the tile (and is "3D") - and
# background (which isn't image) is colored default gray:
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -frame 5 \
mont04.png
data:image/s3,"s3://crabby-images/9a40d/9a40d3d97dbe1d5f63bff09679ad3f8f0821bdbe" alt="монт04"
# #05: add background color spec to command #04:
# that is background behind the tiles - not of the tiles
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -frame 5 -background "brown" \
mont05.png
data:image/s3,"s3://crabby-images/1bd00/1bd00f3ae39a4dd58142168c5c9e861fbccb3337" alt="mont05"
# #06: add mattecolor to command #05:
# "-mattecolor The color used as the frame color."
# but just changes color of the "3D" frame borders
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -frame 5 -mattecolor "white" -background "brown" \
mont06.png
data:image/s3,"s3://crabby-images/0a742/0a7424bd307ffb52e3c178554155b358655108b1" alt="mont06"
# #07: add bordercolor to command #05:
# "-bordercolor The fill color inside the frame for images, or any border padding."
# this does change the color of time background
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -frame 5 -bordercolor "purple" -background "brown" \
mont07.png
data:image/s3,"s3://crabby-images/f0e16/f0e1678aa517e32d74c64e0a92107626953ad4f4" alt="mont07"
# #08: both frame and border :
# no difference from command #07 -
# once the tiles are resized, the entire remaining
# background is used as a "border", and specifying
# "-border 5" size for it has no effect
montage img1.png img3.png img2.png img4.png \
-geometry +2+2 -frame 5 -border 5 -bordercolor "purple" \
mont08.png
data:image/s3,"s3://crabby-images/eff43/eff4397851e4da4be6c4e279ff1f248fee4733e5" alt="mont08"
# #09: add mode Concatenate (with -tile) to #08
# No difference from #08
montage img1.png img3.png img2.png img4.png \
-mode Concatenate -tile 2x2 -geometry +2+2 -frame 5 -border 5 -bordercolor "purple" \
mont09.png
data:image/s3,"s3://crabby-images/cec2e/cec2e915a7175cb9bae28f295428a21aaf38d304" alt="mont09"
# #10 remove -frame, from #09
# now there is no tile background, and
# images are not centered in tiles (they
# have gravity NorthWest instead)
montage img1.png img3.png img2.png img4.png \
-mode Concatenate -tile 2x2 -geometry +2+2 -border 5 -bordercolor "purple" \
mont10.png
data:image/s3,"s3://crabby-images/c98ca/c98ca98f36d041442a697d06159f2099b8a23b2b" alt="монт10"
# #11 Mode Concatenate with only -tile
# images are without padding (as much as possible)
montage img1.png img3.png img2.png img4.png \
-mode Concatenate -tile 2x2 -border 5 -bordercolor "purple" \
mont11.png
data:image/s3,"s3://crabby-images/7f4c1/7f4c1cce49c429298c3ba8edd8343ee33e5b791a" alt="mont11"
# #12 Try geometry +0+0 instead of concatenate
# almost the same as #11, except more correct overall borders
montage img1.png img3.png img2.png img4.png \
-tile 2x2 -geometry +0+0 -border 5 -bordercolor "purple" \
mont12.png
data:image/s3,"s3://crabby-images/ed04c/ed04c22cf6fc19b6eb3672998d68eb05213c2b5e" alt="mont12"
Ну, сподіваємось, це може бути корисним,
ура!
EDIT: Я зібрав невеликий графічний інтерфейс Python / Tkinter / PIL для ImageMagick, tkGui_ImageMagick.py - і, нарешті, я міг знайти відповідний командний рядок для чогось, що я хотів: зробити фотомонтаж із чотирьох зображень, де висота та ширина плитки узгоджуються з якоюсь найбільшою шириною стовпця (або висотою рядка).
У цьому прикладі img1 (200x100) та img2 (300x200) переходять у перший стовпчик, більша ширина - 300 - що має встановити ширину плитки img1. Крім того, img1 має відповідати висоті img3 (300 px), з якою він утворює рядок. Це можна вказати через extent
оператора (див. Також ImageMagick • Переглянути тему - Змінити розмір та накладку замість розтягування ). І цей командний рядок вимагає викликів підпроцесу, щоб розділити montage
s для кожного стовпця - а звідти - окремого convert
s для кожного зображення:
montage \
<(montage \
<(convert \
img1.png -gravity center -extent 300x300 \
bmp:-) \
<(convert \
img2.png -gravity North -extent x400 \
bmp:-) \
-tile 1x -geometry +0+0 \
bmp:-) \
<(montage \
<(convert \
img3.png -gravity center -extent 500x \
bmp:-) \
img4.png \
-tile 1x -geometry +0+0 \
bmp:-) \
-geometry +0+0 -border 2 \
mont13.png
# or as one liner:
montage <(montage <(convert img1.png -gravity center -extent 300x300 bmp:-) <(convert img2.png -gravity North -extent x400 bmp:-) -tile 1x -geometry +0+0 bmp:-) <(montage <(convert img3.png -gravity center -extent 500x bmp:-) img4.png -tile 1x -geometry +0+0 bmp:-) -geometry +0+0 -border 2 mont13.png
data:image/s3,"s3://crabby-images/16229/16229ed169940eab13a526afc392f5cb9abd2a1d" alt="mont13"
Зауважте тут, якби ми використовували -extents
прямо в монтажному рядку, як це:
montage \
img1.png -extent 300x200 -gravity center \
img2.png -extent 0x400 -gravity North \
-tile 1x -geometry +0+0 \
bmp:-
... ми помітимо, що перша специфікація висоти (200) буде ігнорована, а 400 як більша буде застосована до обох плиток будь-коли !
Таким чином , ми повинні контролювати заповнення кожного окремого зображення (по телефону convert
з extents
для кожного ) , - а потім уникати extents
в montage
лінії; і, таким чином, ми повинні знати, що найбільша ширина кожного стовпця (і висота кожного ряду). Зверніть увагу також:
- Оскільки img1 менший за мається на увазі ширину / висоту сусідів, ми мусимо чітко встановити і ширину, і висоту в його розширеннях
- Інший вимір може мати лише вказаний відповідний розмір - а img4, як найбільший, взагалі не повинен бути прокладеним (і пропущеним
convert
)
- В
montage
, як правило, -gravity
має прийти після (повністю вказано: w & h) -extent
; в convert
, -gravity
працює раніше -extent
(зазвичай)