Saturday, June 02, 2012

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 mf = new MedianFilter()
img = mf.filter(img, null)

def wr = img.getRaster()
def buf = new int[wr.getNumDataElements()]

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 nf = new NoiseFilter()
nf.setMonochrome(true)
img = nf.filter(img, null)

def sf = new SmearFilter()
sf.setShape(SmearFilter.LINES)
sf.setDensity(0.7f)
sf.setDistance(7)
sf.setScatter(0.8f)
sf.setAngle((float)Math.PI/4)
img = sf.filter(img, null)

wr = img.getRaster()

buf = new int[wr.getNumDataElements()]

def color1 = 0xccddff
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("monotonedrawing.png"))

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

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.composite.*
import com.jhlabs.image.*

// 画像の端をぼかす
def img = ImageIO.read(new File("sf2.jpg"))
def wr = img.getRaster()
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr2 = img2.getRaster()

def buf = new int[wr.getNumDataElements()]
def buf2 = new int[4]

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf2[0] = buf[0]
    buf2[1] = buf[1]
    buf2[2] = buf[2]
    buf2[3] = Math.min(
      Math.sin(Math.PI*lx/img.getWidth())*255,
      Math.sin(Math.PI*ly/img.getHeight())*255
    )
    wr2.setPixel(lx, ly, buf2)
  }
}
def gf = new GaussianFilter()
gf.setRadius(5f)
img = gf.filter(img, null)

def gr = img.createGraphics()
gr.setComposite(
  AlphaComposite.getInstance(AlphaComposite.SRC_OVER)
)
gr.drawImage(img2, 0, 0, null)
gr.dispose()

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

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

groovyで画像の端を暗くする

groovyで画像の端を暗くするには、以下のコードを実行します。
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*

// 画像の端を暗くする
def img = ImageIO.read(new File("sf2.jpg"))
def wr = img.getRaster()
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr2 = img2.getRaster()

def buf = new int[wr.getNumDataElements()]
def buf2 = new int[4]

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf2[0] = buf2[1] = buf2[2] = 0
    buf2[3] = 255-Math.min(
      Math.sin(Math.PI*lx/img.getWidth())*255,
      Math.sin(Math.PI*ly/img.getHeight())*255
    )
    wr2.setPixel(lx, ly, buf2)
  }
}
def gr = img.createGraphics()
gr.setComposite(
  AlphaComposite.getInstance(AlphaComposite.SRC_OVER, 0.4f)
)
gr.drawImage(img2, 0, 0, null)
gr.dispose()

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

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

groovyで画像の端をグレースケールにする

groovyで画像の端をグレースケールにするには、以下のコードを実行します。
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*

// 画像の端をグレースケールにする
def img = ImageIO.read(new File("sf2.jpg"))
def wr = img.getRaster()
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr2 = img2.getRaster()

buf = new int[wr.getNumDataElements()]
buf2 = new int[4]

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf2[0] = buf[0]
    buf2[1] = buf[1]
    buf2[2] = buf[2]
    buf2[3] = Math.min(
      Math.sin(Math.PI*lx/img.getWidth())*255,
      Math.sin(Math.PI*ly/img.getHeight())*255
    )
    wr2.setPixel(lx, ly, buf2)

    def mono = (buf[0] * 77 + buf[1] * 151 + buf[2] * 28) >> 8
    buf[0] = buf[1] = buf[2] = mono
    wr.setPixel(lx, ly, buf)
  }
}
def gr = img.createGraphics()
gr.setComposite(
  AlphaComposite.getInstance(AlphaComposite.SRC_OVER)
)
gr.drawImage(img2, 0, 0, null)
gr.dispose()

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

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

Friday, June 01, 2012

groovyで画像の端を透明にする

groovyで画像の端を透明にするには、以下のコードを実行します。
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*

// 画像の端を透明にする
def img = ImageIO.read(new File("sf2.jpg"))
def wr = img.getRaster()
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr2 = img2.getRaster()

buf = new int[wr.getNumDataElements()]
buf2 = new int[4]

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf2[0] = buf[0]
    buf2[1] = buf[1]
    buf2[2] = buf[2]
    buf2[3] = Math.min(
      Math.sin(Math.PI*lx/img.getWidth())*255,
      Math.sin(Math.PI*ly/img.getHeight())*255
    )
    wr2.setPixel(lx, ly, buf2)
  }
}
ImageIO.write(img2, "png", new File("transparentedge.png"))

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

groovyで画像の左右を半透明にする

groovyで画像の左右を半透明にするには、以下のコードを実行します。
import java.io.*
import java.awt.*
import java.awt.geom.*
import java.awt.image.*
import javax.imageio.*

// 画像の左右を半透明にする
def img = ImageIO.read(new File("sf2.jpg"))
def wr = img.getRaster()
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr2 = img2.getRaster()

buf = new int[wr.getNumDataElements()]
buf2 = new int[4]

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)
    buf2[0] = buf[0]
    buf2[1] = buf[1]
    buf2[2] = buf[2]
    buf2[3] = Math.sin(Math.PI*lx/img.getWidth())*255
    wr2.setPixel(lx, ly, buf2)
  }
}
ImageIO.write(img2, "png", new File("sintransparenth.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 cf = new ChromeFilter()
cf.setAmount(0.5f)
cf.setExposure(1f)
img = cf.filter(img, null)

def lc = new LinearColormap((int)0xFFFFFFFF, (int)0xFF7799DD)
LookupFilter lf = new LookupFilter(lc)
lf.filter(img, imga)

def ctf = new ContrastFilter()
ctf.setContrast(1.1f)
imga = ctf.filter(imga, null)

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

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

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 = ImageIO.read(new File("sf2.jpg"))
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
def width = 50
def angle = 0
def almond = new Almond(img.getWidth()/2, img.getHeight()/2,
  width, 
  angle
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
gr.fill(almond)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ImageIO.write(img2, "png", new File("almond.png"))
元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4

Wednesday, May 30, 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 = ImageIO.read(new File("sf2.jpg"))
def img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
def radius = 100
def angle = 0
def astroid = new Astroid(img.getWidth()/2, img.getHeight()/2,
  radius, 
  angle
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
gr.fill(astroid)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ImageIO.write(img2, "png", new File("astroid.png"))
元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4