Skip to content

Commit

Permalink
docs(lights): clean up demo
Browse files Browse the repository at this point in the history
* move directives from lights demo to misc/directives
* add SpotLight
* add preview image
* fit scene in default camera view
  • Loading branch information
andretchen0 committed Feb 18, 2025
1 parent 0a95764 commit efe4be3
Show file tree
Hide file tree
Showing 2 changed files with 107 additions and 37 deletions.
128 changes: 93 additions & 35 deletions playground/vue/src/pages/basic/Lights.vue
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
<script setup lang="ts">
import type { TresObject } from '@tresjs/core'
import { OrbitControls } from '@tresjs/cientos'
import { TresCanvas, vDistanceTo, vLightHelper, vLog } from '@tresjs/core'
import { BasicShadowMap, NoToneMapping, SRGBColorSpace } from 'three'
import { TresCanvas, useRenderLoop, vLightHelper } from '@tresjs/core'
import { BasicShadowMap, MeshStandardMaterial, NoToneMapping, SRGBColorSpace } from 'three'
const gl = {
clearColor: '#82DBC5',
clearColor: 'black',
shadows: true,
alpha: false,
shadowMapType: BasicShadowMap,
Expand All @@ -15,48 +14,107 @@ const gl = {
}
const planeRef: Ref<TresObject | null> = ref(null)
const whiteMaterial = new MeshStandardMaterial({ color: '#f8f8f8' })
const orangeMaterial = new MeshStandardMaterial({ color: '#eeac35' })
const blueMaterial = new MeshStandardMaterial({ color: '#7fdac6' })
const z = ref(0)
useRenderLoop().onLoop(({ elapsed }) => {
z.value = Math.sin(elapsed)
})
const previewSrc = ''
</script>

<template>
<TresCanvas

v-bind="gl"
>
<TresPerspectiveCamera
v-distance-to="planeRef"
:position="[3, 3, 3]"
/>
<OverlayInfo>
<h1>Lights</h1>
<h2>Setup</h2>
<p>In this scene, there are:</p>
<ul>
<li>3 meshes</li>
<li>3 lights</li>
<li>a ground plane</li>
</ul>

<p>Lights are, left to right:</p>
<ul>
<li>PointLight</li>
<li>SpotLight</li>
<li>DirectionalLight</li>
</ul>
<p>All lights have helpers.</p>

<h2>Preview</h2>
<img :src="previewSrc" />

<h2>Notes</h2>
<p>At the time of this writing: SpotLight's helper is difficult to see and very large.</p>
</OverlayInfo>
<TresCanvas v-bind="gl">
<TresPerspectiveCamera :position="[0, 3, 15]" />
<OrbitControls />

<TresDirectionalLight
v-light-helper
:position="[0, 8, 4]"
:intensity="0.7"
color="yellow"
cast-shadow
/>
<TresGroup :position-y="2" :position-z="z">
<TresPointLight
v-light-helper
:position="[-2, 0, 0]"
:intensity="400"
color="blue"
cast-shadow
/>

<TresSpotLight
v-light-helper
:look-at="[0, 0, 0]"
:intensity="400"
color="#FF0000"
/>

<TresDirectionalLight
v-light-helper
:position="[2, 0, 0]"
:intensity="3.14"
color="green"
cast-shadow
/>
</TresGroup>

<TresGroup :position-y="1">
<TresMesh
:material="blueMaterial"
cast-shadow
receive-shadow
:position="[-1.5, 0, 0]"
>
<TresCylinderGeometry :args="[0, 0.60, 1]" />
</TresMesh>
<TresMesh
cast-shadow
receive-shadow
:material="whiteMaterial"
>
<TresBoxGeometry />
</TresMesh>

<TresMesh
:position="[1.5, 0, 0]"
cast-shadow
receive-shadow
:material="orangeMaterial"
>
<TresSphereGeometry :args="[0.5, 32, 32]" />
</TresMesh>
</TresGroup>

<TresMesh
ref="planeRef"
v-log:material
:rotation="[-Math.PI / 2, 0, 0]"
receive-shadow
>
<TresPlaneGeometry :args="[10, 10, 10, 10]" />
<TresMeshToonMaterial />
</TresMesh>
<TresMesh
:position="[-2, 2, 0]"
>
<TresBoxGeometry :args="[1, 1, 1]" />
<TresMeshToonMaterial color="red" />
</TresMesh>
<TresMesh
:position="[2, 4, 0]"
cast-shadow
>
<TresSphereGeometry :args="[1, 32, 32]" />
<TresMeshToonMaterial color="yellow" />
<TresMeshStandardMaterial color="black" />
</TresMesh>
<TresAmbientLight :intensity="1" />
</TresCanvas>
</template>
16 changes: 14 additions & 2 deletions playground/vue/src/pages/misc/directives/index.vue
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
<script setup lang="ts">
import { OrbitControls } from '@tresjs/cientos'
import { TresCanvas } from '@tresjs/core'
import type { TresObject } from '@tresjs/core'
import { TresCanvas, vDistanceTo, vLog } from '@tresjs/core'
import { BasicShadowMap, NoToneMapping, SRGBColorSpace } from 'three'
import DirectiveSubComponent from './DirectiveSubComponent.vue'
Expand All @@ -12,14 +13,25 @@ const gl = {
outputColorSpace: SRGBColorSpace,
toneMapping: NoToneMapping,
}
const planeRef: Ref<TresObject | null> = ref(null)
</script>

<template>
<TresCanvas v-bind="gl">
<TresPerspectiveCamera :position="[3, 3, 3]" />
<TresPerspectiveCamera v-distance-to="planeRef" :position="[3, 3, 3]" />
<OrbitControls />
<TresGridHelper />
<DirectiveSubComponent />
<TresAmbientLight :intensity="1" />
<TresMesh
ref="planeRef"
v-log:material
:rotation="[-Math.PI / 2, 0, 0]"
receive-shadow
>
<TresPlaneGeometry :args="[10, 10, 10, 10]" />
<TresMeshToonMaterial />
</TresMesh>
</TresCanvas>
</template>

0 comments on commit efe4be3

Please sign in to comment.