Project.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <template>
  2. <div>
  3. <object3d ref="block3d" name="Project" :obj="walls3dObj" :position="wallsPos" />
  4. <object3d ref="top" :obj="top3dObj" :position="topPos" />
  5. <object3d ref="floor" :obj="floor3dObj" :position="floorPos" />
  6. <!-- <object3d ref="level" :obj="level_mesh" :position="level_position" /> -->
  7. <mesh ref="label3d" name="Label" :position="label_position">
  8. <geometry type="Plane" :args="[label_size.x, label_size.y]" />
  9. <material type="MeshLambert" :options="label_opts">
  10. <texture :options="label_texture_opts" />
  11. </material>
  12. </mesh>
  13. <!-- <div v-if="isOpened">
  14. <ContentBlock
  15. v-for="item in data.visibles"
  16. :key="item.id"
  17. :prtPosition="position"
  18. :prtSize="size"
  19. :prtIndex="index"
  20. type="visible"
  21. :data="item"
  22. />
  23. <ContentBlock
  24. v-for="item in data.contexts"
  25. :key="item.id"
  26. :prtPosition="position"
  27. :prtSize="size"
  28. :prtIndex="index"
  29. type="context"
  30. :data="item"
  31. />
  32. <ContentBlock
  33. v-for="item in data.processes"
  34. :key="item.id"
  35. :prtPosition="position"
  36. :prtSize="size"
  37. :prtIndex="index"
  38. type="process"
  39. :data="item"
  40. />
  41. <ContentBlock
  42. v-for="item in data.concepts"
  43. :key="item.id"
  44. :prtPosition="position"
  45. :prtSize="size"
  46. :prtIndex="index"
  47. type="concept"
  48. :data="item"
  49. />
  50. </div> -->
  51. </div>
  52. </template>
  53. <script>
  54. import { mapInstanceState } from '@urbn/vuex-helpers'
  55. import * as THREE from 'three'
  56. // import { ThreeBSP } from 'three-js-csg-es6'
  57. import mixins from 'components/mixins'
  58. // import ContentBlock from 'components/objects/ContentBlock'
  59. // import BgVertex from 'assets/glsl/BgVertex'
  60. // import BuildingFragment from 'assets/glsl/BuildingFragment'
  61. // We'll determine our module based on the moduleName prop on this component
  62. // https://www.npmjs.com/package/@urbn/vuex-helpers
  63. const getModuleName = cmp => `project:${cmp.id}`
  64. export default {
  65. name: 'Project',
  66. components: {
  67. // ContentBlock
  68. },
  69. mixins: [mixins],
  70. props: { id: Number },
  71. data () {
  72. console.log('Project data()')
  73. return {
  74. isOpened: false,
  75. block3d: null,
  76. label3d: null,
  77. label_opts: {
  78. side: THREE.DoubleSide,
  79. // wireframe: false,
  80. transparent: true
  81. // opacity: 0.6
  82. // renderOrder: 0
  83. },
  84. color: 0xffffff,
  85. label_canvas: null,
  86. label_size: null,
  87. label_position: { x: 0, y: 0, z: 0 }
  88. // level_mesh: levelMesh,
  89. // level_position: { ...position },
  90. }
  91. },
  92. computed: {
  93. ...mapInstanceState(getModuleName, {
  94. title: state => state.Titre,
  95. size: state => state.size,
  96. position: state => state.position,
  97. walls3dObj: state => state.walls3dObj,
  98. wallsPos: state => state.wallsPos,
  99. top3dObj: state => state.top3dObj,
  100. topPos: state => state.topPos,
  101. floor3dObj: state => state.floor3dObj,
  102. floorPos: state => state.floorPos
  103. }),
  104. label_texture_opts () {
  105. return {
  106. canvas: this.label_canvas,
  107. minFilter: THREE.LinearFilter,
  108. wrapS: THREE.ClampToEdgeWrapping,
  109. wrapT: THREE.ClampToEdgeWrapping
  110. }
  111. }
  112. },
  113. created () {
  114. this.label_canvas = this.createLabelCanvas(this.title.replace(/ /g, '\n').toUpperCase(), 48, 21, '#000000', '#ffffff')
  115. this.label_position.x = this.position.x - this.size.x / 2 + this.label_size.x / 2 + 1
  116. this.label_position.y = this.position.y + this.size.y / 2 - this.label_size.y / 2 - 1
  117. this.label_position.z = this.position.z + this.size.z / 2 + 0.5
  118. console.log('this.label_position', this.label_position)
  119. },
  120. mounted () {
  121. console.log('project mounted', this)
  122. // record self references
  123. this.block3d = this.$refs.block3d.curObj
  124. // this.block3d.castShadow = true
  125. // this.block3d.receiveShadow = true
  126. this.block3d.userData = {
  127. vnode: this
  128. }
  129. // this.label3d = this.$refs.label3d.curObj
  130. // light
  131. // console.log('project mounted', this.$env3d)
  132. // var light = new THREE.AmbientLight(0xbf1a1a) // soft white light
  133. // this.$env3d.scene.add(light)
  134. },
  135. methods: {
  136. }
  137. }
  138. </script>