相关文章推荐
阳光的金鱼  ·  babel.config.js with ...·  1 月前    · 
深沉的大白菜  ·  ConcurrentDictionary<t ...·  10 月前    · 
痴情的火龙果  ·  CSS 单位 | 菜鸟教程·  1 年前    · 

在参考下面代码使用RGBELoader的时候报这个错误:THREE.RGBELoader: unsupported type : 1009,记录一下.

// import { RGBELoader } from 'three/examples/jsm/loaders/RGBELoader';
const pmremGenerator = new PMREMGenerator(this.renderer); // 使用hdr作为背景色
pmremGenerator.compileEquirectangularShader();
const scene = this.scene;
new RGBELoader()
.setDataType(UnsignedByteType)
.load('/env/railway_bridge_02_1k.hdr', function (texture) {
const envMap = pmremGenerator.fromEquirectangular(texture).texture;
// envMap.isPmremTexture = true;
pmremGenerator.dispose();
scene.environment = envMap; // 给场景添加环境光效果
scene.background = envMap; // 给场景添加背景图

百度跟谷歌一下的资料都很少.然后看了一下RGBELodaer源代码,看报错那一段

没有发现UnsignedByteType,猜想应该是由于版本的关系,这个type去掉了

switch ( this.type ) {
	case FloatType:
		numElements = image_rgba_data.length / 4;
		const floatArray = new Float32Array( numElements * 4 );
		for ( let j = 0; j < numElements; j ++ ) {
			RGBEByteToRGBFloat( image_rgba_data, j * 4, floatArray, j * 4 );
		data = floatArray;
		type = FloatType;
		break;
	case HalfFloatType:
		numElements = image_rgba_data.length / 4;
		const halfArray = new Uint16Array( numElements * 4 );
		for ( let j = 0; j < numElements; j ++ ) {
			RGBEByteToRGBHalf( image_rgba_data, j * 4, halfArray, j * 4 );
		data = halfArray;
		type = HalfFloatType;
		break;
	default:
		console.error( 'THREE.RGBELoader: unsupported type: ', this.type );
		break;
            
		

发表回复 取消回复

  • 如何用一行 CSS 实现 10 种现代布局
  • 【动画进阶】CSS 也能实现完美的文字轮播与图片轮播效果
  • fastadmin bootstrap-table tab页面固定列不可见,高度不准确等解决方法
  • FFMPEG 合并视频文件(无损)
  • 让 UI 早点下班,高阶切图技巧!基于单张图片的任意颜色转换!
  •