Quantcast
Channel: かずきのBlog@hatena
Viewing all articles
Browse latest Browse all 1387

UWPでファイルのドロップをしたい

$
0
0

以下のような感じでいけます。

まず、ドロップのターゲットにAllowDropプロパティをTrueにします。そしてDropOverイベントでドロップされたときの見た目を調整したりします。そして、Dropイベントで、イベント引数のDataViewプロパティのContainsメソッドでドロップされたコンテンツを確認して処理をします。

例えば画面の左半分にドロップされたファイルの名前のリストを、画面の右半分に置いたListViewに表示する場合は以下のようなコードになります。

<Page x:Class="App35.MainPage"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="using:App35"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"mc:Ignorable="d"><Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}"><Grid.ColumnDefinitions><ColumnDefinition /><ColumnDefinition /></Grid.ColumnDefinitions><Grid Background="DarkGray"AllowDrop="True"DragOver="Grid_DragOver"Drop="Grid_Drop"></Grid><ListView x:Name="ListView"Grid.Column="1" /></Grid></Page>

コードビハインドは以下のようになります。

using System;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.ApplicationModel.DataTransfer;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

// 空白ページのアイテム テンプレートについては、http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409 を参照してくださいnamespace App35
{
    /// <summary>/// それ自体で使用できる空白ページまたはフレーム内に移動できる空白ページ。/// </summary>publicsealedpartialclass MainPage : Page
    {
        public MainPage()
        {
            this.InitializeComponent();
        }

        privatevoid Grid_DragOver(object sender, DragEventArgs e)
        {
            // コピーのアイコンに切り替える
            e.AcceptedOperation = Windows.ApplicationModel.DataTransfer.DataPackageOperation.Copy;
        }

        private async void Grid_Drop(object sender, DragEventArgs e)
        {
            // ファイルの場合if (e.DataView.Contains(StandardDataFormats.StorageItems))
            {
                // ファイルのパスをListViewに表示する
                var items = await e.DataView.GetStorageItemsAsync();
                this.ListView.ItemsSource = items.Select(x => x.Path).ToArray();
            }
        }
    }
}

実行するとこんな感じになります。

f:id:okazuki:20160221162616p:plain

ドロップすると

f:id:okazuki:20160221162659p:plain

リストに表示されます。

f:id:okazuki:20160221162752p:plain


Viewing all articles
Browse latest Browse all 1387

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>