Block.cpp 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. #include "Block.h"
  2. #include <Shader.h>
  3. #include <Textur.h>
  4. #include "CustomDX11API.h"
  5. #include "Globals.h"
  6. Block::Block(const BlockType* zType,
  7. Framework::Vec3<int> pos,
  8. Model3DData* model,
  9. Model3DTextur* texture,
  10. int maxHP,
  11. bool transparent,
  12. bool needRequestModelInfo)
  13. : Model3D(),
  14. zType(zType),
  15. location(pos),
  16. maxHP((float)maxHP),
  17. needRequestModelInfo(needRequestModelInfo)
  18. {
  19. hp = (float)maxHP;
  20. memset(sideVisible, 0, 6);
  21. Model3D::setAlpha(transparent);
  22. Model3D::setPosition(
  23. (Framework::Vec3<float>)pos + Framework::Vec3<float>{0.5f, 0.5f, 0.5f});
  24. setModelDaten(model);
  25. setModelTextur(texture);
  26. breakTextur
  27. = uiFactory.initParam.bildschirm->zGraphicsApi()->createOrGetTextur(
  28. "blocks.ltdb/crack.png", 0);
  29. memset(lightData, 0, 6 * 6);
  30. }
  31. Block::~Block()
  32. {
  33. breakTextur->release();
  34. }
  35. void Block::beforeRender(
  36. GraphicsApi* api, Shader* zVertexShader, Shader* zPixelShader)
  37. {
  38. if (needRequestModelInfo)
  39. {
  40. needRequestModelInfo = 0;
  41. World::INSTANCE->zClient()->blockAPIRequest(location, "\0", 1);
  42. }
  43. CustomDX11API* cApi = dynamic_cast<CustomDX11API*>(api);
  44. if (cApi && model->getVertexAnzahl() == 24)
  45. {
  46. int count = 24;
  47. zVertexShader->füllConstBuffer(
  48. (char*)&count, cApi->getVertexShaderLightBufferIndex(), 4);
  49. zVertexShader->füllConstBuffer(
  50. lightBuffer, cApi->getVertexShaderLightBufferIndex() + 1, 24 * 4);
  51. }
  52. else if (cApi)
  53. {
  54. int count = 1;
  55. zVertexShader->füllConstBuffer(
  56. (char*)&count, cApi->getVertexShaderLightBufferIndex(), 4);
  57. zVertexShader->füllConstBuffer(
  58. lightBuffer, cApi->getVertexShaderLightBufferIndex() + 1, 4);
  59. }
  60. }
  61. void Block::afterRender(
  62. GraphicsApi* api, Shader* zVertexShader, Shader* zPixelShader)
  63. {
  64. CustomDX11API* cApi = dynamic_cast<CustomDX11API*>(api);
  65. if (cApi)
  66. {
  67. int count = 0;
  68. zVertexShader->füllConstBuffer(
  69. (char*)&count, cApi->getVertexShaderLightBufferIndex(), 4);
  70. }
  71. }
  72. void Block::api(char* message)
  73. {
  74. // TODO: implement api
  75. switch (message[0])
  76. {
  77. case 0: // hp change
  78. hp = *(float*)(message + 1);
  79. break;
  80. case 1: // model change
  81. {
  82. ByteArrayReader reader(message + 1, 10000, 0);
  83. ModelInfo info(&reader);
  84. setModelDaten(info.getModel());
  85. setModelTextur(info.getTexture());
  86. break;
  87. }
  88. case 2: // update fluid fill state
  89. {
  90. short fluidAmount = *(short*)(message + 1);
  91. if (this->skelett)
  92. {
  93. float z = (float)fluidAmount / 1000.f;
  94. Knochen* k = this->skelett->zKnochen()->zKind();
  95. k->setPosition(Vec3<float>(0.f, 0.f, z - 1));
  96. k = k->zGeschwister();
  97. k->setPosition(Vec3<float>(0.f, 0.f, z - 1));
  98. k = k->zGeschwister();
  99. k->setPosition(Vec3<float>(0.f, 0.f, z - 1));
  100. k = k->zGeschwister();
  101. k->setPosition(Vec3<float>(0.f, 0.f, z - 1));
  102. }
  103. }
  104. }
  105. }
  106. void Block::copyLightTo(Block* zB)
  107. {
  108. memcpy(zB->lightBuffer, lightBuffer, 24 * 4);
  109. memcpy(zB->lightData, lightData, 6 * 6);
  110. memcpy(zB->sideVisible, sideVisible, 6);
  111. }
  112. void Block::setLightData(Direction dir, unsigned char* data)
  113. {
  114. memcpy(lightData + getDirectionIndex(dir) * 6, data, 6);
  115. float dayLightFactor = 1.0; // TODO: day (1.f) - night (0.1f) adjustment
  116. if (model->getVertexAnzahl() == 24)
  117. {
  118. const Vertex3D* verticies = model->zVertexBuffer();
  119. for (int i = 0; i < 24; i++)
  120. { // TODO: calculate rotations
  121. Directions dirs = getDirectionsFromVector(verticies[i].pos);
  122. Vec3<unsigned char> light(0, 0, 0);
  123. for (int d = 0; d < 6; d++)
  124. {
  125. if ((dirs | getDirectionFromIndex(d)) == dirs)
  126. {
  127. light = Vec3<unsigned char>(
  128. max((unsigned char)((float)lightData[d * 6]
  129. * dayLightFactor),
  130. light.x),
  131. max((unsigned char)((float)lightData[d * 6 + 1]
  132. * dayLightFactor),
  133. light.y),
  134. max((unsigned char)((float)lightData[d * 6 + 2]
  135. * dayLightFactor),
  136. light.z));
  137. light = Vec3<float>(max(lightData[d * 6 + 3], light.x),
  138. max(lightData[d * 6 + 4], light.y),
  139. max(lightData[d * 6 + 5], light.z));
  140. }
  141. }
  142. int l = ((((light.x << 8) | light.y) << 8) | light.z) << 8;
  143. *(int*)(lightBuffer + i * 4) = l;
  144. }
  145. }
  146. else if (dir == Direction::TOP)
  147. {
  148. Vec3<unsigned char> light = Vec3<unsigned char>(
  149. max((unsigned char)((float)data[0] * dayLightFactor), data[3]),
  150. max((unsigned char)((float)data[1] * dayLightFactor), data[4]),
  151. max((unsigned char)((float)data[2] * dayLightFactor), data[5]));
  152. int l = ((((light.x << 8) | light.y) << 8) | light.z) << 8;
  153. *(int*)lightBuffer = l;
  154. }
  155. if (data[0] | data[1] | data[2] | data[3] | data[4] | data[5])
  156. sideVisible[getDirectionIndex(dir)] = 1;
  157. else
  158. sideVisible[getDirectionIndex(dir)] = 0;
  159. }
  160. bool Block::isVisible() const
  161. {
  162. return true;
  163. //return sideVisible[0] || sideVisible[1] || sideVisible[2] || sideVisible[3]
  164. // || sideVisible[4] || sideVisible[5];
  165. }
  166. Vec3<int> Block::getLocation() const
  167. {
  168. return location;
  169. }
  170. const BlockType* Block::zBlockType() const
  171. {
  172. return zType;
  173. }
  174. Textur* Block::zEffectTextur()
  175. {
  176. if (hp < maxHP) return breakTextur;
  177. return 0;
  178. }
  179. float Block::getEffectPercentage()
  180. {
  181. return 1 - hp / maxHP;
  182. }
  183. Text Block::printLightInfo()
  184. {
  185. Text result = "NORTH[0;-1;0](";
  186. result += (int)lightData[0];
  187. result += ",";
  188. result += (int)lightData[1];
  189. result += ",";
  190. result += (int)lightData[2];
  191. result += ";";
  192. result += (int)lightData[3];
  193. result += ",";
  194. result += (int)lightData[4];
  195. result += ",";
  196. result += (int)lightData[5];
  197. result += ")\n";
  198. result += "EAST[1;0;0](";
  199. result += (int)lightData[6];
  200. result += ",";
  201. result += (int)lightData[7];
  202. result += ",";
  203. result += (int)lightData[8];
  204. result += ";";
  205. result += (int)lightData[9];
  206. result += ",";
  207. result += (int)lightData[10];
  208. result += ",";
  209. result += (int)lightData[11];
  210. result += ")\n";
  211. result += "SOUTH[0;1;0](";
  212. result += (int)lightData[12];
  213. result += ",";
  214. result += (int)lightData[13];
  215. result += ",";
  216. result += (int)lightData[14];
  217. result += ";";
  218. result += (int)lightData[15];
  219. result += ",";
  220. result += (int)lightData[16];
  221. result += ",";
  222. result += (int)lightData[17];
  223. result += ")\n";
  224. result += "WEST[-1;0;0](";
  225. result += (int)lightData[18];
  226. result += ",";
  227. result += (int)lightData[19];
  228. result += ",";
  229. result += (int)lightData[20];
  230. result += ";";
  231. result += (int)lightData[21];
  232. result += ",";
  233. result += (int)lightData[22];
  234. result += ",";
  235. result += (int)lightData[23];
  236. result += ")\n";
  237. result += "TOP[0;0;1](";
  238. result += (int)lightData[24];
  239. result += ",";
  240. result += (int)lightData[25];
  241. result += ",";
  242. result += (int)lightData[26];
  243. result += ";";
  244. result += (int)lightData[27];
  245. result += ",";
  246. result += (int)lightData[28];
  247. result += ",";
  248. result += (int)lightData[29];
  249. result += ")\n";
  250. result += "BOTTOM[0;0;-1](";
  251. result += (int)lightData[30];
  252. result += ",";
  253. result += (int)lightData[31];
  254. result += ",";
  255. result += (int)lightData[32];
  256. result += ";";
  257. result += (int)lightData[33];
  258. result += ",";
  259. result += (int)lightData[34];
  260. result += ",";
  261. result += (int)lightData[35];
  262. result += ")\n";
  263. return result;
  264. }