首页 > 其他 > 详细

WPF 循环页面控件

时间:2014-10-09 12:30:23      阅读:262      评论:0      收藏:0      [点我收藏+]

不使用数据驱动来更新UI,而是直接更新页面也是可以的。

多个思路。

 

bubuko.com,布布扣

bubuko.com,布布扣

<Window x:Class="WPFControl.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">
<Grid>
<Grid.RowDefinitions>
<RowDefinition></RowDefinition>
<RowDefinition></RowDefinition>
<RowDefinition></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition></ColumnDefinition>
<ColumnDefinition></ColumnDefinition>
</Grid.ColumnDefinitions>
<StackPanel Grid.Column="0" Grid.Row="0" VerticalAlignment="Center" HorizontalAlignment="Center">
<CheckBox Content="1" Width="100"></CheckBox>
<CheckBox Content="2" Width="100"></CheckBox>
<CheckBox Content="3" Width="100"></CheckBox>
<CheckBox Content="4" Width="100"></CheckBox>
</StackPanel>
<StackPanel Grid.Column="1" Grid.Row="0" VerticalAlignment="Center" HorizontalAlignment="Center">
<CheckBox Content="5" Width="100"></CheckBox>
<CheckBox Content="6" Width="100"></CheckBox>
<CheckBox Content="7" Width="100"></CheckBox>
<CheckBox Content="8" Width="100"></CheckBox>
</StackPanel>
<StackPanel Grid.Column="0" Grid.Row="1" VerticalAlignment="Center" HorizontalAlignment="Center">
<CheckBox Content="9" Width="100"></CheckBox>
<CheckBox Content="10" Width="100"></CheckBox>
<CheckBox Content="11" Width="100"></CheckBox>
<CheckBox Content="12" Width="100"></CheckBox>
</StackPanel>
<StackPanel Grid.Column="1" Grid.Row="1" VerticalAlignment="Center" HorizontalAlignment="Center">
<CheckBox Content="13" Width="100"></CheckBox>
<CheckBox Content="14" Width="100"></CheckBox>
<CheckBox Content="15" Width="100"></CheckBox>
<CheckBox Content="16" Width="100"></CheckBox>
</StackPanel>
<StackPanel Grid.Row="2" Grid.Column="0" Grid.ColumnSpan="2" VerticalAlignment="Center" HorizontalAlignment="Center">
<Button Width="100" Content="全选" Click="ButtonBase_OnClick"></Button>
</StackPanel>
</Grid>
</Window>

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace WPFControl
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}

private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
{
this.GetVisuals().OfType<CheckBox>().ToList().ForEach(a => a.IsChecked = a.IsChecked != true);
}
}
}

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Media;

namespace WPFControl
{
public static class HelpExtend
{
public static IEnumerable<DependencyObject> GetVisuals(this DependencyObject root)
{
int count = VisualTreeHelper.GetChildrenCount(root);
for (int i = 0; i < count; i++)
{
var child = VisualTreeHelper.GetChild(root, i);
yield return child;
foreach (var descendants in child.GetVisuals())
{
yield return descendants;
}
}
}


}
}

 

WPF 循环页面控件

原文:http://www.cnblogs.com/lafei/p/4012313.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!