首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用NEXT js将等长形全景图转换为cubemap格式的三个JS

使用NEXT js将等长形全景图转换为cubemap格式的三个JS
EN

Stack Overflow用户
提问于 2022-01-28 16:49:03
回答 1查看 613关注 0票数 2

我正在尝试将等长形全景图像转换为cubemap格式,使用下一个JS。场景被渲染,但背景不适用。我也不会犯错!

代码语言:javascript
复制
import { useLoader, useThree } from "@react-three/fiber";
import * as THREE from "three";

const Background = (props) => {
    const texture = useLoader(THREE.TextureLoader, "/autoshop.jpg");

    const { gl } = useThree();

    const formatted = new THREE.WebGLCubeRenderTarget(
        texture.image.height
    ).fromEquirectangularTexture(gl, texture);

    console.log("formatted", formatted);

    return <primitive attach="background" object={formatted} />;
};

export default Background;

我称它为悬念:

代码语言:javascript
复制
<Suspense fallback={null}>
    <Background />
</Suspense>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-28 18:29:21

感谢@Marquizzo评论。我发现我可以用另一种方式做同样的事。通过替换:

代码语言:javascript
复制
const formatted = new THREE.WebGLCubeRenderTarget(
    texture.image.height
).fromEquirectangularTexture(gl, texture);

出自:

代码语言:javascript
复制
texture.encoding = THREE.sRGBEncoding;
texture.mapping = THREE.EquirectangularReflectionMapping;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70897248

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档