InkPicture.CursorInRange Event
InkPicture.CursorInRange Event |
Occurs when a cursor enters the physical detection range (proximity) of the tablet context.
Definition
Visual Basic .NET Public Event CursorInRange As InkCollectorCursorInRangeEventHandler C# public event InkCollectorCursorInRangeEventHandler CursorInRange; Managed C++ public: __event InkCollectorCursorInRangeEventHandler CursorInRange;
Remarks
The event handler receives an argument of type InkCollectorCursorInRangeEventArgs that contains data about this event.
When you create a InkCollectorCursorInRangeEventHandler delegate, you identify the method that will handle the event. To associate the event with your event handler, add an instance of the delegate to the event. The event handler is called whenever the event occurs, unless you remove the delegate. For performance reasons, the default event interest is off but is turned on automatically if you add an event handler.
The CursorInRange event is fired even when in select or erase mode, not just when in ink mode. This requires that you monitor the editing mode (which you are responsible for setting) and be aware of the mode before interpreting the event. The advantage of this requirement is greater freedom to innovate on the platform through greater awareness of platform events.
Examples
[C#]
This C# example demonstrates using several event handlers to display the state of the cursors, cursor buttons, and tablets. This simple application has an InkPicture named theInkPicture and a status bar with three panels (sbPanelCursor, sbPanelButton, and sbPanelTablet), where simple messages appear when events are received.
//... using Microsoft.Ink; //... public class Form1 : System.Windows.Forms.Form { private Microsoft.Ink.InkPicture theInkPicture; private System.Windows.Forms.StatusBar statusBar1; private System.Windows.Forms.StatusBarPanel sbPanelCursor; private System.Windows.Forms.StatusBarPanel sbPanelButton; private System.Windows.Forms.StatusBarPanel sbPanelTablet; //... public Form1() { //... // Add event handlers for cursor and button events. theInkPicture.CursorButtonUp += new InkCollectorCursorButtonUpEventHandler(CursorButtonUp_Event); theInkPicture.CursorButtonDown += new InkCollectorCursorButtonDownEventHandler(CursorButtonDown_Event); theInkPicture.CursorOutOfRange += new InkCollectorCursorOutOfRangeEventHandler(CursorOutOfRange_Event); theInkPicture.CursorInRange += new InkCollectorCursorInRangeEventHandler(CursorInRange_Event); theInkPicture.CursorDown += new InkCollectorCursorDownEventHandler(CursorDown_Event); theInkPicture.TabletAdded += new InkCollectorTabletAddedEventHandler(TabletAdded_Event); theInkPicture.TabletRemoved += new InkCollectorTabletRemovedEventHandler(TabletRemoved_Event); } //... private void CursorButtonUp_Event(object sender, InkCollectorCursorButtonUpEventArgs e) { sbPanelButton.Text = e.Button.Name + " Button Up"; } private void CursorButtonDown_Event(object sender, InkCollectorCursorButtonDownEventArgs e) { sbPanelButton.Text = e.Button.Name + " Button Down"; } private void CursorOutOfRange_Event(object sender, InkCollectorCursorOutOfRangeEventArgs e) { sbPanelCursor.Text = e.Cursor.Name + " Out of Range"; } private void CursorInRange_Event(object sender, InkCollectorCursorInRangeEventArgs e) { sbPanelCursor.Text = e.Cursor.Name + " In Range"; } private void CursorDown_Event(object sender, InkCollectorCursorDownEventArgs e) { sbPanelCursor.Text = e.Cursor.Name + " Down"; } private void TabletAdded_Event(object sender, InkCollectorTabletAddedEventArgs e) { sbPanelTablet.Text = "Tablet added: " + e.Tablet.Name; } private void TabletRemoved_Event(object sender, InkCollectorTabletRemovedEventArgs e) { sbPanelTablet.Text = "Tablet removed: " + e.TabletId; } //...
[Visual Basic .NET]
This Microsoft® Visual Basic® .NET example demonstrates using several event handlers to display the state of the cursors, cursor buttons, and tablets. This simple application has an InkPicture named theInkPicture and a status bar with three panels (sbPanelCursor, sbPanelButton, and sbPanelTablet), where simple messages appear when events are received.
Imports Microsoft.Ink Public Class Form1 Inherits System.Windows.Forms.Form #Region " Windows Form Designer generated code " Public Sub New() MyBase.New() 'This call is required by the Windows Form Designer. InitializeComponent() 'Add any initialization after the InitializeComponent() call AddHandler theInkPicture.CursorButtonUp, AddressOf CursorButtonUp_Event AddHandler theInkPicture.CursorButtonDown, AddressOf CursorButtonDown_Event AddHandler theInkPicture.CursorOutOfRange, AddressOf CursorOutOfRange_Event AddHandler theInkPicture.CursorInRange, AddressOf CursorInRange_Event AddHandler theInkPicture.CursorDown, AddressOf CursorDown_Event AddHandler theInkPicture.TabletAdded, AddressOf TabletAdded_Event AddHandler theInkPicture.TabletRemoved, AddressOf TabletRemoved_Event End Sub '... Friend theInkPicture WithEvents theInkPicture As Microsoft.Ink.InkPicture '... #End Region Private Sub CursorButtonUp_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorCursorButtonUpEventArgs) sbPanelButton.Text = e.Button.Name + " Button Up" End Sub Private Sub CursorButtonDown_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorCursorButtonDownEventArgs) sbPanelButton.Text = e.Button.Name + " Button Down" End Sub Private Sub CursorOutOfRange_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorCursorOutOfRangeEventArgs) sbPanelCursor.Text = e.Cursor.Name + " Out of Range" End Sub Private Sub CursorInRange_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorCursorInRangeEventArgs) sbPanelCursor.Text = e.Cursor.Name + " In Range" End Sub Private Sub CursorDown_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorCursorDownEventArgs) sbPanelCursor.Text = e.Cursor.Name + " Down" End Sub Private Sub TabletAdded_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorTabletAddedEventArgs) sbPanelTablet.Text = "Tablet Added: " + e.Tablet.Name End Sub Private Sub TabletRemoved_Event( _ ByVal sender As Object, _ ByVal e As InkCollectorTabletRemovedEventArgs) sbPanelTablet.Text = "Tablet Removed: " + e.TabletId End Sub End Class
See Also