-
-
Notifications
You must be signed in to change notification settings - Fork 2.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HamburgerMenu: Content sometimes moves behind navigation bar #3817
Comments
Hi @floele-sp can you test this with the current release v2.0.0? There were some fixes on this control, maybe it was solved "by accident" Happy testing |
Hi @timunie, the issue still occurs in 2.0.0. Now 100% of the time though (so far). This makes testing much easier, but I'm still not quite sure what I should do with those bindings. |
@floele-sp Can you create a sample with exactly this scenario? This makes it easier to debug this, because I can not see this in the main demo. Thx |
@punker76 I created a small test project with some copy & paste XAML from our application. Apparently the issue reproduces, there is a data binding error as well. |
@floele-sp I think your problem is the DockPanel. IMO a HamburgerMenu should use the complete space of a window (inside a Grid). In your case, if you really need the DockPanel with another Grid (Content) then you should change the DockPanel settings. <DockPanel LastChildFill="True">
<Grid DockPanel.Dock="Right">
<TextBlock>Content</TextBlock>
</Grid>
<mah:HamburgerMenu x:Name="sidebarPanel" ... |
@punker76 When I try your suggested changes it looks like this: How did you make the control fill the gap between the left bar and content? I need the hamburger control to be constrained in any case. |
@floele-sp This happens because of |
@punker76 What about the binding errors though? Should they not be fixed? |
@floele-sp Do you mean this?
Why? IsDocked is no property on HamburgerMenu. |
…ceValue (GH-3817) Fix coercing of OpenPaneLength at HamburgerMenu
@punker76 No, I mean the error seen in the Snoop screenshot in my first post. It also exists in the sample app. |
@floele-sp This will be fixed in another PR. |
@punker76 OK, great! |
@punker76 Did you already fix the binding issues? We still have problems with the HamburgerMenu unfortunately. |
Sometimes, the content of the HamburgerMenu moves behind the navigation bar when starting up the application. In the demo app, it would look like this (assuming that it actually happens):
(here the whitespace on the left is missing)
Unfortunately it only happens rarely and thus is hard to reproduce, but it happens often enough to be a real annoyance.
I've already spent a lot of time on this to figure out why it's happening. The issue occurs because the column width is set to
1*
in ColumnDefinition1 (SplitView.xaml) instead of the expected numeric value.This unexpected value is set by the ClosedCompactLeftStoryboard animation, at some point the value of ColumnDefinition1.Width will be set to
Auto
(so a default GridLength) which then gets converted to1*
by the GridLengthAnimation later in this line of code:return new GridLength(animationClock.CurrentProgress.Value * (toVal - fromVal) + fromVal, GridUnitType.Star);
It should be noted that it doesn't make any difference whether it's
Auto
or1*
though, both values cause the appearance to be incorrect.The root issue seems to be that the binding of the
To
property occasionally breaks:The bindings to
ElementName=ProxyElement
indeed seem a bit fishy to me, especially since there also is a resource<FrameworkElement x:Key="ProxyElement" DataContext="{TemplateBinding TemplateSettings}" />
which isn't being used. Do you have a suggestion for reorganising the bindings so that such a problem can no longer occur?
Environment:
The text was updated successfully, but these errors were encountered: