Friday, September 14, 2007

ImageMagickで透明なラインが入った円を描画する

同心円の透明なラインが入った円を描画するには、以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:none -channel rgba -fx "(i-90)^2+(j-130)^2<=70^2&&floor(sqrt((i-90)^2+(j-130)^2))%%4>1?#C9BFAAFF:#00000000" sample222a.png

出力画像(sample222a.png)


rem 重ねあわせ例
%im%\convert.exe sf.jpg sample222a.png -composite sample222b.jpg

重ね合わせ例(sample222b.jpg)


関連項目
ImageMagickで、グラデーションのかかった同心円を描画する

Thursday, September 13, 2007

ImageMagickでだんだん小さくなっていく水玉模様を描画する

ImageMagickでだんだん小さくなっていく水玉模様を描画するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:none -fx "(i%%20-10)^2+(j%%20-10)^2<=(8-floor(i/20)*0.6)^2?#7090E0:#E0E0F0"
sample221a.jpg

出力画像(sample221a.jpg)


関連項目
ImageMagickで、グラデーションのかかった水玉模様を描画する

ImageMagickで半透明グラデーションの放射ストライプを描画する

ImageMagickで半透明グラデーションの放射ストライプを描画するには、以下のバッチを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:white -channel rgb -fx "floor((atan2(50-i,170-j)+2*pi)/(pi/24))%%2==0?#F8C749:#FCE769" -channel a -fx "0.5-sqrt((50-i)^2+(170-j)^2)/200" -channel rgba sample218a.png

rem 重ねあわせ例
%im%\convert.exe sf.jpg sample218a.png -composite samples218b.jpg

出力画像(sample218a.png)


重ねあわせ例(sample218b.jpg)


2008/01/04追記
ver6.3.7では、以下のように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe -size 200x200 xc:white -channel rgb -fx "floor((atan2(50-i,170-j)+2*pi)/(pi/24))%%2==0?#F8C749:#FCE769" -matte -channel a -fx "0.5-sqrt((50-i)^2+(170-j)^2)/200" -channel rgba sample218a.png
rem 重ねあわせ例
%im%\convert.exe sf.jpg sample218a.png -composite samples218b.jpg

Wednesday, September 12, 2007

ImageMagickで半透明の放射ストライプを画像に重ねあわせる

ImageMagickで半透明の放射ストライプを画像に重ねあわせるには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sf.jpg ( -size 200x200 xc:none -channel rgba -fx "floor((atan2(100-i,170-j)+2*pi)/(pi/24))%%2==0?#7090E050:#00000000" ) -composite sample219a.jpg

元画像(sf.jpg)


出力画像(sample219a.jpg)


関連項目
ImageMagickで半透明グラデーションの放射ストライプを描画する

Monday, September 10, 2007

ImageMagickで任意の位置を中心とした放射ストライプを描画する

ImageMagickで任意の位置を中心とした放射ストライプを描画するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:white -fx "floor((atan2(50-i,170-j)+2*pi)/(pi/24))%%2==0?#F8C749:#FCE769" sample218a.png
上の例では7.5度ごとに2色のストライプを描画します。

出力画像(sample218a.png)


下の例では30度ごとに2色のストライプを描画します。
%im%\convert.exe -size 200x200 xc:white -fx "floor((atan2(100-i,100-j)+2*pi)/(pi/6))%%2==0?#808080:#D0D0D0" sample218b.png

出力画像(sample218b.jpg)


関連項目
ImageMagickで半透明グラデーションの放射ストライプを描画する

ImageMagickで円状に透明スリットが広がるように加工する

ImageMagickで円状に透明スリットが広がるように加工するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:none sf.jpg -channel rgba -fx "dp=sqrt((120-i)^2+(150-j)^2); dp<20||(dp-20)%%15>floor((dp-20)/15)?v.p:#00000000" sample217a.png

元画像(sf.jpg)


出力画像(sample217a.png)


2008/01/04追記
ver6.3.7では、以下のように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe -size 200x200 xc:none sf.jpg -matte -channel rgba -fx "dp=sqrt((120-i)^2+(150-j)^2); dp<20||(dp-20)%%15>floor((dp-20)/15)?v.p:#00000000" sample217a.png

Friday, September 07, 2007

ImageMagickで透明なスリットが徐々に広くなっていく加工をする

ImageMagickで透明なスリットが徐々に広くなっていく加工をするには、
以下のバッチを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 xc:none sf.jpg -channel rgba -fx "j<h/3||(j-h/3)%%15>floor((j-h/3)/15)?v.p:#00000000" sample216a.png
上記では、画面の1/3の高さから徐々にスリットが広がるようになっています。

元画像(sf.jpg)


出力画像(sample216a.png)


2008/01/04追記
ver6.3.7では、以下のように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe -size 200x200 xc:none sf.jpg -matte -channel rgba -fx "j<h/3||(j-h/3)%%15>floor((j-h/3)/15)?v.p:#00000000" sample216a.png


関連項目
ImageMagickで円状に透明スリットが広がるように加工する

ImageMagickで透明なスリットの入ったグラデーションの角丸四角を描画する

ImageMagickで透明なスリットの入ったグラデーションの角丸四角を描画するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
rem 1ピクセルごとに透過ライン
%im%\convert.exe -size 150x150 xc:none -fill gradient:#7090E0-#F8C749 -draw "roundrectangle 0,0 149,149 15,15" -channel rgba -fx "j%%2==0?p:#00000000" sample215a.png

出力画像(sample215a.png)


rem 重ねあわせ例
%im%\convert.exe sf.jpg sample215a.png -geometry +25+25 -composite sample215b.jpg

重ねあわせ例(sample215b.jpg)


rem 2ピクセルごとに2ピクセルの透過ライン
%im%\convert.exe -size 150x150 xc:none -fill gradient:#7090E0-#F8C749 -draw "roundrectangle 0,0 149,149 15,15" -channel rgba -fx "j%%4>1?p:#00000000" sample215c.png

出力画像(sample215c.png)

Thursday, September 06, 2007

ImageMagickで任意の大きさの十字柄の背景画像を作成する

ImageMagickで任意の大きさの十字柄の背景画像を作成するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 100x100 xc:none -fx "gw=20; gh=20; lw=10; lh=10; spx=(gw-lw)/2; epx=lw+spx; spy=(gh-lh)/2; epy=lh+spy; ((i%%gw>=spx)&&amp;amp;(i%%gw<=epx)&&(j%%gh==floor(gh/2)))||((j%%gh>=spy)&&amp;amp;(j%%gh<=epy)&&(i%%gw==floor(gw/2)))?#2060D4:#FFFFF0" sample214a.jpg

出力画像(sample214a.jpg)

Wednesday, September 05, 2007

ImageMagickで指定の円の外側を徐々に引き伸ばす

ImageMagickで指定の円の外側を徐々に引き伸ばすには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sample6.jpg -fx "cx=50; cy=50; rc=20; dx=cx-i; dy=cy-j; pr=atan2(dx,dy)+pi/2; dp=sqrt(dx^2+dy^2); dm=dp-sqrt(dp-rc); dp>rc?p{cx+cos(pr)*dm,cy-sin(pr)*dm}:p" sample213a.png

上記バッチでは、中心50,50で半径20の円の外側が引き伸ばされています。

元画像(sample6.jpg)


出力画像(sample213a.png)


下のバッチでは、中心100,150、半径60ピクセルの円の外側が引き伸ばされています。
%im%\convert.exe sf.jpg -fx "cx=100; cy=150; rc=60; dx=cx-i; dy=cy-j; pr=atan2(dx,dy)+pi/2; dp=sqrt(dx^2+dy^2); dm=dp-(dp-rc)/3; dp>rc?p{cx+cos(pr)*dm,cy-sin(pr)*dm}:p" sample213b.png

元画像(sf.jpg)


出力画像(sample213b.png)



Tuesday, September 04, 2007

ImageMagickで黄色っぽい部分以外が透明な透過PNGを作成する

ImageMagickで黄色っぽい部分以外が透明な透過PNGを作成するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sample6.jpg -channel a -fx "(hue>0.11&&amp;hue<0.19&&intensity<0.93&&saturation>0.5)?1:0" sample212a.png
%im%\convert.exe sample7.jpg -channel a -fx "(hue>0.11&&amp;hue<0.19&&intensity<0.93&&saturation>0.5)?1:0" sample212b.png

元画像1(sample6.jpg)


出力画像1(sample212a.png)


元画像2(sample7.jpg)


出力画像2(sample212b.png)


2008/01/04追記
ver6.3.7では、以下のように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe sample6.jpg -matte -channel a -fx "(hue>0.11&&hue<0.19&&intensity<0.93&&saturation>0.5)?1:0" sample212a.png
%im%\convert.exe sample7.jpg -matte -channel a -fx "(hue>0.11&&hue<0.19&&intensity<0.93&&saturation>0.5)?1:0" sample212b.png

Monday, September 03, 2007

ImageMagickで任意の位置からゆらぎをかける

ImageMagickで任意の位置からゆらぎをかけるには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sample3b.jpg -fx "j>h/3?p[cos(pi*(j-h/3)/10)*sqrt(j-h/3),0]:p" sample211a.jpg

上記のバッチでは、1/3の高さから揺らぎを徐々に強くかけています。

元画像(sample3b.jpg)


出力画像(sample211a.jpg)
ImageMagickでゆらぎをかけた画像

関連項目
ImageMagickで、画像を中心から上下へ徐々に大きく揺らす
RMagickで画像を揺らす (RMagickによる同様の処理)

Sunday, September 02, 2007

ImageMagickで任意の位置から右方向に画像を引き伸ばす

ImageMagickで任意の位置から右方向に画像を引き伸ばすには、
以下のバッチを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sample4.jpg -fx "i>w/2?p[-sqrt(i-w/2),0]:p" sample210a.jpg

元画像(sample4.jpg)


出力画像(sample210a.jpg):画面の右半分を引き伸ばした例


さらに引き伸ばす場合は、以下のコマンドを実行します。
%im%\convert.exe sample4.jpg -fx "i>w/2?p[-(i-w/2)/2,0]:p" sample210b.jpg

出力画像(sample210b.jpg)

ImageMagickで任意の大きさの水玉模様を描画する

ImageMagickで任意の大きさの水玉模様を描画するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 100x100 xc:none -fx "(i%%20-10)^2+(j%%20-10)^2<=8^2?#F4D6D4:#FFF0F0" sample209a.jpg

出力画像(sample209a.jpg)


関連項目
ImageMagickで、グラデーションのかかった水玉模様を描画する
ImageMagickで交互に円が配置された水玉模様を描画する

Friday, August 31, 2007

ImageMagickで任意の大きさの斜め四角模様を作成する

ageMagickで任意の大きさの斜め四角模様を作成するには、
以下のバッチを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 100x100 xc:none -fx "((200+j-i)%%10==0)||((i+j)%%10==0)?#404080:#7090F0" sample208a.jpg

上記の例では10x10の大きさの四角を斜めに描画しています。

出力画像(sample208a.jpg)

Thursday, August 30, 2007

ImageMagickで青っぽい部分以外が上下に揺れたような加工をする

ImageMagickで青っぽい部分以外が上下に揺れたような加工をするには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sf.jpg -channel a -fx "(hue>0.47&&amp;hue<0.69&&luminosity>0.5)?1:0" -channel rgba ( sf.jpg -motion-blur 0x5+270 ) +swap -composite sample200a.jpg

元画像(sf.jpg)


出力画像(sample200a.jpg)


2008/01/04追記
ver6.3.7では、以下のように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe sf.jpg -matte -channel a -fx "(hue>0.47&&hue<0.69&&luminosity>0.5)?1:0" -channel rgba ( sf.jpg -motion-blur 0x5+270 ) +swap -composite sample200a.jpg

2008/07/13追記
ver6.4.0あたりからluminosityからlightnessに変わったので、以下のバッチを実行します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.4.2-Q16
%im%\convert.exe sf.jpg -matte -channel a -fx "(hue>0.47&&hue<0.69&&lightness>0.5)?1:0" -channel rgba ( sf.jpg -motion-blur 0x5+270 ) +swap -composite sample200a.jpg

ImageMagickで画像に任意の大きさのグリッドを描画する

ImageMagickで画像に任意の大きさのグリッドを描画するには、
以下のバッチを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x200 sf.jpg -fx "i%%20==0||j%%20==0?0:p" sample207a.png

横方向の大きさはi%%<ピクセル数>の部分で指定し、
縦方向の大きさはj%%<ピクセル数>の部分で指定します。

元画像(sf.jpg)


出力画像(sample207a.png)

Wednesday, August 29, 2007

ImageMagickで二値化して大きめに選択した領域をぼかして切り取り

ImageMagickで二値化して大きめに選択した領域をぼかして切り取りするには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe sample5.jpg ( sample5.jpg -threshold 53000 -channel A -fx "p.r==1?0:1" -blur 0x2 -fx "p.a>0?1:0" -blur 0x2 ) -channel a -fx "v.p{i,j}.a" -channel rgba sample206a.png
%im%\convert.exe -size 100x100 xc:black sample206a.png -composite sample206b.jpg

上記バッチファイルでは、1回目の-blurで領域を増やして領域を増やして、
再度0と1に-fxで計算してから、2回目の-blurでぼかしています。

元画像(sample5.jpg)


出力画像(sample206a.png)


黒背景と重ねあわせ例(sample206b.jpg)


2008/01/04追記
ver6.3.7では、以下のバッチファイルのように-matteを追加します。
rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.7-Q16
%im%\convert.exe sample5.jpg ( sample5.jpg -threshold 53000 -matte -channel A -fx "p.r==1?0:1" -blur 0x2 -fx "p.a>0?1:0" -blur 0x2 ) -matte -channel a -fx "v.p{i,j}.a" -channel rgba sample206a.png
%im%\convert.exe -size 100x100 xc:black sample206a.png -composite sample206b.jpg

関連項目
ImageMagickで画像を2値化して大き目の領域で切り取り

Tuesday, August 28, 2007

ImageMagickで横線の入った文字を描画する

ImageMagickで横線の入った文字を描画するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 200x50 xc:white -fx "j%%3==0?#707070:#FFFFFF" +antialias -font Tahoma-Bold -gravity center -fill white -draw "font-size 28 text 0,0 'ImageMagick'" ( -size 200x50 xc:none +antialias -font Tahoma-Bold -gravity center -fill red -draw "font-size 28 text 0,0 'ImageMagick'" -channel a -fx "(p.r==1)?1:0" -channel rgb -fx "j%%3<2?#707070:#FFFFFF" -channel rgba ) -composite sample205a.png

上記バッチファイルでは、背景部分が3ピクセル毎に横線を引き、
文字の部分は3ピクセルのうち2ピクセルに横線を描画しています。

出力画像(sample205a.png)

Monday, August 27, 2007

ImageMagickで三角模様の背景画像を作成する

ImageMagickで三角模様の背景画像を作成するには、
以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.3.5-Q16
%im%\convert.exe -size 100x100 xc:none -fx "((i%%10+j%%10)>=10)?#FFFFF0:#C0B49D" sample204s.jpg

出力画像(sample204s.jpg)


%im%\convert.exe -size 100x100 xc:none -fx "((j%%15-i%%15)>0)?#A0C0F0:#F0F0FF" sample204b.jpg

出力画像(sample204b.jpg)


関連項目
ImageMagickで三角の背景画像を生成する