Friday, August 17, 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 linelength = 16
def lineinterval = 2;
def padding = 2
Color color1 = new Color((int)0x1C425C)

def interval = linelength + padding*2
def gr = img.createGraphics()
gr.setColor(color1)
for(int ly=0;ly<img.getHeight();ly+=interval){
  def cc=((int)ly/interval)%2==0?0:1
  for(int lx=0;lx<img.getWidth();lx+=interval){
    if( cc%2 == 0 ){
      for(int py=0;py<=linelength;py+=lineinterval){
        gr.drawLine(lx+padding, ly+py+padding, lx+padding+linelength, ly+py+padding)
      }
    } else {
      for(int px=0;px<=linelength;px+=lineinterval){
        gr.drawLine(lx+px+padding, ly+padding, lx+px+padding, ly+padding+linelength)
      }
    }
    cc++
  }
}

ImageIO.write(img, "png", new File("drawhvlines.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.*

class ShearFilter2 extends TransformFilter
{
  float xoffset = 0.0f
  float yoffset = 0.0f
  float dx = 0.0f
  float rx = 0.0f
  float dy = 0.0f
  float ry = 0.0f
  void transformSpace(Rectangle r)
  {
    r.width = (int)r.width+Math.abs(dx)
    rx = dx/r.height
    xoffset = dx>0?-dx:0
    r.height = (int)r.height+Math.abs(dy)
    ry = dy/r.width
    yoffset = dy>0?-dy:0
  }
  void transformInverse(int x, int y, float[] out)
  {
    out[0] = x + xoffset + (y * rx)
    out[1] = y + yoffset + (x * ry)
  }
}

// 傾きのピクセル
def dy = 30

// 画像を折り曲げたように加工する
def img = ImageIO.read(new File("sf2.jpg"))
// 右半分を切り取り
def img2 = img.getSubimage((int)img.getWidth()/2, 0, 
  (int)img.getWidth()/2, img.getHeight());
def imga = new BufferedImage(
  (int)img2.getWidth(), img2.getHeight()+Math.abs(dy), 
  BufferedImage.TYPE_INT_ARGB
)
// 左半分を切り取り
def img3 = img.getSubimage(0, 0, 
  (int)img.getWidth()/2, img.getHeight());

// 明るさを140% 
def ctf = new ContrastFilter()
ctf.setBrightness(1.4f)
img2 = ctf.filter(img2, null)

// 傾ける
def sf = new ShearFilter2()
sf.dy = dy
sf.filter(img2, imga)

def imga2 = new BufferedImage(
  (int)img.getWidth(), imga.getHeight(), 
  BufferedImage.TYPE_INT_ARGB
)

gr = imga2.createGraphics()
gr.drawImage(img3,0,dy,null)
gr.drawImage(imga, img3.getWidth(),0,null)

ImageIO.write(imga2, "png", new File("fold.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Monday, August 13, 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()
def img3 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img3.createGraphics()
gr.drawImage(img, 0, 0, null)
gr.dispose()

// 半透明切取
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] = Math.sin(Math.PI*lx/img.getWidth())*255
    wr2.setPixel(lx, ly, buf2)
  }
}
gr = img2.createGraphics()
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

// モノトーン画像作成
def wr3 = img3.getRaster()
def buf3 = new int[4]

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

for(int ly=0;ly<wr.getHeight();ly++){
  for(int lx=0;lx<wr.getWidth();lx++){
    wr3.getPixel(lx, ly, buf3)
    def mono = (buf3[0] * 77 + buf3[1] * 151 + buf3[2] * 28) >> 8;
    buf3[0] = (int)(mono * red / 255)
    buf3[1] = (int)(mono * green / 255)
    buf3[2] = (int)(mono * blue / 255)
    wr3.setPixel(lx, ly, buf3)
  }
}

// 重ね合わせ
gr = img3.createGraphics()
gr.drawImage(img2, 0, 0, null)
gr.dispose()

ImageIO.write(img3, "png", new File("monotoneleftright.png"))


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Sunday, August 12, 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 interval = 10
def buf = new int[4]
Color color1 = new Color((int)0xF27405)
buf[0] = color1.getRed()
buf[1] = color1.getGreen()
buf[2] = color1.getBlue()
buf[3] = 255

def wr = img.getRaster()
for(int ly=0;ly<wr.getHeight();ly+=interval){
  def cc=((int)ly/interval)%2==0?0:1
  for(int lx=0;lx<wr.getWidth();lx+=interval){
    if( cc%2 == 0 ){
      for(int py=0;py<interval;py++){
        for(int px=0;px<interval;px++){
          if( (py+px)%2 == 0 )wr.setPixel(lx+px, ly+py, buf)
        }
      }
    }
    cc++
  }
}

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


出力画像


動作環境
groovy 1.8.6, JDK7 update4