Border with Shadow triggering "[View] ContentViewGroup not displayed because it is too large to fit into a software layer (or drawing cache)" in Android #17881
Labels
area-drawing
Shapes, Borders, Shadows, Graphics, BoxView, custom drawing
platform/android 🤖
s/triaged
Issue has been reviewed
s/verified
Verified / Reproducible Issue ready for Engineering Triage
t/bug
Something isn't working
Milestone
Description
When a Border is created and then a shadow is applied, this seems to use a massive amount of resources in Android to the extent that if you make the Border object even slightly larger than the screen, it triggers an error:
[View] ContentViewGroup not displayed because it is too large to fit into a software layer (or drawing cache), needs 10501248 bytes, only 10108800 available
This is when using default Google Pixel 5 Android Emulator.
This does not happen for the same project in Windows/iOS (no errors).
Is there any way to fix this? Is there some problem with how the shadows are rendering?
The bug output seems to suggest it is trying to use 10.5 MB to render the shadow. It claims to only have 10.1 MB available.
I think I understand where the numbers are coming from. The Google Pixel 5 resolution is 1080 x 2340, which at 32 bit depth = 10.1 MB as per calculator: https://www.omnicalculator.com/other/image-file-size
Setting the Border a bit bigger than screen resolution creates a 10.5 MB need which apparently is greater than the device capacity.
So it seems the system is claiming it cannot draw a Shadow on any view larger than the device's native resolution. But does this make sense? It doesn't seem to.
It can clearly draw the Border at a size bigger than the screen resolution, so it is capable of rendering objects bigger than that. If you apply a shadow to a View, is it creating a bitmap object essentially the size of the entire object? Ie. In this case something 10.5 MB big? And if so, is there anyway to fix this? iOS and Windows don't give any error or such limitation.
How does it render the Border itself with no issues but the Shadow has problems?
Is there expected to be a known limitation on Android's Shadow function that all Shadow elements must be kept small or they will use massive resources? It seems if one adds many Shadow elements the resource utilization will be rapidly astronomical. Unless there is an issue that can be fixed.
Does the Android shadow function work somehow different than iOS or Windows?
Thanks for any thoughts.
Steps to Reproduce
[View] ContentViewGroup not displayed because it is too large to fit into a software layer (or drawing cache), needs 10501248 bytes, only 10108800 available
screenWidth
multiplier of theBorder1
object or removing the shadow stops the error.Link to public reproduction project repository
https://github.com/jonmdev/ContentViewGroup-Too-Big-Bug
Version with bug
7.0.92
Is this a regression from previous behavior?
No, this is something new
Last version that worked well
Unknown/Other
Affected platforms
Android
Affected platform versions
Android API 33, .NET 7.0
Did you find any workaround?
If this is an intrinsic limitation of Android's Shadow function we must be very careful in how it is used.
However, I suspect it is more of a MAUI problem because when I search "ContentViewGroup not displayed because it is too large to fit into a software layer" I only find 3rd party systems triggering the problem eg. React Native, which to me suggests it is not necessarily a directly Android issue but rather an implementation issue.
Relevant log output
The text was updated successfully, but these errors were encountered: