gpt4 book ai didi

c# - 添加滑动手势以打开 SplitView Pane

转载 作者:IT王子 更新时间:2023-10-29 04:33:34 24 4
gpt4 key购买 nike

我正在尝试向 UWP 的 SplitView 控件(又名“汉堡菜单”)添加滑动手势,类似于向左/向右滑动 Pivot 控件。如何设置一个手势来改变它的显示模式?

在 iOS 8 及更高版本中,我可以使用 UISplitViewController 并设置 presentsWithGesture 属性来执行此操作,但在 WinRT 中没有类似的东西。

阅读此博客后现在:http://blogs.msdn.com/b/cdndevs/archive/2015/07/10/uwp-new-controls-part-2-splitview.aspx ,我意识到 SplitView 控件中有 DisplayMode 属性,我应该使用 VisualStateManager 来更改它的状态但是我如何使用 vsm 将左 Pane 平移进和平移?我不知道这可以通过 vsm 实现。

任何帮助/提示将不胜感激。

最佳答案

有趣的问题! :)

我最近创建了一个 SwipeableSplitView它扩展了 SplitView DisplayMode 时,控件启用从左边缘滑动 手势设置为 Overlay (因为我看不出在其他模式下使用它有什么意义,但可以在需要时随意扩展它)。

我所做的就是,在控件样式内,在 PaneRoot 之上创建另一个层分层并处理那里的所有手势。

<Grid x:Name="PaneRoot" ManipulationMode="TranslateX" Grid.ColumnSpan="2" HorizontalAlignment="Left" Background="{TemplateBinding PaneBackground}" Width="{Binding TemplateSettings.OpenPaneLength, RelativeSource={RelativeSource Mode=TemplatedParent}}">
<Grid.Clip>
<RectangleGeometry x:Name="PaneClipRectangle">
<RectangleGeometry.Transform>
<CompositeTransform x:Name="PaneClipRectangleTransform" />
</RectangleGeometry.Transform>
</RectangleGeometry>
</Grid.Clip>
<Grid.RenderTransform>
<CompositeTransform x:Name="PaneTransform" TranslateX="{Binding RenderTransform.TranslateX, ElementName=PanArea}" />
</Grid.RenderTransform>
<Border Child="{TemplateBinding Pane}" />
<Rectangle x:Name="HCPaneBorder" Fill="{ThemeResource SystemControlForegroundTransparentBrush}" HorizontalAlignment="Right" Visibility="Collapsed" Width="1" x:DeferLoadStrategy="Lazy" />
</Grid>

<!--a new layer here to handle all the gestures -->
<Grid x:Name="OverlayRoot" Grid.ColumnSpan="2">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="{Binding TemplateSettings.OpenPaneGridLength, RelativeSource={RelativeSource Mode=TemplatedParent}}" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<!--the actual element for panning, manipulations happen here-->
<Rectangle x:Name="PanArea" Fill="Transparent" ManipulationMode="TranslateX" Width="{Binding PanAreaThreshold, RelativeSource={RelativeSource Mode=TemplatedParent}}" Grid.Column="1">
<Rectangle.RenderTransform>
<CompositeTransform TranslateX="{Binding PanAreaInitialTranslateX, RelativeSource={RelativeSource Mode=TemplatedParent}}" />
</Rectangle.RenderTransform>
</Rectangle>
<!--this is used to dismiss this swipeable pane-->
<Rectangle x:Name="DismissLayer" Fill="Transparent" Grid.Column="2" />
</Grid>

同时更新 TranslateX新层的变换对象,我也更新了 PaneRoot以保持他们的位置同步。

void OnManipulationStarted(object sender, ManipulationStartedRoutedEventArgs e)
{
_panAreaTransform = PanArea.RenderTransform as CompositeTransform;
_paneRootTransform = PaneRoot.RenderTransform as CompositeTransform;

if (_panAreaTransform == null || _paneRootTransform == null)
{
throw new ArgumentException("Make sure you have copied the default style to Generic.xaml!!");
}
}

void OnManipulationDelta(object sender, ManipulationDeltaRoutedEventArgs e)
{
var x = _panAreaTransform.TranslateX + e.Delta.Translation.X;

// keep the pan within the bountry
if (x < PanAreaInitialTranslateX || x > 0) return;

// while we are panning the PanArea on X axis, let's sync the PaneRoot's position X too
_paneRootTransform.TranslateX = _panAreaTransform.TranslateX = x;
}

void OnManipulationCompleted(object sender, ManipulationCompletedRoutedEventArgs e)
{
var x = e.Velocities.Linear.X;

// ignore a little bit velocity (+/-0.1)
if (x <= -0.1)
{
CloseSwipeablePane();
}
else if (x > -0.1 && x < 0.1)
{
if (Math.Abs(_panAreaTransform.TranslateX) > Math.Abs(PanAreaInitialTranslateX) / 2)
{
CloseSwipeablePane();
}
else
{
OpenSwipeablePane();
}
}
else
{
OpenSwipeablePane();
}
}

请记住,因为 IsPaneOpen属性不是虚拟的,我必须创建另一个 IsSwipeablePaneOpen将前者包裹起来。所以每当你想使用 IsPaneOpen属性(property),使用 IsSwipeablePaneOpen相反。

这就是它在我在 GitHub 中创建的演示应用程序中的工作方式。您可以找到完整的源代码 here .

enter image description here


致谢

关于c# - 添加滑动手势以打开 SplitView Pane ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32108362/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com