繁体   English   中英

如何使UWP飞出全屏

[英]how to make uwp flyout full screen

我正在为平板电脑创建一个应用程序,它将显示一个充满数据的网格。 我希望能够单击每个项目,然后将这些数据显示在弹出窗口或弹出窗口或其他对话框中,以便像表格一样对其进行编辑。 到目前为止,我使用的弹出框包含如下所示的堆栈面板:

            <Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}" Margin="10 0 10 0">
    <GridView ItemsSource="{x:Bind Activities}" ItemsPanel="{StaticResource ResourceKey=ItemsPanelTemplate}">
        <GridView.ItemContainerStyle>
            <Style TargetType="GridViewItem">
                <Setter Property="HorizontalContentAlignment" Value="Stretch" />
            </Style>
        </GridView.ItemContainerStyle>
        <GridView.ItemTemplate>
            <DataTemplate x:DataType="model:TimActivity">
                <Grid Tapped="GridView_Tapped">
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="1*" />
                        <ColumnDefinition Width="1*" />
                        <ColumnDefinition Width="1*" />
                        <ColumnDefinition Width="1*" />
                        <ColumnDefinition Width="1*" />
                        <ColumnDefinition Width="2*" />
                        <ColumnDefinition Width="1*" />
                    </Grid.ColumnDefinitions>
                    <TextBlock Grid.Column="0" Text="{x:Bind Path=Type, Converter={StaticResource TimActivityTypeToStringConverter}}" />
                    <TextBlock Grid.Column="1" Text="{x:Bind StartTime}" />
                    <TextBlock Grid.Column="2" Text="{x:Bind EndTime}" />
                    <TextBlock Grid.Column="3" Text="{x:Bind From}" />
                    <TextBlock Grid.Column="4" Text="{x:Bind To}" />
                    <TextBlock Grid.Column="5" Text="{x:Bind Comment}" />
                    <TextBlock Grid.Column="6" Text="{x:Bind Path=Chargeable, Converter={StaticResource BoolToStringConverter}}" />
                    <FlyoutBase.AttachedFlyout>
                        <Flyout Placement="Full">
                            <StackPanel>
                                        <TextBlock Text="Activity"/>
                                        <TextBox  Text="{x:Bind Path=Type, Converter={StaticResource TimActivityTypeToStringConverter}}" />
                                        <TextBlock Text="Start Time"/>
                                        <TextBox  Text="{x:Bind StartTime}" />
                                        <TextBlock Text="End Time"/>
                                        <TextBox  Text="{x:Bind EndTime}" />
                                        <TextBlock Text="From"/>
                                        <TextBox  Text="{x:Bind From}" />
                                        <TextBlock Text="To"/>
                                        <TextBox  Text="{x:Bind To}" />
                                        <TextBlock Text="Comment"/>
                                        <TextBox  Text="{x:Bind Comment}" />
                                        <TextBlock Text="Chargeable?"/>
                                        <TextBox  Text="{x:Bind Path=Chargeable, Converter={StaticResource BoolToStringConverter}}" />
                            </StackPanel>
                        </Flyout>
                    </FlyoutBase.AttachedFlyout>
                </Grid>
            </DataTemplate>
        </GridView.ItemTemplate>
    </GridView>
</Grid>

我将Placement设置为Full ,但它仅垂直拉伸弹出框,而不是全屏显示。 你能告诉我一个吗? 弹出是对此的正确控制,并且b。 如何使其全屏显示?

根据您的要求,我们建议您使用ConnectedAnimation进行处理。 有关更多步骤,请参考此代码示例

private void TipsGrid_ItemClick(object sender, ItemClickEventArgs e)
{
    ConnectedAnimation animation = null;

    // Get the collection item corresponding to the clicked item.
    var container = collection.ContainerFromItem(e.ClickedItem) as GridViewItem;
    if (container != null)
    {
        // Stash the clicked item for use later. We'll need it when we connect back from the detailpage.
        _storedItem = Convert.ToInt32(container.Content);

        // Prepare the connected animation.
        // Notice that the stored item is passed in, as well as the name of the connected element. 
        // The animation will actually start on the Detailed info page.
        animation = collection.PrepareConnectedAnimation("forwardAnimation", _storedItem, "connectedElement");

    }

    SmokeGrid.Visibility = Visibility.Visible;
   // SmokeGrid.DataContext = e.ClickedItem;
    animation.TryStart(destinationElement);
}

更新资料

然后,我应该能够编辑该表单中的所有字段,并在保存后将其反映在网格中。

您可以使模型继承INotifyPropertyChanged ,然后使用双向绑定将模型属性与xaml代码绑定。

<GridView Name="collection" ItemClick="Conllection_ItemClick" IsItemClickEnabled="True">
    <GridView.ItemTemplate>
        <DataTemplate>
            <Grid x:Name="connectedElement"  Height="100" Width="100" Background="Orange">
                <Grid.RowDefinitions>
                    <RowDefinition Height="Auto" />
                    <RowDefinition Height="*" />
                </Grid.RowDefinitions>
                <TextBlock Text="{Binding Title}" 
                           VerticalAlignment="Center"
                           HorizontalAlignment="Center"
                           TextAlignment="Center"/>
                <TextBlock Grid.Row="1" Text="{Binding Content,Mode=TwoWay}" 
                           VerticalAlignment="Center"
                           HorizontalAlignment="Center"
                           TextAlignment="Center"/>

            </Grid>
        </DataTemplate>
    </GridView.ItemTemplate>
</GridView>

您可以在GridView ItemClick时将项目传递到弹出网格。

private void Conllection_ItemClick(object sender, ItemClickEventArgs e)
{
    ConnectedAnimation animation = null;
    var container = collection.ContainerFromItem(e.ClickedItem) as GridViewItem;
    if(container != null)
    {
        _storedItem = container.Content;
        animation = collection.PrepareConnectedAnimation("forwardAnimation", _storedItem, "connectedElement");
    }
    SmokeGrid.Visibility = Visibility.Visible;
   // pass the item DataContext.
    SmokeGrid.DataContext = e.ClickedItem;

    animation.TryStart(destinationElement);
}

迷你样本已更新,您可以参考。

<Flyout Placement="Full">

即使它不会水平拉伸,这也是最好的方法。您还可以启用LightDismissOverlayMode以获得更多的“模态”选项体验。

全屏弹出没有任何意义,如果不添加其他退出按钮,您甚至无法将其关闭。

但是,如果您确实想这样做,则可以使用Popup ,它是FlyoutBase的一种更原始​​的产品,然后可以将其实际包含页面的宽度和高度绑定到它,例如:

<Popup   Height="{Binding yourpage.ActualHeight}"  Width="{Binding yourpage.ActualWidth}" />
<Button Background="Orange" Height="50" Width=50 />

弹出窗口由其IsOpen属性控制显示,因此请进行相应调整。

从体系结构的角度来看,如果您使用与任何单击的项目动态关联的单个弹出按钮,则更合适。

喜欢 :

YourListview.ItemClicked+=(e,z)=>{ yourSingleFlyout.ShowAt(ElementClicked)};

另外,就像其他人建议的那样,您可以使用Multiview系统,尽管我个人认为这种UI设计与Windows Phone一样死。

此外,仅出于提供信息的原因,Microsoft最近在最新的api更新中扩展了Flyout实体的Placement Enum,但我认为没有什么可能对您有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM