【WPF】如何一键获得一类控件的Name值

做项目的时候遇见了这个问题,在网上查找了一些资料之后解决了这个问题,我把我的代码贴出来分享一下。

先说我的要求:主窗口上有五个TextBlock控件和两个Button按钮(Get和Set),单击Get按钮之后弹出一个对话框,显示出所有TextBlock控件的Name值;单击Set按钮之后,将所有的TextBlock的背景色设为红色。

这是主窗体的代码(控件是手动拖的,所有属性值有点乱):

<Window
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="ExplodeProgram.MainWindow"
    x:Name="Window"
    Title="MainWindow"
    Width="600" Height="400" xmlns:my="clr-namespace:ExplodeProgram">

    <Grid x:Name="LayoutRoot">
        <TextBlock Name="hello" Margin="78,77,98,196" TextWrapping="Wrap" Foreground="#FFFB240F" FontSize="64">
            <Run Language="zh-cn" Text="Hello World!"/></TextBlock>
        <TextBlock Height="23" HorizontalAlignment="Left" Margin="30,179,0,0" Name="textBlock1" 
                   Text="TextBlock1" VerticalAlignment="Top" Width="100" />
        <TextBlock Height="23" HorizontalAlignment="Left" Margin="136,179,0,0" Name="textBlock2" 
                   Text="TextBlock2" VerticalAlignment="Top" Width="100" />
        <TextBlock Height="23" HorizontalAlignment="Left" Margin="291,179,0,0" Name="textBlock3" 
                   Text="TextBlock3" VerticalAlignment="Top" Width="100" />
        <TextBlock Height="23" HorizontalAlignment="Left" Margin="420,179,0,0" Name="textBlock4" 
                   Text="TextBlock4" VerticalAlignment="Top" Width="100" />

        <Button x:Name="get" Content="Get" Margin="102,0,411,45" VerticalAlignment="Bottom" Height="25" Width="65" Click="get_Click" />
        <Button x:Name="set" Content="Set" Width="65" Height="25" Click="set_Click" Margin="185,291,328,45" />
    </Grid>
</Window>

这是后台单击事件的代码:

 private void set_Click(object sender, RoutedEventArgs e)
        {
            foreach (UIElement element in LayoutRoot.Children)
            {
                if (element is TextBlock)
                {
                    TextBlock current = ((TextBlock)element);
                    //设置背景
                    current.Background = Brushes.Red;
                }
            }

        }

        private void get_Click(object sender, RoutedEventArgs e)
        {
            string str = "";
            foreach (UIElement element in LayoutRoot.Children)
            {
                if (element is TextBlock)
                {
                    TextBlock current = ((TextBlock)element);
                    str += current.Name + "\r\n";
                }
            }
            //显示Name值
            MessageBox.Show(str);
        }

搞定。

转载于:https://www.cnblogs.com/shhddb/archive/2013/01/23/2873468.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF中可以通过鼠标交互来修改件的位置真实。需要使用鼠标事件和件的RenderTransform属性来实现。 首先,你需要为件添加鼠标事件处理程序。例如,你可以为件添加MouseDown、MouseMove和MouseUp事件处理程序,如下所示: ``` <Grid> <Button Content="Hello World!" Margin="10" MouseDown="Button_MouseDown" MouseMove="Button_MouseMove" MouseUp="Button_MouseUp"/> </Grid> ``` 接下来,你需要在鼠标事件处理程序中处理鼠标事件,并使用件的RenderTransform属性来修改件的位置真实。例如,你可以在MouseDown事件处理程序中记录件初始位置,然后在MouseMove事件处理程序中计算件的新位置,最后在MouseUp事件处理程序中更新件的位置真实。具体代码如下所示: ``` private Point lastPosition; private void Button_MouseDown(object sender, MouseButtonEventArgs e) { // 记录件初始位置 lastPosition = e.GetPosition(null); ((UIElement)sender).CaptureMouse(); } private void Button_MouseMove(object sender, MouseEventArgs e) { if (e.LeftButton == MouseButtonState.Pressed) { // 计算件的新位置 Point newPosition = e.GetPosition(null); TranslateTransform transform = new TranslateTransform( newPosition.X - lastPosition.X, newPosition.Y - lastPosition.Y); // 更新件的RenderTransform属性 ((UIElement)sender).RenderTransform = transform; } } private void Button_MouseUp(object sender, MouseButtonEventArgs e) { ((UIElement)sender).ReleaseMouseCapture(); } ``` 在上面的代码中,MouseDown事件处理程序记录了件初始位置,并开始捕获鼠标。MouseMove事件处理程序检查鼠标左是否按下,如果按下,则计算件的新位置,并使用TranslateTransform来创建一个新的Transform对象,然后将其设置为件的RenderTransform属性。最后,在MouseUp事件处理程序中释放鼠标捕获。这样,当你拖动件时,它的位置真实将被修改,而不仅仅是视觉上的移动。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值