Saturday, June 30, 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 sf = new SmearFilter()
sf.setShape(SmearFilter.CIRCLES)
sf.setDensity(0.7f)
sf.setDistance(3)
sf.setScatter(0.8f)
img = sf.filter(img, null)

ImageIO.write(img, "png", new File("paintcircles.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.geom.*
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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)

def boxsize = 4
def rsize = 2
def padding = 1
def interval = boxsize + padding

def bf = new BlockFilter()
bf.setBlockSize(interval)
img = bf.filter(img, null)

def gr = img2.createGraphics()
// レンダリングヒントを設定
def rh = new
  RenderingHints(RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON)

rh.put(RenderingHints.KEY_RENDERING,
  RenderingHints.VALUE_RENDER_QUALITY)

gr.setRenderingHints(rh)

gr.setColor(new Color(1F, 1F, 1F, 1F))

for(int ly=0;ly<img.getHeight();ly+=interval){
  for(int lx=0;lx<img.getWidth();lx+=interval){
    def rr = new RoundRectangle2D.Double(
      lx, ly, boxsize, boxsize, rsize*2, rsize*2)
    gr.fill(rr)
  }
}

// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ImageIO.write(img2, "png", new File("tiles.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Friday, June 29, 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 tf = new ThresholdFilter(102)
tf.setWhite(0xffffff)
tf.setBlack(0x000000)
img = tf.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)
    def ratio = (float)0.5f + Math.random()*0.2
    buf[0] = Math.min(255, (int)(buf[0] * ratio))
    buf[1] = Math.min(255, (int)(buf[1] * ratio))
    buf[2] = Math.min(255, (int)(buf[2] * ratio))
    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.8f)
sf.setDistance(6)
sf.setScatter(0.8f)
sf.setAngle((float)Math.PI/4*3)
img = sf.filter(img, null)

ImageIO.write(img, "png", new File("thresholddrawing.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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def wr = img.getRaster()
def wr2 = img2.getRaster()
def buf = new int[4]
def cx = img.getWidth()/2
def cy = img.getHeight()/2
def bwidth = 20
def minradius = 50
def ratio = 1.5
for(int ly=1;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr.getPixel(lx, ly, buf)

    def dr = (int)Math.floor((Math.sqrt(Math.pow(lx-cx, 2) + Math.pow(ly-cy, 2))-minradius)/bwidth)*bwidth
    dr = (dr<0)?0:dr
    buf[3] = (255-dr*ratio)<0?0:(255-dr*ratio)
    wr2.setPixel(lx, ly, buf)
  }
}
ImageIO.write(img2, "png", new File("gradcircleband.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.geom.*
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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def radius = 100.0
def gr = img2.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
def rr = new Ellipse2D.Double(
    img.getWidth()/2-radius, img.getHeight()/2-radius, radius*2, radius*2)
gr.fill(rr)
gr.dispose()
// ぼかす
def gf = new GaussianFilter()
gf.setRadius(10f)
img2 = gf.filter(img2, null)

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

ImageIO.write(img2, "png", new File("blurredcircle.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

織物風の画像を生成する

織物風の画像を生成するには、以下のコードを実行します。
@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 = new BufferedImage(
  200, 200, 
  BufferedImage.TYPE_INT_ARGB
)

def ff = new FillFilter((int)0xff7799dd)
img = ff.filter(img, null)

def wf = new WeaveFilter()
img = wf.filter(img, null)

ImageIO.write(img, "png", new File("drawweave.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 = 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()

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


出力画像


動作環境
groovy 1.8.6, JDK7 update4

Monday, June 25, 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 = 40
def mrr = new MultiRoundRectangle(0, 0, img.getWidth(), img.getHeight(),
  radius, radius, 0, 0
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
gr.fill(mrr)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ImageIO.write(img2, "png", new File("cuttoptab.png"))

元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4