Mercurial > projects > dwt-mac
comparison dwt/dnd/DropTargetEvent.d @ 0:380af2bdd8e5
Upload of whole dwt tree
author | Jacob Carlborg <doob@me.com> <jacob.carlborg@gmail.com> |
---|---|
date | Sat, 09 Aug 2008 17:00:02 +0200 |
parents | |
children | 1a8b3cb347e0 |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:380af2bdd8e5 |
---|---|
1 /******************************************************************************* | |
2 * Copyright (c) 2000, 2007 IBM Corporation and others. | |
3 * All rights reserved. This program and the accompanying materials | |
4 * are made available under the terms of the Eclipse Public License v1.0 | |
5 * which accompanies this distribution, and is available at | |
6 * http://www.eclipse.org/legal/epl-v10.html | |
7 * | |
8 * Contributors: | |
9 * IBM Corporation - initial API and implementation | |
10 *******************************************************************************/ | |
11 module dwt.dnd; | |
12 | |
13 import dwt.events.TypedEvent; | |
14 import dwt.widgets.Widget; | |
15 | |
16 /** | |
17 * The DropTargetEvent contains the event information passed in the methods of the DropTargetListener. | |
18 */ | |
19 public class DropTargetEvent : TypedEvent { | |
20 /** | |
21 * The x-cordinate of the cursor relative to the <code>Display</code> | |
22 */ | |
23 public int x; | |
24 | |
25 /** | |
26 * The y-cordinate of the cursor relative to the <code>Display</code> | |
27 */ | |
28 public int y; | |
29 | |
30 /** | |
31 * The operation being performed. | |
32 * @see DND#DROP_NONE | |
33 * @see DND#DROP_MOVE | |
34 * @see DND#DROP_COPY | |
35 * @see DND#DROP_LINK | |
36 */ | |
37 public int detail; | |
38 | |
39 /** | |
40 * A bitwise OR'ing of the operations that the DragSource can support | |
41 * (e.g. DND.DROP_MOVE | DND.DROP_COPY | DND.DROP_LINK). | |
42 * The detail value must be a member of this list or DND.DROP_NONE. | |
43 * @see DND#DROP_NONE | |
44 * @see DND#DROP_MOVE | |
45 * @see DND#DROP_COPY | |
46 * @see DND#DROP_LINK | |
47 */ | |
48 public int operations; | |
49 | |
50 /** | |
51 * A bitwise OR'ing of the drag under effect feedback to be displayed to the user | |
52 * (e.g. DND.FEEDBACK_SELECT | DND.FEEDBACK_SCROLL | DND.FEEDBACK_EXPAND). | |
53 * <p>A value of DND.FEEDBACK_NONE indicates that no drag under effect will be displayed.</p> | |
54 * <p>Feedback effects will only be applied if they are applicable.</p> | |
55 * <p>The default value is DND.FEEDBACK_SELECT.</p> | |
56 * @see DND#FEEDBACK_NONE | |
57 * @see DND#FEEDBACK_SELECT | |
58 * @see DND#FEEDBACK_INSERT_BEFORE | |
59 * @see DND#FEEDBACK_INSERT_AFTER | |
60 * @see DND#FEEDBACK_SCROLL | |
61 * @see DND#FEEDBACK_EXPAND | |
62 */ | |
63 public int feedback; | |
64 | |
65 /** | |
66 * If the associated control is a table or tree, this field contains the item located | |
67 * at the cursor coordinates. | |
68 */ | |
69 public Widget item; | |
70 | |
71 /** | |
72 * The type of data that will be dropped. | |
73 */ | |
74 public TransferData currentDataType; | |
75 | |
76 /** | |
77 * A list of the types of data that the DragSource is capable of providing. | |
78 * The currentDataType must be a member of this list. | |
79 */ | |
80 public TransferData[] dataTypes; | |
81 | |
82 static final long serialVersionUID = 3256727264573338678L; | |
83 | |
84 /** | |
85 * Constructs a new instance of this class based on the | |
86 * information in the given untyped event. | |
87 * | |
88 * @param e the untyped event containing the information | |
89 */ | |
90 public DropTargetEvent(DNDEvent e) { | |
91 super(e); | |
92 this.data = e.data; | |
93 this.x = e.x; | |
94 this.y = e.y; | |
95 this.detail = e.detail; | |
96 this.currentDataType = e.dataType; | |
97 this.dataTypes = e.dataTypes; | |
98 this.operations = e.operations; | |
99 this.feedback = e.feedback; | |
100 this.item = e.item; | |
101 } | |
102 void updateEvent(DNDEvent e) { | |
103 e.widget = this.widget; | |
104 e.time = this.time; | |
105 e.data = this.data; | |
106 e.x = this.x; | |
107 e.y = this.y; | |
108 e.detail = this.detail; | |
109 e.dataType = this.currentDataType; | |
110 e.dataTypes = this.dataTypes; | |
111 e.operations = this.operations; | |
112 e.feedback = this.feedback; | |
113 e.item = this.item; | |
114 } | |
115 } |