我在堆栈网看到有人问 如何拖动一个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)
{
args.Data.SetText(TextSource.Text);
}
private async void Txttarget_OnDrop(object sender, DragEventArgs e)
{
bool hasText = e.DataView.Contains(StandardDataFormats.Text);
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。这个功能常见于文本编辑器、富文本组件或者任何需要文本移动的UI设计中。下面我们将详细介绍如何实现这一功能。 首先,...
在Windows 10 UWP应用开发中,常常需要创建一种用户友好的交互方式,即当用户右键点击某个元素时,能在一个特定的位置显示一个浮出菜单(MenuFlyout)。本篇文章将详细介绍如何使用C#实现这样的功能,使得MenuFlyout...
在XAML(Extensible Application Markup Language)中,`TextBlock` 是一个非常常用的元素,用于显示文本。它提供了丰富的格式化选项,包括字体样式、颜色、大小等。当需要在 `TextBlock` 中显示上标时,可以通过...
一种方法是创建一个新的自定义控件,继承自ProgressRing,并添加一个TextBlock用于显示百分比。在XAML中,我们首先定义这个新的控件: ```xml <TextBlock x:Name="PercentageText" Text="{TemplateBinding ...
以前写过一个wp8的工程,说实话那会的代码很麻烦,写起来费劲,另外还没多少人下载,不过到windows 10 开始微软出了UWP架构以后一切都像以前的winform wpf一样好转起来,新建一个工程以后模板很简洁。 现在就开始...
为了实现 Marquez 效果,需要使用两个控件:ProgressBar 控件和 TextBlock 控件。ProgressBar 控件用于显示进度条,TextBlock 控件用于显示文字。然后,使用 TranslateTransform 来控制文字的平移变换,从而实现 ...
UWP(Universal Windows Platform)是微软推出的一个跨设备的应用开发平台,旨在为Windows 10设备提供统一的开发体验。本Demo主要介绍如何在UWP平台上构建一个简单的TCP聊天客户端,以便用户能够与其他设备进行实时...
1. **添加字体文件**:将Roboto字体文件放入项目的Resources目录,或者创建一个新的Resources子目录,并将Build Action设置为“Resource”。 2. **定义FontFamily**:与UWP类似,我们也在XAML中定义FontFamily,但...
在XAML中,我们可以绑定控件的属性,如TextBlock的Text属性,到数据模型的相应属性: ```xml <TextBlock Text="{Binding Text}"/> ``` 现在,我们添加一个Button,当点击该按钮时,Text属性的值会发生变化。为此,...
如果是WPF或UWP应用,那么可以利用TextBlock或Label的附加属性来实现类似的效果,比如使用DropShadowEffect。 在源代码中,你可能会看到这些概念和类的实例化和组合,以及可能的自定义逻辑,例如处理不同颜色、透明...
在本篇中,我们将深入探讨如何使用UWP(通用Windows平台)进行Windows 10桌面应用开发,特别是在“编程Windows 10桌面:UWP Focus(N之4)”这一主题下,我们将专注于如何创建一个名为DailyJournal的应用,以此来...
在UWP中实现这样的功能需要利用TextBlock、RichEditBox等控件,以及相关的API和数据绑定技术。 1. **控件选择**:在UWP中,我们通常使用`RichEditBox`来实现富文本编辑功能。这个控件允许用户输入和编辑富文本,并...
这个工具是用来查看运行软件(uwp、win32、win form、wpf)的 UI 元素的 Name、ID、Text 等等。包含在 Windows SDK 中。 安装完 Visual Studio2015后,可以在 C盘下找到:C:\Program Files (x86)\Windows Kits\...
例如,可以使用`Storyboard`定义一个动画,改变`TextBlock`的`Opacity`、`ScaleTransform`或`RotateTransform`属性,实现闪烁、缩放或旋转的效果,达到霓虹灯般的动态感。 2. **循环速度设置**:为了控制霓虹灯效果...
这段代码定义了一个树节点模板,其中`TextBlock`显示`TreeNode`的`Name`属性,`ItemsSource="{Binding Children}"`表示子节点来自于当前节点的`Children`属性。`HierarchicalDataTemplate`使得可以递归地显示子节点...
在XAML中,你可以使用`{Binding}`标记来指定一个属性应该绑定到的数据源。例如,如果你有一个名为`MyProperty`的数据源属性,可以这样写: ```xml <TextBlock Text="{Binding MyProperty}" /> ``` 然而,有时数据...
4. **展示图形**:将转换后的XAML字符串插入到你的WPF或UWP应用的UI元素中,如`TextBlock`或`RichTextBox`,或者动态创建UI元素。 5. **交互和定制**:转换后的XAML图形现在可以像任何其他XAML元素一样进行操作,...
在本文中,我们将深入探讨如何使用C#语言创建一个类库,并将其无缝集成到Silverlight 2.0应用程序中。Silverlight是微软推出的一种轻量级的插件技术,用于在Web浏览器中创建丰富的交互式用户体验,而C#作为.NET框架...
《Windows-universal-samples-master_C#_universal_》是一个针对C#语言开发的Windows通用应用程序(UWP,Universal Windows Platform)的学习资源包。这个压缩包包含了大量的示例代码,是开发者学习如何构建跨平台...