Project.vue 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <template>
  2. <div>
  3. <object3d ref="block3d" name="Project" :obj="walls3dObj" :position="wallsPos" />
  4. <!-- <object3d v-if="debug" ref="gridDebug3d" name="griddebug" :obj="gridBebug3dObj" :position="wallsPos" /> -->
  5. <object3d ref="top" :obj="top3dObj" :position="topPos" />
  6. <object3d ref="floor" :obj="floor3dObj" :position="floorPos" />
  7. <object3d ref="levels" :obj="levels3dObj" :position="levelsPos" />
  8. <mesh ref="label3d" name="Label" :position="label_position">
  9. <geometry type="Plane" :args="[label_size.x, label_size.y]" />
  10. <material type="MeshLambert" :options="label_opts">
  11. <texture :options="label_texture_opts" />
  12. </material>
  13. </mesh>
  14. <div v-if="isOpened">
  15. <ContentBlock
  16. v-for="(item, i) in contents.visibles"
  17. :key="i"
  18. type="visible"
  19. :prtId="id"
  20. :data="item"
  21. />
  22. <ContentBlock
  23. v-for="(item, i) in contents.contexts"
  24. :key="i"
  25. type="context"
  26. :prtId="id"
  27. :data="item"
  28. />
  29. <ContentBlock
  30. v-for="(item, i) in contents.processes"
  31. :key="i"
  32. type="process"
  33. :prtId="id"
  34. :data="item"
  35. />
  36. <ContentBlock
  37. v-for="(item, i) in contents.concepts"
  38. :key="i"
  39. type="concept"
  40. :prtId="id"
  41. :data="item"
  42. />
  43. <div class="elevator">
  44. <ul>
  45. <li :class="{ active: levelVisibles }">
  46. <a
  47. class="btn-level"
  48. href="#visibles"
  49. @click.stop="onClickLevel('visibles', $event)"
  50. @keyup.enter="onClickLevel('visibles')"
  51. >Visible</a>
  52. </li>
  53. <li :class="{ active: levelContexts }">
  54. <a
  55. class="btn-level"
  56. href="#contexts"
  57. @click.stop="onClickLevel('contexts', $event)"
  58. @keyup.enter="onClickLevel('contexts')"
  59. >Context</a>
  60. </li>
  61. <li :class="{ active: levelProcesses }">
  62. <a
  63. class="btn-level"
  64. href="#processes"
  65. @click.stop="onClickLevel('processes', $event)"
  66. @keyup.enter="onClickLevel('processes')"
  67. >Process</a>
  68. </li>
  69. <li :class="{ active: levelConcepts }">
  70. <a
  71. class="btn-level"
  72. href="#concepts"
  73. @click.stop="onClickLevel('concepts', $event)"
  74. @keyup.enter="onClickLevel('concepts')"
  75. >Concept</a>
  76. </li>
  77. </ul>
  78. </div>
  79. </div>
  80. </div>
  81. </template>
  82. <script>
  83. import { mapInstanceState, mapInstanceActions, mapInstanceMutations } from '@urbn/vuex-helpers'
  84. import * as THREE from 'three'
  85. // import { ThreeBSP } from 'three-js-csg-es6'
  86. import mixins from 'components/mixins'
  87. import ContentBlock from 'components/objects/ContentBlock'
  88. // import BgVertex from 'assets/glsl/BgVertex'
  89. // import BuildingFragment from 'assets/glsl/BuildingFragment'
  90. // We'll determine our module based on the moduleName prop on this component
  91. // https://www.npmjs.com/package/@urbn/vuex-helpers
  92. const getModuleName = cmp => `project:${cmp.id}`
  93. export default {
  94. name: 'Project',
  95. components: {
  96. ContentBlock
  97. },
  98. mixins: [mixins],
  99. props: { id: Number },
  100. data () {
  101. // console.log('Project data()')
  102. return {
  103. isOpened: false,
  104. block3d: null,
  105. label3d: null,
  106. label_opts: {
  107. side: THREE.DoubleSide,
  108. transparent: true
  109. // wireframe: false,
  110. // opacity: 0.6
  111. // renderOrder: 0
  112. },
  113. label_canvas: null,
  114. label_size: null,
  115. label_position: { x: 0, y: 0, z: 0 }
  116. // level_mesh: levelMesh,
  117. // level_position: { ...position },
  118. }
  119. },
  120. computed: {
  121. ...mapInstanceState(getModuleName, {
  122. debug: state => state.debug,
  123. title: state => state.Titre,
  124. size: state => state.size,
  125. position: state => state.position,
  126. walls3dObj: state => state.walls3dObj,
  127. wallsPos: state => state.wallsPos,
  128. top3dObj: state => state.top3dObj,
  129. topPos: state => state.topPos,
  130. topColor: state => state.topColor,
  131. floor3dObj: state => state.floor3dObj,
  132. floorPos: state => state.floorPos,
  133. levels3dObj: state => state.levels3dObj,
  134. levelsPos: state => state.levelsPos,
  135. // gridBebug3dObj: state => state.gridBebug3dObj,
  136. contents: state => state.contents,
  137. activeLevel: state => state.activeLevel
  138. }),
  139. label_texture_opts () {
  140. return {
  141. canvas: this.label_canvas,
  142. minFilter: THREE.LinearFilter,
  143. wrapS: THREE.ClampToEdgeWrapping,
  144. wrapT: THREE.ClampToEdgeWrapping
  145. }
  146. },
  147. levelVisibles () {
  148. return this.activeLevel === 'visibles'
  149. },
  150. levelContexts () {
  151. return this.activeLevel === 'contexts'
  152. },
  153. levelProcesses () {
  154. return this.activeLevel === 'processes'
  155. },
  156. levelConcepts () {
  157. return this.activeLevel === 'concepts'
  158. }
  159. },
  160. created () {
  161. this.label_canvas = this.createBuildingTitleCanvas(this.title.replace(/ /g, '\n').toUpperCase(), 48, 21, '#000000', this.topColor)
  162. this.label_position.x = this.position.x - this.size.x / 2 + this.label_size.x / 2 + 1
  163. this.label_position.y = this.position.y + this.size.y / 2 - this.label_size.y / 2 - 1
  164. this.label_position.z = this.position.z + this.size.z / 2 + 0.5
  165. // console.log('this.label_position', this.label_position)
  166. },
  167. mounted () {
  168. console.log('project mounted', this)
  169. // record self references
  170. this.block3d = this.$refs.block3d.curObj
  171. this.block3d.userData.vnode = this
  172. this.block3d.userData.position = this.position
  173. this.label3d = this.$refs.label3d.curObj
  174. },
  175. methods: {
  176. ...mapInstanceActions(getModuleName, {
  177. getContents: 'getContents'
  178. }),
  179. ...mapInstanceMutations(getModuleName, {
  180. setActiveLevel: 'setActiveLevel'
  181. }),
  182. open () {
  183. if (!this.isOpened) {
  184. this.isOpened = true
  185. this.getContents()
  186. }
  187. },
  188. onClickLevel (level, e) {
  189. // e.stopPropagation()
  190. e.preventDefault()
  191. console.log('onclickLevel', level)
  192. this.setActiveLevel(level)
  193. let toPos = { ...this.position }
  194. switch (level) {
  195. case 'visibles':
  196. toPos.y = 2
  197. break
  198. case 'contexts':
  199. toPos.y = -1 * this.size.y * 0.25 + 2
  200. break
  201. case 'processes':
  202. toPos.y = -2 * this.size.y * 0.25 + 2
  203. break
  204. case 'concepts':
  205. toPos.y = -3 * this.size.y * 0.25 + 2
  206. break
  207. }
  208. this.$emit('lift', toPos)
  209. }
  210. }
  211. }
  212. </script>