Saturday, June 09, 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 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.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

// 明るさを50% 
def ctf = new ContrastFilter()
ctf.setBrightness(0.5f)
img = ctf.filter(img, null)

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

ImageIO.write(img, "png", new File("ellipsespot.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 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(1F, 1F, 1F, 1F))
gr.fill(star)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ImageIO.write(img2, "png", new File("cutstar.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 rf = new RippleFilter()
rf.setXAmplitude(0f)
rf.setYAmplitude(10f)
rf.setYWavelength(30f)
img2 = rf.filter(img2, null)

ImageIO.write(img2, "png", new File("vsinwave.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 img2 = new BufferedImage(
  img.getWidth(), img.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 path = new Path2D.Double()

// 分割数
def par = 6
// 中心x
def cx = img.getWidth()/2
// 中心y
def cy = img.getHeight()/2
// 半径
def rad = 100

def dr1=0
path.moveTo(
  (int)(cx-Math.cos(2*Math.PI*dr1/360)*rad),
  (int)(cy-Math.sin(2*Math.PI*dr1/360)*rad)
)
dr1 += 360/par

while(dr1<360){
  path.lineTo(
    (int)(cx-Math.cos(2*Math.PI*dr1/360)*rad),
    (int)(cy-Math.sin(2*Math.PI*dr1/360)*rad)
  )
  dr1 += 360/par
}
gr.fill(path)
// 切り取り 
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("hexagonshadow.png"))

元画像

出力画像


動作環境
groovy 1.8.6, JDK7 update4

Friday, June 08, 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(10f)
rf.setXWavelength(30f)
img2 = rf.filter(img2, null)

ImageIO.write(img2, "png", new File("hsinwave.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 img2 = new BufferedImage(
  img.getWidth(), img.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 path = new Path2D.Double()

// 分割数
def par = 5
// 中心x
def cx = img.getWidth()/2
// 中心y
def cy = img.getHeight()/2
// 半径
def rad = 100

def dr1=0
path.moveTo(
  (int)(cx-Math.cos(2*Math.PI*dr1/360+Math.PI/2)*rad),
  (int)(cy-Math.sin(2*Math.PI*dr1/360+Math.PI/2)*rad)
)
dr1 += 360/par

while(dr1<360){
  path.lineTo(
    (int)(cx-Math.cos(2*Math.PI*dr1/360+Math.PI/2)*rad),
    (int)(cy-Math.sin(2*Math.PI*dr1/360+Math.PI/2)*rad)
  )
  dr1 += 360/par
}
gr.fill(path)
// 切り取り 
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)
BufferedImage img3 = sf.filter(img2, null)

ImageIO.write(img3, "png", new File("pentagonshadow.png"))
元画像 出力画像
動作環境
groovy 1.8.6, JDK7 update4

Monday, June 04, 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()
gr.setRenderingHint(
  RenderingHints.KEY_ANTIALIASING,
  RenderingHints.VALUE_ANTIALIAS_ON
)
gr.setColor(new Color(1F, 1F, 1F, 1F))
def path = new Path2D.Double()

// 分割数
def par = 64
// 中心x
def cx = img.getWidth()/2
// 中心y
def cy = img.getHeight()/2
// 半径(大)
def rad1 = 90
// 半径(小)
def rad2 = 80

def dr1=0
def dr2=360/(par*2)
path.moveTo(
  (int)(cx-Math.cos(2*Math.PI*dr1/360)*rad1),
  (int)(cy-Math.sin(2*Math.PI*dr1/360)*rad1)
)
path.lineTo(
  (int)(cx-Math.cos(2*Math.PI*dr2/360)*rad2),
  (int)(cy-Math.sin(2*Math.PI*dr2/360)*rad2)
)
dr1 += 360/par
dr2 += 360/par

while(dr2<360){
  path.lineTo(
    (int)(cx-Math.cos(2*Math.PI*dr1/360)*rad1),
    (int)(cy-Math.sin(2*Math.PI*dr1/360)*rad1)
  )
  path.lineTo(
    (int)(cx-Math.cos(2*Math.PI*dr2/360)*rad2),
    (int)(cy-Math.sin(2*Math.PI*dr2/360)*rad2)
  )

  dr1 += 360/par
  dr2 += 360/par
}
gr.fill(path)
// 切り取り 
gr.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ShadowFilter 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)
BufferedImage img3 = sf.filter(img2, null)

ImageIO.write(img3, "png", new File("badgeshadow.png"))
元画像 出力画像
動作環境
groovy 1.8.6, JDK7 update4

Sunday, June 03, 2012

画像を丸で切り取って影付けする

画像を丸で切り取って影付けするには、以下のコードを実行します。
@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 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.setComposite(AlphaComposite.SrcIn)
gr.drawImage(img,0,0,null)
gr.dispose()

ShadowFilter 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);
BufferedImage img3 = sf.filter(img2, null);

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

元画像
出力画像

動作環境
groovy 1.8.6, JDK7 update4