Search Issue Tracker
Fixed in 2017.3.0f3
Fixed in 5.6.X, 2018.1.X
Won't Fix in 2017.1.X, 2017.2.X
Votes
0
Found in
5.6.1f1
Issue ID
926629
Regression
No
All canvases in the Scene is being Rebuilt
There are large CPU spikes related to UI. While trying to track down the symptoms, User has found out that Canvas.BuildBatch encompasses *every* active canvas in the scene and subsequently slows SendWillRenderCanvases.
The problem is that all canvases are being rebuilt rather than only ones in the relevant hierarchy.
The event which causes this appears to be the addition of a GameObject to a ScrollRect's viewport. It's expected in that case that only canvas ancestors of that node are rebuilt, not all canvas in the scene. The codebase does *not* call Canvas.ForceUpdateCanvases().
Steps to reproduce:
1. Open User's attached project ("Test-ScrollandAnotherCanvas.zip")
2. Open Profiler
3. Enter Play mode
4. Wait for objects to stop appearing in scroll list
5. Pause Play mode
6. Look for Canvas.BuildBatch in profiler
7. Check Show Related Object
Result: Check that Overlay is being re-build
Reproduced with: 2017.2.0b3, 2017.1.0f3, 5.6.2p3.
Note: Sometimes it is easy to reproduce when the list is already filled, but sometimes not. So to reproduce it easily, move the scroll list when the items are being created.
All about bugs
View bugs we have successfully reproduced, and vote for the bugs you want to see fixed most urgently.
Latest issues
- Character spacing value is not applied when using a specific font asset
- [Android][IL2CPP] Player crashes on __memcpy_aarch64_simd+276 when invoking native code via a plugin on some ARM64 Android devices
- [Android]Resources fail to load when the AAB build contains a large Addressables Bundle
- Unity is loading internal version of SharpZipLib instead of local version
- The Context Menu items are ordered incorrectly
Add comment