Antialiasing

This commit is contained in:
Anuken
2019-01-16 22:45:51 -05:00
parent 6d50a747e3
commit 836a4eb892
115 changed files with 4077 additions and 4026 deletions

View File

@@ -11,6 +11,63 @@ import java.awt.image.BufferedImage
def outFolder = "../core/assets-raw/sprites_out/"
def genFolder = "../core/assets-raw/sprites_out/generated/"
def antialias = {File file ->
def image = ImageIO.read(file)
def out = ImageIO.read(file)
def getRGB = { int ix, int iy ->
return image.getRGB(Math.max(Math.min(ix, image.width - 1), 0), Math.max(Math.min(iy, image.height - 1), 0))
}
def color = new Color()
def sum = new Color()
for (int x = 0; x < image.getWidth(); x++){
for(int y = 0; y < image.getHeight(); y++){
int A =
getRGB(x - 1, y + 1),
B = getRGB(x, y + 1),
C = getRGB(x + 1, y + 1),
D = getRGB(x - 1, y),
E = getRGB(x, y),
F = getRGB(x + 1, y),
G = getRGB(x - 1, y - 1),
H = getRGB(x, y - 1),
I = getRGB(x + 1, y - 1)
int p1=E, p2=E, p3=E, p4=E, p5=E, p6=E, p7=E, p8=E, p9=E
if (D==B && D!=H && B!=F) p1=D
if ((D==B && D!=H && B!=F && E!=C) || (B==F && B!=D && F!=H && E!=A)) p2=B
if (B==F && B!=D && F!=H) p3=F
if ((H==D && H!=F && D!=B && E!=A) || (D==B && D!=H && B!=F && E!=G)) p4=D
p5=E
if ((B==F && B!=D && F!=H && E!=I) || (F==H && F!=B && H!=D && E!=C)) p6=F
if (H==D && H!=F && D!=B) p7=D
if ((F==H && F!=B && H!=D && E!=G) || (H==D && H!=F && D!=B && E!=I)) p8=H
if (F==H && F!=B && H!=D) p9=F
int total = 0
[p1, p2, p3, p4, p5, p6, p7, p8, p9].each{ val ->
Color.argb8888ToColor(color, val)
if(color.a > 0.1){
sum.r += color.r
sum.g += color.g
sum.b += color.b
sum.a += color.a
total++
}
}
sum.mul((float)(1f / total))
int result = Color.argb8888(sum)
out.setRGB(x, y, result)
sum.set(0)
}
}
ImageIO.write(out, "png", file)
}
task swapColors(){
doLast{
@@ -91,6 +148,8 @@ task scaleSprites4x(){
ImageIO.write(scaled, "png", file.file)
}
antialias(file.file)
}
}
}
@@ -110,6 +169,9 @@ task pack(){
copy{
from "../core/assets-raw/sprites_replacement/"
into "../core/assets-raw/sprites_out/"
eachFile{file ->
antialias(file.file)
}
}
TexturePacker.process("core/assets-raw/sprites_out/", "core/assets/sprites/", "sprites.atlas")
@@ -127,6 +189,8 @@ task cleanup(){
}
task cleanSprites(){
finalizedBy 'cleanup'
doLast{
delete{
delete "../core/assets-raw/sprites_out/"