Hi everyone !
1. A concise explanation of the problem you’re experiencing.
I have a webpage displaying a cesium viewer with some entities with 3D models.
When i try to instanciate a second cesium viewer, AFTER the first one is created, i experience a shader compile crash.
If the two viewers are instanciated at the load of the page, no errors.
It only appears if the second viewer is created a few seconds after the first one, or later.
2. A minimal code example. If you’ve found a bug, this helps us reproduce and repair it.
I tend to reproduce the same error in sandcastle.
It’s not exactly the same error message than the error in my website, but it’s the same behavior.
here’s a sandcastle:
https://cesiumjs.org/Cesium/Build/Apps/Sandcastle/#c=rVRtT9swEP4rVqWJIGVOmrawlYLGYNomDY0B4lOkySTXxppjV7bTwqb+952T5oVQjb2dqsa+e+7F99i3YpqsOKxBk2MiYU3OwPAip7elzttLyu2ZkpZxCXrPJz9iSVC4nKu36p5MyZwJA36lNSAgsVzJjzLlCbNK9wEZS9XaoNbqolWqQqSnkufMwtYUy83+USxjOS9kGZEkGtB8oVIQXlWyTwotfJIBX2R2v67MObnvCo+2VIaXzsf1wc6YtrhickTnWuXnsNAAxns5jEY0PByPD4avfTIe03ASjg7Dgyb6URs0A5ZyuWhjXjCbUauuUM2k8YajSRe+5DbJEBx2dFoJ0VNlyx4FH6o0l879CvHeNq9fRfTLIN1ESnNAnh6f90ZjSXOlc0OzXsAvBfZTS4R7dZ98V0bV9zoqhuT2AQNWPaflnoOhLE29bcudSJY77hwjrbLp/7RZdqzdgqfdXQeTO77R2snkpND8SbISzvEWFfklvwdxzb+7iobRqz6I3TvQdcKEA0QhSovYVMtN09rq3Faz5Buk7+p2VH1BzMZ1K5a7rucepUHzO10uTXDN8qWAc2ZZUJ7MBBVPp1xvV19xSRfiDp/aBOuioavjb4O/16qQ6S1kPBHweLfNMZ7UOWIZBI7T3rNDFfH2u/1fNTMj+q2hEbVTo5bd06OWZ6dIA9w1TVrjrqnSsFzTW/0/bXD0H+n7pwx/wmF5Fw3YG56DKqyH5Pnl/XbGgT+YGfsg4KSq6A3Pl0pb94o8TG8BM2OJJrgr8KZbmhjj3GZB7TRL+Yrw9Dge9BiOB6TEoGXNU5tN8ewv4sHJLECPXzlGz3l2fYUq59fnFWjBHhwoG558qpSU0lmA26cZrVLijulOzJ8
You can comment the setTimeout, and uncomment the call to “add” method.
You’ll see that if the add method is called inline, no error.
If it’s called after 2s in the timeout, crash.
I think it’s the same error.
You can also notice that if the 3D models are not added to the second viewer, no error.
3. Context. Why do you need to do this? We might know a better way to accomplish your goal.
I need to have secondary viewpoint of the situation in a separate view.
4. The Cesium version you’re using, your operating system and browser.
Angular 6
npm Cesium 1.55, with explicit rendering on.
Chrome up-to-date.(72)
Windows 10
This crash didn’t happened in the cesium 1.49.
I hope you can find something for me.
Here’s my log in my website:
omar
March 27, 2019, 1:57pm
2
I’m getting a slightly different error when I try this locally:
DeveloperError: sub-region exceeds array bounds.
Error
at new DeveloperError (http://localhost:8080/Source/Core/DeveloperError.js:43:19 )
at getStringFromTypedArray (http://localhost:8080/Source/Core/getStringFromTypedArray.js:29:19 )
at http://localhost:8080/Source/Scene/Model.js:1601:30
at Function.ForEach.object (http://localhost:8080/Source/ThirdParty/GltfPipeline/ForEach.js:47:29 )
at Function.ForEach.shader (http://localhost:8080/Source/ThirdParty/GltfPipeline/ForEach.js:342:28 )
at parseShaders (http://localhost:8080/Source/Scene/Model.js:1593:17 )
at Model.update (http://localhost:8080/Source/Scene/Model.js:4428:25 )
``
Is this the error you’re getting in your application? It looks like this has more to do with model loading incorrectly. In this line:
https://github.com/AnalyticalGraphicsInc/cesium/blob/master/Source/Scene/Model.js#L1600
The “buffer.extras._pipeline.source” has a length of 0 when the crash happens. It’s almost as if the GltfPipeline library is running into some kind of global conflict here. If you remove just the GroundVehicle models from the first viewer, no crash happens.
Hi and thanks for the answer !!
So some more details.
The errors i’ve join in the first post is the actual error i get into my application.
I have the “sub-region exceeds” error in the sandcastle as well.
As i said, i don’t get the same error in my app and in sandcastle, but it’s the same behavior.
If i remove the ground vehicul i still get the error.
I’ve noticed that the error is different regarding what model is loaded in the scene.
But still a gltfPipeline error…
I agree with the fact that it seems to be a “global conflict”.
I really don’t know what to do with this…Thanks for the help anyway !
I hope someone can get some clue about this.
I’m pretty sure dynamically creating many cesium viewers is not the standard use case.
Help me Obi Wan Kenobi you’re my only hope
" "
omar
March 28, 2019, 6:47pm
4
I opened a bug report for it here:
https://github.com/AnalyticalGraphicsInc/cesium/issues/7688
I’m curious for your use case, is it possible to work around it by just creating the 2 viewers once your app initializes, hiding the second one and just showing it when you want to add it?
Thanks for the bug report.
I hope you’ll come to a solution.
For the use case, we want to create dynamically and destroy dynamically cesium viewers, from different point of view.
So it’s not only a matter of 2 viewers, but multiple viewers.
We can’t know in advance the number of viewers that will be created.
It’s also a matter of performance.
If we instanciate a pool of viewers, and showing only the ones that the user wants to display, we might have poor performance.
And it will also limit (of course, if it’s a pool) the number of viewers opened at a time. Wich is not what we want.
I know it’s an uncommon use case.
Thanks for your time !
Let’s keep in touch.
Ok problem solved with the Cesium 1.57 !
Thanks for the bugFix !