1

これは私にはうまくいきません

<UserControl x:Class="BenchmarkPlus.PMT.UI.Views.Circle"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="300" x:Name="root"
             DataContext="{Binding Source={x:Static Brushes.Blue}}">
    <UserControl.Resources>
        <Style TargetType="Ellipse">
            <Setter Property="Fill" Value="{Binding DataContext}" />
        </Style>
    </UserControl.Resources>
    <Grid>
        <Ellipse Stroke="Black"></Ellipse>
    </Grid>
</UserControl>

ここに画像の説明を入力

4

2 に答える 2

4

簡単DataContext="{x:Static Brushes.Blue}"に作成して、に変更Value="{Binding DataContext}"Value="{Binding}"ます。

バインディング式でパスを指定すると、それは常にDataContextに相対的であるため、を使用する{Binding DataContext}と、実際にはにバインドされますがDataContext.DataContext、これは必要なものではありません。

于 2012-04-19T23:09:02.687 に答える
1

私はあなたが欲しいと思います

<UserControl x:Class="BenchmarkPlus.PMT.UI.Views.Circle" 
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008"  
             mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="300" x:Name="root" 
             DataContext="{x:Static Brushes.Blue}"> 
    <UserControl.Resources> 
        <Style TargetType="Ellipse"> 
            <Setter Property="Fill" Value="{Binding}" /> 
        </Style> 
    </UserControl.Resources> 
    <Grid> 
        <Ellipse Stroke="Black"></Ellipse> 
    </Grid> 
</UserControl> 
于 2012-04-19T23:19:31.743 に答える