- Investigating Unsupported Controls in the .NET Compact Framework
- Investigating Unsupported System.Windows.Forms Functionality in the .NET Compact Framework
- Working with the Visual Studio .NET Form Designer
- Understanding the Different Windows Forms Target Platforms
- Working with the Form Control
- Programming the Button Control
- Using the TextBox Control
- Using the Label Control
- Working with RadioButton Controls
- Using the CheckBox Control
- Using the ComboBox Control
- Using the ListBox Control
- Using the NumericUpDown Control
- Using the DomainUpDown Control
- Programming the ProgressBar Control
- Using the StatusBar Control
- Using the TrackBar Control
- Using the ToolBar Control
- Adding Menus with the MainMenu Control
- Using a ContextMenu Control in an Application
- Using the Timer Control
- Using the OpenFileDialog and SaveFileDialog Controls
- Using the Panel Control
- Using the HScrollBar and VScrollBar Controls
- Using the ImageList Control
- Using the PictureBox Control
- Using the ListView Control
- Using the TabControl Control
- Using the TreeView Control
- Working with the DataGrid Control
- In Brief
Using the NumericUpDown Control
The NumericUpDown control is a simple way to give the user a way to select a number that falls between a minimum and a maximum value. The control can accept only integers, and decimal values will be truncated as opposed to rounded. On the Pocket PC, the maximum value cannot be greater than that of a 16-bit signed integer.
The NumericUpDown control is controlled by four integer properties: Minimum, Maximum, Value, and Increment. The Minimum and Maximum properties define the minimum and maximum values of the control. The Value property is the current value of the control. The Increment property defines the amount by which the current value is incremented or decremented when the user clicks the up or down arrow buttons. The current value is always incremented or decremented by the Increment value, unless the resulting value would be out of the range defined by the Minimum and Maximum values.
The user can also change the Value property by typing a new value into the control. If the value that the user types is between the Minimum and Maximum values, then both the Value and Text properties will be changed to reflect the newly entered value. If the new value is outside the set range, then the Text property takes the entered value, whereas the Value property becomes equal to the Maximum property. To stop users from typing data into the control altogether, set the ReadOnly property to true.
When a user changes the value of the NumericUpDown control, a ValueChanged event is fired. The ValueChanged event is fired only when the value is changed through code or via the up and down arrows. The event will not be fired when a user types input into the control. Listing 3.2 demonstrates how to use the NumericUpDown control and how to handle the ValueChanged event:
Listing 3.2
C# using System; using System.Drawing; using System.Collections; using System.Windows.Forms; using System.Data; namespace NumericUpDown { public class Form1 : System.Windows.Forms.Form { private System.Windows.Forms.NumericUpDown numericUpDown1; private System.Windows.Forms.Label label1; private System.Windows.Forms.Label label2; private System.Windows.Forms.MainMenu mainMenu1; public Form1() { InitializeComponent(); } protected override void Dispose( bool disposing ) { base.Dispose( disposing ); } #region Windows Form Designer generated code /// <summary> /// Required method for Designer support - do not modify /// the contents of this method with the code editor. /// </summary> private void InitializeComponent() { this.mainMenu1 = new System.Windows.Forms.MainMenu(); this.numericUpDown1 = new System.Windows.Forms.NumericUpDown(); this.label1 = new System.Windows.Forms.Label(); this.label2 = new System.Windows.Forms.Label(); // // numericUpDown1 // this.numericUpDown1.Location = new System.Drawing.Point(8, 56); this.numericUpDown1.Maximum = new System.Decimal(new int[] {2003, 0, 0, 0}); this.numericUpDown1.Minimum = new System.Decimal(new int[] {1900, 0, 0, 0}); this.numericUpDown1.Value = new System.Decimal(new int[] {190012, 0, 0, 131072}); this.numericUpDown1.ValueChanged += new System.EventHandler(this.numericUpDown1_ValueChanged); // // label1 // this.label1.Location = new System.Drawing.Point(8, 24); this.label1.Size = new System.Drawing.Size(184, 16); this.label1.Text = "In what year were you born?"; this. label1.ParentChanged += new System.EventHandler(this.label1_ParentChanged); // // label2 // this.label2.Location = new System.Drawing.Point(8, 120); this.label2.Size = new System.Drawing.Size(224, 24); // // Form1 // this.Controls.Add(this.label2); this.Controls.Add(this.label1); this.Controls.Add(this.numericUpDown1); this.Menu = this.mainMenu1; this.Text = "Form1"; } #endregion static void Main() { Application.Run(new Form1()); } static string msg = "You are ~{0} years young."; private void numericUpDown1_ValueChanged(object sender, System.EventArgs e) { int yearsOld = System.DateTime.Now.Year - (int)this.numericUpDown1.Value; this.label2.Text = String.Format(msg, yearsOld); } } } VB Public Class Form1 Inherits System.Windows.Forms.Form Friend WithEvents label2 As System.Windows.Forms.Label Friend WithEvents label1 As System.Windows.Forms.Label Friend WithEvents numericUpDown1 As System.Windows.Forms.NumericUpDown Friend WithEvents MainMenu1 As System.Windows.Forms.MainMenu #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 End Sub 'Form overrides dispose to clean up the component list. Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean) MyBase.Dispose(disposing) End Sub 'NOTE: The following procedure is required by the Windows Form Designer 'It can be modified using the Windows Form Designer. 'Do not modify it using the code editor. Private Sub InitializeComponent() Me.MainMenu1 = New System.Windows.Forms.MainMenu Me.label2 = New System.Windows.Forms.Label Me.label1 = New System.Windows.Forms.Label Me.numericUpDown1 = New System.Windows.Forms.NumericUpDown ' 'label2 ' Me.label2.Location = New System.Drawing.Point(8, 104) Me.label2.Size = New System.Drawing.Size(224, 24) ' 'label1 ' Me.label1.Location = New System.Drawing.Point(8, 8) Me.label1.Size = New System.Drawing.Size(184, 16) Me.label1.Text = "In what year were you born?" ' 'numericUpDown1 ' Me.numericUpDown1.Location = New System.Drawing.Point(8, 40) Me.numericUpDown1.Maximum = New Decimal(New Integer() {2003, 0, 0, 0}) Me.numericUpDown1.Minimum = New Decimal(New Integer() {1900, 0, 0, 0}) Me.numericUpDown1.Value = New Decimal(New Integer() {190012, 0, 0, 131072}) ' 'Form1 ' Me.Controls.Add(Me.label2) Me.Controls.Add(Me.label1) Me.Controls.Add(Me.numericUpDown1) Me.Menu = Me.MainMenu1 Me.Text = "Form1" End Sub #End Region Private Sub _ numericUpDown1_ValueChanged_ (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles numericUpDown1.ValueChanged Dim yearsOld As Int32 yearsOld = System.DateTime.Now.Year - numericUpDown1.Value label2.Text = String.Format("You are ~{0} years young.", yearsOld.ToString()) End Sub End Class
Figure 3.10 displays the application running on the Pocket PC 2002 emulator.
Figure 3.10 An application that showcases the NumericUpDown control running on the Pocket PC 2002 emulator.