`
lindexi-gd
  • 浏览: 139540 次
社区版块
存档分类
最新评论

win10 uwp 如何拖动一个TextBlock的文字到另一个TextBlock

 
阅读更多

我在堆栈网看到有人问 如何拖动一个TextBlock的文字到另一个TextBlock 于是看到一个大神给出的方法,下面我就来和大家说下如何拖动

<!--more-->

一开始我们需要一个界面,就放两个TextBlock 一个是源,一个目标。我们拖动源到目标。


<Page
    x:Class="Textvt.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Textvt"
    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}">
        <StackPanel Background="{ThemeResource ApplicationPageBackgroundThemeBrush}" Padding="30">

            <Border BorderBrush="Azure" BorderThickness="2">
                <TextBlock x:Name="TextSource" 
                           Text="我是源" 
                           CanDrag="True" 
                           DragStarting="Txtsource_OnDragStarting"  />
            </Border>
            <Border Margin="20" BorderBrush="Azure" BorderThickness="2"
                    AllowDrop="True" >
                <TextBlock x:Name="TextTarget" Text="目标TextBlock" 
                           Drop="Txttarget_OnDrop"
                           Height="50" Width="400"  
                           AllowDrop="True" 
                           DragEnter="Txttarget_OnDragEnter"/>
            </Border>
        </StackPanel>
    </Grid>
</Page>

在xaml.cs 需要3个事件,开始拖放,拖放,拖放进入。

其中拖放进入是设置鼠标显示的字和其他的东西,可以不要这个函数,不会影响功能。

        private void Txtsource_OnDragStarting(UIElement sender, DragStartingEventArgs args)
        {
            //开始拖放
            //设置拖放文字,文字是我们点击的TextBlock
            args.Data.SetText(TextSource.Text);
        }

        private async void Txttarget_OnDrop(object sender, DragEventArgs e)
        {
            //如果有文字,那么就是把他放在要拖放的TextBlock
            bool hasText = e.DataView.Contains(StandardDataFormats.Text);
            //显示复制还是没有
            //拖动显示可以去我之前写的 http://blog.csdn.net/lindexi_gd/article/details/49757187?locationNum=2&fps=1
            e.AcceptedOperation = hasText ? DataPackageOperation.Copy : DataPackageOperation.None;
            if (hasText)
            {
                var text = await e.DataView.GetTextAsync();
                TextTarget.Text += "\n" + text;
            }
        }

        private void Txttarget_OnDragEnter(object sender, DragEventArgs e)
        {

            bool hasText = e.DataView.Contains(StandardDataFormats.Text);
            e.AcceptedOperation = hasText ? DataPackageOperation.Copy : DataPackageOperation.None;
            if (hasText)
            {
                if (e.DragUIOverride != null)
                {
                    e.DragUIOverride.Caption = "Drop here to insert text";
                }
            }
        }

代码:http://download.csdn.net/detail/lindexi_gd/9739764 可以的话给点积分。

问题原文:

https://stackoverflow.com/questions/41662650/how-to-move-text-from-one-textblock-to-another-textblock-using-drag-and-drop-in

知识共享许可协议
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

<script type="text/javascript"> $(function () { $('pre.prettyprint code').each(function () { var lines = $(this).text().split('\n').length; var $numbering = $('<ul/>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('<li/>').text(i)); }; $numbering.fadeIn(1700); }); }); </script>
分享到:
评论

相关推荐

    如何拖动一个TextBlock的文字到另一个TextBlock

    在本案例中,我们讨论的主题是如何实现一个TextBlock中的文字被拖动并放置到另一个TextBlock。这个功能常见于文本编辑器、富文本组件或者任何需要文本移动的UI设计中。下面我们将详细介绍如何实现这一功能。 首先,...

    C#实现win10 uwp 右击浮出窗在点击位置

    在Windows 10 UWP应用开发中,常常需要创建一种用户友好的交互方式,即当用户右键点击某个元素时,能在一个特定的位置显示一个浮出菜单(MenuFlyout)。本篇文章将详细介绍如何使用C#实现这样的功能,使得MenuFlyout...

    xaml中TextBlock显示上标的方法

    在XAML(Extensible Application Markup Language)中,`TextBlock` 是一个非常常用的元素,用于显示文本。它提供了丰富的格式化选项,包括字体样式、颜色、大小等。当需要在 `TextBlock` 中显示上标时,可以通过...

    UWP环状进度条

    一种方法是创建一个新的自定义控件,继承自ProgressRing,并添加一个TextBlock用于显示百分比。在XAML中,我们首先定义这个新的控件: ```xml &lt;TextBlock x:Name="PercentageText" Text="{TemplateBinding ...

    UWP入门代码之7天酒店

    以前写过一个wp8的工程,说实话那会的代码很麻烦,写起来费劲,另外还没多少人下载,不过到windows 10 开始微软出了UWP架构以后一切都像以前的winform wpf一样好转起来,新建一个工程以后模板很简洁。 现在就开始...

    android 中win10 使用uwp控件实现进度条Marquez效果

    为了实现 Marquez 效果,需要使用两个控件:ProgressBar 控件和 TextBlock 控件。ProgressBar 控件用于显示进度条,TextBlock 控件用于显示文字。然后,使用 TranslateTransform 来控制文字的平移变换,从而实现 ...

    UWP的Tcp聊天客户端Demo

    UWP(Universal Windows Platform)是微软推出的一个跨设备的应用开发平台,旨在为Windows 10设备提供统一的开发体验。本Demo主要介绍如何在UWP平台上构建一个简单的TCP聊天客户端,以便用户能够与其他设备进行实时...

    uwp wpf使用第三方字体

    1. **添加字体文件**:将Roboto字体文件放入项目的Resources目录,或者创建一个新的Resources子目录,并将Build Action设置为“Resource”。 2. **定义FontFamily**:与UWP类似,我们也在XAML中定义FontFamily,但...

    win8数据绑定

    在XAML中,我们可以绑定控件的属性,如TextBlock的Text属性,到数据模型的相应属性: ```xml &lt;TextBlock Text="{Binding Text}"/&gt; ``` 现在,我们添加一个Button,当点击该按钮时,Text属性的值会发生变化。为此,...

    C#124阴影效果的文字 源代码

    如果是WPF或UWP应用,那么可以利用TextBlock或Label的附加属性来实现类似的效果,比如使用DropShadowEffect。 在源代码中,你可能会看到这些概念和类的实例化和组合,以及可能的自定义逻辑,例如处理不同颜色、透明...

    编程Windows 10桌面:UWP Focus(N之4)

    在本篇中,我们将深入探讨如何使用UWP(通用Windows平台)进行Windows 10桌面应用开发,特别是在“编程Windows 10桌面:UWP Focus(N之4)”这一主题下,我们将专注于如何创建一个名为DailyJournal的应用,以此来...

    local-note:使用UWP Framework构建的富文本编辑器

    在UWP中实现这样的功能需要利用TextBlock、RichEditBox等控件,以及相关的API和数据绑定技术。 1. **控件选择**:在UWP中,我们通常使用`RichEditBox`来实现富文本编辑功能。这个控件允许用户输入和编辑富文本,并...

    WindowsApplicationDriver

     这个工具是用来查看运行软件(uwp、win32、win form、wpf)的 UI 元素的 Name、ID、Text 等等。包含在 Windows SDK 中。  安装完 Visual Studio2015后,可以在 C盘下找到:C:\Program Files (x86)\Windows Kits\...

    C# XAML 霓虹灯字体特效源码

    例如,可以使用`Storyboard`定义一个动画,改变`TextBlock`的`Opacity`、`ScaleTransform`或`RotateTransform`属性,实现闪烁、缩放或旋转的效果,达到霓虹灯般的动态感。 2. **循环速度设置**:为了控制霓虹灯效果...

    mvvm treeview 显示

    这段代码定义了一个树节点模板,其中`TextBlock`显示`TreeNode`的`Name`属性,`ItemsSource="{Binding Children}"`表示子节点来自于当前节点的`Children`属性。`HierarchicalDataTemplate`使得可以递归地显示子节点...

    转换xaml.zip

    在XAML中,你可以使用`{Binding}`标记来指定一个属性应该绑定到的数据源。例如,如果你有一个名为`MyProperty`的数据源属性,可以这样写: ```xml &lt;TextBlock Text="{Binding MyProperty}" /&gt; ``` 然而,有时数据...

    SharpVectors.rar

    4. **展示图形**:将转换后的XAML字符串插入到你的WPF或UWP应用的UI元素中,如`TextBlock`或`RichTextBox`,或者动态创建UI元素。 5. **交互和定制**:转换后的XAML图形现在可以像任何其他XAML元素一样进行操作,...

    一个基于C#创建类库并有机集成到Silverlight2.0中调用程序例子

    在本文中,我们将深入探讨如何使用C#语言创建一个类库,并将其无缝集成到Silverlight 2.0应用程序中。Silverlight是微软推出的一种轻量级的插件技术,用于在Web浏览器中创建丰富的交互式用户体验,而C#作为.NET框架...

    Windows-universal-samples-master_C#_universal_

    《Windows-universal-samples-master_C#_universal_》是一个针对C#语言开发的Windows通用应用程序(UWP,Universal Windows Platform)的学习资源包。这个压缩包包含了大量的示例代码,是开发者学习如何构建跨平台...

Global site tag (gtag.js) - Google Analytics