не удалось обнаружить события щелчка правой кнопкой мыши вниз и вверх - PullRequest
0 голосов
/ 09 июля 2020

Я написал программное обеспечение WPF VS 2019 в Windows 7. Я хочу добиться этой функции: когда я щелкаю правой кнопкой мыши и рисую линию на холсте, линия будет нарисована, начиная с точки, когда Я щелкаю правой кнопкой мыши и заканчиваю, когда отпущу ее.

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

<UserControl x:Class="STIGenericReport.UserControl"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Height="407" Width="633" Background="White" BorderBrush="White" Focusable="False">
    <Grid Name="maingrid" Background="White" Height="405" Width="616" MinWidth="500">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="619*" />
            <ColumnDefinition Width="10*" />
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height ="574*" />
            <RowDefinition Height="26" MinHeight="16" />
        </Grid.RowDefinitions>
    <Viewport3D Name="mainViewport" ClipToBounds = "False"  
                IsHitTestVisible="false"
                RenderOptions.EdgeMode="Aliased" Margin="12,52,144,47">
        <Viewport3D.Camera>
            <OrthographicCamera x:Name="camera" Width="2"
                FarPlaneDistance="10"
                NearPlaneDistance="1" 
                LookDirection="0,0,-1"
                UpDirection="0,1,0"
                Position="0,0,2" />
        </Viewport3D.Camera>
        <Viewport3D.Children>
            <ModelVisual3D x:Name="Light1">
                <ModelVisual3D.Content>
                    <DirectionalLight Color="White" Direction="1, 1, -1" />
                </ModelVisual3D.Content>
            </ModelVisual3D>
            <ModelVisual3D x:Name="Light2">
                <ModelVisual3D.Content>
                    <DirectionalLight Color="White" Direction="-1, 1, -1" />
                </ModelVisual3D.Content>
            </ModelVisual3D>
            <ModelVisual3D x:Name="Light3">
                <ModelVisual3D.Content>
                    <DirectionalLight Color="White" Direction="0,-1,-0.5" />
                </ModelVisual3D.Content>
            </ModelVisual3D>
        </Viewport3D.Children>
     </Viewport3D>

    <Canvas x:Name="canvasOn3D" Background="#00E6FFFF" 
            Margin="20,52,102,18"></Canvas>
    <Label Content="Trayinfo    &amp;" FontSize="16" FontWeight="Bold" Height="34" HorizontalAlignment="Left" Margin="192,0,0,0" Name="lblTrayinfo" VerticalAlignment="Top" Width="194" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,257" Name="btn9" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,232" Name="btn8" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button HorizontalAlignment="Left" Margin="499,149,0,207" Name="btn7" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,182" Name="btn6" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,157" Name="btn5" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,132" Name="btn4" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,107" Name="btn3" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,82" Name="btn2" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,57" Name="btn1" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Button Height="25" HorizontalAlignment="Left" Margin="499,0,0,282" Name="btn10" VerticalAlignment="Bottom" Width="50" Background="White" BorderThickness="0" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,57" Name="lbl1" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,82" Name="lbl2" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,107" Name="lbl3" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,132" Name="lbl4" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,157" Name="lbl5" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,182" Name="lbl6" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,207" Name="lbl7" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,232" Name="lbl8" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,257" Name="lbl9" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Height="25" HorizontalAlignment="Right" Margin="0,0,12,282" Name="lbl10" VerticalAlignment="Bottom" Width="45" Background="White" BorderBrush="White" />
    <Label Content="Pacakage info" HorizontalAlignment="Center" Width="Auto" Height="32" Name="lblPkgname" FontSize="16" FontWeight="Bold" Margin="300,0,191,347" />
</Grid>
    private void OnPreviewMouseRightButtonDown(object sender, MouseButtonEventArgs args)     
    {
        if (args.RightButton == MouseButtonState.Pressed)                
        {
            currentPoint = args.GetPosition(this);
        }
    }
    private void OnPreviewMouseRightButtonUp(object sender, MouseButtonEventArgs args)      
    {
        if (args.RightButton == MouseButtonState.Released)                  
        {      
            Line line = new Line();
            line.Stroke = SystemColors.WindowFrameBrush;
            line.X1 = currentPoint.X;
            line.Y1 = currentPoint.Y;
            line.X2 = currentPoint_2.X;
            line.Y2 = currentPoint_2.Y;
            line.StrokeThickness = 2;
            canvasOn3D.Children.Add(line);
         }
    }

Когда я отлаживаю эту программу, она не входит в эту функцию, когда я щелкаю правой кнопкой мыши.

1 Ответ

0 голосов
/ 09 июля 2020

Previewmouserightbuttondown, кажется, не работает даже в простом эксперименте.

У вас также есть некоторые странности в вашем коде.

Координаты вашей мыши должны быть основаны на холст (предположительно).

Вот несколько более простых рабочих разметки и кода.

В Mainwindow я просто добавил холст внутри сетки по умолчанию:

    <Grid>
        <Canvas 
            Name="lineCanvas"
            Background="Transparent"
            PreviewMouseDown="lineCanvas_PreviewMouseDown"
            PreviewMouseUp="lineCanvas_PreviewMouseUp"
                >
        
        </Canvas>
    </Grid>

Обратите внимание, я обрабатываю previewmousedown и вверх. Фон холста установлен на прозрачный, поэтому его можно будет проверить на попадание.

Мой код (который работает):

    public MainWindow()
    {
        InitializeComponent();
    }
    Point startPoint = new Point();

    private void lineCanvas_PreviewMouseDown(object sender, MouseButtonEventArgs e)
    {
        if (e.ChangedButton == MouseButton.Right)
        {
            startPoint = Mouse.GetPosition(lineCanvas);
        }
    }

    private void lineCanvas_PreviewMouseUp(object sender, MouseButtonEventArgs e)
    {
        if (startPoint.X == 0 && startPoint.Y == 0)
        {
            return;
        }
        var currentPoint = Mouse.GetPosition(lineCanvas);
        Line line = new Line();
        line.Stroke = SystemColors.WindowFrameBrush;
        line.X1 = startPoint.X;
        line.Y1 = startPoint.Y;
        line.X2 = currentPoint.X;
        line.Y2 = currentPoint.Y;
        line.StrokeThickness = 2;
        lineCanvas.Children.Add(line);

        startPoint = new Point();
    }

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...