基于
@react-three/drei提供的钩子函数
Sky
-
模拟天空的颜色,可以设置太阳位置,同
threejs中的 sky... <Sky sunPosition={sunPosition} distance={450000} inclination={0} azimuth={0.25} /> ...
Environment
-
自定义天空盒子,支持
hdr格式文件 -
files支持设置单个 hdr 文件或者设置 数组六个文件... <Environment background files={'./assets/sky/acoustical_shell_4k.hdr'} /> ... ... <Environment background files={['px.png','nx.png','py.png','ny.png','pz.png','nz.png']} /> ... -
设置反光效果 有两种方式,一种是 通过自建
mesh方式,一种是通过Lightformer<Environment background files={'./assets/sky/acoustical_shell_4k.hdr'} > {/* 设置反光板 方式一 */} {/* <color args={['#000000']} attach="background" /> <mesh position-z={-5} scale={10}> <planeGeometry /> <meshBasicMaterial color="red" /> </mesh> */} {/* 设置反光板 方式二 */} <Lightformer position-z={-5} scale={10} color={'red'} intensity={10} form={"ring"} /> </Environment> -
模型在场景中贴地显示,设置
ground的参数即可实现<Environment background files={'./assets/sky/acoustical_shell_4k.hdr'} ground={{ height: 10, radius: 28, scale: 100 }} > <Lightformer position-z={-5} scale={10} color={'red'} intensity={10} form={"ring"} /> </Environment>
Stage
-
提供一个可以参数设置的环境设置效果 更多查阅
<Stage adjustCamera intensity={0.5} shadows="contact" environment="city"> <mesh /> </Stage>
本文介绍了如何利用@react-three/drei库在React应用中设置逼真的3D环境,包括Sky组件、自定义天空盒、反光效果、地面处理以及Stage参数调整。详细讲解了SkySunPosition、Environment背景设置和Lightformer的用法。
638

被折叠的 条评论
为什么被折叠?



