renders.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  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 fs = require('fs');
  7. var Canvas = require('canvas');
  8. var Image = Canvas.Image;
  9. var exp = {};
  10. exp.draw_helmet = function(skin_canvas, model_ctx, scale) {
  11. //Helmet - Front
  12. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  13. model_ctx.drawImage(skin_canvas, 40*scale, 8*scale, 8*scale, 8*scale, 10*scale, 13/1.2*scale, 8*scale, 8*scale);
  14. //Helmet - Right
  15. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  16. model_ctx.drawImage(skin_canvas, 32*scale, 8*scale, 8*scale, 8*scale, 2*scale, 3/1.2*scale, 8*scale, 8*scale);
  17. //Helmet - Top
  18. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  19. model_ctx.scale(-1,1);
  20. model_ctx.drawImage(skin_canvas, 40*scale, 0, 8*scale, 8*scale, -3*scale, 5*scale, 8*scale, 8*scale);
  21. };
  22. exp.draw_head = function(skin_canvas, model_ctx, scale) {
  23. //Head - Front
  24. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  25. model_ctx.drawImage(skin_canvas, 8*scale, 8*scale, 8*scale, 8*scale, 10*scale, 13/1.2*scale, 8*scale, 8*scale);
  26. //Head - Right
  27. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  28. model_ctx.drawImage(skin_canvas, 0, 8*scale, 8*scale, 8*scale, 2*scale, 3/1.2*scale, 8*scale, 8*scale);
  29. //Head - Top
  30. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  31. model_ctx.scale(-1,1);
  32. model_ctx.drawImage(skin_canvas, 8*scale, 0, 8*scale, 8*scale, -3*scale, 5*scale, 8*scale, 8*scale);
  33. };
  34. exp.draw_body = function(skin_canvas, model_ctx, scale) {
  35. if (skin_canvas.height == 32 * scale) {
  36. logging.log("old skin");
  37. //Left Leg
  38. //Left Leg - Front
  39. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  40. model_ctx.scale(-1,1);
  41. model_ctx.drawImage(skin_canvas, 4*scale, 20*scale, 4*scale, 12*scale, -16*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  42. //Right Leg
  43. //Right Leg - Right
  44. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  45. model_ctx.drawImage(skin_canvas, 0*scale, 20*scale, 4*scale, 12*scale, 4*scale, 26.4/1.2*scale, 4*scale, 12*scale);
  46. //Right Leg - Front
  47. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  48. model_ctx.drawImage(skin_canvas, 4*scale, 20*scale, 4*scale, 12*scale, 8*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  49. //Arm Left
  50. //Arm Left - Front
  51. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  52. model_ctx.scale(-1,1);
  53. model_ctx.drawImage(skin_canvas, 44*scale, 20*scale, 4*scale, 12*scale, -20*scale, 20/1.2*scale, 4*scale, 12*scale);
  54. //Arm Left - Top
  55. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  56. model_ctx.drawImage(skin_canvas, 44*scale, 16*scale, 4*scale, 4*scale, 0, 16*scale, 4*scale, 4*scale);
  57. //Body
  58. //Body - Front
  59. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  60. model_ctx.drawImage(skin_canvas, 20*scale, 20*scale, 8*scale, 12*scale, 8*scale, 20/1.2*scale, 8*scale, 12*scale);
  61. //Arm Right
  62. //Arm Right - Right
  63. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  64. model_ctx.drawImage(skin_canvas, 40*scale, 20*scale, 4*scale, 12*scale, 0, 16/1.2*scale, 4*scale, 12*scale);
  65. //Arm Right - Front
  66. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  67. model_ctx.drawImage(skin_canvas, 44*scale, 20*scale, 4*scale, 12*scale, 4*scale, 20/1.2*scale, 4*scale, 12*scale);
  68. //Arm Right - Top
  69. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  70. model_ctx.scale(-1,1);
  71. model_ctx.drawImage(skin_canvas, 44*scale, 16*scale, 4*scale, 4*scale, -16*scale, 16*scale, 4*scale, 4*scale);
  72. } else {
  73. logging.log("new skin");
  74. //Left Leg
  75. //Left Leg - Front
  76. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  77. model_ctx.scale(-1,1);
  78. model_ctx.drawImage(skin_canvas, 20*scale, 52*scale, 4*scale, 12*scale, -16*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  79. //Right Leg
  80. //Right Leg - Right
  81. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  82. model_ctx.drawImage(skin_canvas, 0*scale, 20*scale, 4*scale, 12*scale, 4*scale, 26.4/1.2*scale, 4*scale, 12*scale);
  83. //Right Leg - Front
  84. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  85. model_ctx.drawImage(skin_canvas, 4*scale, 20*scale, 4*scale, 12*scale, 8*scale, 34.4/1.2*scale, 4*scale, 12*scale);
  86. //Arm Left
  87. //Arm Left - Front
  88. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  89. model_ctx.scale(-1,1);
  90. model_ctx.drawImage(skin_canvas, 36*scale, 52*scale, 4*scale, 12*scale, -20*scale, 20/1.2*scale, 4*scale, 12*scale);
  91. //Arm Left - Top
  92. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  93. model_ctx.drawImage(skin_canvas, 36*scale, 48*scale, 4*scale, 4*scale, 0, 16*scale, 4*scale, 4*scale);
  94. //Body
  95. //Body - Front
  96. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  97. model_ctx.drawImage(skin_canvas, 20*scale, 20*scale, 8*scale, 12*scale, 8*scale, 20/1.2*scale, 8*scale, 12*scale);
  98. //Arm Right
  99. //Arm Right - Right
  100. model_ctx.setTransform(1,0.5,0,1.2,0,0);
  101. model_ctx.drawImage(skin_canvas, 40*scale, 20*scale, 4*scale, 12*scale, 0, 16/1.2*scale, 4*scale, 12*scale);
  102. //Arm Right - Front
  103. model_ctx.setTransform(1,-0.5,0,1.2,0,0);
  104. model_ctx.drawImage(skin_canvas, 44*scale, 20*scale, 4*scale, 12*scale, 4*scale, 20/1.2*scale, 4*scale, 12*scale);
  105. //Arm Right - Top
  106. model_ctx.setTransform(-1,0.5,1,0.5,0,0);
  107. model_ctx.scale(-1,1);
  108. model_ctx.drawImage(skin_canvas, 44*scale, 16*scale, 4*scale, 4*scale, -16*scale, 16*scale, 4*scale, 4*scale);
  109. }
  110. };
  111. exp.draw_model = function(uuid, img, scale, helm, body, callback) {
  112. var image = new Image();
  113. image.onerror = function(err) {
  114. logging.error("render error: " + err);
  115. callback(err, null);
  116. };
  117. image.onload = function() {
  118. var width = 64 * scale;
  119. var height = (image.height == 32 ? 32 : 64) * scale;
  120. var model_canvas = new Canvas(20 * scale, (body ? 44.8 : 17.6) * scale);
  121. var skin_canvas = new Canvas(width, height);
  122. var model_ctx = model_canvas.getContext('2d');
  123. var skin_ctx = skin_canvas.getContext('2d');
  124. skin_ctx.drawImage(image,0,0,64,64,0,0,64,64);
  125. //Scale it
  126. scale_image(skin_ctx.getImageData(0,0,64,64), skin_ctx, 0, 0, scale);
  127. if (body) {
  128. logging.log("drawing body");
  129. exp.draw_body(skin_canvas, model_ctx, scale);
  130. }
  131. logging.log("drawing head");
  132. exp.draw_head(skin_canvas, model_ctx, scale);
  133. if (helm) {
  134. logging.log("drawing helmet");
  135. exp.draw_helmet(skin_canvas, model_ctx, scale);
  136. }
  137. model_canvas.toBuffer(function(err, buf){
  138. if (err) {
  139. logging.log("error creating buffer: " + err);
  140. }
  141. callback(err, buf);
  142. });
  143. };
  144. image.src = img;
  145. };
  146. exp.open_render = function(renderpath, callback) {
  147. fs.readFile(renderpath, function (err, buf) {
  148. if (err) {
  149. logging.error("error while opening skin file: " + err);
  150. }
  151. callback(err, buf);
  152. });
  153. };
  154. function scale_image(imageData, context, d_x, d_y, scale) {
  155. var width = imageData.width;
  156. var height = imageData.height;
  157. context.clearRect(0,0,width,height); //Clear the spot where it originated from
  158. for(y=0; y<height; y++) { //height original
  159. for(x=0; x<width; x++) { //width original
  160. //Gets original colour, then makes a scaled square of the same colour
  161. var index = (x + y * width) * 4;
  162. context.fillStyle = "rgba(" + imageData.data[index+0] + "," + imageData.data[index+1] + "," + imageData.data[index+2] + "," + imageData.data[index+3] + ")";
  163. context.fillRect(d_x + x*scale, d_y + y*scale, scale, scale);
  164. }
  165. }
  166. }
  167. module.exports = exp;