代码注意事项:
1、代码实现的样式赋值
XXX.Style = TryFindResource("StyleName") as Style;
2.WPF中FindName方法的使用
(1)简单的使用 前台代码:
<Button x:Name="btnName" Click="btnName_Click">Test Method FindName</Button>
后台代码:
private void btnName_Click(object sender, RoutedEventArgs e)
{
Button b = FindName("btnName") as Button;
MessageBox.Show(b.Name);
}
(2)在模板中使用FindName方法
<Grid> <Grid x:Name="childGrid"> <Button x:Name="rootBtn"> <Button.Template> <ControlTemplate> <Button x:Name="btnName" Click="btnName_Click">Test Method FindName</Button> </ControlTemplate> </Button.Template> </Button> </Grid> </Grid>
后台代码:
private void btnName_Click(object sender, RoutedEventArgs e) { Button b = rootBtn.Template.FindName("btnName",rootBtn) as Button; MessageBox.Show(b.Name); }
3.使用多个绑定参数
<Button Height="23" Command="{Binding AddCommand}" Content="计算" HorizontalAlignment="Left" Margin="20,0,0,49" Name="button1" VerticalAlignment="Bottom" Width="75"> <Button.CommandParameter> <MultiBinding Converter="{StaticResource ParameterConverter}"> <Binding Path="Text" ElementName="textBox1"/> <Binding Path="Text" ElementName="textBox2"/> </MultiBinding> </Button.CommandParameter>
4、将代码写在XAML中
<Grid> <x:Code> <![CDATA[ private void button1_Click(object sender, RoutedEventArgs e) { button1.Background = Brushes.Blue; button1.Content = "The code is in XAML"; MessageBox.Show("hi"); } ]]></x:Code> <Button Height="23" Margin="46,56,32,0" Name="button1" VerticalAlignment="Top" Click="button1_Click">Click me!</Button> </Grid>
5、各属性对应的C#代码
5.1<Window><Grid><Button ...></Grid></window>
等效代码如下:
Grid g = new Grid(); Button b = new Button(); b.Width = 100; b.Height = 100; b.Content = "Test Button"; b.Foreground = Brushes.LightBlue; g.Children.Add(b); myWindow.AddChild(g);
6、ItemContainerGenerator.ContainerFromIndex方法的使用
TreeViewItem item = (TreeViewItem)myTreeView.ItemContainerGenerator.ContainerFromIndex(1);
7、WPF获取子控件和父控件方法
public class Globals { /// <summary> /// 获取父控件方法。该方法将根据当前控件,遍历查找其父控件是否存在。参数1是表示当前子控件名,参数2是要查询父控件名; /// </summary> public T GetParentObject<T>(DependencyObject obj, string name) where T : FrameworkElement { DependencyObject parent = VisualTreeHelper.GetParent(obj); while (parent != null) { if (parent is T && (((T)parent).Name == name | string.IsNullOrEmpty(name))) { return (T)parent; } parent = VisualTreeHelper.GetParent(parent); } return null; } /// <summary> /// 该方法将根据当前控件,遍历查找其子控件是否存在。参数1是表示当前父控件名,参数2是要查询子控件名; /// </summary> public T GetChildObject<T>(DependencyObject obj, string name) where T : FrameworkElement { DependencyObject child = null; T grandChild = null; for (int i = 0; i <= VisualTreeHelper.GetChildrenCount(obj) - 1; i++) { child = VisualTreeHelper.GetChild(obj, i); if (child is T && (((T)child).Name == name | string.IsNullOrEmpty(name))) { return (T)child; } else { grandChild = GetChildObject<T>(child, name); if (grandChild != null) return grandChild; } } return null; } /// <summary> /// 该方法将把所有子控件作为List集合返回到客户端。 /// 其中第一个参数是父控件参数,而第二个参数是特定子控件名称, /// 如果需要遍历全部子控件,第二个参数留空即可。 /// </summary> public List<T> GetChildObjects<T>(DependencyObject obj, string name) where T : FrameworkElement { DependencyObject child = null; List<T> childList = new List<T>(); for (int i = 0; i <= VisualTreeHelper.GetChildrenCount(obj) - 1; i++) { child = VisualTreeHelper.GetChild(obj, i); if (child is T && (((T)child).Name == name || string.IsNullOrEmpty(name))) { childList.Add((T)child); } childList.AddRange(GetChildObjects<T>(child, "")); } return childList; } }
XAML:
Globals VTHelper = new Globals(); StackPanel sp = VTHelper.GetChildObject<StackPanel>(this.LayoutRoot, "spDemoPanel"); Grid layoutGrid = VTHelper.GetParentObject<Grid>(this.spDemoPanel, "LayoutRoot"); List<TextBlock> textblock = VTHelper.GetChildObjects<TextBlock>(this.LayoutRoot, "");
8.GridSplitter控件的使用:
<Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="90*" /> <ColumnDefinition Width="Auto" /> <ColumnDefinition Width="180*" /> </Grid.ColumnDefinitions> <Grid.RowDefinitions> <RowDefinition Height="190*" /> <RowDefinition Height="Auto" /> <RowDefinition Height="70*" /> </Grid.RowDefinitions> <Button Content="ButtonA" Margin="3" Grid.Row="0" Grid.Column="0" Grid.RowSpan="3" /> <Button Content="ButtonB" Margin="3" Grid.Row="0" Grid.Column="2" /> <Button Content="ButtonC" Margin="3" Grid.Row="2" Grid.Column="2" /> <GridSplitter Width="3" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Grid.Row="0" Grid.Column="1" Grid.RowSpan="3"></GridSplitter> <GridSplitter Height="3" VerticalAlignment="Stretch" HorizontalAlignment="Stretch" Grid.Row="1" Grid.Column="2"></GridSplitter> </Grid>
效果图:
9.UniformGrid控件中每行没列都相等
<UniformGrid> <Button Content="ButtonA" /> <Button Content="ButtonB" /> <Button Content="ButtonC" /> <Button Content="ButtonD" /> <Button Content="ButtonE" /> <Button Content="ButtonF" /> <Button Content="ButtonG" /> <Button Content="ButtonH" /> </UniformGrid>
如图:
作者:Work Hard Work Smart
出处:http://www.cnblogs.com/linlf03/
欢迎任何形式的转载,未经作者同意,请保留此段声明!