Прочитать на английском

Поделиться через


DragEventArgs Класс

Определение

Предоставляет данные для события DragDrop, DragEnterили DragOver.

[System.Runtime.InteropServices.ComVisible(true)]
public class DragEventArgs : EventArgs
public class DragEventArgs : EventArgs
Наследование
DragEventArgs
Производный
Атрибуты

Примеры

В следующем примере демонстрируется операция перетаскивания между двумя элементами управления ListBox. В примере вызывается метод DoDragDrop при запуске действия перетаскивания. Действие перетаскивания начинается, если мышь перемещает больше SystemInformation.DragSize из расположения мыши во время события MouseDown. Метод IndexFromPoint используется для определения индекса элемента для перетаскивания во время события MouseDown.

В примере также показано использование пользовательских курсоров для операции перетаскивания. В примере предполагается, что два файла курсора, 3dwarro.cur и 3dwno.cur, существуют в каталоге приложения для настраиваемых курсоров перетаскивания и без перетаскивания соответственно. Пользовательские курсоры будут использоваться при проверке UseCustomCursorsCheckCheckBox. Пользовательские курсоры задаются в обработчике событий GiveFeedback.

Состояние клавиатуры вычисляется в обработчике событий DragOver для правой ListBox, чтобы определить, какая операция перетаскивания будет основываться на состоянии клавиш SHIFT, CTRL, ALT или CTRL+ALT. Расположение в ListBox, где будет происходить удаление, также определяется во время события DragOver. Если данные для удаления не являются String, то DragEventArgs.Effect для DragDropEffects.Noneзадано значение DragDropEffects.None. Наконец, состояние удаления отображается в DropLocationLabelLabel.

Данные, которые нужно удалить для правой ListBox, определяются в обработчике событий DragDrop, а значение String добавляется в соответствующее место в ListBox. Если операция перетаскивания перемещается за пределы формы, операция перетаскивания отменяется в обработчике событий QueryContinueDrag.

Этот фрагмент кода демонстрирует использование класса DragEventArgs. См. метод DoDragDrop для полного примера кода.

private void ListDragTarget_DragOver(object sender, DragEventArgs e)
{
    // Determine whether string data exists in the drop data. If not, then
    // the drop effect reflects that the drop cannot occur.
    if (!e.Data.GetDataPresent(typeof(System.String)))
    {
        e.Effect = DragDropEffects.None;
        DropLocationLabel.Text = "None - no string data.";
        return;
    }

    // Set the effect based upon the KeyState.
    if ((e.KeyState & (8 + 32)) == (8 + 32) &&
        (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link)
    {
        // KeyState 8 + 32 = CTRL + ALT

        // Link drag-and-drop effect.
        e.Effect = DragDropEffects.Link;
    }
    else if ((e.KeyState & 32) == 32 &&
        (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link)
    {
        // ALT KeyState for link.
        e.Effect = DragDropEffects.Link;
    }
    else if ((e.KeyState & 4) == 4 &&
        (e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move)
    {
        // SHIFT KeyState for move.
        e.Effect = DragDropEffects.Move;
    }
    else if ((e.KeyState & 8) == 8 &&
        (e.AllowedEffect & DragDropEffects.Copy) == DragDropEffects.Copy)
    {
        // CTRL KeyState for copy.
        e.Effect = DragDropEffects.Copy;
    }
    else if ((e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move)
    {
        // By default, the drop action should be move, if allowed.
        e.Effect = DragDropEffects.Move;
    }
    else
    {
        e.Effect = DragDropEffects.None;
    }

    // Get the index of the item the mouse is below. 

    // The mouse locations are relative to the screen, so they must be 
    // converted to client coordinates.

    indexOfItemUnderMouseToDrop =
        ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(new Point(e.X, e.Y)));

    // Updates the label text.
    if (indexOfItemUnderMouseToDrop != ListBox.NoMatches)
    {
        DropLocationLabel.Text = "Drops before item #" + (indexOfItemUnderMouseToDrop + 1);
    }
    else
    {
        DropLocationLabel.Text = "Drops at the end.";
    }
}

В следующем примере показано, как DragEventArgs передаются между источником и целевым объектом операции перетаскивания. В этом примере элемент управления ListBox является источником данных, а элемент управления RichTextBox является целевым объектом. В примере предполагается, что элемент управления ListBox заполнен списком допустимых имен файлов. Когда пользователь перетаскивает одно из отображаемых имен файлов из элемента управления ListBox в элемент управления RichTextBox, откроется файл, на который ссылается имя файла.

Операция инициируется в событии MouseDown элемента управления ListBox. В обработчике событий DragEnter в примере используется метод GetDataPresent для проверки того, что данные отображаются в формате, который элемент управления RichTextBox может отображать, а затем задает свойство DragDropEffects, чтобы указать, что данные должны быть скопированы из системы управления версиями в целевой элемент управления. Наконец, обработчик событий DragDrop элемента управления RichTextBox использует метод GetData для получения имени файла для открытия.

private void Form1_Load(object sender, EventArgs e) 
{
   // Sets the AllowDrop property so that data can be dragged onto the control.
   richTextBox1.AllowDrop = true;

   // Add code here to populate the ListBox1 with paths to text files.
}

private void listBox1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e)
{
   // Determines which item was selected.
   ListBox lb =( (ListBox)sender);
   Point pt = new Point(e.X,e.Y);
   int index = lb.IndexFromPoint(pt);

   // Starts a drag-and-drop operation with that item.
   if(index>=0) 
   {
      lb.DoDragDrop(lb.Items[index].ToString(), DragDropEffects.Link);
   }
}

private void richTextBox1_DragEnter(object sender, DragEventArgs e) 
{
   // If the data is text, copy the data to the RichTextBox control.
   if(e.Data.GetDataPresent("Text"))
      e.Effect = DragDropEffects.Copy;
}

private void richTextBox1_DragDrop(object sender, DragEventArgs e) 
{
   // Loads the file into the control. 
   richTextBox1.LoadFile((String)e.Data.GetData("Text"), System.Windows.Forms.RichTextBoxStreamType.RichText);
}

Комментарии

Событие DragDrop происходит, когда пользователь завершает операцию перетаскивания, перетаскивая объект по элементу управления, а затем сбрасывая его на элемент управления, освобождая кнопку мыши. Событие DragEnter происходит, когда пользователь перемещает указатель мыши на элемент управления при перетаскивании объекта с помощью мыши. Событие DragOver возникает при перемещении указателя мыши на элемент управления при перетаскивании объекта с помощью мыши.

Объект DragEventArgs указывает любые данные, связанные с этим событием; текущее состояние клавиш SHIFT, CTRL и ALT; расположение указателя мыши; и эффекты перетаскивания, разрешенные источником и целевым объектом события перетаскивания.

Сведения о модели событий см. в обработке и вызове событий.

Конструкторы

DragEventArgs(IDataObject, Int32, Int32, Int32, DragDropEffects, DragDropEffects, DropImageType, String, String)

Инициализирует новый экземпляр класса DragEventArgs.

DragEventArgs(IDataObject, Int32, Int32, Int32, DragDropEffects, DragDropEffects)

Инициализирует новый экземпляр класса DragEventArgs.

Свойства

AllowedEffect

Возвращает, какие операции перетаскивания разрешены источником (или источником) события перетаскивания.

Data

Возвращает IDataObject, содержащую данные, связанные с этим событием.

DropImageType

Возвращает или задает тип изображения описания удаления.

Effect

Возвращает или задает эффект перетаскивания целевого объекта в операции перетаскивания.

KeyState

Возвращает текущее состояние клавиш SHIFT, CTRL и ALT, а также состояние кнопок мыши.

Message

Возвращает или задает текст описания удаления, например "Переместить в %1".

MessageReplacementToken

Возвращает или задает текст описания удаления, например "Документы", если %1 указан в Message.

X

Возвращает координату x указателя мыши в координатах экрана.

Y

Возвращает координату y указателя мыши в координатах экрана.

Методы

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.

(Унаследовано от Object)
GetHashCode()

Служит хэш-функцией по умолчанию.

(Унаследовано от Object)
GetType()

Возвращает Type текущего экземпляра.

(Унаследовано от Object)
MemberwiseClone()

Создает неглубокую копию текущей Object.

(Унаследовано от Object)
ToString()

Возвращает строку, представляющую текущий объект.

(Унаследовано от Object)

Применяется к

Продукт Версии
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

См. также раздел