Skip to content

Commit

Permalink
fix: attach detach (#749)
Browse files Browse the repository at this point in the history
* test: add insert/remove tests

* feat: add filterInPlace

* refactor: make some LocalState fields non-optional

* test: add LocalState graph tests

* refactor: add prepare() to add __tres field

* refactor: add TODOs

* refactor: maintain parent/objects relationship in __tres

* test: add dispose=null test

* feat: allow "dispose=null" to bail out tree disposal

* refactor: update  comments

* refactor: add todo

* test: add/unskip  tests

* refactor(nodeOps): move helper functions to new file

* test: add primitive tests

* refactor: move nodeOpsUtils to utils

* feat: add pierced attach/detach

* chore: clean up merge

* chore: lint

* docs: add playground demo

* chore: update demos

---------

Co-authored-by: Alvaro Saburido <[email protected]>
  • Loading branch information
andretchen0 and alvarosabu authored Jul 5, 2024
1 parent 45777f1 commit 8c1c668
Show file tree
Hide file tree
Showing 14 changed files with 918 additions and 239 deletions.
47 changes: 47 additions & 0 deletions playground/src/pages/advanced/materialArray/index.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
<script setup lang="ts">
import { TresCanvas } from '@tresjs/core'
import { OrbitControls } from '@tresjs/cientos'
const previewDataUri = ''
const i = shallowRef(0)
setInterval(() => {
i.value += 1
i.value %= 6
}, 500)
</script>

<template>
<TresCanvas clear-color="gray">
<TresPerspectiveCamera :position="[5, 5, 5]" :look-at="[1, 2, 3]" />
<OrbitControls />
<TresMesh>
<TresBoxGeometry />
<TresMeshBasicMaterial v-if="i !== 0" color="yellow" attach="material-0" />
<TresMeshBasicMaterial v-if="i !== 1" color="orange" attach="material-1" />
<TresMeshBasicMaterial v-if="i !== 2" color="red" attach="material-2" />
<TresMeshBasicMaterial v-if="i !== 3" color="purple" attach="material-3" />
<TresMeshBasicMaterial v-if="i !== 4" color="blue" attach="material-4" />
<TresMeshBasicMaterial v-if="i !== 5" color="green" attach="material-5" />
</TresMesh>
</TresCanvas>
<OverlayInfo>
<h1>Material array</h1>
<h2>Setup</h2>
<p>
In this scene, there is a Mesh with a BoxGeometry and multiple materials - one for each side of the box. The sides of the box should individually disappear and reappear.
</p>
<h3>"Pierced attach"</h3>
<p>Multiple materials are each added with a "pierced attach": <code>&lt;TresMeshBasicMaterial attach="material-0" /&gt;</code></p>
<p>"material-0" has 2 parts:</p>
<ul>
<li>"material": this tells Tres to use the parent's "material" field</li>
<li>"0": this tells Tres to use the "zeroeth" position on the "material" field</li>
</ul>
<h2>Preview</h2>
<p>The single on-screen box should be animated, with sides disappearing/reappearing as in this image:</p>
<img :src="previewDataUri" />
<h2>Issue</h2>
<a href="https://github.com/Tresjs/tres/issues/496">Allow TresObject3D#material to set Array (#496)</a>
</OverlayInfo>
</template>
36 changes: 0 additions & 36 deletions playground/src/pages/models/RiggedModel.vue

This file was deleted.

File renamed without changes.
Loading

0 comments on commit 8c1c668

Please sign in to comment.