質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

.NET Framework 4.0

Microsoft Windows用のソフトウェア開発環境/実行環境である .NET Frameworkの4番目のメジャーバージョンです。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

2回答

8142閲覧

WPFで独自コントロールをDrapDropしたいです。

cancat

総合スコア313

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

.NET Framework 4.0

Microsoft Windows用のソフトウェア開発環境/実行環境である .NET Frameworkの4番目のメジャーバージョンです。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

0グッド

0クリップ

投稿2016/11/27 12:49

編集2016/11/27 13:06

こんにちは。
Windows10でWPFのアプリケーションを開発しています。
Visual Studio 2015 Communityを使っています。

###前提・実現したいこと
独自のUserControlをスタックパネル間でドラッグ&ドロップしたいです。
そのときの設定について教えてください。

1)DropするときにMyUserControlを受けとりたいが、e.Dataからどのように受けとればよいか。
ひょっとして、
MyUserControl muc = e.Data;
panel.Children.Add(muc);
でOK?

MyUserControl muc = (MyUserControl)e.Data.GetData("MyUserControl");
もだめっぽいです。

2)MouseDownのときのDragDrop.DoDragDropの引数を変更する必要がありますか?

###Error
現在はDropしたときに、
追加情報:型 'System.Windows.DataObject' のオブジェクトを型 'MyUserControl' にキャストできません。
とエラーです。

###該当のソースコード

XAML(UserControl.xaml)

1<UserControl x:Class="MyWindow.MyUserControl" 2 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 3 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 4 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 5 xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 6 xmlns:local="clr-namespace:MyWindow" 7 mc:Ignorable="d" 8 d:DesignHeight="300" d:DesignWidth="300"> 9 <Grid Background="lightBlue" MouseDown="Grid_MouseDown"> 10 <Grid.RowDefinitions> 11 <RowDefinition Height="20"/> 12 <RowDefinition Height="40*"/> 13 </Grid.RowDefinitions> 14 <TextBox Grid.Row="1" TextWrapping="WrapWithOverflow"/> 15 </Grid> 16</UserControl>

C#(UserControl.xaml.cs)

1 private void Grid_MouseDown(object sender, System.Windows.Input.MouseButtonEventArgs e) { 2 DragDrop.DoDragDrop(sender as MyUserControl, sender as MyUserControl, DragDropEffects.Copy); 3 }

MainWindow.xaml.cs

1 private void StackPanel_PreviewDragOver(object sender, DragEventArgs e) { 2 e.Effects = DragDropEffects.Copy; 3 e.Handled = true; 4 } 5 6 private void StackPanel_Drop(object sender, DragEventArgs e) { 7 StackPanel panel = sender as StackPanel; 8 //panel.Children.Add(e.Data.GetData(MyUserControl)//<--ここあやふや。 9 }

###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft Visual Studio Community 2015
Version 14.0.25424.00 Update 3
Microsoft .NET Framework
Version 4.6.01038

インストールしているバージョン:Community

Visual C# 2015 00322-20000-00000-AA575
Microsoft Visual C# 2015

です。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

DoDragDropはMainWindowの方に書いてtypeofでGetしてやればユーザーコントロールそのものを取得できたようです。

XAML

1<Window x:Class="tera56760.MainWindow" 2 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 3 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 4 xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 5 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 6 xmlns:local="clr-namespace:tera56760" 7 mc:Ignorable="d" 8 Title="MainWindow" Height="350" Width="525" AllowDrop="True" MouseUp="Window_MouseUp"> 9 <Grid> 10 <Grid.ColumnDefinitions> 11 <ColumnDefinition Width="*"/> 12 <ColumnDefinition Width="*"/> 13 </Grid.ColumnDefinitions> 14 <StackPanel Grid.Column="0" AllowDrop="True" Background="LightCoral" 15 PreviewDragEnter="StackPanel_PreviewDragEnter" 16 Drop="StackPanel_Drop"/> 17 <StackPanel Grid.Column="1" Orientation="Vertical"> 18 <local:UserControl1 19 PreviewMouseDown="UserControl1_PreviewMouseDown" 20 MouseMove="UserControl1_MouseMove" 21 /> 22 </StackPanel> 23 </Grid> 24</Window>

C#

1using System; 2using System.Collections.Generic; 3using System.Linq; 4using System.Text; 5using System.Threading.Tasks; 6using System.Windows; 7using System.Windows.Controls; 8using System.Windows.Data; 9using System.Windows.Documents; 10using System.Windows.Input; 11using System.Windows.Media; 12using System.Windows.Media.Imaging; 13using System.Windows.Navigation; 14using System.Windows.Shapes; 15 16namespace tera56760 { 17 /// <summary> 18 /// MainWindow.xaml の相互作用ロジック 19 /// </summary> 20 public partial class MainWindow : Window { 21 public MainWindow() { 22 InitializeComponent(); 23 } 24 25 private void StackPanel_PreviewDragEnter(object sender, DragEventArgs e) { 26 if(e.Data.GetDataPresent(typeof(UserControl1))) { 27 e.Effects = DragDropEffects.Move; 28 e.Handled = true; 29 } 30 } 31 32 private void StackPanel_Drop(object sender, DragEventArgs e) { 33 var uc1 = e.Data.GetData(typeof(UserControl1)) as UserControl1; 34 if(uc1 == null) return; 35 Console.WriteLine("kitayo"); 36 } 37 38 bool dd = false; 39 private void UserControl1_PreviewMouseDown(object sender, MouseButtonEventArgs e) { 40 var uc1 = sender as UserControl1; 41 if(uc1 == null) return; 42 dd = true; 43 } 44 45 private void UserControl1_MouseMove(object sender, MouseEventArgs e) { 46 if(!dd) return; 47 var uc1 = sender as UserControl1; 48 if(uc1 == null) return; 49 DragDrop.DoDragDrop(uc1, uc1, DragDropEffects.Move); 50 } 51 52 private void Window_MouseUp(object sender, MouseButtonEventArgs e) { 53 dd = false; 54 } 55 } 56}

投稿2016/11/27 14:48

Hey_CH

総合スコア437

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2016/11/28 14:26

ありがとうございます。 検証しました。とてもうまくいきました。
guest

0

Grid に対する MouseDown イベントハンドラ内で DoDragDrop メソッドをコールしていますが、
そのイベントハンドラの第 1 引数は Grid コントロールになるため、
ドラッグしたいコントロールになっていませんね。
HeyHeyHo さんが回答されているようにユーザーコントロールを配置したほうの XAML で
ユーザーコントロール (UserControl1) のイベントハンドラを登録し、
そちらで DoDragDrop メソッドをコールしないといけません。

余談ですが、ドラッグ&ドロップのような汎用性の高い機能は
よく添付ビヘイビアとして作成されることが多いです。
そのほうが別の機会に使い回すことができるからです。

「wpf ドラッグ&ドロップ 添付ビヘイビア」で検索すると
下記のようなサイトが結構出てくるので
一度調べてみてください。

M'sLabo report: 添付ビヘイビアでドラッグ&ドロップを簡単実装
YKSoftware: tips - ドラッグ&ドロップ操作によるリストの並べ替え

投稿2016/11/28 00:45

twyujiro15

総合スコア217

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問