Environment
Environment is the foundational component responsible for bridging the pre-prepared threejs context and the Electric UI context.
data:image/s3,"s3://crabby-images/ca6ca/ca6ca8616e8365474e74d5f17626af25097048c4" alt="Screenshot of component Environment basic"
Environment
is the dashed outline, not the geometry inside it!
Usage
Like ChartContainer
acting as the parent for specific charting features, the Environment
component builds a react-three-fibre
scene with the necessary setup and tweaks for easier integration.
It defaults to rendering with a transparent background for easier integration with your front-end.
import { Environment } from '@electricui/components-desktop-three' <Environment > // Add geometry, lighting, and other scene components <mesh > <sphereBufferGeometry attach ="geometry" args ={[8, 16, 16]} /> <meshStandardMaterial attach ="material" color ="orange" roughness ={0.6} /> </mesh > <ambientLight intensity ={0.8} /> </Environment >
Environment
from@electricui/components-desktop-three
is required for use withControlledGroup
components. We handle suspense and context bridging to provide access to Electric UI state.
Size
Environment
default behaviour is to auto-fill it's parent.
We recommend controlling the size of the 3D canvas by setting width
and height
css properties on the parent (px
, %
, em
are all accepted as normal).
data:image/s3,"s3://crabby-images/3d095/3d095cabc14275350abdbad36bed263d6e00322f" alt="Screenshot of component Environment size"
<div style ={{width : "100px", height : "100px"}}> <Environment > // ... </Environment ></div >
Camera Control
Environment
accepts a camera
property, with the various settings defined as members of a Javascript Object.
FoV
Modify the camera's field of view by providing a number
value for the fov
member.
data:image/s3,"s3://crabby-images/c3104/c3104f7107f888e9d47c4239ac7589a3bf9ca299" alt="Screenshot of component Environment fov"
<Environment camera ={{ fov : 30, }} > // ...</Environment >
Position
The position
property is specified as a Vector3
, controlling the camera's starting position. By default, the camera will look towards the world origin [0, 0, 0]
.
data:image/s3,"s3://crabby-images/bb029/bb029c37f547d0485ccb227df931c13de865e644" alt="Screenshot of component Environment position"
<Environment camera ={{ position : [15, 5, -15], }} > // ...</Environment >
Zoom
The zoom
property controls the zoom factor for the camera.
It accepts a single number. Default is 1
.
<Environment camera ={{ zoom : 50, }} > // ...</Environment >
Orthographic Camera
Adding the orthographic
property to Environment
is useful when creating mock-2D visualisations, or scenes where camera controls are locked.
data:image/s3,"s3://crabby-images/7e38d/7e38d50b25a42064eb9f0d07b410b38f0b25a947" alt="Screenshot of component Environment orthographic"
<Environment orthographic > // ...</Environment >