I was trying to bake an MDLLightProbe but the app is crashing. I have stripped down the code to bare minimum but still getting the same crash. Attaching the code and the stack.
SCNNode *ambientLight = [SCNNode node];
ambientLight.light = [SCNLight light];
ambientLight.light.type = SCNLightTypeAmbient;
ambientLight.light.color = [NSColor whiteColor];
ambientLight.light.intensity = 1000.0;
MDLLight *light = [MDLLight lightWithSCNLight:ambientLight.light];
NSArray<MDLLight*> *lights = [NSArray arrayWithObjects: light, nil];
MDLTransform* t = [[MDLTransform alloc] initWithIdentity];
SCNNode* sph = [SCNNode node];
sph.geometry = [SCNSphere sphereWithRadius:1.];
sph.position = SCNVector3Make(1., 0.1, 0.);
sph.geometry.firstMaterial.diffuse.contents = [NSColor grayColor];
NSArray<MDLObject*> *obs = [NSArray arrayWithObjects: sph, nil];
MDLLightProbe *probe2 = [MDLLightProbe lightProbeWithTextureSize:256 forLocation:t lightsToConsider: lights objectsToConsider:obs reflectiveCubemap:nil irradianceCubemap:nil];
* thread #1, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=1, address=0x66736e617288)
frame #0: 0x00007ff803415bdd libobjc.A.dylib`objc_msgSend_stret + 29
frame #1: 0x00007ff90b3bb094 SceneKit`-[SCNNode transform] + 38
frame #2: 0x00007ff9169e5b53 ModelIO`___lldb_unnamed_symbol16530$$ModelIO + 107
frame #3: 0x00007ff9169e5c25 ModelIO`___lldb_unnamed_symbol16531$$ModelIO + 9
frame #4: 0x00007ff916a07f5d ModelIO`___lldb_unnamed_symbol16765$$ModelIO + 459
frame #5: 0x00007ff91691eff7 ModelIO`___lldb_unnamed_symbol14669$$ModelIO + 552
xcode 13.3.1
macOS 12.3.1
. Any help is appreciated. Thanks!
I don't use theses libs, but after checking the doc:
The method you use is:
+ (MDLLightProbe *)lightProbeWithTextureSize:(NSInteger)textureSize
forLocation:(MDLTransform *)transform
lightsToConsider:(NSArray<MDLLight *> *)lightsToConsider
objectsToConsider:(NSArray<MDLObject *> *)objectsToConsider
reflectiveCubemap:(MDLTexture *)reflectiveCubemap
irradianceCubemap:(MDLTexture *)irradianceCubemap;
So in objectsToConsider
, it awaits for a NSArray
of MDLObject
.
So, in order to do so, you created:
NSArray<MDLObject*> *obs = [NSArray arrayWithObjects: sph, nil];
But the thing, is that Objective-C doesn't really check the type of objects you put in an NSArray
. It's more a "for your information".
Here, sph
is a SCNNode
, not a MDLObject
. Let's check if there is a common class between them:
@interface SCNNode : NSObject
@interface MDLObject : NSObject
There are different. So you need to create a MDLObject
from a SCNNode
.
And there is one: objectWithSCNNode:
So it should be:
NSArray<MDLObject*> *obs = [NSArray arrayWithObjects: [MDLObject objectWithSCNNode:sph], nil];
Unrelated, but with modern Objective-C, you could write @[light];
instead if [NSArray arrayWithObjects: light, nil];
, might be "simpler" to read.