一、 Input事件列表
看了Input事件列表、本以为用OnDrag和OnDrop两个事件就能完成 data:image/s3,"s3://crabby-images/80153/801535254d2e6fbd0971bc8333a7fca719c267ee" alt="在这里插入图片描述"
二、准备UMG蓝图
- 创建目标蓝图ItemSlot,待拖动的Item,里面只有一张图片
data:image/s3,"s3://crabby-images/9d06a/9d06aa4bfab2604ac7053117fa985d2c80e0c4f4" alt="在这里插入图片描述" - 创建移动中显示的蓝图ItemSlotDraging,相较于ItemSlot多了个Text标识用于区别显示
data:image/s3,"s3://crabby-images/611ec/611ec91a397963b149149bcadb0f1318cb8329f1" alt="在这里插入图片描述" 3. 创建目标Item蓝图载体,或者称为背景蓝图
data:image/s3,"s3://crabby-images/2fe92/2fe92371173967986f4b6c142c639b83bb217cf2" alt="在这里插入图片描述"
三、编写代码逻辑
过程中共使用了三个输入事件OnMouseButtonDown、OnDragDetected、OnDrop
- 打开关卡蓝图,将UI蓝图渲染到屏幕上,允许输入事件,将鼠标显示出来
data:image/s3,"s3://crabby-images/57cda/57cda789f4ed4b5fc11b17a159a7af44b11b1e48" alt="在这里插入图片描述" - 使用OnMouseButtonDown设置为左键按下拖拽触发的方式,根据OnMouseButtonDown的解释可以看出,这个方法应该写在目标拖拽蓝图中,即复写ItemSlot中的OnMouseButtonDown,注意ReturnNode需要传入一个参数
data:image/s3,"s3://crabby-images/03b3a/03b3ad6ee8898f36e07a23499ceb7da53c18f7bc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/96094/960948b265651c38570eae853646497016860660" alt="在这里插入图片描述" - 使用OnDragDetected编写拖动的逻辑,根据OnDragDetected的解释:当一个控件即将被拖动时调用,得知应该复写ItemSlot中的OnDragDetected方法
data:image/s3,"s3://crabby-images/28afa/28afafe7a0434b119d707aacb5db2f8b006e3f28" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0f181/0f1810c3449a900399478c7aff1a7240aa9d54c1" alt="在这里插入图片描述"
注:
- 拖动时创建控件ItemSlotDraging,传入ClassItemSlotDraging
- 将拖动生成的控件赋值给DragVisual,即拖拽时的显示
- CreateDragDropOperation中的Class选择DragDropOperation类或自己新建的DragDropOperation类型的蓝图
- CreateDragDropOperation中的Pivot与Offset决定了鼠标指针与移动控件的相对位置
- 这里将self传递过去相当与一个参数传递
- 通过OnDrop函数移动位置,根据OnDrop函数的解释:当玩家将一个东西丢弃到Widget上时出发,可知改Widget应该是背景蓝图,相当与该示例中的UI蓝图,所以应该复写UI中的OnDrop方法
data:image/s3,"s3://crabby-images/fa051/fa0516102054397405a316026dd03ec07e527476" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/73ae8/73ae8de1ac745a44a3890bd52dc7a37b34c3af41" alt="在这里插入图片描述"
注:
四、结果
data:image/s3,"s3://crabby-images/490ad/490ad4125f0466d849e8d8c6f0aa3fa3a469887c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/be994/be994ebe861c8d57457323dd2e28299026e003cb" alt="在这里插入图片描述"
五、注意
- UI蓝图中的蓝底Image不仅仅是突出物品Item的显示,在本例中还控制了OnDrop的响应区域,因为UI中没有多余的控件了
- 因为UI蓝图中ItemSlot的Alignment是item的中间,所以OnDragDetected中的CreateDragDropOperation节点中的Pivot选择CenterCenter想呼应,会使刚拖拽或刚丢弃时的操作更顺滑,否则如果不对应会有明显的偏移。(Pivot还可以选择MouseDown,表示鼠标按下时的相对位置)
|