Saturday, August 16, 2008

ImageMagickで、青色っぽい部分とそれ以外の部分を色付けする

画像の青色っぽい部分とそれ以外の部分を、それぞれ白黒化して別の色で着色するには、以下のバッチファイルを実行します。

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.45)?1:0" -channel rgb -fx "luminance" -fill #aaccff -tint 90 ( sf.jpg -fx "luminance" -fill #F8C749FF -tint 90 ) +swap -composite sample534a.jpg

上記バッチでは、青色っぽい部分を白黒化して#aaccffで着色して、それ以外の部分も白黒化してオレンジ色(#F8C749FF)で着色しています。

元画像(sf.jpg)


出力画像(sample534a.jpg)


関連項目
ImageMagickで、青っぽい所以外を白黒にする

ImageMagickとPHPで一部だけ焦点の合っている画像に処理する

ImageMagickとPHPで一部だけ焦点の合っている画像に処理するには、以下のコードを実行します。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja" dir="ltr">
<head>
<title>sample533(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 指定の点から徐々にぼかす */
/* 円の中心 */
$cx = 130;
$cy = 160;
/* 半径初期値 */
$ir = 30;
/* 半径増分値 */
$dr = 20;
/* ぼかし */
$ib = 0;
/* ぼかし増分値 */
$db = 1;
/* 繰り返し回数 */
$ct = 8;
/* 読み込み画像名 */
$fn = "sf.jpg";

$im = new Imagick($fn);
$im->setImageMatte(true);
for($li=0;$li<$ct;$li++){
$imt = new Imagick($fn);
/* マスク画像を生成 */
$mask = new Imagick();
$mask->newImage($im->getImageWidth(), $im->getImageHeight(), 'none');
/* 円を描画 */
$idraw = new ImagickDraw();
$idraw->setFillColor("#FFFFFF");
$idraw->ellipse($cx, $cy, $ir, $ir, 0, 360);
$mask->drawImage($idraw);
/* マスク画像を使用して画像を切り取り */
$mask->compositeImage($imt, Imagick::COMPOSITE_IN, 0, 0, Imagick::CHANNEL_ALL);
$mask->blurImage(0, $ib, Imagick::CHANNEL_ALL);
$images[] = $mask;
$ir += $dr;
$ib += $db;
$imt->clear();
$imt->destroy();
}
$im->blurImage(0, $ib, Imagick::CHANNEL_ALL);
for($li=$ct-1;$li>=0;$li--){
$im->compositeImage($images[$li], Imagick::COMPOSITE_DEFAULT, 0, 0, Imagick::CHANNEL_ALL);
$images[$li]->clear();
$images[$li]->destroy();
}

$im->writeImage('sample533a.jpg');
/* $im->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im->destroy();
?>

<img src="sample533a.jpg" />

</body>
</html>


元画像(sf.jpg)


出力画像(sample533a.jpg)


環境
Apache 2.2.8/PHP5.2.5/ImageMagick6.4.2

関連項目
ImageMagickで一部分だけ焦点のあっている画像に処理する (Convertコマンドでの同様の処理)

Thursday, August 14, 2008

RMagickで画像の上下を半透明にする

RMagickで画像の上下を半透明にするには、以下のコードを実行します。

require 'RMagick'
include Magick

# 上下が半透明になった画像の生成
images = ImageList.new("sf.jpg")
images[0].alpha = ActivateAlphaChannel
mo = images.fx("abs(sin(pi*j/h))", Magick::AlphaChannel)
mo.write("sample532a.png")

# クリーム色の背景と重ね合わせ
img2 = Image.new(images[0].columns+20, images[0].rows+20){
self.background_color = "#ffffe0"
}
img3 = img2.composite(mo, CenterGravity, 0, 0, OverCompositeOp);
img3.write("sample532b.png")

exit

元画像(sf.jpg)


出力画像(sample532a.png)



出力画像(sample532b.png)


動作環境
ruby1.8.6-26/RMagick-2.3.0-ImageMagick-6.4.0-2-Q8

関連項目
ImageMagickで画像の上下を半透明グラデーションにする (Convertコマンドでの同様の処理)

Wednesday, August 13, 2008

Java2Dで画像を2値化する

Java2Dで画像を2値化するには、以下のコードを実行します。

import java.io.*;
import java.awt.*;
import java.awt.geom.*;
import java.awt.image.*;
import javax.imageio.*;

public class Java2DTest15
{
public static void main(String args[])
throws Exception
{
/* 画像を2値化する */
BufferedImage img = ImageIO.read(new File("sf.jpg"));

/* まずグレースケールに変換 */
WritableRaster wr = img.getRaster();
int buf[] = new int[wr.getNumDataElements()];
for(int ly=0;ly<wr.getHeight();ly++){
for(int lx=0;lx<wr.getWidth();lx++){
wr.getPixel(lx, ly, buf);

int maxval = Math.max(Math.max(buf[0], buf[1]), buf[2]);
int minval = Math.min(Math.min(buf[0], buf[1]), buf[2]);
buf[0] = buf[1] = buf[2] = (maxval+minval)/2;

wr.setPixel(lx, ly, buf);
}
}

/* lookupデータ作成 */
byte dat[] = new byte[256];
for(int di=0;di<256;di++){
dat[di] = di>256*0.55?(byte)255:(byte)0;
}
LookupOp lo = new LookupOp(new ByteLookupTable(0, dat), null);
BufferedImage img2 = lo.filter(img, null);

ImageIO.write(img2, "jpg", new File("sample531a.jpg"));
}
}

元画像(sf.jpg)


出力画像(sample531a.jpg)


環境
JDK6 Upadate6(JDK1.6.0_06)

Tuesday, August 12, 2008

ImageMagickとPHPで画像の端を暗くする

Imagickで画像の端を暗くするには、以下のコードを実行します。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja" dir="ltr">
<head>
<title>sample530(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 画像の周りを暗くする */
$im = new Imagick("sf.jpg");
$im2 = new Imagick();
$im2->newImage($im->getImageWidth(), $im->getImageHeight(), 'none');
$im2->setImageBackgroundColor('#000000a0');
$im2->spliceImage(10, 10, $im->getImageWidth(), $im->getImageHeight());
$im2->spliceImage(10, 10, 0, 0);
$im2->blurImage(0, 10, Imagick::CHANNEL_ALL);
$im2->cropImage($im->getImageWidth(), $im->getImageHeight(), 10, 10);
$im->compositeImage($im2, Imagick::COMPOSITE_DEFAULT, 0, 0);
$im->writeImage('sample530a.jpg');
/* $im2->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im2->destroy();
/* $im->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im->destroy();
?>

<img src="sample530a.jpg" />

</body>
</html>

元画像(sf.jpg)


出力画像(sample530a.jpg)


環境
Apache 2.2.8/PHP5.2.5/ImageMagick6.4.2

ImageMagickで四角の墨をグラデーションのように塗る - その2

ImageMagickで四角の墨をグラデーションのように塗るには、以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.4.0-Q16
%im%\convert.exe -size 100x100 xc:white -background #ccddff -virtual-pixel background -blur 0x10 sample408a.png

出力画像(sample408a.png)

Monday, August 11, 2008

Rmagickで半透明のぼかし文字列を描画する

Rmagickで半透明のぼかし文字列を描画するには、以下のコードを実行します。

require 'RMagick'
include Magick

images = ImageList.new("sf.jpg")
images[0].alpha = ActivateAlphaChannel
img2 = Image.new(images[0].columns, images[0].rows){
self.background_color = "none"
}
img2.alpha = ActivateAlphaChannel

dr = Draw.new
# 使用フォント
dr.font = "Tahoma"
# ポイントサイズ
dr.pointsize = 20
# 描画色
dr.fill = "#ffffffa0"
# gravity
dr.gravity = CenterGravity
dr.annotate(img2, 0, 0, 0, 0, "San Francisco")
img3 = img2.blur_channel(0, 1, ChannelType::AllChannels)

images << images =" images.mosaic">

元画像(sf.jpg)


出力画像(sample527a.png)


動作環境
ruby1.8.6-26/RMagick-2.3.0-ImageMagick-6.4.0-2-Q8

関連項目
RMagickで半透明影つきの文字列を描画する
RMagickで日本語文字列を描画する

Sunday, August 10, 2008

ImageMagickとPHPで手書き風の文字列をアニメーションGIFにする

ImageMagickとPHPで手書き風の文字列をアニメーションGIFにするには、以下のコードを実行します。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja" dir="ltr">
<head>
<title>sample526(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 手書き風の文字列を描画する */
$im = new Imagick();

for($li=0;$li<3;$li++){
$im2 = new Imagick();
$im2->newImage(300, 80, 'white');

$idraw = new ImagickDraw();
/* フォント設定 */
$idraw->setFont("Comic-Sans-MS-Bold");
/* フォントサイズ設定 */
$idraw->setFontSize(40);
/* gravity設定 */
$idraw->setGravity(Imagick::GRAVITY_CENTER);
/* 描画色 */
$idraw->setFillColor("#bbddff");
$im2->annotateImage($idraw, 0, 0, 0, "ImageMagick");
$im2->spreadImage(1);
$im2->medianFilterImage(1);
$im->addImage($im2);
$im->setImageDelay(30);
/* $im2->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im2->destroy();
}

$im->writeImages('sample526a.gif', true);
/* $im->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im->destroy();
?>

<img src="sample526a.gif" />

</body>
</html>

出力画像(sample526a.gif)


環境
Apache 2.2.8/PHP5.2.5/ImageMagick6.4.2

関連項目
PHPとImageMagickでアニメーションGIFを生成する
ImageMagickとPHPで文字列を画像で塗りつぶす
ImageMagickとPHPで半透明のぼかし文字列を描画する
ImageMagickとPHPで、画像に日本語の文字列を描画する
ImageMagickとPHPで手書き風の円に囲まれた文字を描画する