Saturday, June 16, 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 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.sin(Math.PI*lx/img.getWidth())*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("darkerleftright.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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.drawImage(img,0,0,null)
gr.dispose()

def sf = new ShatterFilter()
sf.setRotation(10)
sf.setTransition(0.1f)
sf.setTile(8)
sf.setIterations(15)
img2 = sf.filter(img2, null)

ImageIO.write(img2, "png", new File("shatter.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 margin = 10
def imgb = new BufferedImage(
  img.getWidth()+margin*2, img.getHeight()+margin*2, BufferedImage.TYPE_INT_ARGB
)
def grb = imgb.createGraphics()
grb.drawImage(img,margin,margin,null)
grb.dispose()

// 角丸四角の画像を作成 
def img2 = new BufferedImage(
  imgb.getWidth(), imgb.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
def rr = new RoundRectangle2D.Double(
    (double)margin, (double)margin, img.getWidth()-1, img.getHeight()-1, 20.0*2, 20.0*2)
gr.fill(rr)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(imgb,0,0,null)
gr.dispose()

def sf = new ShadowFilter()
// 半径
sf.setRadius(7f)
// 透明度
sf.setOpacity(0.9f)
// 角度
sf.setAngle((float)300f/180f*ImageMath.PI)
// 距離
sf.setDistance(5f)
// 影の色
sf.setShadowColor((int)0xff202020)
// 影のマージン
sf.setAddMargins(false)
// 影のみにするか
sf.setShadowOnly(false)
img2 = sf.filter(img2, null)

ImageIO.write(img2, "png", new File("roundrectshadow.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 = 20.0
def gr = img2.createGraphics()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
def rr1 = new Ellipse2D.Double(
    -radius, -radius, radius*2, radius*2)
gr.fill(rr1)
def rr2 = new Ellipse2D.Double(
    img.getWidth()-radius, -radius, radius*2, radius*2)
gr.fill(rr2)
def rr3 = new Ellipse2D.Double(
    -radius, img.getHeight()-radius, radius*2, radius*2)
gr.fill(rr3)
def rr4 = new Ellipse2D.Double(
    img.getWidth()-radius, img.getHeight()-radius, radius*2, radius*2)
gr.fill(rr4)
gr.dispose()
def iaf = new InvertAlphaFilter()
img2 = iaf.filter(img2, null)
gr = img2.createGraphics()

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

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


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Thursday, June 14, 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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.drawImage(img,0,0,null)
gr.dispose()

def rf = new RippleFilter()
rf.setWaveType(RippleFilter.SAWTOOTH)
rf.setXAmplitude(10f)
rf.setXWavelength(30f)
img2 = rf.filter(img2, null)

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


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Wednesday, June 13, 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.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 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)

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

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()

def sf = new ShadowFilter()
// 半径
sf.setRadius(7f)
// 透明度
sf.setOpacity(0.9f)
// 角度
sf.setAngle((float)300f/180f*ImageMath.PI)
// 距離
sf.setDistance(5f)
// 影の色
sf.setShadowColor((int)0xff202020)
// 影のマージン
sf.setAddMargins(false)
// 影のみにするか
sf.setShadowOnly(false)
img2 = sf.filter(img2, null)

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


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Tuesday, June 12, 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 img2 = new BufferedImage(
  img.getWidth(), img.getHeight(), BufferedImage.TYPE_INT_ARGB
)
def gr = img2.createGraphics()
gr.drawImage(img,0,0,null)
gr.dispose()

def rf = new RippleFilter()
rf.setXAmplitude(5f)
rf.setXWavelength(10f)
rf.setYAmplitude(5f)
rf.setYWavelength(10f)
img2 = rf.filter(img2, null)

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


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Monday, June 11, 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.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 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)

def radius = 9
def padding = 2
def interval = radius*2 + padding

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

def rc = 0
for(int ly=0;ly<img.getHeight();ly+=interval){
  for(int lx=0;lx<img.getWidth()+radius;lx+=interval){
    def rr = new Ellipse2D.Double(
      lx-((rc%2==0)?0:interval/2), ly, radius*2, radius*2)
    gr.fill(rr)
  }
  rc++;
}

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

def sf = new ShadowFilter()
// 半径
sf.setRadius(7f)
// 透明度
sf.setOpacity(0.9f)
// 角度
sf.setAngle((float)300f/180f*ImageMath.PI)
// 距離
sf.setDistance(5f)
// 影の色
sf.setShadowColor((int)0xff202020)
// 影のマージン
sf.setAddMargins(false)
// 影のみにするか
sf.setShadowOnly(false)
img2 = sf.filter(img2, null)

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


元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4