bx-865-apps #1

Merged
ksenia_mikhailova merged 140 commits from bx-865-apps into main 2024-06-27 15:03:27 +03:00
1 changed files with 27 additions and 3 deletions
Showing only changes of commit a51a3158e2 - Show all commits

View File

@ -1,12 +1,13 @@
<script setup lang="ts"> <script setup lang="ts">
import { SERVER_URL, IMAGE_URL } from '../../constants' import { IMAGE_URL, SERVER_URL, } from '../../constants'
import { onMounted, reactive } from 'vue'; import { onMounted, reactive, ref } from 'vue';
import { Vector3 } from 'three'; import { Vector3 } from 'three';
import { TresCanvas } from '@tresjs/core'; import { TresCanvas } from '@tresjs/core';
import { CameraControls, useGLTF, useProgress } from '@tresjs/cientos' import { CameraControls, useGLTF, useProgress } from '@tresjs/cientos'
import Env from './env.vue' import Env from './env.vue'
import ModelItem from './modelItem.vue';
const minPan = new Vector3(-10, 1, -5); const minPan = new Vector3(-10, 1, -5);
const maxPan = new Vector3(5, 1, 5); const maxPan = new Vector3(5, 1, 5);
@ -35,8 +36,26 @@ const point_light = reactive({
intensity: 10000, intensity: 10000,
position: new Vector3(-100, 5, 5), position: new Vector3(-100, 5, 5),
}) })
interface element3DType {
id: number
model_file: string
name: string
description: string
parent?: number
}
interface model3DType extends element3DType {
modelUrl?: string
}
const models = ref<model3DType[]>([])
const loadModels = async () => { const loadModels = async () => {
const res = await fetch(`${SERVER_URL}/api/front_img/`) const res = await fetch(`${SERVER_URL}/api/obj/element/?parent__isnull=True`)
const data = await res.json() as element3DType[]
for (let index = 0; index < data.length; index++) {
const element = data[index];
const item = { ...element } as model3DType
item.modelUrl = `${IMAGE_URL}/${item.model_file}`
models.value.push(item)
}
} }
onMounted(() => { onMounted(() => {
loadModels() loadModels()
@ -53,6 +72,11 @@ onMounted(() => {
<Suspense> <Suspense>
<Env /> <Env />
</Suspense> </Suspense>
<Suspense>
<TresGroup v-for="item in models">
<ModelItem :model-url="item.modelUrl" />
</TresGroup>
</Suspense>
<TresMesh> <TresMesh>
<TresBoxGeometry :args="[1, 1, 1]" /> <TresBoxGeometry :args="[1, 1, 1]" />
<TresMeshStandardMaterial /> <TresMeshStandardMaterial />