通过XamlReader()和MainWindow.Xaml加载的元素表现不同?

时间:2017-12-23 16:47:29

标签: c# wpf xaml xamlreader

我在MainWindow.Xaml中有以下Viewbox:

    <Viewbox x:Name="R1C1Viewbox" Grid.Row="1" Grid.Column="2"
                                   Grid.ColumnSpan="1" Grid.RowSpan="1">
      <Border x:Name="R1C1Border" BorderBrush="White" CornerRadius="3"
                                  BorderThickness="2" Background="White"  
                                  Height="40" Width="40" Margin="0,3,3,0">
        <Grid x:Name="R1C1Grid">
          <TextBlock x:Name="R1C1TextBlock1" HorizontalAlignment="Center" VerticalAlignment="Center" FontFamily="Arial" FontWeight="Bold" Text="+" FontSize="22"></TextBlock>
          <Polygon x:Name="R1C1LED"
              Points="0,0 15,0 0,15"
              Stroke="#FFED1C24" 
              StrokeThickness="1">
            <Polygon.Fill>
              <RadialGradientBrush>
                <GradientStop Color="White" Offset="2.5"/>
                <GradientStop Color="Black"/>
              </RadialGradientBrush>
            </Polygon.Fill>
          </Polygon>
          <Button x:Name="R1C1Button" Background="Transparent"
                  BorderBrush="Transparent">
          </Button>
        </Grid>
      </Border>
    </Viewbox>

在我的代码中,我为Polygon.Fill属性定义了2个RadialGradientBrushes:

public static RadialGradientBrush ledOn = new RadialGradientBrush();
public static RadialGradientBrush ledOff = new RadialGradientBrush();


  ledOn.GradientStops.Add(new GradientStop(Colors.Red, .8));
  ledOn.GradientStops.Add(new GradientStop(Colors.White, 0));
  ledOff.GradientStops.Add(new GradientStop(Colors.White, 2.5));
  ledOff.GradientStops.Add(new GradientStop(Colors.Black, 0));

如果我只从MainWindow.xaml加载视图框,我可以使用:

    R1C1LED.Fill = ledOn;

R1C1LED.Fill = ledOff;

并且填充按预期更改。如果我使用XamlReader()从文件加载完全相同的xaml,Viewbox将完全按预期显示,但使用后面的代码更改填充,不会更改填充,也不会生成错误。

1 个答案:

答案 0 :(得分:0)

示例代码:

private void OnTest(object sender, RoutedEventArgs e)
{
    var xaml =
        @"<Window 
             xmlns='http://schemas.microsoft.com/winfx/2006/xaml/presentation'
             xmlns:x='http://schemas.microsoft.com/winfx/2006/xaml'
             xmlns:d='http://schemas.microsoft.com/expression/blend/2008'
             xmlns:mc='http://schemas.openxmlformats.org/markup-compatibility/2006'
             mc:Ignorable='d'
             Title='WPF App' Height='450' Width='800'>

            <StackPanel Orientation='Vertical'>
                <Button x:Name='R1C1LED' Content='Load Data' />
            </StackPanel>
        </Window>";


    var win = (Window)XamlReader.Parse(xaml);
    var button = (Button)win.FindName("R1C1LED");
    button.Background = Brushes.Red;
    button.Click += (obj, args) => { MessageBox.Show("Hi!"); };
    win.Show();

}