Figure 1.1: WinForms Projects
Figure 1.2: The WinForms Designer
Figure 1.3: The Property Browser
Figure 1.4: List of Events
Figure 1.5: Nicely Laid-Out Form at Ideal Size
Figure 1.6: Nicely Laid-Out Form Resized
Figure 1.7: Setting the Anchor Property
Figure 1.8: Anchoring Text Boxes Top, Left, Right and Buttons Bottom, Right
Figure 1.9: Setting the Dock Property
Figure 1.10: Docking and Splitting
Figure 1.11: Adding a New Project to an Existing Solution
Figure 1.12: A User Control Shown in the Designer
Figure 1.13: Hosting a User Control
Figure 1.14: Dynamic Properties for MainForm
Figure 1.15: A Dialog Box (See Plate 1)
Figure 1.16: ErrorProvider Providing an Error (See Plate 2)
Figure 1.17: Custom Drawing (See Plate 3)
Figure 1.18: A Database Connection in Server Explorer
Figure 1.19: A DataGrid Bound to a Data Set
Figure 2.1: Owner-Owned Relationship
Figure 2.2: A Child ListBox Control Clipped to the Client Area of Its Parent Form
Figure 2.3: The DesktopLocation, Location, ClientSize, and Size Properties (See Plate 4)
Figure 2.4: Opacity (See Plate 5)
Figure 2.5: Form Shown in Front of Notepad with TransparencyKey Set to BackColor
Figure 2.6: TransparencyKey Combined with FormBorderStyle.None
Figure 2.7: The VS.NET Menu Designer
Figure 2.8: Context Menu Designer
Figure 2.9: Z-Order and Tab Order
Figure 2.10: Unthemed Buttons in Windows XP
Figure 2.11: Themed Buttons in Windows XP
Figure 2.12: WinForms FlatStyles
Figure 2.13: Customize Toolbox Dialog
Figure 2.14: COM Component Added to the Toolbox
Figure 2.15: A Sample Form at Normal Size Fonts
Figure 2.16: Increasing the Form's Font Size at Normal Size Fonts
Figure 2.17: The Sample Form at Large Size Fonts
Figure 2.18: All Controls Anchored Top, Left
Figure 2.19: Setting the Anchor Property in the Property Browser
Figure 2.20: Anchoring Settings before Widening
Figure 2.21: Anchoring Settings after Widening
Figure 2.22: A Docking Example
Figure 2.23: Setting the Dock Property in the Property Browser
Figure 2.24: Two Status Bars Docked to the Bottom Edge
Figure 2.25: TextBox Whose DockStyle.Fill Has Higher Docking Priority than StatusBar
Figure 2.26: An Example of Splitting (with Pointer Indicating a Potential Drag)
Figure 2.27: Horizontal Splitting
Figure 2.28: Grouping, Docking, and Anchoring
Figure 2.29: A TabControl with Two TabPage Controls
Figure 2.30: Custom Layout Example
Figure 2.31: Sample MDI Form
Figure 2.32: An MDI Child Management Menu
Figure 2.33: MDI Parent File Menu with No MDI Children
Figure 2.34: MDI Parent File Menu with an MDI Child
Figure 2.35: The Parent and Child Menus in the Designer
Figure 2.36: Mixing Docking and MDI
Figure 2.37: Base Class Used in Visual Inheritance
Figure 2.38: EditorForm Derived from BaseForm
Figure 2.39: The Inheritance Picker Dialog
Figure 3.1: Typical Main Window Form Settings
Figure 3.2: Typical Modal Form Settings
Figure 3.3: Typical Modal Form Settings
Figure 3.4: A Sample Form Used as a Dialog (See Plate 6)
Figure 3.5: Sample Use of the ErrorProvider Component
Figure 3.6: Using Tooltips
Figure 3.7: Combining the ToolTip Component with the ErrorProvider Component
Figure 3.8: Using HelpProvider to Implement the Help Button
Figure 3.9: Showing the loanAmount Subtopic
Figure 4.1: Ellipse Form before Resizing
Figure 4.2: Ellipse Form after Resizing
Figure 4.3: Sample Brushes (Plate 6)
Figure 4.4: Various TextureBrush WrapMode Values (See Plate 7)
Figure 4.5: Available Hatch Brush Styles Shown with Black Foreground and White Background
Figure 4.6: Normal, Triangle, and Bell Linear Gradient Brushes (See Plate 8)
Figure 4.7: Four Sample Uses of the PathGradientBrush Class (See Plate 9)
Figure 4.8: A PathGradientBrush with One Red Surrounding Point and Two Blue Ones (See Plate 10)
Figure 4.9: Examples from the LineCap Enumeration
Figure 4.10: Examples Using the DashStyle Enumeration
Figure 4.11: A Single Rectangle Drawn with a Pen Using a Compound Array
Figure 4.12: Pen Alignment Options (See Plate 11)
Figure 4.13: Sample PenJoin Values
Figure 4.14: Creating a Pen from a LinearGradientBrush
Figure 4.15: The Basic Shapes (See Plate 12)
Figure 4.16: Curves Drawn with Various Values of Tension
Figure 4.17: Three Bezier Curves Drawn Using the Same Set of Points in Different Orders
Figure 4.18: The Effect of Changing the SmoothingMode from AntiAlias to None
Figure 4.19: A Rounded Rectangle Composed of Arc Figures in a GraphicsPath Object (See Plate 13)
Figure 4.20: Starting a New Figure in a Path Without Closing the Current Figure (See Plate 14)
Figure 4.21: Figures That Overlap Completely Act Subtractively
Figure 4.22: Overlapping Figures and the Alternate FillMode (See Plate 15)
Figure 4.23: Scaling an Image Versus Clipping an Image
Figure 4.24: A Form That Pans an Image in Four Directions
Figure 4.25: An Example of Skewing an Image
Figure 4.26: The Rotating and Flipping Types from the RotateFlipType Enumeration (See Plate 16)
Figure 4.27: An Example of Mapping Color.Lime to Color.White (See Plate 17)
Figure 4.28: Using Color.Transparent in a Color Map (See Plate 18)
Figure 4.29: Sample Animation, First Frame
Figure 4.30: Sample Animation, Middle Frame
Figure 4.31: Sample Animation, Last Frame
Figure 4.32: Example of Drawing to an Image
Figure 4.33: Icon Properties from the SystemIcons Class as Shown under Windows XP
Figure 4.34: System Cursors from the Cursors Class
Figure 5.1: Automatic Word-Wrap Performed by DrawString Compared with Manual Word-Wrap Using Font.GetHeight (See Plate 19)
Figure 5.2: The Parts of a Font Family's Height
Figure 5.3: The Effect of the LineLimit StringFormatFlags Value
Figure 5.4: Examples of the StringTrimming Enumeration
Figure 5.5: StringDigitSubstitute Values as Applied to Thailand Thai
Figure 5.6: Examples of the TextRenderingHint Enumeration
Figure 5.7: Using a GraphicsPath Object to Simulate an Outline-Only Font
Figure 6.1: Manually Drawing in Inches
Figure 6.2: Scaling Font Height Independently of Font Width
Figure 6.3: Line from (0, 0) to (250, 0) Rotated by Degrees 0 “90
Figure 6.4: Line from (25, 25) to (275, 25) Rotated by Degrees 0 “90
Figure 6.5: Line from (25, 25) to (275, 25) Rotated by Degrees 0 “90 at (25, 25)
Figure 6.6: Rectangle(0, 0, 125, 125) Drawn at Two Origins
Figure 6.7: Drawing a Constant-Size Rectangle at Various Shearing Values
Figure 6.8: Path Flattening, Widening, and Warping
Figure 6.9: Rectangle Clipped to an Ellipse Region
Figure 6.10: Region Combination Operations
Figure 7.1: The Printing Dialog shown by the PrintControllerWithStatusDialog
Figure 7.2: The PreviewPrintController in use by the PrintPreviewControl
Figure 7.3: The PrintPreviewControl Hosted in a Custom Form
Figure 7.4: Previewing Multiple Pages at Once in PrintPreviewControl
Figure 7.5: The PrintPreviewDialog Component
Figure 7.6: Printing Multiple Pages
Figure 7.7: PageBounds Versus MarginBounds
Figure 7.8: PageSetupDialog Component with Default Page Settings
Figure 7.9: The PrintDialog Component
Figure 8.1: Custom Type Shown in a ListBox Control
Figure 8.2: Multicolumn ListView
Figure 8.3: A Parent Node and a Child Node in a TreeView Control
Figure 8.4: A DataGrid Showing a Collection of Custom Types
Figure 8.5: Container Controls in Action
Figure 8.6: A TreeView Using an ImageList
Figure 8.7: Owner-Drawn List Box
Figure 8.8: An Owner-Drawn List Box Using Variable Height
Figure 8.9: An Owner-Drawn Status Bar Panel Using ControlPaint
Figure 8.10: Customizing the Toolbox
Figure 8.11: Custom Controls Added to the Toolbox in VS.NET
Figure 8.12: The EllipseLabel Custom Control Hosted on a Form
Figure 8.13: Setting the Font Property on the EllipseLabel Control
Figure 8.14: Setting the Font Property on the Hosting Form
Figure 8.15: A Contained Control Overriding the Value of the Ambient Font Property
Figure 8.16: A Custom Property in the Property Browser
Figure 8.17: A Custom Event Shown in the Property Browser
Figure 8.18: DisplayRectangle Versus ClientRectangle (See Plate 20)
Figure 8.19: FileTextBox with a File That Does Not Exist (See Plate 21)
Figure 8.20: FileTextBox with a File Name That Does Exist (See Plate 22)
Figure 8.21: A Sample User Control in Action
Figure 8.22: A New User Control
Figure 8.23: The FileBrowseTextBox User Control in the Designer
Figure 8.24: Cryptic Drag-and-Drop Error Message
Figure 8.25: A Drag-and-Drop Operation Showing the None Effect
Figure 8.26: Drop Target Indicating the Copy Effect
Figure 8.27: Completed Drag-and-Drop Copy Operation
Figure 8.28: Dragging without Ctrl, Causing a Move
Figure 8.29: Dragging with Ctrl, Causing a Copy
Figure 8.30: After a Drag-and-Drop Move Operation
Figure 9.1: Locations of Components and Controls Hosted on a Form
Figure 9.2: The Timer Component Firing Every 100 Milliseconds
Figure 9.3: A New Component Design Surface
Figure 9.4: A Component Design Surface Hosting a Timer Component
Figure 9.5: Design-Time Architecture
Figure 9.6: Snazzy Clock Control
Figure 9.7: Design-Time Control Debugging
Figure 9.8: Default Toolbox Icon
Figure 9.9: New and Improved Toolbox Icon
Figure 9.10: Visual Studio.NET with a Clock Control Chosen
Figure 9.11: Alarm Property with CategoryAttribute and DescriptionAttribute Applied
Figure 9.12: Resetting a Property to Its Default Value
Figure 9.13: Default Property Highlighted in the Property Browser
Figure 9.14: Invalid Value Entered into the Property Browser
Figure 9.15: Form with Multiple Time Zones
Figure 9.16: One Provider Control for Each Client Control
Figure 9.17: One Provider Control for All Client Controls, Accessed with Code
Figure 9.18: One Provider Control for All Client Controls, Accessed with a Property Set
Figure 9.19: Extended Property in Action
Figure 9.20: The Property Browser and Design-Time Conversion
Figure 9.21: Enumeration Type Displayed in the Property Browser via EnumConverter
Figure 9.22: Complex Properties in the Property Browser
Figure 9.23: HandConverter in Action (See Plate 23)
Figure 9.24: Expanded Property Value
Figure 9.25: HandConverter Derived from ExpandableObjectConverter
Figure 9.26: Relationship between Root and Nested Properties and Design-Time Property Instance
Figure 9.27: Color Property Drop-Down UI Editor
Figure 9.28: Custom View Drop-Down UI Editor
Figure 9.29: The DigitalTimeFormat Property
Figure 9.30: Custom DigitalTimeFormat Modal UI Editor
Figure 9.31: Accessing a Modal UITypeEditor
Figure 9.32: Splitter Dashed Border When BorderStyle Is None
Figure 9.33: Splitter with BorderStyle.Fixed3D
Figure 9.34: Border Displayed from ClockControlDesigner
Figure 9.35: ShowBorder Property Value Serialized to the Host Form's Resource File
Figure 9.36: ShowBorder Option in the Property Browser
Figure 9.37: ShowBorder Option in the Property Browser and the Context Menu
Figure 10.1: Setting a File's Build Action to Embedded Resource
Figure 10.2: ildasm Showing an Embedded Manifest Resource
Figure 10.3: A VS.NET Project's Default Namespace
Figure 10.4: The Azul.jpg Resource File in the foo\bar Project Subfolder
Figure 10.5: How VS.NET Composes the Name of a Resource in a Project Subfolder
Figure 10.6: A Summary of Manifest Resource Naming and Name Resolution
Figure 10.7: Adding a .resx File to a Project
Figure 10.8: A Simple .resx File in the Data View of the Designer
Figure 10.9: An Embedded .resources File
Figure 10.10: Logical View of the Way ResourceManager Uses ResourceReader
Figure 10.11: Resource Naming and ResourceManager
Figure 10.12: A Component's .resx File
Figure 10.13: Localized Currencies and Dates
Figure 10.14: Choosing a Culture in the Property Browser
Figure 10.15: One Form with Localization Information for Several Cultures
Figure 10.16: Localizing a Form Using winres .exe
Figure 10.17: ildasm Showing a Culture-Specific Resource Satellite Assembly
Figure 10.18: The Resource Manager's Resource Resolution Algorithm
Figure 11.1: Default .NET Unhandled-Exception Dialog Box
Figure 11.2: Default WinForms Unhandled-Exception Dialog Box
Figure 11.3: Custom Unhandled-Exception Dialog
Figure 11.4: A Sample Multi- SDI Application
Figure 11.5: Assembly Properties Shown in the Shell
Figure 11.6: Dynamic Properties in the Property Browser
Figure 11.7: Dynamic Properties Dialog
Figure 11.8: Opacity Marked as a Dynamic Property
Figure 11.9: The Registry Editor
Figure 11.10: Using the Registry for User Settings
Figure 11.11: Using the Store Admin Tool to List Stores and Streams
Figure 12.1: .NET Data Architecture
Figure 12.2: Showing Retrieved Data
Figure 12.3: A Sample Relation between the Customers Table and the Orders Table
Figure 12.4: Showing the Results of GetChildRows Using a Relation
Figure 12.5: Data Toolbox
Figure 12.6: Data Link Properties Dialog
Figure 12.7: Command Properties
Figure 12.8: Query Builder
Figure 12.9: An Empty Typed Data Set
Figure 12.10: Server Explorer
Figure 12.11: Typed Data Set with New Tables
Figure 12.12: XML Schema Toolbox
Figure 12.13: Edit Key Dialog
Figure 12.14: Edit Relation Dialog
Figure 12.15: Typed Data Set with a New Relation
Figure 12.16: Adding a New Column to Be Used as an Expression Column
Figure 12.17: Adding a Typed Data Set to a Form
Figure 13.1: Complex Data Binding
Figure 13.2: Result of Complex Data Binding
Figure 13.3: Simple Data Binding
Figure 13.4: Simple Data Binding
Figure 13.5: Simple Data Binding to an Item Data Source
Figure 13.6: Simple Binding to a String Object
Figure 13.7: Simple Binding to the Length Property of a String Object
Figure 13.8: Binding the Text and Font Properties of a TextBox Control
Figure 13.9: Simple Data Binding to a List Data Source
Figure 13.10: Simple Data Binding to a Property of a List Data Source
Figure 13.11: Simple Binding to a Data Set
Figure 13.12: Adding a Data Binding in the Property Browser
Figure 13.13: A Currency Manager Maintaining a Position into a List Data Source
Figure 13.14: A Property Manager Managers Only a Single Item
Figure 13.15: Managing Currency
Figure 13.16: Two Controls Bound to the Same Data Source
Figure 13.17: Two Controls Bound to the Same Data Source Sharing the Same Currency Manager
Figure 13.18: Losing Focus Does Not Trigger an End to the Edit
Figure 13.19: Don't Use the dataset.table + Column Technique to Specify the Data Source
Figure 13.20: Use the Dataset + table.column Technique to Specify a Data Source
Figure 13.21: Using Data Binding to Populate a List Control
Figure 13.22: Binding to a Sort View
Figure 13.23: Binding to a Filtered View
Figure 13.24: Master-Detail Relations
Figure 13.25: Composing a Data Member from a Relation in the Property Browser
Figure 13.26: Binding to a DataGrid
Figure 13.27: Showing 3-D Data in a Data Grid
Figure 13.28: Showing Relations
Figure 13.29: Drilling Through Relations
Figure 13.30: DataGridTableStyle Collection Editor
Figure 13.31: DataGridColumnStyle Collection Editor with Added Columns
Figure 13.32: A Stylish Data Grid
Figure 13.33: The Data Grid Auto Format Dialog (See Plate 24)
Figure 13.34: An Example of What WinForms Provides for Data Programmers (See Plate 25)
Figure 13.35: Binding to a Custom Item Data Source
Figure 13.36: Binding to a Custom Item Data Source without a Conversion to String
Figure 13.37: Binding to a Custom Item Data Source with a Conversion to String
Figure 13.38: Binding to a Custom List Data Source without a String Conversion
Figure 13.39: Binding to a Custom List Data Source with a String Conversion
Figure 13.40: Binding Properties as Data Members
Figure 13.41: Showing the Top Level of an Object Hierarchy in a Data Grid
Figure 13.42: Showing the Second Level of an Object Hierarchy in a Data Grid
Figure 14.1: Digits of Pi Application
Figure 14.2: Calculating Pi to 1,000 Digits
Figure 14.3: No Paint for You!
Figure 14.4: Na ve Multithreading
Figure 14.5: Safe Multithreading
Figure 14.6: Letting the User Cancel a Long-Running Operation
Figure 14.7: The Result of a Canceled Call to the Pi Web Service
Figure 15.1: A WinForms Control Hosted in IE
Figure 15.2: The Sample Control Shown in the Designer
Figure 15.3: Default Internet Permission Set
Figure 15.4: The Game of Wahoo!
Figure 15.5: Debugging an NTD Application Using ieexec.exe
Figure 15.6: Adjusting .NET Security
Figure 15.7: Using the Internet Control Panel to Add Trusted Sites
Figure 15.8: Trusting All Assemblies Having the Same Public Key
Figure 15.9: How Much an Assembly Is Trusted
Figure 15.10: Setup Project Custom Actions
Figure 15.11: Choosing a Folder for a Custom Action
Figure 15.12: Choosing the Primary Output of Your Class Library Project to Act as a Custom Action
Figure 15.13: NET 1.1 NTD Security Settings
Figure A.1: A Sample Document-Based Genghis Application
Figure D.1: Components Versus Controls
Figure D.2: A Sample Usage of the ColorDialog Component
Figure D.3: A Sample Usage of the FontDialog Component
Figure D.4: A Sample Usage of the OpenFileDialog Component
Figure D.5: A Sample Usage of the SaveFileDialog Component
Figure D.6: A Sample Usage of the FolderBrowserDialog Component
Figure D.7: A Sample Usage of the NotifyIcon Component (See Plate 26)
Figure D.8: Image Collection Editor
Figure D.9: A Sample Usage of the ContextMenu Component
Figure D.10: A Sample Usage of the ErrorProvider Component
Figure D.11: A Sample Usage of the HelpProvider Component
Figure D.12: A Sample Usage of the ToolTip Component
Figure D.13: A Label Control in Action
Figure D.14: A LinkLabel Control in Action
Figure D.15: A TextBox Control in Action
Figure D.16: A Button Control in Action
Figure D.17: A CheckBox Control in Action
Figure D.18: A RadioButton Control in Action
Figure D.19: A PictureBox Control in Action
Figure D.20: A ListBox Control in Action
Figure D.21: A CheckedListBox Control in Action
Figure D.22: A ComboBox Control in Action
Figure D.23: A ListView Control in Action
Figure D.24: A TreeView Control in Action
Figure D.25: A DataGrid Control in Action
Figure D.26: A MonthCalendar Control in Action
Figure D.27: A DateTimePicker Control in Action
Figure D.28: A DateTimePicker with ShowUpDown Enabled
Figure D.29: An HScrollBar Control in Action
Figure D.30: A VScrollBar Control in Action
Figure D.31: A DomainUpDown Control in Action
Figure D.32: A NumericUpDown Control in Action
Figure D.33: A TrackBar Control in Action
Figure D.34: A ProgressBar Control in Action
Figure D.35: A RichTextBox Control in Action
Figure D.36: A PrintPreviewControl Control in Action
Figure D.37: A Splitter Control in Action
Figure D.38: A ToolBar Control in Action
Figure D.39: A StatusBar Control in Action
Figure D.40: A Panel Control in Action
Figure D.41: A GroupBox Control in Action
Figure D.42: A TabControl Control in Action