Hubbry Logo
search
logo

Cursor (user interface)

logo
Community Hub0 Subscribers
Read side by side
from Wikipedia

A blinking text cursor while typing the word Wikipedia

In human–computer interaction, a cursor is an indicator used to show the current position on a computer monitor or other display device that will respond to input, such as a text cursor or a mouse pointer.

Etymology

[edit]

Cursor is Latin for 'runner'. A cursor is a name given to the transparent slide engraved with a hairline used to mark a point on a slide rule. The term was then transferred to computers through analogy.

Cursor on a slide rule

On 14 November 1963, while attending a conference on computer graphics in Reno, Nevada, Douglas Engelbart of Augmentation Research Center (ARC) first expressed his thoughts to pursue his objective of developing both hardware and software computer technology to augment human intelligence by pondering how to adapt the underlying principles of the planimeter to inputting X- and Y-coordinate data, and envisioned something like the cursor of a mouse he initially called a bug, which, in a 3-point form, could have a "drop point and 2 orthogonal wheels".[1] He wrote that the "bug" would be "easier" and "more natural" to use, and unlike a stylus, it would stay still when let go, which meant it would be "much better for coordination with the keyboard."[1]

According to Roger Bates, a young hardware designer at ARC under Bill English, the cursor on the screen was for some unknown reason also referred to as CAT at the time, which led to calling the new pointing device a mouse as well.[2][3]

Text cursor

[edit]
The cursor for the Windows Command Prompt (appearing as an underscore at the end of the line)

In most command-line interfaces or text editors, the text cursor, also known as a caret,[4] is an underscore, a solid rectangle, or a vertical line, which may be flashing or steady, indicating where text will be placed when entered (the insertion point). In text mode displays, it was not possible to show a vertical bar between characters to show where the new text would be inserted, so an underscore or block cursor was used instead. In situations where a block was used, the block was usually created by inverting the pixels of the character using the Boolean math exclusive or function.[5] On text editors and word processors of modern design on bitmapped displays, the vertical bar is typically used instead.

In a typical text editing application, the cursor can be moved by pressing various keys. These include the four cursor keys, the Page Up and Page Down keys, the Home key, the End key, and various key combinations involving a modifier key such as the Control key. The position of the cursor also may be changed by moving the mouse pointer to a different location in the document and clicking.

The blinking of the text cursor is usually temporarily suspended when it is being moved; otherwise, the cursor may change position when it is not visible, making its location difficult to follow.

The concept of a blinking cursor can be attributed to Charles Kiesling Sr. via US Patent 3531796,[6][7] filed in August 1967.[8]

Some interfaces use an underscore or thin vertical bar to indicate that the user is in insert mode, a mode where text will be inserted in the middle of the existing text, and a larger block to indicate that the user is in overtype mode, where inserted text will overwrite existing text. In this way, a block cursor may be seen as a piece of selected text one character wide, since typing will replace the text in the cursor with the new text.

Bi-directional text

[edit]

A vertical line text cursor with a small left-pointing or right-pointing appendage is for indicating the direction of text flow on systems that support bi-directional text, and is thus usually known among programmers as a 'bidi cursor'. In some cases, the cursor may split into two parts, each indicating where left-to-right and right-to-left text would be inserted.[9]

Pointer

[edit]
The common pointer roles for a pointer set
Common pointer types (enlarged)

In computing, a pointer or mouse pointer (as part of a personal computer WIMP style of interaction)[10][11][12] is a symbol or graphical image on the computer monitor or other display device that echoes movements of the pointing device, commonly a mouse, touchpad, or stylus pen. It signals the point where actions of the user take place. It can be used in text-based or graphical user interfaces to select and move other elements. The keyboard cursor may also be repositioned using the pointer.

Though it is distinct from the text cursor, the mouse pointer is also being called a cursor or mouse cursor.[13]

The pointer commonly appears as an angled arrow (angled because historically that improved appearance on low-resolution screens[14]), but it can vary within different programs or operating systems. The use of a pointer is employed when the input method, or pointing device, is a device that can move fluidly across a screen and select or highlight objects on the screen. In GUIs where the input method relies on hard keys, such as the five-way key on many mobile phones, there is no pointer employed, and instead, the GUI relies on a clear focus state.

The pointer echoes movements of the pointing device, commonly a mouse, touchpad or trackball. This kind of pointer is used to manipulate elements of graphical user interfaces such as menus, buttons, scrollbars or any other widget.

Appearance

[edit]
A wait pointer replaces the pointer with an hourglass.

The pointer hotspot is the active pixel of the pointer, used to target a click or drag. The standard arrow pointer has the hotspot at the tip; otherwise, it is frequently in the center, though it may reside at any location in the pointer.[15][16]

In many GUIs, moving the pointer around the screen may reveal other screen hotspots as the pointer changes shape depending on the circumstances. For example:

  • In text that the user can select or edit, the pointer changes to a vertical bar with little cross-bars (or curved serif-like extensions) at the top and bottom — sometimes called an I-beam since it resembles the cross-section of the construction detail of the same name.
  • When displaying a document, the pointer can appear as a hand with all fingers extended allowing scrolling by pushing the displayed page around.
  • Graphics applications often display pointers such as brushes, pencils, or paint buckets, depending on which tool is active.
  • On an edge or corner of a window the pointer usually changes into a double arrow (horizontal, vertical, or diagonal) indicating that the user can drag the edge/corner in an indicated direction to adjust the size of the window. Double arrows are similarly used with movable dividers when a window is split into two or more parts.
  • The corners and edges of the whole screen may also act as screen hotspots. According to Fitts's law, which predicts the time it takes to reach a target area, moving mouse and stylus pointers to those spots is easy and fast. As the pointer usually stops when reaching a screen edge, the size of those spots can be considered of virtual infinite size, so the hot corners and edges can be reached quickly by throwing the pointer toward the edges.[17][18]
  • While a computer process is performing tasks and cannot accept user input, a wait pointer (an hourglass in Windows before Vista and many other systems, a spinning ring in Windows Vista and later, a watch in classic Mac OS, or a spinning pinwheel in macOS) is displayed when the mouse pointer is in the corresponding window.
  • When the pointer hovers over a hyperlink, a mouseover event changes the pointer into a hand with an outstretched index finger. Often some informative text about the link may pop up in a tooltip, which disappears when the user moves the pointer away. The tooltips revealed in the box depend on the implementation of the web browser; many web browsers will display the title of the element (most common nowadays), the alt attribute (historically), or the non-standard tooltips attribute. This pointer shape was first used for hyperlinks in Apple Computer's HyperCard.
  • In Windows 7, when Windows Touch was introduced in the mainstream to make Windows more touch-friendly, a touch pointer is displayed instead of the mouse pointer. The touch pointer can be switched off in Control Panel and resembles a small diamond shape. When the screen is touched a blue ripple appears around the touch pointer to provide visual touch feedback. When swiping to scroll etc., the touch pointer would follow the finger as it moves. If touch and hold to right-click is enabled, touching and holding will show a thick white ring around the touch pointer. When this ring appears, releasing one's finger would perform a right-click.
    • If a pen is used the left-click ripple is colorless instead of blue and the right-click ring is a thinner ring that appears closer to the pen tip making contact with the screen. A click (either left or right) will not show the touch pointer, but swiping would still show the pointer which would follow the pen tip.
    • Also, the touch pointer would only appear on the desktop once a user has signed in to Windows 7. On the sign-in screen, the mouse pointer would simply jump to the point touched and a left click would be sent on a tap, similar to when a touch input is used on operating systems before Windows 7.
  • In Windows 8 and above with a touchscreen, visual touch feedback displays a translucent circle where the finger makes contact with the screen, and a square when attempting to touch and hold to right-click. A swipe is shown by a translucent line of varying thickness. Feedback can be switched on and off in Pen and Touch settings of the Control Panel in Windows 8 and Windows 8.1 or in the Settings app on Windows 10, and feedback can also be made darker and larger where it needs to be emphasized, such as when presenting. However, the touch pointer is normally less commonly visible in touchscreen environments of Windows operating systems later than Windows 7.
  • The mouse-over or hover gesture can also show a tooltip, which presents information about what the pointer is hovering over; the information is a description of what selecting an active element is for or what it will do. The tooltip appears only when stationary over the content. A common use of viewing the information is when browsing the internet to know the destination of a link before selecting it, if the URL of the text is not recognizable.
    • When using touch or a pen with Windows, hovering when supported or performing a set gesture or flick may show the tooltip.

I-beam pointer

[edit]
The I-beam pointer

The I-beam pointer (also called the I-cursor) is a cursor shaped like a serifed capital letter I. The purpose of this cursor is to indicate that the text beneath the cursor can be highlighted and sometimes inserted or changed.[19]

Pointer trails and animation

[edit]
An example of mouse pointer trails

Pointer trails can be used to enhance its visibility during movement. Pointer trails are a feature of GUI operating systems to enhance the visibility of the pointer. Although disabled by default, pointer trails have been an option in every version of Microsoft Windows since Windows 3.1x.

When pointer trails are active and the mouse or stylus is moved, the system waits a moment before removing the pointer image from the old location on the screen. A copy of the pointer persists at every point that the pointer has visited at that moment, resulting in a snake-like trail of pointer icons that follow the actual pointer. When the user stops moving the mouse or removes the stylus from the screen, the trails disappear and the pointer returns to normal.

Pointer trails have been provided as a feature mainly for users with poor vision and for screens where low visibility may become an issue, such as LCD screens in bright sunlight.

In Windows, pointer trails may be enabled in the Control Panel, usually under the Mouse applet.

Introduced with Windows NT, an animated pointer was a small looping animation that was played at the location of the pointer.[20] This is used, for example, to provide a visual cue that the computer is busy with a task.[21] After their introduction, many animated pointers became available for download from third party suppliers. Animated pointers are not without their problems. In addition to imposing a small additional load on the CPU, the animated pointer routines did introduce a security vulnerability. A client-side exploit known as the Windows Animated Cursor Remote Code Execution Vulnerability used a buffer overflow vulnerability to load malicious code via the animated cursor load routine of Windows.[22]

3D cursor

[edit]
An example of the 3D cursor within Blender (center)

The idea of a cursor being used as a marker or insertion point for new data or transformations, such as rotation, can be extended to a 3D modeling environment. Blender, for instance, uses a 3D cursor to determine where operations such as placing meshes are to take place in the 3D viewport.[23]

See also

[edit]

References

[edit]
[edit]
Revisions and contributorsEdit on WikipediaRead on Wikipedia
from Grokipedia
In graphical user interfaces (GUIs), a cursor is an onscreen graphical indicator—typically an arrow, hand, or other symbol—that represents the current position of a pointing device, such as a mouse, trackpad, or stylus, and enables users to select, point to, and interact with elements on the display.[1][2] The cursor's position is dynamically updated based on the device's movement, serving as a primary tool for navigation and input in modern computing environments.[3] Distinct from the text insertion point (often called a caret or I-beam cursor), the primary cursor provides visual feedback on possible actions, such as clicking links or resizing windows.[4] Cursors originated in early GUI systems like the Xerox Alto in the 1970s and became standardized in commercial operating systems, including Apple's Macintosh (1984) and Microsoft's Windows (1985), where they are defined as small bitmapped images, often 16x16 or 32x32 pixels in size.[5] In Windows, for instance, cursors are small pictures controlled by pointing devices to indicate position and support interactions like dragging or hovering.[6] On macOS, cursors are black-and-white or color images stored in resources, with a designated "hot spot" (e.g., the arrow tip) marking the precise interaction point, and they can animate to signal ongoing processes.[5] Web browsers and applications use CSS properties to customize cursors, employing predefined values like pointer for clickable elements or wait for loading states to enhance usability.[4] Key types of cursors include the default arrow for general pointing, the I-beam for text selection, hourglass or spinner for busy operations, and resizing icons (e.g., double arrows) for edge manipulation, all designed to intuitively communicate interface affordances and improve user experience across platforms.[7] Applications can load custom cursors or hide them entirely for specific contexts, such as full-screen games, while operating systems ensure accessibility features like high-contrast modes or keyboard navigation alternatives.[6] In touch-based interfaces like Android, cursor-like pointers emerge in mouse-emulation modes, bridging traditional and modern input methods.[8] Overall, the cursor remains a foundational element of GUI design, balancing simplicity with expressive feedback to facilitate efficient human-computer interaction.[3]

Etymology and History

Etymology

The term "cursor" originates from the Latin cursor, meaning "runner" or "messenger," derived from the verb currere ("to run"), with roots in the Proto-Indo-European kers- ("to run").[9] This etymology reflects the concept of swift movement or indication, initially applied in the late 16th century to mechanical devices such as the sliding runner or indicator on slide rules and scales, used for precise alignment in calculations.[9] In the context of computing and user interfaces, the term was adopted in the mid-1960s, by 1967, to describe the on-screen indicator marking the position for text insertion or pointer location on early display systems.[9] This usage drew from the slide rule analogy, where the cursor "slides" to a specific point, as well as the visual metaphor of it "running" across cathode-ray tube (CRT) terminal screens in systems like those developed during the 1960s. An early documented reference is Douglas Engelbart's work in 1963, when he sketched initial ideas for a mouse-like device to control an on-screen pointer in his notebook, inspired by a computer graphics conference in Reno, Nevada.[10]

Historical Development

The cursor's origins trace back to the transition from batch processing to interactive computing in the 1960s, when text-based cursors first appeared on early cathode-ray tube (CRT) terminals to indicate the position for data entry. The IBM 2260 Display Station, introduced in 1965 as one of the earliest video display terminals, featured a character-based interface with a cursor for keyboard-driven interaction with mainframe systems like the IBM System/360.[11] This marked a shift from punch-card inputs to real-time visual feedback, enabling operators to edit and query data directly on screen.[12] A pivotal innovation was the blinking text cursor, developed in 1967 by Charles A. Kiesling at Sperry Rand to resolve visibility challenges in text displays; the blinking effect drew attention to the insertion point amid static text, and Kiesling patented it in 1970.[13] By the late 1960s, this feature became integral to terminals and early word processing tools, standardizing user awareness of the active position. Graphical cursors emerged prominently in 1968 with Douglas Engelbart's "Mother of All Demos," a public presentation of the oN-Line System (NLS) at Stanford Research Institute, where Engelbart showcased the first computer mouse controlling an on-screen pointer for manipulating text, windows, and hyperlinks—foreshadowing modern GUIs.[14] The 1970s saw further advancements with the Xerox Alto prototype in 1973, developed at Xerox PARC; it introduced a bitmapped display and mouse-driven cursor in a complete GUI environment, supporting overlapping windows and icon selection, though limited to internal research use.[15] Standardization accelerated in the 1980s as GUIs entered commercial products; the Apple Macintosh, launched in January 1984, integrated a mouse pointer with blinking text cursors in applications like MacWrite, democratizing graphical interaction for general users through its intuitive desktop metaphor.[16] Post-2000 developments emphasized customization and web integration, with the CSS cursor property—defined in the W3C's CSS Level 2 specification of 1998—enabling developers to alter pointer appearances (e.g., hand icons for links) across browsers, evolving further with HTML5 for dynamic and custom images. Accessibility enhancements proliferated in the 2010s; Windows 10, released in 2015, added options to resize and recolor the mouse pointer in its Ease of Access settings, improving visibility for low-vision users without third-party tools.[17] macOS Ventura, introduced in 2022, refined pointer controls with features like temporary enlargement during rapid movement and a "shake to locate" gesture, aiding motor-impaired individuals in tracking the cursor.[18] Mobile adaptations addressed touch interfaces; iOS 14 in 2020 enhanced AssistiveTouch to support Bluetooth mice and trackpads with a customizable virtual pointer, simulating precise cursor navigation on touchscreen devices for accessibility.[19] From 2023 to 2025, experimental research integrated AI for predictive cursor assistance, including deep learning models for motor imagery-based control in brain-computer interfaces, enabling real-time trajectory prediction to support users with neuromuscular disabilities.[20] Such systems, like AI-driven neural eye cursors, analyze gaze or intent signals to anticipate movements, reducing input latency in assistive UIs.[21]

Text Cursor

Basic Functionality

The text cursor, also known as the caret or insertion point, is a blinking vertical line or underscore that visually indicates the location within a text field or editor where subsequent keystrokes will insert new characters.[22][23] It serves as a critical user interface element in text input environments, allowing users to precisely control the position of text entry without disrupting the displayed content.[24] The cursor typically appears as a thin line to minimize visual intrusion while remaining noticeable through its periodic flashing, which helps maintain user awareness of the active insertion site.[25] Core behaviors of the text cursor include navigation via keyboard input, such as arrow keys to shift position left, right, up, or down by individual characters or lines, and Home or End keys to jump to the start or end of a line.[26] With mouse interaction, clicking at a specific position in the text causes the cursor to relocate there immediately, facilitating quick jumps across longer documents.[26] In editors like Vim, cursor shape changes between modes are common in supporting terminal emulators: often a vertical bar in insert mode and a block in normal or replace mode, where new characters overwrite existing ones at the cursor's position.[27][28] This distinction, achieved via terminal escape sequences, helps users differentiate modes intuitively. Unlike text selection highlights, which outline a range of characters for copying, cutting, or formatting, the text cursor denotes only the exact point of insertion and does not encompass multiple characters unless in overtype contexts where it aligns closely with replacement behavior.[23][29] The cursor is implemented through operating system-level APIs, such as Windows' CreateCaret function in the Win32 API for rendering the caret using GDI resources, or macOS's Core Text framework and AppKit (e.g., NSTextView) for layout and display of insertion points in user interfaces.[30][31] In contemporary systems, hardware acceleration via GPUs enhances cursor rendering efficiency, particularly in dynamic environments like web browsers or applications with real-time text updates.[32] To optimize energy consumption in mobile devices, modern implementations often feature adaptive blinking for the text cursor, which pauses after short inactivity periods or adjusts based on battery levels—a refinement increasingly common since around 2015 to reduce unnecessary CPU and GPU cycles.[33][34] Accessibility features allow users to adjust the blink rate (e.g., 200-1200 ms in Windows, default 600 ms) or disable blinking entirely to accommodate visual impairments or reduce distractions.[35][36] This approach balances usability with power efficiency and inclusivity without compromising the cursor's primary role in text editing. The text cursor's design traces back briefly to early computer terminals in the 1960s and 1970s, where it first emerged as a simple indicator for character-based input on cathode-ray tube displays.[37]

Bi-directional Text Support

Bi-directional text support in text cursors addresses the complexities arising from mixed left-to-right (LTR) and right-to-left (RTL) scripts, such as English and Arabic, where the cursor must navigate discrepancies between logical input order and visual display order.[38] The Unicode Bidirectional Algorithm (UBA), developed in the 1990s and first formalized in Unicode 2.0 in 1996, introduced these challenges by reordering characters for visual rendering while preserving logical storage, requiring cursors to "jump" between positions in mixed scripts like an English phrase followed by Arabic text. In such cases, the cursor visually appears to skip segments as it moves, reflecting the algorithm's embedding levels that isolate directional runs.[39] A key distinction lies in logical versus visual cursor positioning: users perceive the visual caret on screen, governed by the UBA's resolved levels (e.g., LTR at level 0, RTL at odd levels like 1), but text insertion occurs at the logical offset, ensuring correct sequence in storage.[38] For instance, in a sentence like "Hello مرحبا" (where "مرحبا" is Arabic for "hello"), placing the cursor after "Hello" logically inserts new LTR text there, but visually, it may appear before the Arabic segment due to reordering, complicating navigation with arrow keys that must align visual movement with logical intent.[40] This dual-order handling prevents errors in editing, such as unintended insertions disrupting script boundaries.[41] Implementations have evolved to mitigate these issues, with Windows providing robust support through its text services framework, including Uniscribe for complex scripts since 2000 and enhanced in DirectWrite API (introduced in Windows 7, 2009) for accurate caret positioning in bidi contexts. In web browsers, CSS Writing Modes Level 3, first proposed in a 2011 working draft, reached Candidate Recommendation in 2019 and became a W3C Recommendation in March 2020, with updates through 2022, integrates with the unicode-bidi property to enable proper cursor navigation in mixed-direction inline elements, ensuring the caret respects embedding levels during user input.[42] These APIs map logical indices to visual coordinates, allowing smooth arrow-key traversal across script boundaries without disorienting jumps. Post-2020 enhancements have further refined bidi cursor behavior, particularly in cross-platform frameworks like Flutter, which leverages the Dart intl package's Bidi class—updated in versions aligning with Flutter 2.0 (March 2021)—to implement UBA-compliant cursor placement in TextField widgets, resolving earlier navigation glitches in RTL-heavy interfaces.[43] Additionally, handling emojis in mixed scripts has improved, as emojis are classified as neutral (BN or ON in UBA) and thus inherit surrounding directionality, but multi-codepoint emojis (e.g., skin tone modifiers) can affect cursor granularity; modern systems like those in iOS and Android now ensure precise positioning by treating them as atomic units during bidi resolution.[44] For example, inserting an emoji like 👋 after "Hello" in an LTR-RTL mix visually aligns it with the preceding run, with the cursor advancing logically past its full grapheme cluster to avoid splitting. These advancements enhance usability in globalized applications, reducing cognitive load for multilingual users.

Pointer

Standard Appearances

The standard pointer cursor, often referred to as the arrow cursor, is typically depicted as a simple bitmap image pointing northwest, serving as the default indicator for general navigation and selection in graphical user interfaces. In Microsoft Windows, this arrow design has been a core element since the release of Windows 1.0 in 1985, where it was introduced as part of the initial mouse support to facilitate pointing and clicking interactions. The cursor is commonly rendered at a resolution of 32x32 pixels in modern implementations, though it can vary based on system configurations and historical versions that used smaller sizes like 16x16 pixels.[45][46] Operating systems exhibit variations in the arrow cursor's appearance to align with their design languages. On macOS, the arrow cursor maintains a slanted, northwest-pointing shape with a white outline and black fill by default, as described in official documentation, and received enhanced customization options for outline and fill colors starting with macOS Monterey in 2021. In Linux environments, particularly under the GNOME desktop, cursor themes are highly customizable, drawing from X11 cursor standards that support bitmap-based themes, with evolution to Wayland compositors since around 2012 enabling smoother rendering and theme compatibility across applications.[7][47][48] Cursor size and appearance adapt to display characteristics for usability on diverse hardware. Modern operating systems implement DPI-aware scaling, where the arrow cursor enlarges proportionally on high-resolution displays—for instance, doubling to approximately 64x64 pixels at 200% scaling on post-2010 high-DPI monitors—to maintain visibility without pixelation. Additionally, some systems apply color inversion or contrast adjustments, such as rendering the arrow in white against dark backgrounds, to ensure legibility in varying themes.[49][50] In web-based interfaces, the standard arrow cursor is governed by the CSS cursor property, which includes values like default for the arrow, auto for contextual adaptation, and pointer (a hand icon) for interactive elements such as hyperlinks; this specification was formalized in the W3C's CSS Level 2 recommendation in 1998. Contemporary applications built on frameworks like Electron, released in 2013, extend these standards by supporting vector-based cursors, such as SVG images via the CSS url() function, allowing scalable, high-fidelity arrows that avoid bitmap limitations in cross-platform desktop apps.[4][51]

I-beam Pointer

The I-beam pointer, which indicates the position for text insertion or selection when hovering over editable text fields in graphical user interfaces, features a horizontal double-line design resembling the capital letter "I" or a structural I-beam, often with small serifs at the ends of the lines to enhance visibility and precision. This shape signals to users that clicking will place the insertion point for typing or editing.[52][53] In terms of functionality, the I-beam enables precise text manipulation: a single click positions the caret for insertion, double-clicking selects an entire word, and dragging highlights a range of text for copying, cutting, or deletion. Outside of text areas, the pointer reverts to a standard arrow shape for general navigation, providing contextual feedback on the interaction mode.[7][54] The I-beam pointer originated in early graphical user interfaces, with its introduction in the Xerox Star workstation released in 1981, where it facilitated WYSIWYG text editing as part of the system's pioneering desktop metaphor. It was later standardized in Microsoft Windows 3.0 in 1990, which popularized the GUI for personal computing, and in Apple's macOS, building on influences from Xerox PARC innovations.[55][56] Variations of the I-beam adapt to specific contexts, such as a vertical orientation for languages with vertical writing systems like Chinese, Japanese, and Korean (CJK), where the double-line shape rotates 90 degrees to align with the text flow. Accessibility features in operating systems allow enlargement of the I-beam for users with visual impairments; for instance, Windows introduced customizable pointer sizes through Ease of Access settings starting with Windows Vista in 2007, enabling thicker or larger I-beams to improve visibility. In touch-based environments, iPadOS added support for a magnified I-beam in 2019 with version 13, where the pointer enlarges via Accessibility > Pointer Control options to accommodate precise text selection on smaller screens without a physical mouse.[57][17][58]

Trails and Animations

Pointer trails are a dynamic visual effect in which multiple fading copies of the mouse pointer are displayed behind the current position as it moves across the screen, enhancing visibility particularly on displays with refresh rate limitations or for users with low vision. This feature was introduced in Windows 95 to help track the pointer more easily during rapid movements, originally addressing issues with CRT monitor flickering but later adapted for LCD screens where persistence of vision aids perception.[59][60] It serves accessibility purposes, such as assisting individuals with visual impairments or those experiencing motion-related challenges, by providing a persistent trail that reduces the need for high-speed tracking.[61] Cursor animations indicate system or application states through motion-based indicators, evolving from static symbols to smooth, informative visuals. In macOS, the spinning beach ball (also known as the spinning wheel of death) was introduced in Mac OS X 10.0 Cheetah in 2001 as a wait cursor to signal that an application is unresponsive or processing, originating from NeXTSTEP's design in the late 1980s but adapted for modern use since the early 2000s.[62] In Windows, the hourglass wait cursor, first appearing in Windows 1.0 in 1985, animates to show busy operations, later replaced by a spinning circle in Windows 8 (2012) for a more fluid indication, often combined with progress bars for determinate tasks.[63] Web-based interfaces utilize CSS transitions, standardized in the 2000s, to smoothly animate cursor changes, such as from a default arrow to a wait spinner, though the cursor property itself is not directly animatable and relies on JavaScript for complex effects.[64][65] Accessibility considerations for trails and animations emphasize inclusivity, with guidelines requiring high-contrast visuals for non-text elements like pointers to ensure perceivability. WCAG 2.1, published in 2018, mandates a contrast ratio of at least 3:1 for user interface components, including animated cursors, against adjacent colors to support users with low vision.[66] Reduced motion options mitigate vestibular sensitivities; iOS introduced this in version 7 (2013) with refinements in iOS 8 (2014), allowing users to disable non-essential animations including cursor effects via Settings > Accessibility > Motion.[67] Similarly, Android 11 (2020) enhanced its "Remove animations" setting in Accessibility to respect reduced motion preferences, aligning with the CSS @media prefers-reduced-motion query for web content.[68][69] Modern implementations leverage GPU acceleration to maintain smooth performance without input lag during animations. In Windows, the Desktop Window Manager (DWM) has utilized DirectX for hardware-accelerated rendering of UI elements, including cursors, since Windows Vista (2007), with DirectX 12 (introduced in 2015) enabling more efficient GPU scheduling for complex trails and transitions. In emerging VR/AR environments, such as the Oculus Quest (released 2019), hand-based cursors incorporate tracking animations for natural interaction, using camera-based gestures with subtle motion feedback to guide user input without overwhelming visuals.[70]

3D Cursor

Core Functionality

In 3D modeling software such as Blender, the 3D cursor is a movable point in 3D space that serves as the origin for transformations such as rotation, scaling, and object placement. It defines the position where newly added objects appear and acts as a pivot for the transform gizmo, enabling users to manipulate elements relative to this reference point. This functionality provides a flexible anchor for precise geometric operations, distinct from fixed world origins or object centers. Similar capabilities exist in other software under different names, such as snapping tools in Autodesk Maya or raycasting in Unity.[71] The 3D cursor concept gained prominence in computer-aided design (CAD) software during the 1980s and 1990s. Early CAD tools like AutoCAD, first released in 1982 for 2D drafting, laid the groundwork for accessible modeling on personal computers, with 3D solid modeling features introduced in AutoCAD Release 11 in 1990, including advanced positioning tools in later versions. It was refined in open-source 3D suites like Blender, where the cursor has been integral since the software's inception in 1994 and its transition to open-source licensing in 2002, enhancing accessibility for collaborative development.[72][73] Positioning the 3D cursor occurs primarily through left-mouse-button clicks on viewport surfaces or via direct numerical input in coordinate fields for X, Y, and Z values, allowing sub-unit precision when needed. Snapping mechanisms enable alignment to grids, object origins, or mesh surfaces, typically in configurable increments such as 1 unit, which streamlines tasks like vertex extrusion or component alignment. These controls integrate with viewport navigation, supporting both interactive and programmatic placement.[71] In terms of behaviors, the 3D cursor supports local and global coordinate modes, where transformations can reference the scene's world axes or the cursor's own orientation for context-specific adjustments. Visibility toggles appear in viewport overlay settings, permitting users to hide the cursor during complex scenes without losing its positional data. Axes are conventionally color-coded—red for X, green for Y, and blue for Z—to visually distinguish directional controls, a standard adopted across major 3D platforms.[71][74] Advancements in extended reality (XR) have extended the role of cursor-like tools, as seen in Unity's 2021 LTS updates to the XR Interaction Toolkit, which incorporate cursor-based pointing for VR interactions like raycasting to UI elements or spatial anchors. As of 2025, ongoing developments in XR continue to integrate AI-assisted interactions for more intuitive 3D placement in collaborative VR environments.[75]

Applications in Software

In 3D modeling software like Blender, the 3D cursor serves as a pivotal tool for rigging by acting as a temporary pivot point for object transformations, a feature enhanced in version 2.8 released in 2019 to streamline workflows for animators and character designers.[76] Users can snap the cursor to specific vertices or locations and then set the object's origin to it via Object > Set Origin > Origin to 3D Cursor, enabling precise rotations and scalings during bone placement in armature setups.[77] Autodesk Maya integrates snapping mechanisms akin to a 3D cursor for precise modeling, where users snap components to grids, curves, or other geometry during operations, a capability tied to its construction history system introduced with Maya 1.0 in 1998.[78] This allows real-time updates to model history as snaps modify node connections, ensuring parametric edits propagate efficiently in complex scenes without rebuilding from scratch.[79] In game development environments such as Unity, introduced in the 2010s, the 3D cursor equivalent relies on raycasting from the mouse position to navigate and interact with scenes, enabling developers to place objects or query positions in the viewport for level design and prototyping.[80] Similarly, Adobe Substance 3D Painter, following Adobe's 2020 acquisition of Allegorithmic, uses an enhanced cursor in its viewport for texture mapping, where users paint directly onto models with projection tools updated in version 2020.1 for better UV and tri-planar alignments.[81] Advanced applications extend to virtual reality and collaborative platforms. In Tilt Brush, launched in 2017 by Google, gesture-based pointers are realized through VR controllers that track hand movements to paint and sculpt in immersive space, allowing intuitive stroke placement without traditional mouse input.[82] Cloud-based tools like Onshape, founded in 2012, incorporate collaborative cursors that display multiple users' pointers in real-time during shared sessions, facilitating simultaneous edits on parametric models for engineering teams.[83] In Unreal Engine 5, released in 2022, real-time ray-tracing enhances interactions by providing accurate occlusion and lighting feedback during scene placement, as rays from editor tools simulate photorealistic previews on the fly.[84]

References

User Avatar
No comments yet.