/* * Copyright MagicBane 2013 */ package engine.util; import engine.InterestManagement.RealmMap; import engine.InterestManagement.Terrain; import engine.gameManager.ConfigManager; import engine.server.MBServerStatics; import org.pmw.tinylog.Logger; import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.util.Arrays; import java.util.stream.Stream; public enum MapLoader { MAPLOADER; public static int[][] loadMap() { BufferedImage image; int[][] realmMap; long timeToLoad = System.currentTimeMillis(); long bytesRead = 0; long realmsWritten = 0; int realmUUID; String mapPath = null; // Load image from disk try { mapPath = ConfigManager.DEFAULT_DATA_DIR + "realmmaps/" + ConfigManager.MB_WORLD_REALMMAP.getValue() + ".png"; image = ImageIO.read(new File(mapPath)); // Array size determined by image size MBServerStatics.SPATIAL_HASH_BUCKETSX = image.getWidth(); MBServerStatics.SPATIAL_HASH_BUCKETSY = image.getHeight(); realmMap = new int[MBServerStatics.SPATIAL_HASH_BUCKETSX][MBServerStatics.SPATIAL_HASH_BUCKETSY]; } catch (IOException e) { Logger.error("Error loading realm map: " + mapPath); return null; } // Flip image on the y axis image = flipImage(image); // Load spatial imageMap with color data from file for (int i = 0; i < MBServerStatics.SPATIAL_HASH_BUCKETSY; i++) { for (int j = 0; j < MBServerStatics.SPATIAL_HASH_BUCKETSX; j++) { Color pixelColor = new Color(image.getRGB(j, i)); realmUUID = RealmMap.getRealmIDByColor(pixelColor); realmMap[j][i] = realmUUID; bytesRead++; if (realmUUID != 0) realmsWritten++; } } timeToLoad = System.currentTimeMillis() - timeToLoad; Logger.info("Realmmap: " + mapPath); Logger.info(bytesRead + " pixels processed in " + timeToLoad + " milis"); Logger.info(realmsWritten + " realm pixels written "); return realmMap; } public static BufferedImage flipImage(BufferedImage img) { int w = img.getWidth(); int h = img.getHeight(); BufferedImage dimg = new BufferedImage(w, h, img.getColorModel() .getTransparency()); Graphics2D g = dimg.createGraphics(); g.drawImage(img, 0, 0, w, h, 0, h, w, 0, null); g.dispose(); return dimg; } public static void loadAlHeightMaps() { // Load pixel data for heightmaps try (Stream filePathStream = Files.walk(Paths.get(ConfigManager.DEFAULT_DATA_DIR + "heightmaps/TARGA/"))) { filePathStream.forEach(filePath -> { if (Files.isRegularFile(filePath)) { File imageFile = filePath.toFile(); BufferedImage heightmapImage; try { heightmapImage = ImageIO.read(imageFile); } catch (IOException e) { throw new RuntimeException(e); } int fileName = Integer.parseInt(imageFile.getName().substring(0, imageFile.getName().lastIndexOf("."))); boolean singleBandRaster = heightmapImage.getRaster().getNumBands() == 1; int color; // Generate pixel data for this heightmap. short[][] colorData = new short[heightmapImage.getWidth()][heightmapImage.getHeight()]; for (int y = 0; y < heightmapImage.getHeight(); y++) for (int x = 0; x < heightmapImage.getWidth(); x++) { if (singleBandRaster) color = heightmapImage.getRaster().getSample(x, y, 0); else color = new Color(heightmapImage.getRGB(x, y)).getRed(); colorData[x][y] = (short) color; } // Add pixel for this TGA image into the collection Terrain._heightmap_pixel_cache.put(fileName, colorData); } }); // Try with resources block // Generate full white alternate to 1600300 // Declare and initialize an array of short[16][16] short[][] heightMapEntry = new short[16][16]; for (short[] shorts : heightMapEntry) Arrays.fill(shorts, (short) 255); Terrain._heightmap_pixel_cache.put(1006301, heightMapEntry); } catch (IOException e) { Logger.error(e); } } }