WPF动态添加按钮并相应事件。

50 篇文章 2 订阅
上code:
<Window x:Class="WpfApplication1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded">
    <Grid>
        <Canvas Name="abc" Margin="0,57,0,0">
            <Button Canvas.Left="400" Canvas.Top="207" Content="Button" Height="30" Name="Button2" Width="85" Click="btn_click" />
        </Canvas>
    </Grid>
</Window>


上面是布局的时候加了个按钮,下面的代码中会加入个程序中创建的。
 
namespace WpfApplication1
{
    ///

    /// MainWindow.xaml 的交互逻辑

    ///

    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            
        }

        private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            Button btn = new Button
                {
                    Name = "Button1",
                    Content = "OK",
                    Height = 23,
                    Width = 64,
                    HorizontalAlignment = HorizontalAlignment.Left,
                    Margin = new Thickness(10, 10, 0, 0),
                    VerticalAlignment = VerticalAlignment.Top,
                    Visibility = Visibility.Visible
                };
            btn.Click += new RoutedEventHandler(btn_click);
            abc.Children.Add(btn);

        }
        private void btn_click(object sender, RoutedEventArgs e)
        {
            Button btn = sender as Button;
            if ("Button1" == btn.Name)
            {
                System.Windows.MessageBox.Show("hello");
            }
            else if ("Button2" == btn.Name)
            {
                System.Windows.MessageBox.Show("World.");
            }

        }
    }
}

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在WPF中,要为列表控件的列头添加折叠按钮,可以使用自定义控件模板来实现。 首先,创建一个自定义控件模板,例如: ```XAML <ControlTemplate x:Key="ColumnHeaderTemplate" TargetType="{x:Type GridViewColumnHeader}"> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="Auto"/> <ColumnDefinition Width="*"/> </Grid.ColumnDefinitions> <ToggleButton x:Name="ToggleBtn" Grid.Column="0" Width="20" Height="20" Content="▲" VerticalAlignment="Center" Click="ToggleBtn_Click"/> <ContentPresenter Grid.Column="1" Content="{TemplateBinding Content}" VerticalAlignment="Center"/> </Grid> </ControlTemplate> ``` 然后,将这个自定义控件模板应用到列表控件的列头,例如: ```XAML <ListView> <ListView.View> <GridView> <GridViewColumn HeaderContainerStyle="{StaticResource ColumnHeaderStyle}" HeaderTemplate="{StaticResource ColumnHeaderTemplate}" DisplayMemberBinding="{Binding PropertyName1}"/> <GridViewColumn HeaderContainerStyle="{StaticResource ColumnHeaderStyle}" HeaderTemplate="{StaticResource ColumnHeaderTemplate}" DisplayMemberBinding="{Binding PropertyName2}"/> </GridView> </ListView.View> </ListView> ``` 最后,在代码中实现折叠按钮的点击事件,例如: ```C# private void ToggleBtn_Click(object sender, RoutedEventArgs e) { ToggleButton toggleBtn = sender as ToggleButton; GridViewColumnHeader columnHeader = toggleBtn.TemplatedParent as GridViewColumnHeader; if (toggleBtn.IsChecked == true) { // 隐藏列 columnHeader.Visibility = Visibility.Collapsed; } else { // 显示列 columnHeader.Visibility = Visibility.Visible; } } ``` 这样,就可以通过点击列头上的折叠按钮来隐藏或显示该列了。当按钮被点击时,会触发ToggleBtn_Click事件,根据ToggleBtn的IsChecked属性来判断是隐藏还是显示列头。 ### 回答2: 在WPF中,可以通过自定义控件模板来实现列头添加折叠按钮的功能。 首先,需要使用一个带有折叠按钮的ToggleButton控件作为列头的模板。可以使用样式来定义这个控件的外观和交互行为。 接下来,在DataGrid控件中设置列头的模板,可以通过设置DataGrid.ColumnHeaderStyle属性来实现。 在样式的模板中,可以使用Grid或者其他布局控件来布局列头的内容和折叠按钮。可以使用触发器来控制折叠按钮的显示和隐藏。 在折叠按钮的Click事件中,可以处理相应的逻辑,比如修改列头的显示或者隐藏状态。 最后,可以使用绑定来实现动态控制列头的折叠状态,可以绑定到相应的属性或者命令。 总结起来,通过自定义控件模板、样式、布局和绑定,可以在WPF中实现列头添加折叠按钮的功能。具体的实现方式可以根据具体需求进行调整和扩展。 ### 回答3: 在WPF中,要为列表头添加折叠按钮,可以通过使用ListView控件的GridView列头模板来实现。 首先,在ListView的XAML代码中,我们需要定义GridView的列头模板。可以使用Grid或者其他类似容器来组织内容。在这个模板中,我们可以添加一个Button控件作为折叠按钮,以及显示列标题的TextBlock控件。例如: ``` <ListView> <ListView.View> <GridView> <GridViewColumn> <GridViewColumnHeader> <Grid> <Button Width="20" Height="20" Click="Button_Click"> <Button.Content> <Image Source="collapse.png" /> </Button.Content> </Button> <TextBlock Text="列标题"/> </Grid> </GridViewColumnHeader> <GridViewColumn.CellTemplate> <DataTemplate> ... </DataTemplate> </GridViewColumn.CellTemplate> </GridViewColumn> </GridView> </ListView.View> </ListView> ``` 在这个例子中,我们为列头添加了一个Button按钮,并为按钮添加了点击事件处理程序`Button_Click`。当按钮被点击时,可以编写相关的C#代码来实现折叠效果。例如,可以使用VisualStateManager来改变按钮的外观,同时收起或展开相应的列内容。 在C#代码中,我们可以定义`Button_Click`事件处理程序,然后在事件处理程序中根据需要更新相关的界面元素。 需要注意的是,折叠效果的具体实现方式可以根据实际需求进行调整。例如,可以使用其他控件替代按钮,或者使用自定义的样式和动画效果来实现更加复杂的折叠效果。以上代码仅为示例,具体实现方式可以根据项目需要进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值