Saturday, September 29, 2012

groovyで画像を強調したモノトーンに変換する

groovyで画像を強調したモノトーンに変換するには、以下のコードを実行します。
@Grab(group='com.jhlabs', module='filters', version='2.0.235')
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*
import com.jhlabs.image.*

// 画像を強調したモノトーンに変換する
def img = ImageIO.read(new File("sf2.jpg"))

def bf = new BumpFilter()
img = bf.filter(img, null)

def wr = img.getRaster()

buf = new int[wr.getNumDataElements()]

def color1 = 0x99bbee
def red = (color1 >> 16) & 0xff
def green = (color1 >> 8) & 0xff
def blue = color1 & 0xff

for(int ly=1;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    def mono = (buf[0] * 77 + buf[1] * 151 + buf[2] * 28) >> 8;
    buf[0] = (int)(mono * red / 255)
    buf[1] = (int)(mono * green / 255)
    buf[2] = (int)(mono * blue / 255)
    wr.setPixel(lx, ly, buf)
  }
}
ImageIO.write(img, "png", new File("bumpmonotone.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Sunday, September 23, 2012

pycairoを使用してSVGファイルに直線を描画する

pycairoを使用してSVGファイルに直線を描画するには、以下のコードを実行します。
import cairo
import rsvg

file = file('test1.svg', 'w')
width = 200
height = 200
surface = cairo.SVGSurface(file, width, height)
ctx = cairo.Context(surface)
ctx.set_source_rgb(0xcc/float(0xff), 0xdd/float(0xff), 0xff/float(0xff))
ctx.move_to(0, 0)
ctx.line_to(200, 200)
ctx.stroke()
surface.finish()


出力画像

動作環境
CentOS6.2, python 2.6.6

補足
pycairoでSVGを使用するにはpyrsvgをインストールします。
yum install gnome-python2-rsvg