Back to Devexpress

DataViewBase.DropRecord Event

wpf-devexpress-dot-xpf-dot-grid-dot-dataviewbase-0b8c6bef.md

latest8.1 KB
Original Source

DataViewBase.DropRecord Event

Occurs when a record is dropped on the drop target element.

Namespace : DevExpress.Xpf.Grid

Assembly : DevExpress.Xpf.Grid.v25.2.Core.dll

NuGet Package : DevExpress.Wpf.Grid.Core

Declaration

csharp
public event EventHandler<DropRecordEventArgs> DropRecord
vb
Public Event DropRecord As EventHandler(Of DropRecordEventArgs)

Event Data

The DropRecord event's data class is DropRecordEventArgs. The following properties provide information specific to this event:

PropertyDescription
AllowedEffectsGets a member of the DragDropEffects enumeration that specifies which operations are allowed by the originator of the drag event. Inherited from DragEventArgsBase.
DataGets or sets a data object that contains the data associated with the corresponding drag event. Inherited from DragEventArgsBase.
DropPositionGets a drop position that specifies how a record is placed after it has been dropped. Inherited from DragEventArgsBase.
EffectsGets or sets the target drag-and-drop operation. Inherited from DragEventArgsBase.
HandledGets or sets a value that indicates the present state of the event handling for a routed event as it travels the route. Inherited from RoutedEventArgs.
IsFromOutsideGets whether the dragged record is from another control. Inherited from DragEventArgsBase.
KeyStatesGets a flag enumeration indicating the current state of the SHIFT, CTRL, and ALT keys, as well as the state of the mouse buttons. Inherited from DragEventArgsBase.
OriginalSourceGets the original reporting source as determined by pure hit testing, before any possible Source adjustment by a parent class. Inherited from RoutedEventArgs.
RoutedEventGets or sets the RoutedEvent associated with this RoutedEventArgs instance. Inherited from RoutedEventArgs.
SourceGets or sets a reference to the object that raised the event. Inherited from RoutedEventArgs.
TargetRecordGets a record that is drop target. Inherited from DragEventArgsBase.
TargetRowHandleGets the target row handle. Inherited from DragEventArgsBase.

The event data class exposes the following methods:

MethodDescription
GetRecordType()Gets the Type of the transferred records. Inherited from DragEventArgsBase.
InvokeEventHandler(Delegate, Object)When overridden in a derived class, provides a way to invoke event handlers in a type-specific way, which can increase efficiency over the base implementation. Inherited from RoutedEventArgs.
OnSetSource(Object)When overridden in a derived class, provides a notification callback entry point whenever the value of the Source property of an instance changes. Inherited from RoutedEventArgs.

Remarks

You can use the DropRecord event to customize a drag-and-drop operation:

xaml
<dxg:GridControl>
   <!---->
   <dxg:GridControl.View>
      <dxg:TreeListView AllowDragDrop="True" DropRecord="OnDropRecord" />
   </dxg:GridControl.View>
</dxg:GridControl>
csharp
void OnDropRecord(object sender, DropRecordEventArgs e) {
   object data = e.Data.GetData(typeof(RecordDragDropData));
   foreach (Employee employee in ((RecordDragDropData)data).Records) {
      employee.Position = ((Employee)e.TargetRecord).Position;
      employee.Department = ((Employee)e.TargetRecord).Department;
   }
   if (e.DropPosition == DropPosition.Inside) {
      foreach(Employee employee in ((RecordDragDropData)data).Records) {
         employee.Position = "";
      }
   }
}

View Example: How to manually control Drag-and-Drop in the GridControl

The following code snippet (auto-collected from DevExpress Examples) contains a reference to the DropRecord event.

Note

The algorithm used to collect these code examples remains a work in progress. Accordingly, the links and snippets below may produce inaccurate results. If you encounter an issue with code examples below, please use the feedback form on this page to report the issue.

how-to-implement-drag-and-drop-between-the-gridcontrol-and-other-controls-t566741/CS/MainWindow.xaml#L28

xml
DragRecordOver="OnDragRecordOver"
                   DropRecord="OnDropRecord"/>
</dxg:GridControl.View>

See Also

Process Drag-and-Drop Operations

DataViewBase Class

DataViewBase Members

DevExpress.Xpf.Grid Namespace