Jump to content

Component of prefab uses prefab's scene in Load


Go to solution Solved by Josh,

Recommended Posts

Posted

If i just use component with saved scene from Load() everything works.

But if i save entity as prefab, scene will expire. Most likely it's due scene in Load is Prefab's scene - scene->navmeshes is empty for prefab component in Load when real scene have it. Component and its prefab example

TestPrefab.zip

  • Dreikblack changed the title to Component of prefab uses prefab's scene in Load
Posted

This is by design. The prefab has a temporary scene all entities are loaded into, which allows each component to retrieve the objects in that prefab.

What happens if you move the navmesh code into the first call to the Update() method? Something like this:

class component
{
	std::weak_ptr<Scene> scene;
}
void component::Update()
{
  auto scene = this->scene.lock();
  if (not scene)
  {
      scene = MyGame->scene;
      this->scene = scene;
      if (scene and not scene->navmeshes.empty())
      {
            //do some things here...
      }
  }
}

 

My job is to make tools you love, with the features you want, and performance you can't live without.

Posted
3 hours ago, Josh said:
scene = MyGame->scene;

This is something that i can do in my game by using Singletones, but it's not proper option for components to share in Downloads or tutorials.

3 hours ago, Josh said:

component to retrieve the objects in that prefab.

Which should be possible via kids of root entity and normal scene anyway?

Posted
2 hours ago, Dreikblack said:

This is something that i can do in my game by using Singletones, but it's not proper option for components to share in Downloads or tutorials.

Which should be possible via kids of root entity and normal scene anyway?

Not exactly. Prefabs have a UUID for each entity, but since there can be multiple prefabs of the same file loaded, a new UUID is generated when the prefab gets added to the main scene. It's messy.

  • Sad 1

My job is to make tools you love, with the features you want, and performance you can't live without.

Posted

I am going to leave this open because I want to think about it more.

My job is to make tools you love, with the features you want, and performance you can't live without.

  • 1 month later...
Posted

Okay, it appears the way you are using the prefab scene object is to add a created entity into the scene.

This seems like a bad approach to me. Is there some reason this must be done?

		auto targetPivotShared = CreatePivot(gameCamera->GetWorld());
		targetPivotShared->SetPickMode(PICK_NONE);
		targetPivotShared->SetPosition(targetPosition);
		targetPivotShared->SetRotation(0, gameCamera->GetRotation(true).y, gameCamera->GetRotation(true).z);
		gameCamera->SetParent(targetPivotShared); 
		sceneWeak.lock()->AddEntity(targetPivotShared);
		targetPivot = targetPivotShared;

 

My job is to make tools you love, with the features you want, and performance you can't live without.

Posted
7 hours ago, Josh said:

This seems like a bad approach to me. Is there some reason this must be done?

It's most clear approach if anything for this case and just one of many uses of scene. Another often case is getting navemesh.

It's done to temporally save pivot until scene will be deleted. Camera have to be parented to this pivot so camera component can't have strong reference to the pivot to avoid circular references. The only another way to do it would be making extra component for a pivot which is already worse approach.

And no, it will not work if i will use pivot instead of camera and spawn camera with component because it would be require a LOT of extra stuff to make it work (pivot should be on the ground, so it could not be placed in the Editor like camera in air etc.).

Posted

The need to access the navmesh in order to create navigation agents is a good argument for some solution to be found for this.

Maybe the engine could replace all entity UUID values with the new ones in the loaded scene and pass the scene handle to the Load command.

My job is to make tools you love, with the features you want, and performance you can't live without.

  • Solution
Posted

I have made the change and I am compiling now. If everything works correctly, you may mark this issue solved.

  • Like 1

My job is to make tools you love, with the features you want, and performance you can't live without.

Posted

FYI, this means that prefabs cannot contain navmeshes that can be accessed. I think this is the right choice.

My job is to make tools you love, with the features you want, and performance you can't live without.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...