Drag and drop

In
As a feature, drag-and-drop support is not found in all software, though it is sometimes a fast and easy-to-learn technique. However, it is not always clear to users that an item can be dragged and dropped, or what command is performed by the drag and drop, which can decrease usability.[1]
Actions
The basic sequence involved in drag and drop is:
- Move the pointerto the object
- Press, and hold down, the button on the mouse or other pointing device, to "grab" the object
- "Drag" the object to the desired location by moving the pointer to this one
- "Drop" the object by releasing the button
Dragging requires more physical effort than moving the same pointing device without holding down any buttons. Because of this, a user cannot move as quickly and precisely while dragging (see
A design problem appears when the same button selects and drags items. Imprecise movement can cause an attempt to select an object to register as a dragging motion.
Another problem is that the target of the dropping can be hidden under other objects. The user would have to stop the dragging, make both the source and the target visible and start again. In classic Mac OS the top-of-screen menu bar served as a universal "drag cancel" target. This issue has been dealt with in
In Mac OS
Drag and drop, called click and drag at the time, was used in the original Macintosh to manipulate files (for example, copying them between disks[3] or folders[4]). System 7 added the ability to open a document in an application by dropping the document icon onto the application's icon.
Apple added "Macintosh Drag and Drop" to
For most of its history Mac OS has used a single button mouse with the button covering a large portion of the top surface of the mouse. This may mitigate the ergonomic concerns of keeping the button pressed while dragging.
In OS/2
The Workplace Shell of OS/2 uses dragging and dropping extensively with the secondary mouse button, leaving the primary one for selection and clicking. Its use like that of other advanced
In HTML
The HTML5 working draft specification includes support for drag and drop.[5] HTML5 supports different kinds of dragging and dropping features including:
- Drag and Drop texts and HTML codes
- Drag and Drop HTML elements
- Drag and Drop files
Based on needed action, one of the above types can be used. Note that when an HTML element is dragged for moving its current position, its ID is sent to the destination parent element; so it sends a text and can be considered as the first group.
Google's web-based e-mail application Gmail supports drag-and-drop of images and attachments in the latest Google Chrome browser and Apple's Safari (5.x). Google Images permits users to drag and drop image files into a browser to perform a reverse image search.
On a touch screen
Touch screen interfaces also include drag and drop, or more precisely, long press, and then drag, e.g. on the iPhone or Android home screens.
iOS 11 implements a drag-and-drop feature which allows the user to touch items (and tap with other fingers to drag more) within an app or between apps on iPads.[6] On iPhones, the functionality is only available within the same app that the user started the drag.[7]
In end-user programming
Drag and drop is considered an important program construction approach in many
Examples
A common example is dragging an icon on a virtual
.Further examples include:
- Dragging a data file onto a program icon or window for viewing or processing. For instance, dropping an icon that represents a text file into a Microsoft Word window signifies "Open this document as a new document in Word"
- Moving or copying files to a new location/directory/folder,
- Adding objects to a list of objects to be processed,
- Rearranging widgets in a graphical user interfaceto customize their layout,
- Dragging an attribute onto an object to which the command is to be applied,
- e.g. dragging a color onto a graphical object to change its color,
- Dragging a tool to a canvas location to apply the tool at that location,
- Creating a hyperlink from one location or word to another location or document.
- Most word processors allow dragging selected text from one point to another.
- Dragging a series of code blocks such as in Blender for designing shaders and materials.
See also
- Mouse gesture
- Point and click
- Snap (computer graphics)
References
- ^ Jakob Nielsen, "Top-10 Application-Design Mistakes," http://www.useit.com/alertbox/application-mistakes.html (19 February 2008).
- ^ Buxton, W. (1986). "Chunking and Phrasing and the Design of Human-Computer Dialogues". Proceedings of the IFIP World Computer Congress. pp. 475–480. Archived from the original on 7 June 2004.
- ^ "Disk Swapper's Elbow". folklore.org.
- ^ "The Grand Unified Model (2): The Finder". folklore.org.
- ^ "HTML5 W3C Working Draft". w3.org.
- ^ "iPad Drag and Drop, Multitasking, and Split View in iOS 11: Everything you need to know!". iMore. Retrieved 10 October 2017.
- ^ Vincent, James (7 June 2017). "The iPhone is also getting drag and drop with iOS 11". The Verge. Retrieved 23 June 2017.
- ^ "Moving Beyond Syntax: Lessons from 20 Years of Blocks Programing in AgentSheets" (PDF). Journal of Visual Languages and Sentient Systems. Archived from the original (PDF) on 28 April 2019. Retrieved 29 November 2018.
- ^ "Render – Blender Reference Manual". blender.org. Archived from the original on 23 March 2015. Retrieved 24 January 2014.