170 likes | 294 Views
Graphical User Interface Concepts: Part 1. Outline Introduction Windows Forms Event-Handling Model - Basic Event Handling. Introduction. Graphical user interface Is an object that allows user to interact with program visually using keyboard or mouse
E N D
Graphical User Interface Concepts: Part 1 OutlineIntroductionWindows FormsEvent-Handling Model - Basic Event Handling
Introduction • Graphical user interface • Is an object that allows user to interact with program visually using keyboard or mouse • Built from window gadgets aka widgets (controls) • Give program distinct look and feel • Consistency enables users to learn new apps faster
Introduction Button Label Menu Bar TextBox Scrollbar Sample Internet Explorer window with GUI components.
Introduction What are these?
Windows Forms • WinForms • Create GUIs for programs • Graphical element on the desktop • Represented by: • Dialog • Window • Multiple document interface (MDI) window • Acts as a container form components and controls
Windows Forms • Control • Visible component with graphical part • Such as button or label • Component • Class that implements IComponent interface (defines behaviors components must implement) • Lacks visual parts • Such as Timer or DirectorySearcher • Event • Generated by movement from mouse or keyboard • Event handlers performs action • Specifics written by programmer
Design Process • For creating Windows Applications • Create a windows form • Set its properties • Add controls • Set their properties • Implement event handlers
Event-Handling Model • GUIs are event driven • User moves or clicks mouse, clicks a button, types in a textbox, selects from a menu or listbox, closes a window • Event handlers • Methods that process events and perform tasks. • Each control that can generate events has an associated delegate • Object that reference methods • Defines the signature for control’s event handler • Event delegates are multicast • Contain lists of method references (every one is called) • Each must have same signature
calls Handler 1 for event E calls Object A raises event E Delegate for event E Handler 2 for event E Handler 3 for event E Event-Handling Model • Intermediary for object and methods Event-handling model using delegates.
Basic Event Handling Events icon List of events supported by control Current even handler (none) Selected event Event description Events section of the Properties window. DEMO!
//SimpleEventExample.cs using System; usingSystem.Windows.Forms; namespace SimpleEventExample2 { //program that shows a simple event handler publicpartialclassMyForm : Form { publicMyForm() { InitializeComponent(); } // Visual Studio .NET creates an empty handler, // we write definition: show message box when form clicked privatevoidMyForm_Click( object sender, System.EventArgs e ) { MessageBox.Show( "Form was pressed" ); } } //end class MyForm } Create an event handler Class EventArgs is base class for objects with event information Reference to the object that raised the event (sender) Signature of the event handler Reference to an event arguments object (e)
Basic Event Handling • Event handler • ControlName_EventName MyForm_Click • Two object references are passed in (sender and e) • Must have same signature as corresponding delegate • Clicking name of event brings up its delegate • Must be registered with delegate object • Add event handlers to the delegate’s invocation list • Visual Studio.NET does this for us • Controls have a delegate reference for each event • New delegate object for each event handler this.Click += new System.EventHandler (this.MyForm_Click);
Basic Event Handling • Event multicasting • Have multiple handlers for one event • Order called for event handlers is indeterminate
List of events Class name List of Form events.
Event name Event delegate Event argument class Details of Click event.