Full file at
Chapter 2
Creating a User Interface
At a Glance
Instructor’s Manual Table of Contents
- Chapter Overview
- Chapter Objectives
- Teaching Tips
- Quick Quizzes
- Class Discussion Topics
- Additional Projects
- Additional Resources
- Key Terms
Lecture Notes
Chapter Overview
Chapter 2 provides an introduction to the creation of a graphical user interface using Visual Basic. Students learn how to create TOE charts and design forms and use textboxes and buttons. Students also learn about dialog boxes, access keys, tab order, container controls, and splash screens. Good design principles and Windows standards are emphasized.
Chapter Objectives
After studying this chapter, the student should be able to:
•Plan an application using a TOE chart
•Use a text box and table layout panel
•Follow the Windows standards regarding the layout and labeling of controls
•Follow the Windows standards regarding the use of graphics, fonts, and color
•Assign access keys to controls
•Set the tab order
•Add a splash screen to a project
•Use the Font and Color dialog boxes
•Designate a default button
•Print the interface during run time
•Play an audio file
Teaching Tips
Planning an Application
- Describe the process of planning an application.
- Stress the importance of working with the user at the planning stage.
Teaching
Tip / The most common cause of failure of a new application is that the programmers did not understand what the users really needed. The importance of including the users in the planning stage of development cannot be overemphasized.- Introduce the concept of a TOE chart.
- Point out that tasks, objects, and events should be identified in the early stages of planning.
Sunshine Cellular Company
- Introduce the sample application to be developed.
Identifying the Application’s Tasks
- Discuss the procedures currently in use for this application. Use Figure 2-2 as a guide.
- Review the design questions that should be asked to identify the required input, output, and processing.
- Using Figure 2-3, illustrate how the application’s tasks are incorporated into a TOE chart.
Identifying the Objects
- Describe the next step of assigning each task to an object.
- Introduce the textbox and describe how it is normally used.
- Point out that buttons will be used to trigger actions.
- Point out that labels are necessary to identify what the user sees on the form.
Teaching
Tip / Stress the importance of meaningful labels that will instruct the user what to enter in each textbox.- Discuss how each of the controls on the form relates to the tasks that must be completed by the application.
- Show how this object information is incorporated into a TOE chart, using Figure 2-4.
Identifying the Events
- Point out that textboxes do not require any special events when the user enters data.
Teaching
Tip / Verify that the students understand that a textbox has many events, but none are required for this program. Also, you may wish to point out that while none are required, there are some events that are sometimes used to perform actions that enhance the usability of textboxes, such as highlighting, changing font colors to indicate errors, etc.- Point out that since labels are only used as displays to guide the user, the user does not interact with them in any way.
- Discuss the click event as the main event of interest for button controls.
- Show how event information is incorporated into the TOE chart, using Figures 2-5 and 2-6.
Designing the User Interface
- Discuss the importance of following Windows standards.
Teaching
Tip / It is well accepted from usability studies that users will perceive an application to be easier to use simply because Windows standards in menus, screen layouts, etc. have been used.Arranging the Controls on a Form
- Describe the guidelines for arranging controls on a form.
Teaching
Tip / The human brain prefers order to disorder. The simple act of making controls the same width and aligning them vertically and horizontally produces a more pleasing appearance as well as better user acceptance.- Introduce the concept of container controls, including the group box control, panel control, and table layout panel control.
- Compare and contrast the vertical arrangement of controls shown in Figure 2-7 and the horizontal arrangement shown in Figure 2-8.
- Point out the effects of using the container controls to provide a better visual experience.
Teaching
Tip / In addition to simply making the screen appear more organized, the groupings also suggest that the items within each group are related to each other. This provides some logical information to the user though a simple visual effect.- Discuss the additional guidelines about label and button captions.
- Introduce sentence capitalization and book title capitalization.
- Discuss the guidelines on margins and on sizing and aligning controls.
Teaching
Tip / Students often resist taking the time to incorporate all of these guidelines in their programs. Remind them that commercial software is welldesigned and has a polished professional look.Including Graphics in the User Interface
- Point out that graphics tend to draw the user’s attention away from the work area of the form.
- Discuss why graphics should be used sparingly.
Including Different Fonts in the User Interface
- Introduce the Font property and describe its use.
- Introduce the concept of a font and a point as a measurement of font size.
- Explain the difference between serif and sans serif fonts.
Teaching
Tip / You can demonstrate the difference between serif and sans serif fonts by opening a Word document and comparing Times New Roman and Arial fonts.- Discuss the guidelines for using fonts on a form and the recommendation to use Segoe UI for Windows Vista and Windows 7.
Teaching
Tip / Point out that because a control inherits the form setting used on the form, you should configure the desired font on the form before adding controls.Including Color in the User Interface
- Like graphics, bright colors tend to draw the user’s attention away from the work area of the form.
- Discuss the guidelines for using color in applications.
Teaching
Tip / A brief discussion of accessibility features in Windows for visually impaired users can help students understand the importance of these guidelines.Borders and Sizing of Controls
- Introduce the BorderStyle property for setting the style of a control's border.
- Describe the appropriate settings for BorderStyle for identifying labels and for output labels.
Quick Quiz 1
- What control is used to provide prompts to the user about what data should be entered into a form?
Answer: label control
- What control is used to allow users to type text into a form?
Answer: textbox control
- What three elements appear in a TOE chart?
Answer: tasks, objects, and events
Assigning Access Keys
- Introduce the concept of an access key, using Figure 2-9.
Teaching
Tip / Opening the File menu on any Windows application allows you to show the use of access keys in menus with which the students are already familiar.- Discuss the guidelines for using access keys.
Teaching
Tip / Remind students of the importance of using Windows standards for the choice of which key to designate as the access key for a particular action.- Describe the advantages of using access keys.
Teaching
Tip / While it is common practice to use access keys on buttons, it is not as common to assign access keys to every label on a form. Use of the Tab key to navigate from one text box to the next is usually sufficient if the form will be completed in sequential fashion.- Describe the use of the ampersand character to indicate which character in the caption of a button or label will be the access key.
Controlling the Tab Order
- Introduce the TabIndex property, and describe how it affects cursor movement.
- Introduce the concept of focus.
- Discuss the desired order for focus in controls on the application, using Figure 2-10.
- Describe how to seta value for TabIndex in the sample application, using Figures 2-11 and 2-12.
Teaching
Tip / Point out that setting TabIndex is important for the usability of the application because it allows the form to be efficiently used without having to employ the mouse.Quick Quiz 2
- What character is used to designate an access key?
Answer: ampersand (&)
- Which property controls the cursor movement on a form when the user presses the Tab key?
Answer: TabIndex
- When a control is ready to accept input from a user, we say that the control has the ____.
Answer: focus
Splash Screens
- Discuss the purpose of including a splash screen in a project, using Figure 2-13.
- Describe the process of creating a splash screen, using Figures 2-14through 2-16.
Teaching
Tip / The purpose of a splash screen is to entertain the user while initialization of the application is occurring. Point out that if the application must open files or databases or do any additional processing before displaying the first screen, it is best to display a splash screen until all processing is complete rather than to display the first screen before it is usable.- Describe how to specify the splash screen, using Figures 2-17 and 2-18.
- Describe the use of the Assembly Information to provide data for the Splash Screen at run time, using Figures 2-19 and 2-20.
Dialog Boxes
- Introduce the concept of the primary window, using Figure 2-21.
- Introduce the concept of the dialog box and compare it to the primary window, using Figure 2-21.
- Compare and contrast the primary window’s capabilities to that of the dialog box.
Teaching
Tip / You might briefly demonstrate the Open File dialog as an example of a dialog box supporting an application.- Describe the use of the Dialog template in the Add New Item dialog box for creating a dialog box.
- Introduce the MinimizeBox and MaximizeBox form properties and describe their effects.
Teaching
Tip / Ask the students if they can think of a situation in which a form should not have a Close button or Control menu box. An answer might be any dialog box that must be completed by the user and that will initiate specific required actions when the form’s own buttons are used.- Explain that Visual Basic provides tools for commonlyused dialog boxes such as Color, Font, and Save As.
- Explain the purpose of the component tray in the IDE, using Figure 2-22.
- Introduce the concept of a modal form.
- Use Figures 2-23 and 2-24 to describe the code used to show the Font dialog box and to retrieve the user’s selections.
- Use Figures 2-25 and 2-26 to describe the code used to show the Color dialog box and to retrieve the user’s selections.
- Introduce the concept of the default button and the cancel button on a form.
Designating Default Button on a Form
- Introduce the AcceptButton property, and point out that this is a form property, not a button property.
- Describe the visual cue provided when a default button has been designated, using Figure 2-27.
Teaching
Tip / Point out that a button that causes a destructive and irreversible action should not be designated as the default button.Printing an Interface during Run Time
- Introduce the PrintForm tool in the Visual Basic PowerPacks section of the toolbox.
- Describe the purpose of the Print Preview and Print buttons, using Figure 2-28.
- Discuss the code used with the Print Preview and Print buttons, shown in Figure 2-29.
Playing Audio Files
- Introduce the My feature in Visual Basic and describe its purpose.
- Describe the use of the Computer object and the Audio object.
- Introduce the concept of arguments and describe how to specify them.
- Discuss the steps involved in playing an audio file at run time, using Figure 2-30.
Programming Tutorial 1
- Describe the Color Game Application that is developed in the tutorial, using Figure 2-40.
- Encourage students to create the program in this tutorial by following all of the steps.
Teaching
Tip / Remind students that programming is learned through practice. The more hands-on experience they get, the easier it will be to write programs. The tutorial will guide them through every step.Programming Tutorial 2
- Describe the Music Sampler Application that is developed in the tutorial, using Figure 2-47.
- Encourage students to create the program in this tutorial by following all of the steps.
Programming Example
- Describe the Moonbucks Coffee programming example application to be developed, using Figure 2-57.
- Encourage students to create the program described in the example.
Teaching
Tip / Point out that this is an opportunity for the students to employ the concepts they have learned and practiced.Quick Quiz 3
- A special form showing information about the application that is shown first when the application starts is called a(n) ____.
Answer: splash screen
- Which keyword in Visual Basic allows you to access the Computer object?
Answer: My
- True/False: A splash screen allows the user to interact with it.
Answer: False
Class Discussion Topics
- Discuss the benefits of following Windows standards for menus, positioning of buttons, colors, etc. Answers might include user familiarity and comfort, efficiency, and ease of use.
- How important are these standards for users with disabilities? Ask students to attempt to use an application without using a mouse. How difficult is it to even launch a program without a mouse?
Additional Projects
- Do some research on accessibility issues and the options that are available in Windows to support users with disabilities. Then write a short report describing some of the ways that a program can be written to assist users with specific disabilities such as visual disabilities or motor disabilities.
- Do some research on the history of the graphical user interface (GUI) and write a short report listing the key developments.
Additional Resources
- Principles of good GUI design according to design expert Alan Cooper:
- Tutorials on accessibility features in Windows:
- History of the Graphical User Interface:
- How to create the best user experience for your application:
- Using a Groupbox control:
Key Terms
Access key—the underlined character in an object’s identifying label or caption; allows the user to select the object using the Alt key in combination with the character
Arguments—the items within parentheses after a method’s name; represent information that the method needs to perform its task
Book title capitalization—the capitalization used for the text ona button’s face; refers to capitalizing the first letter in each word, except for articles, conjunctions, and prepositions that do not occur at either the beginning or the end of the text
Cancel button—abutton that can be selected by pressing the Esc key
Default button—abutton that can be selected by pressing the Enter key even when it does not have the focus
Dialog boxes—windows that support and supplement a user’s activities in a primary window
Focus—indicates that a control is ready to accept user input
Modal—refers to the fact that the dialog box remains on the screen until the user closes it; while it is on the screen, no input from the keyboard or mouse can occur in the application’s primary window; however, you can access other applications
Panel control—used to group together related controls
My feature—the Visual Basic feature that exposes a set of commonly-used objects (such as the Computer object) to the programmer
Primary window—the window in which the primary viewing and editing of your application’s data takes place
Sentence capitalization—The capitalization used for identifying labels; refers to capitalizing only the first letter in the first word and in any words that are customarily capitalized
Text box—a control that provides an area for the user to enter data