Хорошо, это работает, так что хороший ответ, но есть ли способ работать с кружком, а не с Path, потому что мне нужно изменить размер автоматически, а не Path Так что попробую другое решение ниже.

дал элемент управления UserControl, представляющий собой кольцо, наложив 2 круга, при этом маленький круг остается пустым, а второй - за наименьшим цветным.

В моем приложении WPF я хочу поместить несколько колец, но маленький круг скрывает другие кольца. Я бы хотел видеть сквозь него, а также захватить событие мыши для кольца за другими кольцами, иначе это не настоящие кольца. Является ли это возможным ?

Я пробовал OpacityMask для маленького эллипса, как указано ответом наhttp://social.msdn.microsoft.com/forums/en-US/wpf/thread/551201d1-c5b3-4e17-ae63-625cfbb8bcc4 но до сих пор не вижу кольца за дырой:

<UserControl x:Class="MyUserControls.MyRing"
             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="150" d:DesignWidth="150" SizeChanged="UserControl_SizeChanged">
    <Grid Height="150" Name="Grid" Width="150" MouseMove="ellipse1_MouseMove">
        <Ellipse Fill="Red" Height="150" Width="150" HorizontalAlignment="Left" Margin="0,0,0,0" Name="ellipse1" Stroke="Black" VerticalAlignment="Top"  >
            <Ellipse.OpacityMask>
                <RadialGradientBrush>
                    <GradientStop Color="#FFB94444" Offset="0.496"/>
                    <GradientStop Color="#00FFFFFF" Offset="0.491"/>
                </RadialGradientBrush>
            </Ellipse.OpacityMask>
        </Ellipse>
        <Ellipse Fill="White" Height="100" Width="100" Margin="25,25,25,0" Name="ellipse2" Stroke="Black" VerticalAlignment="Top" />       
    </Grid>
</UserControl>

Ответы на вопрос(2)

Ваш ответ на вопрос