Control.DragEnter Událost
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Generuje se při přetažení objektu do hranic ovládacího prvku.
public:
event System::Windows::Forms::DragEventHandler ^ DragEnter;
public event System.Windows.Forms.DragEventHandler DragEnter;
public event System.Windows.Forms.DragEventHandler? DragEnter;
member this.DragEnter : System.Windows.Forms.DragEventHandler
Public Custom Event DragEnter As DragEventHandler
Event Type
Příklady
Následující příklad kódu ukazuje operaci přetažení mezi dvěma ListBox ovládacími prvky. Příklad volá metodu DoDragDrop při spuštění akce přetažení. Akce přetažení se spustí, pokud se myš během MouseDown události přesunula více než SystemInformation.DragSize z umístění myši. Metoda IndexFromPoint se používá k určení indexu položky, která se má během MouseDown
události přetáhnout.
Příklad také ukazuje použití vlastních kurzorů pro operaci přetažení. Příklad vyžaduje, 3dwarro.cur
aby v adresáři aplikace existovaly dva soubory kurzoru a 3dwno.cur
, pro vlastní kurzory přetahování a bez přetažení. Vlastní kurzory se použijí, pokud je zaškrtnuté UseCustomCursorsCheck
CheckBox . Vlastní kurzory jsou nastaveny v obslužné rutině GiveFeedback události.
Stav klávesnice se vyhodnocuje v DragOver obslužné rutině události pro pravou ListBox
, aby bylo možné určit, jaká operace přetahování bude založená na stavu kláves SHIFT, CTRL, ALT nebo CTRL+ALT. Během události se určí také umístění v místě ListBox
, kde by došlo k poklesu DragOver
. Pokud data, která se mají vypustit, nejsou String
, je DragEventArgs.Effect hodnota nastavená na None
hodnotu v DragDropEffects. Nakonec se stav dropu zobrazí v DropLocationLabel
Label.
Data, která se mají vypustit vpravo ListBox
, se určí v DragDrop obslužné rutině události a String
hodnota se přidá na příslušném místě v ListBox
souboru . Pokud se operace přetažení přesune mimo hranice formuláře, je operace přetažení v obslužné rutině QueryContinueDrag události zrušena.
Tento výňatek kódu ukazuje použití DragEnter události. Kompletní příklad kódu najdete v DoDragDrop metodě.
void ListDragTarget_DragEnter( Object^ /*sender*/, System::Windows::Forms::DragEventArgs^ /*e*/ )
{
// Reset the label text.
DropLocationLabel->Text = "None";
}
private void ListDragTarget_DragEnter(object sender, DragEventArgs e)
{
// Reset the label text.
DropLocationLabel.Text = "None";
}
Private Sub ListDragTarget_DragEnter(ByVal sender As Object, ByVal e As DragEventArgs) Handles ListDragTarget.DragEnter
' Reset the label text.
DropLocationLabel.Text = "None"
End Sub
Poznámky
Událost DragEnter je vyvolána, když uživatel poprvé přetáhne kurzor myši na ovládací prvek během operace přetažení.
Poznámka
Pokud ve verzích starších než .NET Framework 2.0 vložíte UserControl události s DragEnter a DragDrop do formuláře Windows Form a přetáhnete něco do objektu UserControl při návrhu DropDrop
, vyvolá se události a DropEnter
. Když ale řešení zavřete a znovu otevřete, DragEnter události a DragDrop se znovu nevyvolají.
Následující článek popisuje, jak a kdy jsou vyvolány události související s operacemi přetažení.
Metoda DoDragDrop určuje ovládací prvek pod aktuálním umístěním kurzoru. Pak zkontroluje, jestli je ovládací prvek platným cílem vyřazení.
Pokud je ovládací prvek platným cílem přetažení, GiveFeedback událost je vyvolána se zadaným efektem přetažení. Seznam efektů přetažení najdete ve výčtu DragDropEffects .
Sledují se změny v pozici kurzoru myši, stavu klávesnice a stavu tlačítka myši.
Pokud se uživatel přesune mimo okno, vyvolá se DragLeave událost.
Pokud myš přejde na jiný ovládací prvek, DragEnter vyvolá se hodnota pro tento ovládací prvek.
Pokud se myš přesune, ale zůstane ve stejném ovládacím DragOver prvku, událost se vyvolá.
Pokud dojde ke změně stavu klávesnice nebo tlačítka myši, QueryContinueDrag vyvolá se událost a určí, jestli chcete pokračovat v přetažení, odstranit data nebo zrušit operaci na základě hodnoty Action vlastnosti události QueryContinueDragEventArgs.
Pokud hodnota je DragAction
Continue
, DragOver událost se vyvolá, aby pokračovala v operaci, a GiveFeedback událost se vyvolá s novým efektem, aby bylo možné nastavit odpovídající vizuální zpětnou vazbu. Seznam platných efektů přetažení najdete ve výčtu DragDropEffects .Poznámka
Události DragOver a GiveFeedback se spárují, takže když se myš přesune přes cíl přetažení, dostane uživatel nejaktuálnější zpětnou vazbu o pozici myši.
Pokud je
Drop
hodnota DragAction je , vrátí se do zdroje hodnota efektu poklesu, takže zdrojová aplikace může se zdrojovými daty provést příslušnou operaci, například vyjmout data, pokud operace byla přesunem.Pokud je
Cancel
hodnota parametru DragAction , vyvolá se DragLeave událost.Poznámka
Vlastnosti XDragEventArgs a Y jsou v souřadnicích obrazovky, ne v souřadnicích klienta. Následující řádek kódu jazyka Visual C# převede vlastnosti na klienta Point.
Point clientPoint = targetControl.PointToClient(new Point(de.X, de.Y));
Další informace o zpracování událostí najdete v tématu Zpracování a vyvolávání událostí.
Platí pro
Viz také
Váš názor
https://aka.ms/ContentUserFeedback.
Připravujeme: V průběhu roku 2024 budeme postupně vyřazovat problémy z GitHub coby mechanismus zpětné vazby pro obsah a nahrazovat ho novým systémem zpětné vazby. Další informace naleznete v tématu:Odeslat a zobrazit názory pro