c# - ресурсы - динамический xaml



Событие WPF MouseDown не срабатывает повсюду в элементе управления (1)

<StackPanel Background="Transparent" ...

или

<Border Background="Transparent" ...

должен сделать трюк ...

Это делает сетку прозрачной, однако видимой для щелчков мыши.

Посмотрите здесь форму.

Существуют и другие условия, в которых вы должны использовать PreviewXXX -Event, это когда дочерний элемент «проглатывает» событие, но в вашем случае вышеупомянутое shpould то, что вы ищете.

В настоящее время я борюсь с другой борьбой WPF, а именно с mouseEvents. У меня в основном есть очень простой элемент управления ( Border содержащая Grid которая сама имеет несколько TextBlocks ). Я пытаюсь добиться простого поведения. Двойной щелчок должен превратить элемент управления в режим редактирования (который фактически скрывает TextBlocks с TextBoxes привязанными к тем же данным.

Ничего необычного, да? Ну, я боюсь. MouseDoubleClick связанный с моим UserControl просто срабатывает, когда я нажимаю элемент управления (например, нажав на текстовый блок). Если я нажимаю на пустое место между TextBlocks , ничего не запускается. Даже MouseDown .

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

Вот несколько проектов кода, которые я сделал для вас, чтобы запустить его:

XAML:

<StackPanel Orientation="Vertical">
    <Border Height="400" Width="400" HorizontalAlignment="Center" VerticalAlignment="Center" BorderBrush="Black" BorderThickness="2"
        MouseDown="Border_MouseDown" MouseUp="Border_mouseUp">
        <Grid>
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*" />
                <ColumnDefinition Width="*" />
                <ColumnDefinition Width="*" />
            </Grid.ColumnDefinitions>
            <Grid.RowDefinitions>
                <RowDefinition Height="*" />
                <RowDefinition Height="*" />
                <RowDefinition Height="*" />
            </Grid.RowDefinitions>

            <TextBlock Text="BLUFF" Grid.Column="0" Grid.Row="0" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="0" Grid.Row="1" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="0" Grid.Row="2" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="1" Grid.Row="0" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="1" Grid.Row="1" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="1" Grid.Row="2" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="2" Grid.Row="0" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="2" Grid.Row="1" HorizontalAlignment="Center" VerticalAlignment="Center"/>
            <TextBlock Text="BLUFF" Grid.Column="2" Grid.Row="2" HorizontalAlignment="Center" VerticalAlignment="Center"/>
        </Grid>

    </Border>

    <TextBlock Height="100" Width="300" HorizontalAlignment="Center" TextAlignment="Center" x:Name="thetext" Visibility="Collapsed"
               Foreground="White" Background="Red" Text="CLICKED!" />
</StackPanel>

Код позади:

private void Border_MouseDown(object sender, MouseButtonEventArgs e)
    {
        thetext.Visibility = Visibility.Visible;
    }

    private void Border_mouseUp(object sender, MouseButtonEventArgs e)
    {
        thetext.Visibility = Visibility.Collapsed;
    }

Теперь попробуйте нажать один из текстов «BLUFF»: появится текст «CLICKED». Попробуйте щелкнуть в другом месте, между TextBlocks: ничего не происходит.

Спасибо!





mouseevent