鸿蒙OpenHarmony【拖拽控制】ArkTS组件通用属性

设置组件是否可以响应拖拽事件。

说明

从API Version 10开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。

ArkUI框架对以下组件实现了默认的拖拽能力,支持对数据的拖出或拖入响应,开发者只需要将这些组件的draggable属性设置为true,即可使用默认拖拽能力。其中,Text、TextInput、TextArea、Hyperlink、Image、RichEditor和Web组件的draggable属性默认为true。

  • 默认支持拖出能力的组件(可从组件上拖出数据):[Search]、[TextInput]、[TextArea]、[RichEditor]、[Text]、[Image]、[Hyperlink]
  • 默认支持拖入能力的组件(目标组件可响应拖入数据):[Search]、[TextInput]、[TextArea]、[Video]、[RichEditor]

开发者也可以通过实现通用拖拽事件来自定义拖拽响应。

其他组件需要开发者将draggable属性设置为true,并在onDragStart等接口中实现数据传输相关内容,才能正确处理拖拽。

说明

Text组件需配合[copyOption]一起使用,设置copyOptions为CopyOptions.InApp或者CopyOptions.LocalDevice。

allowDrop

allowDrop(value: Array | null)

设置该组件上允许落入的数据类型。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value Array<[UniformDataType]> null12+

draggable

draggable(value: boolean)

设置该组件是否允许进行拖拽。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 设置该组件是否允许进行拖拽。默认值:false

dragPreview11+

dragPreview(value: CustomBuilder | DragItemInfo | string)

设置组件拖拽过程中的预览图。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value [CustomBuilder] [DragItemInfo] string12+

dragPreviewOptions11+

dragPreviewOptions(value: DragPreviewOptions, options?: DragInteractionOptions)

设置拖拽过程中背板图处理模式及数量角标的显示。不支持onItemDragStart拖拽方式。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value [DragPreviewOptions]11+ 设置拖拽过程中背板图处理模式及数量角标的
在C#中,若要让DevExpress的`richEditControl1`控件不允许拖入图片,可通过处理`DragDrop`和`DragOver`事件达成。以下是示例代码: ```csharp using DevExpress.XtraRichEdit; using System; using System.Windows.Forms; namespace YourNamespace { public partial class YourForm : Form { public YourForm() { InitializeComponent(); richEditControl1.DragDrop += RichEditControl1_DragDrop; richEditControl1.DragOver += RichEditControl1_DragOver; } private void RichEditControl1_DragOver(object sender, DragEventArgs e) { // 检查拖放的数据是否包含图像格式 if (e.Data.GetDataPresent(DataFormats.Bitmap) || e.Data.GetDataPresent(DataFormats.FileDrop)) { // 如果是图像格式,不允许拖放 e.Effect = DragDropEffects.None; } else { // 其他格式允许拖放 e.Effect = DragDropEffects.Copy; } } private void RichEditControl1_DragDrop(object sender, DragEventArgs e) { // 检查拖放的数据是否包含图像格式 if (e.Data.GetDataPresent(DataFormats.Bitmap) || e.Data.GetDataPresent(DataFormats.FileDrop)) { // 如果是图像格式,不进行任何操作 return; } // 处理其他格式的拖放 // 这里可以添加其他拖放处理逻辑 } } } ``` 在上述代码里,`RichEditControl1_DragOver`事件会在拖放操作进行时被触发,检查拖放的数据是否为图像格式,若为图像格式,就把`e.Effect`设为`DragDropEffects.None`,以此禁止拖放。`RichEditControl1_DragDrop`事件会在拖放操作完成时触发,若拖放的数据是图像格式,就不进行任何操作。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值