Friday, August 22, 2008

Java2Dでコントラストを落とした画像を作成する

Java2Dでコントラストを落とした画像を作成するには、以下のコードを実行します。

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

public class Java2DTest16
{
public static void main(String args[])
throws Exception
{
/* コントラストを落とした画像を作成する */
BufferedImage img = ImageIO.read(new File("sf2.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);
buf[0] = (byte)(buf[0]*0.2 + 256*0.4);
buf[1] = (byte)(buf[1]*0.2 + 256*0.4);
buf[2] = (byte)(buf[2]*0.2 + 256*0.4);
wr.setPixel(lx, ly, buf);
}
}

ImageIO.write(img, "jpg", new File("sample540a.jpg"));
}
}

元画像(sf2.jpg)


出力画像(sample540a.jpg)


環境
JDK6 Upadate6(JDK1.6.0_06)

Thursday, August 21, 2008

ImageMagickで画像の左上の右下に半透明グラデーションをかける

画像の左上の右下に半透明グラデーションをかけるには、以下のバッチファイルを実行します。

rem 環境によって変えてね
set im=C:\Progra~1\ImageMagick-6.4.2-Q16
%im%\convert.exe sf2.jpg ( -size 300x225 xc:black -matte -channel rgba -strokewidth 200 -stroke white +antialias -draw "line 0,225,300,0" -fill #bbddffd0 -opaque black -transparent white -blur 0x20 ) -composite sample539a.jpg

上記バッチファイルでは、極太の線を左下から右上に描画し、白黒の色を半透明の青っぽい
色と透明に変えてからぼかして重ね合わせています。

元画像(sf2.jpg)


出力画像(sample539a.jpg)

Wednesday, August 20, 2008

ImageMagickとPHPで画像を円形に切り取って、点線が回転するアニメーションGIFを作成する

Imagickで画像を円形に切り取って、点線が回転するアニメーション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>sample538(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 画像を円形に切り取って、点線が回転するアニメーションGIFを作成する */
$images = new Imagick();

for($ii=0;$ii<8;$ii++){
$im = new Imagick('sample3b.jpg');
$im2 = new Imagick();
$im2->newImage($im->getImageWidth(), $im->getImageHeight(), "none");
$idraw = new ImagickDraw();
$idraw->setFillColor('#ffffff');
$idraw->ellipse(
$im->getImageWidth()/2, $im->getImageHeight()/2,
$im->getImageWidth()/2-2, $im->getImageHeight()/2-2,0,360);
$im2->drawImage($idraw);
$idraw->clear();
$idraw->destroy();
/* マスクを使用して切り取り */
$im2->compositeImage($im, Imagick::COMPOSITE_IN, 0, 0, Imagick::CHANNEL_ALL);
$idraw = new ImagickDraw();
$idraw->setFillColor("none");
$idraw->setStrokeColor('#c0b49d');
/* 点線のスタイル */
$idraw->setStrokeDashArray(array(4,4));
/* 点線のオフセット */
$idraw->setStrokeDashOffset($ii);
/* 線の太さ */
$idraw->setStrokeWidth(2);
$idraw->ellipse(
$im->getImageWidth()/2, $im->getImageHeight()/2,
$im->getImageWidth()/2-3, $im->getImageHeight()/2-3,0,360);
$im2->drawImage($idraw);

$images->addImage($im2);
/* $idraw->clear(); 2008/09/30追記:destroyと同様にClearDrawingWandを呼ぶので必要なし */
$idraw->destroy();
/* $im2->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im2->destroy();
/* $im->clear(); 2008/09/30追記:destroyと同様にClearMagicWandを呼ぶので必要なし */
$im->destroy();
}

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

<img src="sample538a.gif" />

</body>
</html>



元画像(sample3b.jpg)


出力画像(sample538a.gif)

Tuesday, August 19, 2008

RMagickで画像を揺らす

RMagickで1/3の位置から画像を揺らすには、以下のコードを実行します。

require 'RMagick'
include Magick

images = ImageList.new("sf2.jpg")
mo = images.fx("j>h/3?p[cos(pi*(j-h/3)/10)*sqrt(j-h/3),0]:p", Magick::AllChannels)
mo.write("sample537a.jpg")

exit

元画像(sf2.jpg)


出力画像(sample537a.jpg)


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

関連項目
ImageMagickで任意の位置からゆらぎをかける
RMagickで、画像を中心から上下へ徐々に大きく揺らす

Monday, August 18, 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>sample536(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 半透明の円形に画像を切り取って、ほかの画像と重ね合わせる */
$im = new Imagick('sf2.jpg');
/* 角丸四角のマスクを作成 */
$im2 = new Imagick();
$im2->newImage($im->getImageWidth(), $im->getImageHeight(), "none");
$idraw = new ImagickDraw();
$idraw->setFillColor('#ffffff');
$idraw->ellipse(130,110,100,100,0,360);
$im2->drawImage($idraw);
$im2->blurImage(10, 10, Imagick::CHANNEL_ALL);
/* マスクを使用して切り取り */
$im2->compositeImage($im, Imagick::COMPOSITE_IN, 0, 0, Imagick::CHANNEL_ALL);
$im2->resizeImage(200, 225*200/300, imagick::FILTER_MITCHELL, 1);

/* 別の画像 */
$im3 = new Imagick('sf.jpg');
$im3->compositeImage($im2, Imagick::COMPOSITE_DEFAULT, -10, -10);

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

<img src="sample536a.jpg" />

</body>
</html>

元画像(sf.jpg)


元画像(sf.jp2g)


出力画像(sample536a.jpg)

Sunday, August 17, 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>sample535(ImageMagick6.4.2)</title>
</head>
<body>
<?php
/* 角丸四角の領域以外を暗くする */
$im = new Imagick('sf2.jpg');
/* 角丸四角のマスクを作成 */
$im2 = new Imagick();
$im2->newImage($im->getImageWidth(), $im->getImageHeight(), "none");
$idraw = new ImagickDraw();
$idraw->setFillColor('#ffffff');
$idraw->roundrectangle(10,10,214,214,20,20);
$im2->drawImage($idraw);
/* マスクを使用して切り取り */
$im2->compositeImage($im, Imagick::COMPOSITE_IN, 0, 0, Imagick::CHANNEL_ALL);

/* 暗くした画像を生成 */
$im3 = new Imagick('sf2.jpg');
/* $im3->modulateImage(30, 100, 100);
なぜかmodulateImageが上手くいかないのでfxで代用*/
$im3 = $im3->fxImage("p*0.3");
$im3->compositeImage($im2, Imagick::COMPOSITE_DEFAULT, 0, 0);

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

<img src="sample535a.jpg" />

</body>
</html>

元画像(sf2.jpg)


出力画像(sample535a.jpg)


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

関連項目
ImageMagickで、任意の矩形領域、角丸四角、円以外の領域を暗くする (Convertコマンドでの同様の処理)
ImageMagickとPHPで、ぼかした領域以外を暗くする