renders.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. // Skin locations are based on the work of Confuser
  2. // https://github.com/confuser/serverless-mc-skin-viewer
  3. // Permission to use & distribute https://github.com/confuser/serverless-mc-skin-viewer/blob/master/LICENSE
  4. var helpers = require('./helpers');
  5. var logging = require('./logging');
  6. var exp = {};
  7. var Canvas = require('canvas');
  8. var Image = Canvas.Image;
  9. exp.draw_helmet = function(skin_canvas, model_ctx, scale) {
  10. //Helmet - Front
  11. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  12. model_ctx.drawImage(skin_canvas, 40*scale, 8*scale, 8*scale, 8*scale, 10*scale, 13/1.2*scale, 8*scale, 8*scale);
  13. //Helmet - Right
  14. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  15. model_ctx.drawImage(skin_canvas, 32*scale, 8*scale, 8*scale, 8*scale, 2*scale, 3/1.2*scale, 8*scale, 8*scale);
  16. //Helmet - Top
  17. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  18. model_ctx.scale(-1,1);
  19. model_ctx.drawImage(skin_canvas, 40*scale, 0, 8*scale, 8*scale, -3*scale, 5*scale, 8*scale, 8*scale);
  20. }
  21. exp.draw_head = function(skin_canvas, model_ctx, scale) {
  22. //Head - Front
  23. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  24. model_ctx.drawImage(skin_canvas, 8*scale, 8*scale, 8*scale, 8*scale, 10*scale, 13/1.2*scale, 8*scale, 8*scale);
  25. //Head - Right
  26. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  27. model_ctx.drawImage(skin_canvas, 0, 8*scale, 8*scale, 8*scale, 2*scale, 3/1.2*scale, 8*scale, 8*scale);
  28. //Head - Top
  29. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  30. model_ctx.scale(-1,1);
  31. model_ctx.drawImage(skin_canvas, 8*scale, 0, 8*scale, 8*scale, -3*scale, 5*scale, 8*scale, 8*scale);
  32. }
  33. exp.draw_body = function(skin_canvas, model_ctx, scale) {
  34. //Left Leg
  35. //Left Leg - Front
  36. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  37. model_ctx.scale(-1,1);
  38. model_ctx.drawImage(skin_canvas, 4*scale, 20*scale, 4*scale, 12*scale, -16*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  39. //Right Leg
  40. //Right Leg - Right
  41. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  42. model_ctx.drawImage(skin_canvas, 0*scale, 20*scale, 4*scale, 12*scale, 4*scale, 26.4/1.2*scale, 4*scale, 12*scale);
  43. //Right Leg - Front
  44. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  45. model_ctx.drawImage(skin_canvas, 4*scale, 20*scale, 4*scale, 12*scale, 8*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  46. //Arm Left
  47. //Arm Left - Front
  48. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  49. model_ctx.scale(-1,1);
  50. model_ctx.drawImage(skin_canvas, 44*scale, 20*scale, 4*scale, 12*scale, -20*scale, 20/1.2*scale, 4*scale, 12*scale);
  51. //Arm Left - Top
  52. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  53. model_ctx.drawImage(skin_canvas, 44*scale, 16*scale, 4*scale, 4*scale, 0, 16*scale, 4*scale, 4*scale);
  54. //Body
  55. //Body - Front
  56. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  57. model_ctx.drawImage(skin_canvas, 20*scale, 20*scale, 8*scale, 12*scale, 8*scale, 20/1.2*scale, 8*scale, 12*scale);
  58. //Arm Right
  59. //Arm Right - Right
  60. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  61. model_ctx.drawImage(skin_canvas, 40*scale, 20*scale, 4*scale, 12*scale, 0, 16/1.2*scale, 4*scale, 12*scale);
  62. //Arm Right - Front
  63. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  64. model_ctx.drawImage(skin_canvas, 44*scale, 20*scale, 4*scale, 12*scale, 4*scale, 20/1.2*scale, 4*scale, 12*scale);
  65. //Arm Right - Top
  66. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  67. model_ctx.scale(-1,1);
  68. model_ctx.drawImage(skin_canvas, 44*scale, 16*scale, 4*scale, 4*scale, -16*scale, 16*scale, 4*scale, 4*scale);
  69. }
  70. exp.draw_model = function(uuid, img, scale, helm, body, callback) {
  71. var image = new Image;
  72. var width = 64 * scale;
  73. var height = 64 * scale;
  74. var model_canvas = new Canvas(20 * scale, (body ? 44.8 : 17.6) * scale);
  75. var skin_canvas = new Canvas(width, height);
  76. var model_ctx = model_canvas.getContext('2d');
  77. var skin_ctx = skin_canvas.getContext('2d');
  78. image.onerror = function(err) {
  79. logging.error("render error: " + err);
  80. callback(err, null);
  81. };
  82. image.onload = function() {
  83. skin_ctx.drawImage(image,0,0,64,64,0,0,64,64);
  84. //Scale it
  85. scale_image(skin_ctx.getImageData(0,0,64,64), skin_ctx, 0, 0, scale);
  86. if (body) {
  87. logging.log("drawing body");
  88. exp.draw_body(skin_canvas, model_ctx, scale);
  89. }
  90. logging.log("drawing head");
  91. exp.draw_head(skin_canvas, model_ctx, scale);
  92. if (helm) {
  93. logging.log("drawing helmet");
  94. exp.draw_helmet(skin_canvas, model_ctx, scale);
  95. }
  96. model_canvas.toBuffer(function(err, buf){
  97. callback(err, buf);
  98. });
  99. };
  100. image.src = img;
  101. }
  102. function scale_image(imageData, context, d_x, d_y, scale) {
  103. var width = imageData.width;
  104. var height = imageData.height;
  105. context.clearRect(0,0,width,height); //Clear the spot where it originated from
  106. for(y=0; y<height; y++) { //height original
  107. for(x=0; x<width; x++) { //width original
  108. //Gets original colour, then makes a scaled square of the same colour
  109. var index = (x + y * width) * 4;
  110. context.fillStyle = "rgba(" + imageData.data[index+0] + "," + imageData.data[index+1] + "," + imageData.data[index+2] + "," + imageData.data[index+3] + ")";
  111. context.fillRect(d_x + x*scale, d_y + y*scale, scale, scale);
  112. }
  113. }
  114. }
  115. module.exports = exp;