less copy protection, more size visualization
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
 
 
 

208 lignes
8.5 KiB

  1. const scenes = {};
  2. scenes["Default"] = () => {
  3. importScene({"entities":[{"name":"Fen","scale":1,"view":"back","x":"0.5152113970588236","y":"1"}],"world":{"height":2.9053707516337908,"unit":"meters"}});
  4. fitWorld(true);
  5. }
  6. scenes["Demo"] = () => {
  7. importScene({"entities":[{"name":"Fen","scale":13.37613697164259,"view":"back","x":"0.4739888072901602","y":"1"},{"name":"Cars","scale":1,"view":"Toyota Prius C (Side)","x":"0.5446325587240624","y":"1"},{"name":"Flagpole","scale":1,"view":"medium","x":"0.6884494749664603","y":"1"},{"name":"Aircraft","scale":1,"view":"Cessena 172 (Side)","x":"0.5554263161666061","y":"0.22135128477620036"},{"name":"Bus","scale":1,"view":"side","x":"0.3384726446176792","y":"1"},{"name":"Leopard 2 Rev. 1","scale":1,"view":"side","x":"0.6168929701770606","y":"1"},{"name":"Trees","scale":1,"view":"sycamore","x":"0.19678198200160846","y":"1"},{"name":"18-Wheeler","scale":1,"view":"side","x":"0.7563502890715608","y":"1"},{"name":"Cars","scale":1,"view":"Toyota Prius C (Top)","x":"0.5363900938385269","y":"0.7215473541048467"},{"name":"Human","scale":1,"view":"woman1","x":"0.4756975717747481","y":"1"},{"name":"Human","scale":1,"view":"man1","x":"0.47400075247875356","y":"0.2538019287833828"}],"world":{"height":38.5,"unit":"meters"}})
  8. fitWorld(true);
  9. }
  10. scenes["Military"] = () => {
  11. removeAllEntities();
  12. let entity = availableEntitiesByName["Asana (Mech)"].constructor();
  13. displayEntity(entity, entity.defaultView, 0, 1);
  14. entity = availableEntitiesByName["Napalm"].constructor();
  15. displayEntity(entity, entity.defaultView, 0, 1);
  16. entity = availableEntitiesByName["Chez"].constructor();
  17. displayEntity(entity, entity.defaultView, 0, 1);
  18. entity = availableEntitiesByName["Leopard 2 Rev. 1"].constructor();
  19. displayEntity(entity, entity.defaultView, 0, 1);
  20. entity = availableEntitiesByName["Asana"].constructor();
  21. displayEntity(entity, entity.defaultView, 0, 1);
  22. entity = availableEntitiesByName["Ashtrek"].constructor();
  23. entity.views[entity.view].height = entity.sizes[0].height;
  24. displayEntity(entity, entity.defaultView, 0, 1);
  25. arrangeEntities(getSortedEntities());
  26. fitWorld(true);
  27. }
  28. function makeSlice(min, max) {
  29. return () => {
  30. const characters = availableEntities["characters"].filter(x => {
  31. const entity = x.constructor();
  32. return math.compare(entity.views[entity.view].height, min) == 1 && math.compare(entity.views[entity.view].height, max) != 1
  33. });
  34. characters.forEach(character => {
  35. const entity = character.constructor();
  36. displayEntity(entity, entity.view, 0, 1);
  37. });
  38. arrangeEntities(getSortedEntities());
  39. fitWorld(true);
  40. }
  41. }
  42. scenes["x < 10m"] = makeSlice(math.unit(0, "meters"), math.unit(10, "meters"));
  43. scenes["10m < x <= 100m"] = makeSlice(math.unit(10, "meters"), math.unit(100, "meters"));
  44. scenes["100m < x <= 1km"] = makeSlice(math.unit(100, "meters"), math.unit(1000, "meters"));
  45. scenes["1km < x <= 10km"] = makeSlice(math.unit(1000, "meters"), math.unit(10000, "meters"));
  46. scenes["10km < x <= 100km"] = makeSlice(math.unit(10000, "meters"), math.unit(100000, "meters"));
  47. scenes["100km < x <= 1000km"] = makeSlice(math.unit(100000, "meters"), math.unit(1000000, "meters"));
  48. scenes["Everyone"] = () => {
  49. config.height = math.unit(11, "meters");
  50. availableEntities.characters.map(maker => {
  51. return maker.constructor();
  52. }).reduce((counter, entity) => {
  53. entity.views[entity.view].height = math.unit(1, "meter");
  54. const count = availableEntities.characters.length;
  55. const x = 0.05 + math.floor(counter / 10) / math.ceil(count / 10);
  56. const y = (counter % 10) / 10 + 0.1;
  57. displayEntity(entity, entity.view, x, y);
  58. return counter + 1;
  59. }, 0);
  60. updateSizes(true);
  61. }
  62. scenes["EVERYTHING"] = () => {
  63. config.height = math.unit(11, "meters");
  64. Object.values(availableEntitiesByName).map(maker => {
  65. return maker.constructor();
  66. }).reduce((counter, entity) => {
  67. entity.views[entity.view].height = math.unit(1, "meter");
  68. const count = Object.values(availableEntitiesByName).length;
  69. const x = 0.05 + math.floor(counter / 10) / math.ceil(count / 10);
  70. const y = (counter % 10) / 10 + 0.1;
  71. displayEntity(entity, entity.view, x, y);
  72. return counter + 1;
  73. }, 0);
  74. updateSizes(true);
  75. }
  76. scenes["EVERY VIEW AAAAA"] = () => {
  77. config.height = math.unit(11, "meters");
  78. Object.values(availableEntitiesByName).map(maker => {
  79. return maker.constructor();
  80. }).flatMap(entity => {
  81. return Object.keys(entity.views).map(view => {
  82. const newEntity = availableEntitiesByName[entity.identifier].constructor();
  83. newEntity.view = view;
  84. return newEntity;
  85. });
  86. }).reduce((counter, entity) => {
  87. entity.views[entity.view].height = math.unit(1, "meter");
  88. const count = Object.values(availableEntitiesByName).length;
  89. const x = 0.05 + math.floor(counter / 10) / math.ceil(count / 10);
  90. const y = (counter % 10) / 10 + 0.1;
  91. displayEntity(entity, entity.view, x, y);
  92. return counter + 1;
  93. }, 0);
  94. updateSizes(true);
  95. }
  96. function makeOwnerScene(owner) {
  97. return () => {
  98. availableEntities["characters"].filter(x => {
  99. const entity = x.constructor();
  100. const owners = ownersOf(entity.views[entity.view].image.source);
  101. if (owners)
  102. return owners.indexOf(owner) != -1;
  103. else
  104. return false;
  105. }).map(maker => {
  106. return maker.constructor();
  107. }).sort((e1, e2) => {
  108. return e1.sizes[e1.sizes.length - 1].height.toNumber() - e2.sizes[e2.sizes.length - 1].height.toNumber()
  109. }).forEach(entity => {
  110. displayEntity(entity, entity.view, 0, 1);
  111. });
  112. arrangeEntities(getSortedEntities());
  113. fitWorld(true);
  114. }
  115. }
  116. function makeOwnerSceneViews(owners) {
  117. return () => {
  118. owners.flatMap(owner => {
  119. return availableEntities["characters"].filter(x => {
  120. const entity = x.constructor();
  121. const owners = ownersOf(entity.views[entity.view].image.source);
  122. if (owners)
  123. return owners.indexOf(owner) != -1;
  124. else
  125. return false;
  126. })
  127. }).map(maker => {
  128. return maker.constructor();
  129. }).flatMap(entity => {
  130. return Object.keys(entity.views).map(view => {
  131. const newEnt = availableEntitiesByName[entity.identifier].constructor();
  132. newEnt.view = view;
  133. return newEnt;
  134. });
  135. }).sort((e1, e2) => {
  136. return e1.views[e1.view].height.toNumber() - e2.views[e2.view].height.toNumber()
  137. }).forEach(entity => {
  138. console.log(entity)
  139. displayEntity(entity, entity.view, 0, 1);
  140. });
  141. arrangeEntities(getSortedEntities());
  142. fitWorld(true);
  143. }
  144. }
  145. scenes["Kurri"] = () => {
  146. availableEntities["characters"].filter(x => {
  147. const entity = x.constructor();
  148. return entity.info.author == "Kurrikage";
  149. }).forEach(maker => {
  150. const entity = maker.constructor();
  151. displayEntity(entity, entity.view, 0, 1);
  152. });
  153. arrangeEntities(getSortedEntities());
  154. fitWorld(true);
  155. }
  156. scenes["Neopuc"] = () => {
  157. availableEntities["characters"].filter(x => {
  158. const entity = x.constructor();
  159. const owners = ownersOf(entity.views[entity.view].image.source);
  160. if (owners)
  161. return owners.indexOf("neopuc") != -1;
  162. else
  163. return false;
  164. }).map(maker => {
  165. return maker.constructor();
  166. }).sort((e1, e2) => {
  167. return e1.sizes[e1.sizes.length - 1].height.toNumber() - e2.sizes[e2.sizes.length - 1].height.toNumber()
  168. }).reduce((size, entity) => {
  169. entity.views[entity.view].height = math.unit(100 * Math.sqrt(size) * (entity.name == "Ilisha Devya" ? 2 : 1), "meters");
  170. displayEntity(entity, entity.view, 0, 1);
  171. return size+1;
  172. }, 1)
  173. arrangeEntities(getSortedEntities());
  174. fitWorld(true);
  175. }
  176. scenes["Fidverse"] = () => {
  177. makeOwnerSceneViews(["fidchell", "cam"])();
  178. document.querySelector("#entity-" + (entityIndex-1)).dataset.x = 0.5;
  179. document.querySelector("#entity-" + (entityIndex-2)).dataset.x = 0.25;
  180. document.querySelector("#entity-" + (entityIndex-3)).dataset.x = 0.75;
  181. updateSizes();
  182. fitWorld(true, 1);
  183. }