2017-01-13 11 views
0

スクロールビューア内でキャンバスをラップすると、境界のドラッグアンドドロップが機能しなくなるという問題があります。ScrollViewerでドラッグアンドドロップが動作しない

1200x1200キャンバスを500x500スクロールビューアに入れました。キャンバスをスクロールビューアでスクロール可能(タッチスライド)したい。スクロールビューアに挿入する前に、キャンバスのドラッグアンドドロップが完全に機能しています。

MainWindow.xaml

<Grid ClipToBounds="True"> 
     <ScrollViewer Name="scbb" Width="500" Height="500" HorizontalScrollBarVisibility="Hidden" 
      VerticalScrollBarVisibility="Hidden" HorizontalAlignment="Left" 
      VerticalAlignment="Top" Background="LightBlue" ScrollViewer.CanContentScroll="True"> 
     <Canvas x:Name="canvas" Width="1200" Height="1200" 
      MouseLeftButtonDown="CanvasMouseLeftButtonDown" 
      MouseLeftButtonUp="CanvasMouseLeftButtonUp" 
      MouseMove="CanvasMouseMove"> 
     </Canvas> 
     </ScrollViewer> 
     <Button x:Name="btnEnable" Content="Enable" Height="50" Width="50" Margin="0,0,115,10" VerticalAlignment="Bottom" 
      HorizontalAlignment="Right" Click="btnEnable_Click"/> 
     <Button Content="Add Image" Width="100" Height="100" VerticalAlignment="Bottom" 
      HorizontalAlignment="Right" Click="AddButtonClick" Margin="0,0,10,10"/> 
    </Grid> 

MainWindow.xaml.cs

private void AddButtonClick(object sender, RoutedEventArgs e) 
     { 
      int iNum = SETTING.GetTableRunningNumber(); 

      var borderWrap = new Border(); 
      borderWrap.Width = 100; 
      borderWrap.Height = 100; 
      borderWrap.Background = Brushes.Green; 

      var label1 = new Label(); 
      label1.VerticalAlignment = VerticalAlignment.Center; 
      label1.HorizontalAlignment = HorizontalAlignment.Center; 
      label1.Content = "Table " + iNum.ToString(); 
      label1.Name = "Table" + iNum.ToString(); 
      label1.Foreground = Brushes.White; 
      label1.FontWeight = FontWeights.Bold; 

      borderWrap.Child = label1; 
      borderWrap.MouseDown += TableMouseDown; 

      Canvas.SetLeft(borderWrap, 10); 
      Canvas.SetTop(borderWrap, 10); 
      canvas.Children.Add(borderWrap); 

      iNum += 1; 
      SETTING.SetTableRunningNumber(iNum); 
     } 

     private Point mousePosition; 
     private Border draggedBorder; 

     private void TableMouseDown(object sender, MouseButtonEventArgs e) 
     { 
      if (!SETTING.GetEnableDrag()) 
      { 
       var cLabel = e.Source as Label; 
       var bBorder = e.Source as Border; 

       if (cLabel != null) 
       { 
        MessageBox.Show(cLabel.Name.ToString()); 
       } 
      } 
     } 

     private void CanvasMouseLeftButtonDown(object sender, MouseButtonEventArgs e) 
     { 
      if (SETTING.GetEnableDrag()) 
      { 
       var dBorder = e.Source as Border; 
       var cLabel = e.Source as Label; 

       if (dBorder == null) 
       { 
        dBorder = (Border)cLabel.Parent; 
       } 

       if (dBorder != null && canvas.CaptureMouse()) 
       { 
        mousePosition = e.GetPosition(canvas); 
        draggedBorder = dBorder; 
        Panel.SetZIndex(draggedBorder, 1); 
       } 
      }   
     } 

     async Task PutTaskDelay100() 
     { 
      await Task.Delay(100); 
     } 

     private async void CanvasMouseLeftButtonUp(object sender, MouseButtonEventArgs e) 
     { 
      if (SETTING.GetEnableDrag()) 
      { 
       await PutTaskDelay100(); 
       if (draggedBorder != null) 
       { 
        canvas.ReleaseMouseCapture(); 
        Panel.SetZIndex(draggedBorder, 0); 
        draggedBorder = null; 
       } 

      } 
     } 

     private void CanvasMouseMove(object sender, MouseEventArgs e) 
     { 
      if (SETTING.GetEnableDrag()) 
      { 
       double canvasSize = 1200; 
       if (draggedBorder != null) 
       { 
        var position = e.GetPosition(canvas); 
        var offset = position - mousePosition; 
        mousePosition = position; 

        double newTop = Canvas.GetTop(draggedBorder) + offset.Y; 
        double newLeft = Canvas.GetLeft(draggedBorder) + offset.X; 

        if (newTop < 0) 
        { 
         newTop = 0; 
        } 
        else if (newTop + draggedBorder.ActualWidth > canvasSize) 
         newTop = canvasSize - draggedBorder.ActualWidth; 

        if (newLeft < 0) 
        { 
         newLeft = 0; 
        } 
        else if (newLeft + draggedBorder.ActualWidth > canvasSize) 
         newLeft = canvasSize - draggedBorder.ActualWidth; 

        Canvas.SetLeft(draggedBorder, newLeft); 
        Canvas.SetTop(draggedBorder, newTop); 
       } 
      }  
     } 

答えて

0

私はヶ月前に問題を抱えていたし、これらの追加と背後にあるコードでそれを解決しました。 WindowMain.xaml.cs内のInitializeComponent後

追加:

public WindowMain() 
{ 
    InitializeComponent(); 

    // your code, etc. 

    scrollViewer.AllowDrop = true; 
    scrollViewer.PreviewDragEnter += scrollViewer_PreviewDragEnter; 
    scrollViewer.PreviewDragOver += scrollViewer_PreviewDragOver; 
    scrollViewer.Drop += scrollViewer_Drop; 
} 


void scrollViewer_PreviewDragEnter(object sender, DragEventArgs e) 
{ 
    if (e.Data.GetDataPresent(DataFormats.FileDrop)) 
    { 
     e.Effects = DragDropEffects.Copy; 
    } 
    else 
    { 
     e.Effects = DragDropEffects.None; 
    } 
} 

void scrollViewer_PreviewDragOver(object sender, DragEventArgs e) 
{ 
    e.Handled = true; 
} 

bool IsDataAvailable = false; 
void scrollViewer_Drop(object sender, DragEventArgs e) 
{ 
    // Get data object 
    var dataObject = e.Data as DataObject; 

    // Check for file list 
    if (dataObject.ContainsFileDropList()) 
    { 
     // Process file names 
     StringCollection fileNames = dataObject.GetFileDropList(); 
     bool isIsDataAvailable = false; 
     try 
     { 
      var uri = new Uri(fileNames[0]); 
      BitmapSource imageSource = new BitmapImage(uri); 
      isIsDataAvailable = true; 
     } 
     catch (Exception error) 
     { 
      string errorMessage = error.ToString(); 
     } 
     finally 
     { 
      IsDataAvailable = isIsDataAvailable; 
     } 
    } 
} 

私のプログラムはちょうど私がScrollViewerの上でドロップエクスプローラのファイルリストからドロップされたファイルをロードします。 ScrollViewerのscbb.AllowDrop=trueを設定する必要があります。そして、基本的なドラッグ・アンド・ドロップを処理するルーチン。 ScrollViewerでドロップが可能になると、コードは機能します。

+0

ありがとう、私のコードは、ドラッグアンドドロップは、キャンバスで行われます。 1200x1200のキャンバスは500x500のスクロールビューアに配置されました。スクロールビューアでキャンバスがスクロール可能(タッチスライド)したい。 –

+1

Ok、CanvasをScrollViewerに追加すると、Canvasが機能しませんでした。 ScrollViewerがドロップできない場合は、にscbb.AllowDrop = trueを追加します。 – Wayne

関連する問題