
Security News
Crates.io Users Targeted by Phishing Emails
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
@react-three/lgl
Advanced tools
A React(-three-fiber) abstraction for the LGL-Raytracer.
It does its best to remove all unwanted complexity, you can build your scenes as you always would. This is mostly for photorealistic still-images that can take a while to process but will look absolutely stunning. It is side-effect free, when you unmount it goes back to the default WebGLRenderer.
Demos: [sandbox], [studio-setup]
npm install @react-three/lgl
import { Canvas } from '@react-three/fiber'
import { Raytracer } from '@react-three/lgl'
function App() {
return (
<Canvas>
<Raytracer>
<mesh>
<sphereGeometry args={[1, 64, 64]} />
<meshStandardMateral />
</mesh>
...
</Raytracer>
</Canvas>
)
}
samples
, How many frames it takes to complete a still-image, 64
by default. Set this to something higher if you want to wait for high-quality images, or Infinity
if you want it to go on forever, but keep in mind that raytracing is very expensive!Otherwise <Raytracer>
takes all the LGL raytracer's options: https://lgltracer.com/docs/index.html#/api/LGLTracerRenderer
LGL ignores threejs lights, it wants to use its own. But in three-fiber you can simply extend, and now the JSX natives will refer to LGL.
import { extend } from '@react-three/fiber'
import { PointLight, RectAreaLight } from 'lgl-tracer'
extend({ PointLight, RectAreaLight })
<rectAreaLight width={2} height={2} position={[3, 3, 3]} />
<pointLight position={[-3, 3, -10]} />
If you plan to switch between renderers you can make lights opt in.
extend({ LglPointLight: PointLight, LglRectAreaLight: RectAreaLight })
<lglPointLight />
<lglRectAreaLight />
Simply drop the <Environment>
component from drei into your scene, it knows how to work with that ootb, just make sure both the raytracer and the environment are under the same suspense boundary so that they are in sync.
import { Environment } from '@react-three/drei'
<Canvas>
<Suspense fallback={null}>
<Rayctracer>
<Scene />
</Raytracer>
<Environment preset="city" />
Your scene has to be static, it will ignore moving parts. This will never be fast enough for runtime usage but you can get away with some camera movement by lowering your resolution (and your expectations). Do not forget to mark your controls as makeDefault
so that the raycaster can react to it. Try something like this for example:
import { OrbitControls } from '@react-three/drei'
<Canvas dpr={1}>
<Raytracer
samples={32}
bounces={3}
enableTemporalDenoise
enableSpatialDenoise
movingDownsampling>
...
</Raytracer>
<OrbitControls makeDefault />
In order to obtain a screenshot the drawing-buffer has to be preserved, this is a setting in Threejs.
import { Canvas, useThree } from '@react-three/fiber'
<Canvas gl={{ preserveDrawingBuffer: true }}>
<Raycaster>
</Scene>
...
const gl = useThree(state => state.gl)
...
const link = document.createElement('a')
link.setAttribute('download', 'canvas.png')
link.setAttribute('href', gl.domElement.toDataURL('image/png').replace('image/png', 'image/octet-stream'))
link.click()
FAQs
A React abstraction for the LGL Raytracer
We found that @react-three/lgl demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 17 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
Product
Socket now lets you customize pull request alert headers, helping security teams share clear guidance right in PRs to speed reviews and reduce back-and-forth.
Product
Socket's Rust support is moving to Beta: all users can scan Cargo projects and generate SBOMs, including Cargo.toml-only crates, with Rust-aware supply chain checks.