Add 'fetchskins' and 'refreshskins' settings to control server face/skin loading and updating

This commit is contained in:
Mike Primm 2011-10-03 05:58:29 +08:00 committed by mikeprimm
parent 3e2d518ed5
commit c5287b8427
2 changed files with 68 additions and 43 deletions

View File

@ -26,7 +26,8 @@ public class PlayerFaces {
private File faces8x8dir; private File faces8x8dir;
private File faces16x16dir; private File faces16x16dir;
private File faces32x32dir; private File faces32x32dir;
private boolean fetchskins;
private boolean refreshskins;
private class LoadPlayerImages implements Runnable { private class LoadPlayerImages implements Runnable {
public String playername; public String playername;
@ -34,10 +35,20 @@ public class PlayerFaces {
this.playername = playername; this.playername = playername;
} }
public void run() { public void run() {
File img_8x8 = new File(faces8x8dir, playername + ".png");
File img_16x16 = new File(faces16x16dir, playername + ".png");
File img_32x32 = new File(faces32x32dir, playername + ".png");
boolean has_8x8 = img_8x8.exists();
boolean has_16x16 = img_16x16.exists();
boolean has_32x32 = img_32x32.exists();
boolean missing_any = !(has_8x8 && has_16x16 && has_32x32);
BufferedImage img = null; BufferedImage img = null;
try { try {
if(fetchskins && (refreshskins || missing_any)) {
URL url = new URL("http://s3.amazonaws.com/MinecraftSkins/" + playername + ".png"); URL url = new URL("http://s3.amazonaws.com/MinecraftSkins/" + playername + ".png");
img = ImageIO.read(url); /* Load skin for player */ img = ImageIO.read(url); /* Load skin for player */
}
} catch (IOException iox) { } catch (IOException iox) {
Debug.debug("Error loading skin for '" + playername + "' - " + iox); Debug.debug("Error loading skin for '" + playername + "' - " + iox);
} }
@ -73,7 +84,7 @@ public class PlayerFaces {
} }
} }
/* Write 8x8 file */ /* Write 8x8 file */
File img_8x8 = new File(faces8x8dir, playername + ".png"); if(refreshskins || (!has_8x8)) {
FileLockManager.getWriteLock(img_8x8); FileLockManager.getWriteLock(img_8x8);
try { try {
FileLockManager.imageIOWrite(face8x8.buf_img, ImageFormat.FORMAT_PNG, img_8x8); FileLockManager.imageIOWrite(face8x8.buf_img, ImageFormat.FORMAT_PNG, img_8x8);
@ -81,6 +92,9 @@ public class PlayerFaces {
Log.severe("Cannot write player icon " + img_8x8.getPath()); Log.severe("Cannot write player icon " + img_8x8.getPath());
} }
FileLockManager.releaseWriteLock(img_8x8); FileLockManager.releaseWriteLock(img_8x8);
}
/* Write 16x16 file */
if(refreshskins || (!has_16x16)) {
/* Make 16x16 version */ /* Make 16x16 version */
DynmapBufferedImage face16x16 = DynmapBufferedImage.allocateBufferedImage(16, 16); DynmapBufferedImage face16x16 = DynmapBufferedImage.allocateBufferedImage(16, 16);
for(int i = 0; i < 16; i++) { for(int i = 0; i < 16; i++) {
@ -88,8 +102,6 @@ public class PlayerFaces {
face16x16.argb_buf[i*16+j] = face8x8.argb_buf[(i/2)*8 + (j/2)]; face16x16.argb_buf[i*16+j] = face8x8.argb_buf[(i/2)*8 + (j/2)];
} }
} }
/* Write 16x16 file */
File img_16x16 = new File(faces16x16dir, playername + ".png");
FileLockManager.getWriteLock(img_16x16); FileLockManager.getWriteLock(img_16x16);
try { try {
FileLockManager.imageIOWrite(face16x16.buf_img, ImageFormat.FORMAT_PNG, img_16x16); FileLockManager.imageIOWrite(face16x16.buf_img, ImageFormat.FORMAT_PNG, img_16x16);
@ -98,7 +110,10 @@ public class PlayerFaces {
} }
FileLockManager.releaseWriteLock(img_16x16); FileLockManager.releaseWriteLock(img_16x16);
DynmapBufferedImage.freeBufferedImage(face16x16); DynmapBufferedImage.freeBufferedImage(face16x16);
}
/* Write 32x32 file */
if(refreshskins || (!has_32x32)) {
/* Make 32x32 version */ /* Make 32x32 version */
DynmapBufferedImage face32x32 = DynmapBufferedImage.allocateBufferedImage(32, 32); DynmapBufferedImage face32x32 = DynmapBufferedImage.allocateBufferedImage(32, 32);
for(int i = 0; i < 32; i++) { for(int i = 0; i < 32; i++) {
@ -106,8 +121,6 @@ public class PlayerFaces {
face32x32.argb_buf[i*32+j] = face8x8.argb_buf[(i/4)*8 + (j/4)]; face32x32.argb_buf[i*32+j] = face8x8.argb_buf[(i/4)*8 + (j/4)];
} }
} }
/* Write 32x32 file */
File img_32x32 = new File(faces32x32dir, playername + ".png");
FileLockManager.getWriteLock(img_32x32); FileLockManager.getWriteLock(img_32x32);
try { try {
FileLockManager.imageIOWrite(face32x32.buf_img, ImageFormat.FORMAT_PNG, img_32x32); FileLockManager.imageIOWrite(face32x32.buf_img, ImageFormat.FORMAT_PNG, img_32x32);
@ -116,6 +129,7 @@ public class PlayerFaces {
} }
FileLockManager.releaseWriteLock(img_32x32); FileLockManager.releaseWriteLock(img_32x32);
DynmapBufferedImage.freeBufferedImage(face32x32); DynmapBufferedImage.freeBufferedImage(face32x32);
}
DynmapBufferedImage.freeBufferedImage(face8x8); DynmapBufferedImage.freeBufferedImage(face8x8);
/* TODO: signal update for player icon to client */ /* TODO: signal update for player icon to client */
@ -124,13 +138,20 @@ public class PlayerFaces {
private class LoginListener extends PlayerListener { private class LoginListener extends PlayerListener {
@Override @Override
public void onPlayerLogin(PlayerLoginEvent event) { public void onPlayerLogin(PlayerLoginEvent event) {
MapManager.scheduleDelayedJob(new LoadPlayerImages(event.getPlayer().getName()), 0); Runnable job = new LoadPlayerImages(event.getPlayer().getName());
if(fetchskins)
MapManager.scheduleDelayedJob(job, 0);
else
job.run();
} }
} }
public PlayerFaces(DynmapPlugin plugin) { public PlayerFaces(DynmapPlugin plugin) {
this.plugin = plugin; this.plugin = plugin;
fetchskins = plugin.configuration.getBoolean("fetchskins", true); /* Control whether to fetch skins */
refreshskins = plugin.configuration.getBoolean("refreshskins", true); /* Control whether to update existing fetched skins or faces */
plugin.registerEvent(Type.PLAYER_LOGIN, new LoginListener()); plugin.registerEvent(Type.PLAYER_LOGIN, new LoginListener());
facesdir = new File(plugin.tilesDirectory, "faces"); facesdir = new File(DynmapPlugin.tilesDirectory, "faces");
facesdir.mkdirs(); /* Make sure directory exists */ facesdir.mkdirs(); /* Make sure directory exists */
faces8x8dir = new File(facesdir, "8x8"); faces8x8dir = new File(facesdir, "8x8");
faces8x8dir.mkdirs(); faces8x8dir.mkdirs();
@ -139,6 +160,4 @@ public class PlayerFaces {
faces32x32dir = new File(facesdir, "32x32"); faces32x32dir = new File(facesdir, "32x32");
faces32x32dir.mkdirs(); faces32x32dir.mkdirs();
} }
} }

View File

@ -258,6 +258,12 @@ enabletilehash: true
# Optional - control rendering of fences (joining to blocks, as in 1.9+) - default is true for 1.9+, false for 1.8.x # Optional - control rendering of fences (joining to blocks, as in 1.9+) - default is true for 1.9+, false for 1.8.x
#fence-to-block-join: true #fence-to-block-join: true
# Control loading of player faces (if set to false, skins are never fetched)
#fetchskins: false
# Control updating of player faces, once loaded (if faces are being managed by other apps or manually)
#refreshskins: false
render-triggers: render-triggers:
#- chunkloaded #- chunkloaded
#- playermove #- playermove