Copyright © 2006 Thomas P. Skinner

Slides:



Advertisements
Similar presentations
 2007 Dr. Natheer Khasawneh. Chapter 13. Graphical User Interface Concepts: Part 1.
Advertisements

Chapter 1: An Introduction to Visual Basic 2012
© by Pearson Education, Inc. All Rights Reserved. continued …
Chapter 5 Menus, Common Dialog Boxes, Sub Procedures, and Function Procedures Copyright © 2011 by The McGraw-Hill Companies, Inc. All Rights Reserved.
Chapter 6 Multiform Projects Copyright © 2011 by The McGraw-Hill Companies, Inc. All Rights Reserved. McGraw-Hill.
Graphical User Interface (GUI) A GUI allows user to interact with a program visually. GUIs are built from GUI components. A GUI component is an object.
Copyright © 2012 Pearson Education, Inc. Chapter 2 Introduction to Visual C#
Chapter 13: Advanced GUI and Graphics
1 Introduction to the Visual Studio.NET IDE Powerpoint slides modified from Deitel & Deitel.
1 Windows Printing. 2 Objectives You will be able to Output text and graphics to a printer. Print multipage documents. Use the standard Windows print.
Lecture 2 Managing Windows OS Introduction to.NET Framework C# & Microsoft Visual Studio.NET 2008.
BIM313 – Advanced Programming Simple Controls 1. Contents Traditional Controls – Labels, Text Boxes, Buttons, Check Boxes, List Boxes, Combo Boxes Advanced.
XHTML Introductory1 Forms Chapter 7. XHTML Introductory2 Objectives In this chapter, you will: Study elements Learn about input fields Use the element.
Teach Yourself Windows 98 Module 2: Working with Files, Folders, and the Desktop.
Multiple Forms and Standard Modules
5-1 aslkjdhfalskhjfgalsdkfhalskdhjfglaskdhjflaskdhjfglaksjdhflakshflaksdhjfglaksjhflaksjhf.
McGraw-Hill © 2009 The McGraw-Hill Companies, Inc. All rights reserved. Chapter 5 Menus, Common Dialog Boxes, Sub Procedures, and Function Procedures.
CSC 298 Windows Forms.
Copyright © 2006 Thomas P. Skinner1 Chapter 5 Indexers, Interfaces, and Enumerators.
Chapter 5 Menus, Common Dialog Boxes, and Methods Programming in C#.NET © 2003 by The McGraw-Hill Companies, Inc. All rights reserved.
Microsoft Visual Basic 2005: Reloaded Second Edition Chapter 2 Creating a User Interface.
Chapter 5 Menus, Common Dialog Boxes, Sub Procedures, and Function Procedures Copyright © 2011 by The McGraw-Hill Companies, Inc. All Rights Reserved.
Chapter 11 Bitmaps, Icons and Cursors. Copyright 2006 © Thomas P. Skinner2 Background Bitmaps are easy in.NET. Two kinds of graphics: 1.Vector 2.Bitmaps.
McGraw-Hill © 2009 The McGraw-Hill Companies, Inc. All rights reserved. Chapter 6 Multiform Projects.
Copyright © 2012 Pearson Education, Inc. Chapter 9 Classes and Multiform Projects.
Chapter 2 – Introduction to the Visual Studio .NET IDE
1 Creating Windows GUIs with Visual Studio. 2 Creating the Project New Project Visual C++ Projects Windows Forms Application Give the Project a Name and.
Computer Programming and Basic Software Engineering 9 Building Graphical User Interface Creating a Multiple-Form Interface.
Creating Menus Menu Bar – behaves like standard Windows menus Can be used in place of or in addition to buttons to execute a procedure Menu items are controls.
Object-Oriented Programming: Inheritance and Polymorphism.
11 User Controls Beginning ASP.NET in C# and VB Chapter 8.
Creating New Forms Projects can appear more professional when using different windows for different types of information. Select Add Windows Form from.
IE 411/511: Visual Programming for Industrial Applications Lecture Notes #2 Introduction to the Visual Basic Express 2010 Integrated Development Environment.
 You won’t write a single line of program code.  Instead, you’ll use visual programming techniques.  Visual Studio processes your actions (such as mouse.
Programming with Microsoft Visual Basic 2012 Chapter 1: An Introduction to Visual Basic 2012.
Module 3: Creating Windows-based Applications. Overview Creating the Main Menu Creating and Using Common Dialog Boxes Creating and Using Custom Dialog.
Dialog Boxes Getting information from user. Types of Windows Five types we’ll be using 1. Main Application Window 2. Child Windows 3. Dialog Boxes 4.
Chapter 8 Multiple Forms, Modules, and Menus. Introduction This chapter demonstrates how to: – Add multiple forms to a project – Create a module to hold.
Chapter 1: An Introduction to Visual Basic .NET
Microsoft Visual Basic 2005: Reloaded Second Edition
Chapter 2: The Visual Studio .NET Development Environment
Chapter 2 – Introduction to the Visual Studio .NET IDE
How to design a Windows Forms application
Working with Dialogs and Controls
Reference: COS240 Syllabus
Using Multiple Forms.
Chapter 1: An Introduction to Visual Basic 2015
Introduction to the Visual C# 2005 Express Edition IDE
Using Procedures and Exception Handling
Standard Controls.
Windows Desktop Applications
Variables and Arithmetic Operations
Multi-form applications and dialogs
Chapter 6 Multiform Projects
Chapter 2 – Introduction to the Visual Studio .NET IDE
Windows xp PART 1 DR.WAFAA SHRIEF.
Windows Forms Introduction
Building an Application in the Visual Basic .NET Environment
Self Study GUI Properties & Events
Lecture Set 11 Creating and Using Classes
Using Cascading Style Sheets (CSS)
Multi-Form Applications Things You Need to Know
Object-Oriented Programming: Inheritance and Polymorphism
Module 8: Creating Windows-based Applications
Based on Murach Chapter 10
Copyright © 2006 Thomas P. Skinner
Chapter 2 User Interface Design
Brief description on how to navigate within this presentation (ppt)
Creating Additional Input Items
– A principal I/O mechanism in Windows
Presentation transcript:

Copyright © 2006 Thomas P. Skinner Chapter 6 Dialogs 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Basics A dialog is just a form with certain properties set. Right click the project name and then select Add|New Item. When the new item dialog appears select Windows Form and change the name to something appropriate, for example, “OptionsDialog.” 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Adding the Dialog 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Properties Set these properties: Property Value FormBorderStyle FormBorderStyle.FixedDialog ControlBox false MinimizeBox MaximizeBox ShowInTaskbar 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner The Empty Dialog 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Adding Controls Use the designer to add controls just as you would do with the main form. Size the dialog appropriately. You will interact with the form just as you do with the main form except that you use the reference variable for the dialog. For example: Dialog1.TextBox1.Text="hello". 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Displaying the Dialog There are two main types of dialogs, the modal dialog and the modeless dialog. The modal dialog is a dialog that must be closed after use in order to continue using the main form. The modeless dialog stays on the screen and the user can switch back and forth between the main form and the dialog. Normally we provide a pair of buttons, OK and Cancel, for the user to indicate his or her intentions when changes are made in the dialog. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Displaying the Dialog – Contd. The ShowDialog method is called to display a modal dialog. The OK or Cancel button is normally used to close the dialog, but a dialog can be closed by typing Alt-F4. Here is the call to ShowDialog: myDialog.ShowDialog(); 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog Results The ShowDialog method returns one of these values: Member Description Abort The dialog box return value is Abort (usually sent from a button labeled Abort). Cancel The dialog box return value is Cancel (usually sent from a button labeled Cancel). Ignore The dialog box return value is Ignore (usually sent from a button labeled Ignore). No The dialog box return value is No (usually sent from a button labeled No). None Nothing is returned from the dialog box. This means that the modal dialog continues running. OK The dialog box return value is OK (usually sent from a button labeled OK). Retry The dialog box return value is Retry (usually sent from a button labeled Retry). Yes The dialog box return value is Yes (usually sent from a button labeled Yes). 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog Results – Contd. The DialogResult property is set to one of these values which are included in the DialogResult Enumeration. Notes that DialogResult is both a proerty and an enumeration. Again, the context is used to determine which. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog1 Example 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog1 Example Dialog1 – Dialog1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace Dialog1 { public partial class Dialog : Form public Dialog() 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog1 Example – Contd. { InitializeComponent(); } private void OKbutton_Click(object sender, EventArgs e) DialogResult = DialogResult.OK; private void Cancelbutton_Click(object sender, EventArgs e) DialogResult = DialogResult.Cancel; 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog1 Main Form The main form has a simple menu to invoke the dialog. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog1 Main Form Code Dialog1 – Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace Dialog1 { public partial class Form1 : Form private string boxtext = ""; 12/5/2018 Copyright © 2006 Thomas P. Skinner

Dialog1 Main Form Code – Contd. public Form1() { InitializeComponent(); } private void dIsplayToolStripMenuItem_Click( object sender, EventArgs e) Dialog myDialog = new Dialog(); myDialog.data.Text = boxtext; if(myDialog.ShowDialog()==DialogResult.OK) boxtext=myDialog.data.Text; 12/5/2018 Copyright © 2006 Thomas P. Skinner

DialogResult Shortcut All we need to do is to set the DialogResult property for each of the buttons to the appropriate value. No code needs to be written. No event handlers for the buttons are needed now. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Design Issues Making the dialog fields public is not always the best approach. Properties are obviously the preferred solution. This way the dialog internals can be hidden. It is often better to instantiate the dialog only once for the life of the program rather than each time it is needed. The Dialog3 example demonstrates these techniques. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog3 Example Dialog3 – Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace Dialog3 { public partial class Form1 : Form private string boxtext = ""; 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog3 Example – Contd. private Dialog myDialog = new Dialog(); public Form1() { InitializeComponent(); } private void dIsplayToolStripMenuItem_Click(object sender, EventArgs e) myDialog.data.Text = boxtext; if(myDialog.ShowDialog()==DialogResult.OK) boxtext=myDialog.data.Text; 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Accept and Cancel If a button control has the focus then pressing the return key or typing a space is identical to clicking on it with your mouse. If a non-button control has the focus then hitting return has a different effect depending on the control. It is very simple to associate the default action for the return key, if it is not processed by the control (e.g. by a text box). The AcceptButton and CancelButton properties of the form can be set to the buttons of your choice. Return associates with accept and ESC associates with cancel. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Setting the Properties 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Screen Position Use the following as appropriate: Member Description CenterParent The form is centered within the bounds of its parent form. CenterScreen The form is centered on the current display, and has the dimensions specified in the form's size. Manual The position of the form is determined by the Location property. WindowsDefaultBounds The form is positioned at the Windows default location and has the bounds determined by Windows default. WindowsDefaultLocation The form is positioned at the Windows default location and has the dimensions specified in the form's size. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner The Parent Container The default container for a new form is the desktop. If you want the dialog centered in the main form you need to set the Owner property: myDialog.Owner = this; Normally this property is set when you instantiate the dialog object. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Using CenterParent 12/5/2018 Copyright © 2006 Thomas P. Skinner

Handling Events in a Dialog You can add event handlers in a dialog that are processed by the dialog code rather than code in the main form. The designer automatically adds event handlers for a form in that form itself. This is usually what you want. For example, you might want to reset all the controls in the form to a default state. Dialog4 is a simple example that changes the background color. In the color dialog rather than make the radio buttons public I added a property that returns a Color object. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog4 Example 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Modeless Dialogs A modeless dialog is designed to stay on the screen until the user closes it. Work can be done using the main form while the modeless dialog is displayed. Normally an OK or Cancel button is not appropriate for a modeless dialog. A Close button or other appropriate button is provided instead. Use also normally need at least one action button that applies the information in the dialog to your application. Use the Show method instead of ShowDialog. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Modeless Dialog Techniques In the following example I instantiate the modeless dialog only once, in the main form's constructor. A right mouse click displays the modeless dialog. The Close button does not actually close the form which would require re-instantiating the class. I used the Hide method to remove the form from the screen. It's still there though. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Example Resize the Form 12/5/2018 Copyright © 2006 Thomas P. Skinner

After Changing the Size 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog Code ModelessDialog – SetSize.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace ModelessDialog { public partial class SetSize : Form public SetSize() InitializeComponent(); } private void close_Click(object sender, EventArgs e) Hide(); 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Dialog Code – Contd. } private void resizeButton_Click(object sender, EventArgs e) { int w, h; try w = Convert.ToInt32(width.Text); h = Convert.ToInt32(height.Text); catch MessageBox.Show("Invalad size!"); return; Owner.Width = w; Owner.Height = h; 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Main Form Code ModelessDialog – Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace ModelessDialog { public partial class Form1 : Form SetSize sizeDialog = new SetSize(); 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner public Form1() { InitializeComponent(); } private void Form1_MouseDown(object sender, MouseEventArgs e) if (e.Button == MouseButtons.Right) sizeDialog.Show(this); 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Common Dialog Classes Windows has always included several standard dialogs internal to the operating system. These are wrapped by .NET classes and are simple to use. The following table lists the common dialogs available under .NET. I will show you the font and color dialogs. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Available Common Dialogs Class Description System.Windows.Forms.ColorDialog Represents a common dialog box that displays available colors along with controls that allow the user to define custom colors. System.Windows.Forms.FileDialog Displays a dialog box from which the user can select a file. System.Windows.Forms.FolderBrowserDialog Prompts the user to select a folder. . This class cannot be inherited. System.Windows.Forms.FontDialog Prompts the user to choose a font from among those installed on the local computer. System.Windows.Forms.PageSetupDialog Enables users to change page-related print settings, including margins and paper orientation. System.Windows.Forms.PrintDialog Allows users to select a printer and choose which portions of the document to print. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner The Font Dialog Selecting a font is very common in applications. The user wants to select at least the font, size, and style. It is also useful to see what the font looks like in a sample. The font dialog does all this and a bit more. To use a common dialog all we do is to instantiate it and use the properties and methods that are appropriate. In some cases it is even possible to inherit from a common dialog. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner The Font Dialog 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Font Example CommDlg - Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace CommDlg1 { public partial class Form1 : Form private Font myFont; public Form1() InitializeComponent(); myFont = Font; //default font } protected override void OnPaint(PaintEventArgs e) 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Font Example – Contd. { Graphics g = e.Graphics; g.DrawString("Right click to change the font.", myFont, Brushes.Black, 10, 10); } private void Form1_MouseClick(object sender, MouseEventArgs e) if (e.Button == MouseButtons.Right) FontDialog fontDialog = new FontDialog(); fontDialog.Font = myFont; if (fontDialog.ShowDialog() == DialogResult.OK) myFont = fontDialog.Font; Invalidate(); Sets the initial font to display. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Result with a Font Change 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner The Color Dialog The color dialog allows the user to select a color using several different methods including RGB. Initially the dialog opens in a simple selection mode. Custom colors can be defined which displays more extensive selection methods. The following example allows changing the backgroudn color using a color dialog. 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Color Dialog Example CommDlg2 - Form1.cs using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace CommDlg2 { public partial class Form1 : Form public Form1() InitializeComponent(); } protected override void OnPaint(PaintEventArgs e) 12/5/2018 Copyright © 2006 Thomas P. Skinner

Color Dialog Example – Contd. Graphics g = e.Graphics; g.DrawString("Right click to change the form's backgroun color.", Font, Brushes.Black, 10, 10); } private void Form1_MouseClick(object sender, MouseEventArgs e) { ColorDialog colorDialog = new ColorDialog(); colorDialog.Color = BackColor; if (e.Button == MouseButtons.Right) if (colorDialog.ShowDialog() == DialogResult.OK) BackColor = colorDialog.Color; Invalidate(); 12/5/2018 Copyright © 2006 Thomas P. Skinner

The Simple Color Dialog 12/5/2018 Copyright © 2006 Thomas P. Skinner

Copyright © 2006 Thomas P. Skinner Color Dialog Expanded 12/5/2018 Copyright © 2006 Thomas P. Skinner