以编程方式向 UWP 应用添加按钮
Programmatically add buttons to a UWP app
假设我的应用有一个按钮可以添加另一个按钮。
如果我按下它,另一个按钮应该出现在第一个按钮的旁边。
此外,新按钮应成为 "add a new button" 按钮。
我该怎么做?
我的方法是创建一个 RelativePanel,因为在编辑器中,您可以说 "Place this left of that"。
但是,它找不到在 C# 代码中执行此操作的方法。
您可以按照 并通过在代码中设置附加的 属性 值来完成。示例可能如下所示 - XAML:
<RelativePanel x:Name="myPanel" Margin="100">
<Button Content="StartBtn" Click="Button_Click"/>
</RelativePanel>
在后面的代码中:
private void Button_Click(object sender, RoutedEventArgs e)
{
Button newButton = new Button { Content = "CreatedBtn" };
newButton.Click += Button_Click;
RelativePanel.SetLeftOf(newButton,sender);
myPanel.Children.Add(newButton);
}
这可以正常工作,但是如果您双击一个按钮,第二个新创建的按钮将与第一次单击创建的按钮重叠。如果这不是所需的行为,您将不得不以其他方式进行,在这种情况下,您需要一个按钮列表。为此,我使用了水平 ListView:
<ListView x:Name="myList">
<ListView.ItemsPanel>
<ItemsPanelTemplate>
<ItemsStackPanel Orientation="Horizontal" ScrollViewer.HorizontalScrollMode="Enabled" ScrollViewer.VerticalScrollMode="Disabled"/>
</ItemsPanelTemplate>
</ListView.ItemsPanel>
<ListView.ItemTemplate>
<DataTemplate>
<Button Content="{Binding}" Click="ListButton_Click"/>
</DataTemplate>
</ListView.ItemTemplate>
<x:String>StartBtn</x:String>
</ListView>
private void ListButton_Click(object sender, RoutedEventArgs e)
{
int index = myList.Items.IndexOf((e.OriginalSource as FrameworkElement).DataContext);
myList.Items.Insert(index, $"Btn {myList.Items.Count}");
}
这需要更多样式,但应该展示基本思想。
假设我的应用有一个按钮可以添加另一个按钮。 如果我按下它,另一个按钮应该出现在第一个按钮的旁边。 此外,新按钮应成为 "add a new button" 按钮。
我该怎么做?
我的方法是创建一个 RelativePanel,因为在编辑器中,您可以说 "Place this left of that"。 但是,它找不到在 C# 代码中执行此操作的方法。
您可以按照
<RelativePanel x:Name="myPanel" Margin="100">
<Button Content="StartBtn" Click="Button_Click"/>
</RelativePanel>
在后面的代码中:
private void Button_Click(object sender, RoutedEventArgs e)
{
Button newButton = new Button { Content = "CreatedBtn" };
newButton.Click += Button_Click;
RelativePanel.SetLeftOf(newButton,sender);
myPanel.Children.Add(newButton);
}
这可以正常工作,但是如果您双击一个按钮,第二个新创建的按钮将与第一次单击创建的按钮重叠。如果这不是所需的行为,您将不得不以其他方式进行,在这种情况下,您需要一个按钮列表。为此,我使用了水平 ListView:
<ListView x:Name="myList">
<ListView.ItemsPanel>
<ItemsPanelTemplate>
<ItemsStackPanel Orientation="Horizontal" ScrollViewer.HorizontalScrollMode="Enabled" ScrollViewer.VerticalScrollMode="Disabled"/>
</ItemsPanelTemplate>
</ListView.ItemsPanel>
<ListView.ItemTemplate>
<DataTemplate>
<Button Content="{Binding}" Click="ListButton_Click"/>
</DataTemplate>
</ListView.ItemTemplate>
<x:String>StartBtn</x:String>
</ListView>
private void ListButton_Click(object sender, RoutedEventArgs e)
{
int index = myList.Items.IndexOf((e.OriginalSource as FrameworkElement).DataContext);
myList.Items.Insert(index, $"Btn {myList.Items.Count}");
}
这需要更多样式,但应该展示基本思想。