Friday, August 10, 2012

groovyで鉛筆画風の星を描画する

groovyで鉛筆画風の星を描画するには、以下のコードを実行します。
@Grab(group='com.jhlabs', module='filters', version='2.0.235')
@Grab(group='org.codehaus.griffon', module='jsilhouette-geom', version='0.4')
import java.awt.*
import java.awt.image.*
import java.io.*
import javax.imageio.*
import com.jhlabs.composite.*
import com.jhlabs.image.*
import org.codehaus.griffon.jsilhouette.geom.*

// 鉛筆画風の星を描画する
def img = new BufferedImage(
    200, 200, BufferedImage.TYPE_INT_ARGB
)
def img2 = new BufferedImage(
    200, 200, BufferedImage.TYPE_INT_ARGB
)
def gr2 = img2.createGraphics()
gr2.setColor(new Color((int)0xeedd00))
gr2.fillRect(0, 0, img2.getWidth(), img2.getHeight())
gr2.dispose()

def gr = img.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
def radius1 = 100
def radius2 = 50
def angle = 0

def star = new Star(img.getWidth()/2, img.getHeight()/2,
  radius1, radius2, 5, angle
)
gr.setColor(new Color((int)0xffffff))
gr.fill(star)
gr.dispose()
// 拡散
def df = new DiffuseFilter()
df.setScale(4)
img = df.filter(img, null)

def wr = img2.getRaster()
def buf = new int[4]

for(int ly=1;ly<wr.getHeight();ly+=2){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf[0] = Math.min(255, (int)(buf[0] * 1.7f))
    buf[1] = Math.min(255, (int)(buf[1] * 1.7f))
    buf[2] = Math.min(255, (int)(buf[2] * 1.7f))
    wr.setPixel(lx, ly, buf)
  }
}
// 線画
def sf = new SmearFilter()
sf.setShape(SmearFilter.LINES)
sf.setDensity(0.7f)
sf.setDistance(7)
sf.setScatter(0.8f)
sf.setAngle((float)Math.PI/3)
img = sf.filter(img, null)
img2 = sf.filter(img2, null)
// 角度を変更して
sf.setDensity(0.2f)
sf.setAngle((float)Math.PI/4)
img = sf.filter(img, null)
img2 = sf.filter(img2, null)

// 切り取り 
gr2 = img.createGraphics()
gr2.setComposite(AlphaComposite.SrcIn)
gr2.drawImage(img2,0,0,null)
gr2.dispose()

ImageIO.write(img, "png", new File("drawstarpencil.png"))


出力画像


動作環境
groovy 1.8.6, JDK7 update4

Wednesday, August 08, 2012

groovyで点状の放射ストライプを描画する

groovyで点状の放射ストライプを描画するには、以下のコードを実行します。
@Grab(group='org.codehaus.griffon', module='jsilhouette-geom', version='0.4')
import java.awt.*
import java.awt.image.*
import java.io.*
import javax.imageio.*
import org.codehaus.griffon.jsilhouette.geom.*

// 点状の放射ストライプを描画する
def img = new BufferedImage(
  200, 200, BufferedImage.TYPE_INT_ARGB
)
def gr = img.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
def radius = 200
def nrays = 10
def rays = new Rays(img.getWidth()/2, img.getHeight()/2,
  radius, nrays
)
gr.setColor(new Color((int)0xccddff))
gr.fill(rays)
gr.dispose()

def buf = new int[4]
buf[0] = buf[1] = buf[2] = buf[3] = 0

def wr = img.getRaster()
for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    if( lx%2 == 1 || ly%2 == 0 ){
      wr.setPixel(lx, ly, buf)
    }
  }
}

ImageIO.write(img, "png", new File("drawdottedrays.png"))


出力画像


動作環境
groovy 1.8.6, JDK7 update4

Tuesday, August 07, 2012

groovyで手書き風の星を描画する

groovyで手書き風の星を描画するには、以下のコードを実行します。
@Grab(group='com.jhlabs', module='filters', version='2.0.235')
@Grab(group='org.codehaus.griffon', module='jsilhouette-geom', version='0.4')
import java.awt.*
import java.awt.image.*
import java.io.*
import javax.imageio.*
import com.jhlabs.composite.*
import com.jhlabs.image.*
import org.codehaus.griffon.jsilhouette.geom.*

// 手書き風の星を描画する
def img = new BufferedImage(
    200, 200, BufferedImage.TYPE_INT_ARGB
)
def gr = img.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
def radius1 = 100
def radius2 = 50
def angle = 0
def scale = 5

def star = new Star(img.getWidth()/2, img.getHeight()/2,
  radius1, radius2, 5, angle
)
gr.setColor(new Color((int)0xeedd00))
gr.fill(star)
gr.dispose()

def df = new DiffuseFilter()
df.setScale((int)scale)
img = df.filter(img, null)

def mf = new MedianFilter()
img = mf.filter(img, null)
img = mf.filter(img, null)

ImageIO.write(img, "png", new File("drawstarhand.png"))


出力画像


動作環境
groovy 1.8.6, JDK7 update4

groovyで画像を二値化してぼかす

groovyで画像を二値化してぼかすには、以下のコードを実行します。
@Grab(group='com.jhlabs', module='filters', version='2.0.235')
import java.awt.*
import java.awt.image.*
import java.io.*
import javax.imageio.*
import com.jhlabs.composite.*
import com.jhlabs.image.*

// 二値化してぼかす
def img = ImageIO.read(new File("sf2.jpg"))
def imga = new BufferedImage(
    img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = imga.createGraphics()
gr.drawImage(img,0,0,null)
gr.dispose()

def threshold = 127
def white = (int)0x00000000
def black = (int)0xff5d6056

def wr = imga.getRaster()
def buf = new int[4]
for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)

    if( PixelUtils.brightness((buf[0]<<16)+(buf[1]<<8)+buf[2]) > threshold ){
      buf[0] = (white >> 16) & 0xff
      buf[1] = (white >> 8) & 0xff
      buf[2] = white & 0xff
      buf[3] = (white >> 24) & 0xff
    } else {
      buf[0] = (black >> 16) & 0xff
      buf[1] = (black >> 8) & 0xff
      buf[2] = black & 0xff
      buf[3] = (black >> 24) & 0xff
    }

    wr.setPixel(lx, ly, buf)
  }
}
def gf = new GaussianFilter()
gf.setRadius(5f)
imga = gf.filter(imga, null)

ImageIO.write(imga, "png", new File("thresholdblur.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Sunday, August 05, 2012

groovyでレンガ模様を描画する

groovyでレンガ模様を描画するには、以下のコードを実行します。
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*

// レンガ模様を描画する
def img = new BufferedImage(
  200, 200, BufferedImage.TYPE_INT_ARGB
)

def brickwidth = 20
def brickheight = 10
def padding = 2
def xinterval = brickwidth + padding
def yinterval = brickheight + padding

def gr = img.createGraphics()
gr.setColor(new Color((int)0xCCB18E))

def rc = 0
for(int ly=0;ly<img.getHeight();ly+=yinterval){
  for(int lx=0;lx<img.getWidth();lx+=xinterval){
    gr.fillRect((int)lx-(rc%2==0?0:brickwidth/2), ly, brickwidth, brickheight)
  }
  rc++;
}
gr.dispose()

ImageIO.write(img, "png", new File("drawbrick.png"))


出力画像


動作環境
groovy 1.8.6, JDK7 update4