@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
No comments:
Post a Comment