package readers; import java.awt.Color; import java.awt.Graphics2D; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.nio.file.Paths; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.regex.Pattern; import javax.imageio.ImageIO; import readers.fonts.Font; import readers.fonts.Glyph; public class PopnReader extends Reader{ List extraRegions = new ArrayList<>(); static int lastJump=0; public PopnReader(){ addRegion(new Box(941,609,275,54),NUMBER); //score[0] addRegion(new Box(1060,684,157,40),NUMBER); //cool[1] addRegion(new Box(1060,724,157,39),NUMBER); //great[2] addRegion(new Box(1060,761,157,40),NUMBER); //good[3] addRegion(new Box(1060,800,157,40),NUMBER); //bad[4] addRegion(new Box(1060,858,157,42),NUMBER); //combo[5] addRegion(new Box(970,288,271,50)); //diff[6] addRegion(new Box(689,345,547,128)); //song[7] addRegion(new Box(502,23,314,288)); //rating[8] addRegion(new Box(692,525,532,16)); //lifebar[9] extraRegions.add(new Box(699,616,179,44)); //score text[0] extraRegions.add(new Box(712,680,164,40)); //cool text[1] extraRegions.add(new Box(712,721,168,38)); //great text[2] extraRegions.add(new Box(712,759,150,40)); //good text[3] extraRegions.add(new Box(712,800,101,38)); //bad text[4] extraRegions.add(new Box(708,861,170,39)); //combo text[5] extraRegions.add(new Box(970,290,194,47)); //diff text[6] init(); } void ColorFilter(int[] arr,int region,int width) { switch (region) { case 0:{ process(arr,width, 240,255,100,130,0,10, 240,255,100,255,0,100); }break; case 1:{ process(arr,width, 240,255,0,10,240,255, 240,255,0,150,240,255); }break; case 2:{ process(arr,width, 240,255,180,225,0,10, 240,255,180,255,0,140); }break; case 3:{ process(arr,width, 240,244,0,40,0,10, 240,255,0,180,0,255); }break; case 4:{ process(arr,width, 90,120,180,220,240,255, 90,255,180,255,0,255); }break; case 5:{ process(arr,width, 0,10,0,60,240,255, 0,20,0,100,240,255); }break; case 6:{ process(arr,width, 240,255,230,255,0,40, 240,255,230,255,0,240); }break; case 400:{ process(arr,width, 240,255,0,10,0,10, 240,255,0,10,0,10); }break; case 401:{ process(arr,width, 230,255,0,10,240,255, 230,255,0,10,240,255); }break; case 402:{ process(arr,width, 240,255,200,255,0,10, 240,255,200,255,0,10); }break; case 403:{ process(arr,width, 240,255,0,50,0,10, 240,255,0,50,0,10); }break; case 404:{ process(arr,width, 90,120,180,220,240,255, 85,120,160,220,180,255); }break; case 405:{ process(arr,width, 0,20,0,80,240,255, 0,20,0,80,240,255); }break; case 406:{ process(arr,width, 240,255,240,255,240,255, 210,255,210,255,210,255); }break; } } public void interpretBoxes(Path img){ /*String dataString = readAllBoxes(img); String[] data = dataString.split(Pattern.quote("\n")); String[] ja_data = data[0].split(Pattern.quote(")")); String[] en_data = data[2].split(Pattern.quote(")")); trimAllData(ja_data); trimAllData(en_data); System.out.println(Arrays.toString(ja_data)); System.out.println(Arrays.toString(en_data));*/ int regionHeights = 0; int maxWidth = 0; int counter = 0; for (int i=0;imaxWidth) { maxWidth=readRegions.get(i).w; } } try { BufferedImage originalImg = ImageIO.read(img.toFile()); BufferedImage cutImg = new BufferedImage(maxWidth,regionHeights,BufferedImage.TYPE_INT_ARGB); Graphics2D g = cutImg.createGraphics(); int currentHeight=0; for (int i=0;i glyphs = Glyph.split(cutImg); return f.convertGlyphs(glyphs); } case 1: case 2: case 3: case 4:{ Font f = Font.FONT_POPN_NOTECOUNT; List glyphs = Glyph.split(cutImg); return f.convertGlyphs(glyphs); } case 5:{ Font f = Font.FONT_POPN_COMBO; List glyphs = Glyph.split(cutImg); return f.convertGlyphs(glyphs); } } return ""; } @Override void interpretResults(String[] finalData) { for (int i=0;i