在Windows 8 Metro App中拖放图像

Ruw*_*aka 2 c# wpf xaml windows-8

有没有办法在Windows 8 metro应用程序中拖放图像.我正在使用C#和XAML.以下是我需要的......

在此输入图像描述

Joh*_*ner 5

当然有.你必须自己控制它,但它很容易.你需要使用这样的一些指针事件:

XAML:

<Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}"   PointerMoved="GridPointerMoved">
    <Image x:Name="image1" HorizontalAlignment="Left" Height="100" VerticalAlignment="Top" Width="100" Source="Assets/imageFile.png"  PointerPressed="ImagePointerPressed" PointerReleased="ImagePointerReleased"/>
</Grid>
Run Code Online (Sandbox Code Playgroud)

然后在你的CS文件中:

Point positionWithinImage;
private void ImagePointerPressed(object sender, PointerRoutedEventArgs e)
{
    Debug.WriteLine("Pressed");
    holding = true;

    positionWithinImage = e.GetCurrentPoint(sender as Image).Position;
}

private void ImagePointerReleased(object sender, PointerRoutedEventArgs e)
{
    Debug.WriteLine("Released");
    holding = false;
}

bool holding = false;

private void GridPointerMoved(object sender, PointerRoutedEventArgs e)
{
    if (holding)
    {
        var pos = e.GetCurrentPoint(image1.Parent as Grid).Position;
        image1.Margin = new Thickness(pos.X - this.positionWithinImage.X, pos.Y - this.positionWithinImage.Y, 0, 0);
    }
}
Run Code Online (Sandbox Code Playgroud)


小智 5

我在这里找到了一个很好的解决方案:http://xatazch.blogspot.pt/2012/08/drag-and-drop-item-using.html

使用TranslateTransform,我们可以为可拖动项目获得平滑且"实时"的移动.

void MainPage_Loaded(object sender, RoutedEventArgs e)
{
     image1.ManipulationDelta += DragableItem_ManipulationDelta;
     image1.RenderTransform = new TranslateTransform();
}

private void DragableItem_ManipulationDelta(object sender, ManipulationDeltaRoutedEventArgs e)
{
     Image dragableItem = sender as Image;
     TranslateTransform translateTransform = dragableItem.RenderTransform as TranslateTransform;

     translateTransform.X += e.Delta.Translation.X;
     translateTransform.Y += e.Delta.Translation.Y;
}
Run Code Online (Sandbox Code Playgroud)

希望能帮助到你!