[HybridRenderer] Spawning identical entities from code in different frames creates separate chunks

**Workaround found! See here **

Problem is explained in the title…

Why doesn’t spawning in different frames add to the same chunk?

Spawning 100 entities at once:

Spawning one entity per frame:

5539039--569791--problemee.gif

Test Code:

using UnityEngine;
using Unity.Mathematics;
using Unity.Entities;
using Unity.Transforms;
using Unity.Rendering;

public class RenderEntityTest : MonoBehaviour
{
    EntityManager manager;
    EntityArchetype particleArch;

    public Mesh mesh;
    public Material material;

    RenderMesh rm;
    RenderBounds rb;

    void Start()
    {
        manager = World.DefaultGameObjectInjectionWorld.EntityManager;

        particleArch = manager.CreateArchetype(
            typeof(Translation),
            typeof(LocalToWorld),
            typeof(RenderBounds),

            typeof(RenderMesh));

        rm = new RenderMesh()
        {
            castShadows = UnityEngine.Rendering.ShadowCastingMode.On,
            receiveShadows = true,
            mesh = mesh,
            material = material,
        };

        rb = new RenderBounds() { Value = mesh.bounds.ToAABB() };

        // This will create 100 entities in the same chunk:
        //SpawnABunch(100);
    }

    void Update()
    {
        // This will create a new chunk for each new entity:
        SpawnABunch(1);
    }

    void SpawnABunch(int count)
    {
        for (int i = 0; i < count; i++)
        {
            Spawn(UnityEngine.Random.insideUnitSphere * 10);
        }
    }

    void Spawn(Vector3 pos)
    {
        Entity e = manager.CreateEntity(particleArch);
        manager.SetComponentData(e, new Translation { Value = pos });
        manager.SetSharedComponentData(e, rm);
        manager.SetComponentData(e, rb);
    }
}

I’ve seen this issue pop up multiple times on these forums. Could you test something for me out of interest?

Instead of including RenderMesh as part of the archetype, do a AddSharedComponentData

Nope, it behaves the same.

I am pretty sure this is a problem with the AddWorldAndChunkRenderBounds system, because if you don’t add one of the necessary components, for example MeshBounds, which prevents that system from kicking in, the entities are added into existing chunks as they should be.

@tertle I took a peek into AddWorldAndChunkRenderBounds, and copied over components it adds to my archetype and now it works.

archetype = manager.CreateArchetype(
   typeof(Translation),
   typeof(LocalToWorld),
   typeof(RenderBounds),
   typeof(RenderMesh),

   // copied from AddWorldAndChunkRenderBounds system:
   ComponentType.ReadWrite<WorldRenderBounds>(),
   ComponentType.ChunkComponent<ChunkWorldRenderBounds>()
   );

Although I found a solution, this looks like a big problem that should not happen and Unity must fix

What version of Hybrid Renderer package are you running?

The latest version is supposed to have resolved this chunk fragmentation problem, according to this post .

I’m using the latest 0.3.4-preview.24 in Unity 2019.3.3f1

And yes, I need to create RenderBounds manually as is mentioned in the post. So, apparently this version should’ve had the fragmentation issue fixed, but it doesn’t?

That’s my understanding, but perhaps he means that the change has been made to enable a future fix.
@SebastianAaltonen ?

If you use prefabs, the issue is solved. If you don’t use prefabs and instead build entity from scratch, then you need to add a couple of chunk components manually to solve the issue. I believe you need at least to add ChunkWorldRenderBounds. You could check in entity debugger which chunk components exist in the entity and add those yourself.

Also it’s worth noting that adding all components manually causes several structural changes, and is thus significantly slower than instantiating a prefab which has all components added beforehand during conversion. Prefabs are the fast path for instantiation and result in zero fragmentation too.

1 Like

We will add a test scene to hybrid.renderer sample projects to show how to build entity from scratch in code in a way that doesn’t cause fragmentation. I would however still recommend instantiating prefabs as that is faster.