diff --git a/components/calcModels.vue b/components/calcModels.vue
index 5689f78..78d0687 100644
--- a/components/calcModels.vue
+++ b/components/calcModels.vue
@@ -1,7 +1,8 @@
-
-
-
-
-
-
-
-
+
+
+
+
-
-
-
-
+
+
-
-
-
+
diff --git a/components/model/parametric.vue b/components/model/parametric.vue
index 9f5fb1f..ca51df2 100644
--- a/components/model/parametric.vue
+++ b/components/model/parametric.vue
@@ -4,8 +4,12 @@ import {
EquirectangularReflectionMapping,
CineonToneMapping,
Euler,
+ Mesh,
+ Group,
+ Object3D,
} from 'three';
import { GainMapLoader, } from '@monogrid/gainmap-js'
+//@ts-ignore
import { useGLTF, } from '@tresjs/cientos'
import { getColorHexFromRal, type ralTypes } from '../ral';
@@ -18,23 +22,41 @@ const max_size = use_max_size()
const { scene, renderer, camera } = useTresContext()
renderer.value.toneMapping = CineonToneMapping
renderer.value.toneMappingExposure = 0.5
-// renderer.value.gammaOutput = true
renderer.value.shadowMap.enabled = true
renderer.value.shadowMap.type = PCFSoftShadowMap
const { scene: top_model } = await useGLTF('/models_one/verh_100.glb', { draco: true })
-const { scene: fence_model } = await useGLTF('/models_one/fence.glb', { draco: true })
-const { scene: fastening_model } = await useGLTF('/models_one/krepleniye_planok (1).glb', { draco: true })
-const { scene: lamelle_model } = await useGLTF('/models_one/lamel_100.glb', { draco: true })
+// const { scene: fence_model } = await useGLTF('/models_one/fence.glb', { draco: true })
+const { scene: model_fence_top } = await useGLTF('/fence_one/top.glb')
+const { scene: model_fence_center } = await useGLTF('/fence_one/center.glb')
+const { scene: model_fence_bottom } = await useGLTF('/fence_one/bottom.glb')
+const { scene: fastening_model } = await useGLTF('/models_one/krepleniye_planok (1).glb', { draco: true });
+const { scene: lamelle_model } = await useGLTF('/models_one/lamel_100.glb', { draco: true });
+
+[model_fence_top, model_fence_bottom].map((sc: Object3D) =>
+ sc.traverse((child: Object3D) => {
+ if (child instanceof Mesh) {
+ child.position.z = 0
+ }
+ })
+)
const top = ref(top_model)
-const fence = ref(fence_model)
+const fence = ref(model_fence_center)
+const fence_top = ref(model_fence_top)
+const fence_bottom = ref(model_fence_bottom)
const fastening = ref(fastening_model)
const lamelle = ref(lamelle_model)
+if (!pillar_color.value) {
+ const r = Math.floor(Math.random() * predefPillarColors.length)
+ pillar_color.value = predefPillarColors[r] as ralTypes
+ lamelle_color.value = predefLamelleColors[r] as ralTypes
+}
+
set_material(lamelle.value, getColorHexFromRal(lamelle_color.value));
-[top, fence, fastening].map((el: any) => { set_material(el.value, getColorHexFromRal(pillar_color.value)) })
+[top, fence, fence_bottom, fence_top, fastening].map((el: any) => { set_material(el.value, getColorHexFromRal(pillar_color.value)) })
const { seek, seekAll } = useSeek()
watch(lamelle_color, () => {
@@ -72,7 +94,9 @@ onMounted(async () => {
'hdrmaps/hdr-gainmap.webp',
'hdrmaps/hdr.json',
])
- renderer.value.render(scene.value, camera.value)
+ if (camera.value) {
+ renderer.value.render(scene.value, camera.value)
+ }
scene.value.environment = result.renderTarget.texture
scene.value.background = result.renderTarget.texture
scene.value.background.mapping = EquirectangularReflectionMapping
@@ -86,7 +110,7 @@ onMounted(async () => {
-
+
\ No newline at end of file
diff --git a/pages/calc.vue b/pages/calc.vue
new file mode 100644
index 0000000..8f12135
--- /dev/null
+++ b/pages/calc.vue
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/public/fence_one/bottom.glb b/public/fence_one/bottom.glb
new file mode 100644
index 0000000..14c14e8
Binary files /dev/null and b/public/fence_one/bottom.glb differ
diff --git a/public/fence_one/center.glb b/public/fence_one/center.glb
new file mode 100644
index 0000000..4ff9196
Binary files /dev/null and b/public/fence_one/center.glb differ
diff --git a/public/fence_one/top.glb b/public/fence_one/top.glb
new file mode 100644
index 0000000..a9a456a
Binary files /dev/null and b/public/fence_one/top.glb differ
diff --git a/utils/material.ts b/utils/material.ts
index 2976a67..0c76fad 100644
--- a/utils/material.ts
+++ b/utils/material.ts
@@ -1,4 +1,4 @@
-import { Color, MeshStandardMaterial } from "three"
+import { Color, DoubleSide, MeshStandardMaterial } from "three"
const set_metaril_func = (scene: any, material: any) => {
scene.children.forEach((el: any) => {
@@ -17,7 +17,8 @@ export const set_material = (scene: any, color: any) => {
transparent: true,
opacity: 1,
roughness: 0.5,
- metalness: 0
+ metalness: 0,
+ side: DoubleSide
})
set_metaril_func(scene, material)
}
\ No newline at end of file