ImpulseAction giving strange error

I am trying to apply impulseAction to an entity but everytime entity.playAnimation(impulseAnimation) is executed, the log says Cannot find a BindPoint for any bind path: "". I can't figure out what is wrong. Could someone please help me with this?

import SwiftUI
import RealityKit
import RealityKitContent

struct ImmersiveView: View {

    var body: some View {
        RealityView { content in
            // Add the initial RealityKit content
            if let immersiveContentEntity = try? await Entity(named: "Immersive", in: realityKitContentBundle), var sphere = immersiveContentEntity.findEntity(named: "Sphere") {
                
                sphere.components.set(CollisionComponent(shapes: [ShapeResource.generateSphere(radius: 0.1)]))
                sphere.components.set(PhysicsBodyComponent(shapes: [ShapeResource.generateSphere(radius: 0.1)], mass: 1000))
                
                
                sphere.components[PhysicsBodyComponent.self]?.isAffectedByGravity = false
                sphere.position = [0, 1, -1]
                
                content.add(immersiveContentEntity)
                
                
                // Create an action to apply an impulse, forcing the object to move upwards.
                let impulseAction = ImpulseAction(linearImpulse: [0, 1, 0])


                // Create a small positive duration value.
                let duration: TimeInterval = 1 / 30.0


                // Create an animation for the action, which will start playing
                // after five seconds.
                do {
                    let impulseAnimation = try AnimationResource
                        .makeActionAnimation(for: impulseAction,
                                             duration: duration,
                                             delay: 5.0)


                    // Play the sequence animation that will play the actions.
                    sphere.playAnimation(impulseAnimation)
                } catch {
                    print("Error: \(error)")
                }
                
            }
        }
    }
}

All the logs:

Could not locate file 'default-binaryarchive.metallib' in bundle.
Error creating the CFMessagePort needed to communicate with PPT.
AddInstanceForFactory: No factory registered for id <CFUUID 0x6000029a5b80> F8BB1C28-BAE8-11D6-9C31-00039315CD46
cannot add handler to 0 from 1 - dropping
nw_socket_copy_info [C1:2] getsockopt TCP_INFO failed [102: Operation not supported on socket]
nw_socket_copy_info getsockopt TCP_INFO failed [102: Operation not supported on socket]
Registering library (/Library/Developer/CoreSimulator/Volumes/xrOS_22N840/Library/Developer/CoreSimulator/Profiles/Runtimes/xrOS 2.2.simruntime/Contents/Resources/RuntimeRoot/System/Library/PrivateFrameworks/CoreRE.framework/default.metallib) that already exists in shader manager. Library will be overwritten.
cannot add handler to 0 from 1 - dropping
Cannot find a BindPoint for any bind path: "", ""
Sync object without snapshot while removing view (id: 2816861686082450363, type: 6373420419761316588[SelectableSceneContentIdentifierComponent]).

But i think only Cannot find a BindPoint for any bind path: "", "" is relevant.

Answered by Vision Pro Engineer in 820329022

Hi @WeAreAllSatoshi

Thanks for providing code to recreate the issue. It makes your question easier to understand and answer.

I'm not sure why that warning shows up, but if your goal is to make the animation work, try applying an impulse that is closer to the sphere's mass. I ran the code and saw the same warning, but never entered the catch block. The animation appeared to do nothing, so I changed the mass on PhysicsBodyComponent from 1000 to 1, and the sphere animates along the Y axis.

I am using Xcode 16.2

Accepted Answer

Hi @WeAreAllSatoshi

Thanks for providing code to recreate the issue. It makes your question easier to understand and answer.

I'm not sure why that warning shows up, but if your goal is to make the animation work, try applying an impulse that is closer to the sphere's mass. I ran the code and saw the same warning, but never entered the catch block. The animation appeared to do nothing, so I changed the mass on PhysicsBodyComponent from 1000 to 1, and the sphere animates along the Y axis.

ImpulseAction giving strange error
 
 
Q