Fix TextBox in AdornerLayer causes collection modified exception in Arrange pass #14714
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What does the pull request do?
This PR changes VisualLayerManager so that layers can be added during its Arrange pass.
What is the current behavior?
In my previous PR #14484 I intentionally didn't touch ArrangeOverride method, as I didn't want to touch things that are not directly required.
However, it turned out it is required.
I assumed that Measure will always be called before Arrange. However, this is not always true. Consider this:
In
root.Arrange
,root
already has valid measurement (IsMeasureValid = true) yet in the meantime a new control was added, which will reference VisualLayerManager.TextSelectorLayer -> crash.What is the updated/expected behavior with this PR?
Both Measure and Arrange methods in VisualLayerManager will support adding layers during iteration.
Checklist
Breaking changes
n/a
Obsoletions / Deprecations
n/a
Fixed issues
#14483