V 1.0 Programming III. Comparison of GUI APIs WPF Hello World UI elements Content models Inheritance chains.

Slides:



Advertisements
Similar presentations
View-Based Application Development Lecture 1 1. Flows of Lecture 1 Before Lab Introduction to the Game to be developed in this workshop Comparison between.
Advertisements

Win8 on Intel Programming Course Desktop : WPF Cédric Andreolli Intel Software
Information System Design Lab 5&6. User Interface Design.
1 Moderne GUI og Silverlight Windows Presentation Foundation.
Getting Started with VB .NET
A Guide to Oracle9i1 Introduction To Forms Builder Chapter 5.
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.
Exploring the Basics of Windows XP. Objectives Start Windows XP and tour the desktop Explore the Start menu Run software programs, switch between them,
Chapter 2: The Visual Studio.NET Development Environment Visual Basic.NET Programming: From Problem Analysis to Program Design.
Getting Started Example ICS2O curriculum
Visual Basic Chapter 1 Mr. Wangler.
NOTE: To change the image on this slide, select the picture and delete it. Then click the Pictures icon in the placeholder to insert your own image. WEB.
Overview of Previous Lesson(s) Over View  ASP.NET Pages  Modular in nature and divided into the core sections  Page directives  Code Section  Page.
Doncho Minkov Telerik School Academy academy.telerik.com Technical Trainer
V 1.0 Programming III. Creation of additional windows Routed events.
1 COS240 O-O Languages AUBG, COS dept Lecture 33 Building Apps Technologies C# (WPF part 1)
1 Intro XAML Attribute syntax & property syntax Panels Reusable resources Controls Data binding Steen Jensen, spring 2014.
V 1.1 Programming III. GUI APIs WPF Hello World Important UI elements UI elements / content models UI elements / inheritance.
An Introduction to Silverlight Matt Harrington Developer Evangelist, Microsoft October 20, 2011.
Department of Mechanical Engineering, LSUSession VII MATLAB Tutorials Session VIII Graphical User Interface using MATLAB Rajeev Madazhy
Introduction to Visual Basic. Quick Links Windows Application Programming Event-Driven Application Becoming familiar with VB Control Objects Saving and.
Chapter 3 Introducing Visual Basic.NET. 3.1 Visual Basic.NET Windows Programming -Used to create Windows, Web, and Console applications -Uses predefined.
Multiple Forms, Container Controls, AddHandler This presentation is based on the Forms and ContainerControls VB Projects 1.
V 1.1 Programming III. Important events, properties, methods of UI elements XAML basics.
Chapter 12: Using Controls. Examining the IDE’s Automatically Generated Code A new Windows Forms project has been started and given the name FormWithALabelAndAButton.
1 1 Lab1 Ismail M. Romi – IT Dept, PPU, Visual Basic 2005 Programming Tour.
Tutorial 121 Creating a New Web Forms Page You will find that creating Web Forms is similar to creating traditional Windows applications in Visual Basic.
A First Look At Microsoft Visual Basic Lesson 1. What is Microsoft Visual Basic? Microsoft Visual Basic is a software development tool, which means it.
Tutorial 111 The Visual Studio.NET Environment The major differences between Visual Basic 6.0 and Visual Basic.NET are the latter’s support for true object-oriented.
V 1.1 Programming III. Creating additional windows Event handling: preview/routed events.
NOTE: To change the image on this slide, select the picture and delete it. Then click the Pictures icon in the placeholder to insert your own image. WEB.
Basic WPF Controls Doncho Minkov Telerik School Academy schoolacademy.telerik.com Technical Trainer
V 1.0 Programming III. Automatic notifications (…Changed, INofityPropertyChanged, ObservableCollection ) Data formatters Data conversions Resources.
Graphical User Interface Concepts - Part 2 Session 09 Mata kuliah: M0874 – Programming II Tahun: 2010.
S511 Session 7, IU-SLIS 1 DB Implementation: MS Access Forms.
COS240 O-O Languages AUBG, COS dept Lecture 33 Title: C# vs. Java (GUI Programming) Reference: COS240 Syllabus.
Tutorial 11 Five windows included in the Visual Basic Startup Screen Main Form Toolbox Project Explorer (Project) Properties.
LAYOUT CONTROLS. XAML Overview XAML : eXtensible Application Markup Language pronounced (ZAMEL) is a markup language used to design user interfaces XML-based.
Object Oriented Software Development 9. Creating Graphical User Interfaces.
CHAPTER TWO INTRODUCTION TO VISUAL BASIC © Prepared By: Razif Razali 1.
Windows Presentation Foundation Maximilian Knor Developer Evangelist Developer and Plattform Group Microsoft Österreich
Joe Hummel, PhD Dept of Mathematics and Computer Science Lake Forest College
WaveMaker Visual AJAX Studio 4.0 Training Basics: Building Your First Application Designer Basics.
Visual Basic.NET BASICS Lesson 1 A First Look at Microsoft Visual Basic.NET.
Visual C# 2012 How to Program © by Pearson Education, Inc. All Rights Reserved.
DB Implementation: MS Access Forms. MS Access Forms  Purpose Data entry, editing, & viewing data in tables Forms are user-friendlier to end-users than.
C# GUI - Basics. Objectives.NET supports two types: WinForms, traditional, desktop GUI apps. WebForms – newer, for Web apps. Visual Studio.NET supports.
Controls. Adding Controls to Form -You can pick controls from the toolbox. -To add the controls from Toolbox to the Form You have be in design view. -To.
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.
Microsoft Visual Basic 2005 BASICS Lesson 1 A First Look at Microsoft Visual Basic.
C# kursus Rohde & Schwarz1 Moderne GUI Windows Presentation Foundation.
Visual C# 2012 How to Program © by Pearson Education, Inc. All Rights Reserved.
Module 3 Designing and Developing a User Interface.
Object-Oriented Application Development Using VB.NET 1 Chapter 10 VB.NET GUI Components Overview.
1 Visual Basic Part I - A tool for customizing your program Principles of GIS
COMPUTER PROGRAMMING I 3.01 Apply Controls Associated With Visual Studio Form.
Module 1 Introducing C# and the.NET Framework. Module Overview Introduction to the.NET Framework 4 Creating Projects Within Visual Studio 2010 Writing.
V 1.0 Programming III. XAML Data Binding I.. V 1.0ÓE-NIK, 2014 XAML namespaces Namespaces define the allowed tags and attributes The one without the prefix.
COMPUTER PROGRAMMING I 3.01 Apply Controls Associated With Visual Studio Form.
 2002 Prentice Hall. All rights reserved. 1 Introduction to the Visual Studio.NET IDE Outline Introduction Visual Studio.NET Integrated Development Environment.
Microsoft Visual C# 2010 Fourth Edition Chapter 3 Using GUI Objects and the Visual Studio IDE.
Part of the Microsoft.NET Framework 3.0 Tomer Shamam.NET Technologies Expert Sela Group
Chapter 2: The Visual Studio.NET Development Environment Visual Basic.NET Programming: From Problem Analysis to Program Design.
3.01 Apply Controls Associated With Visual Studio Form
3.01 Apply Controls Associated With Visual Studio Form
WPF AKEEL AHMED.
Resources & Controls AKEEL AHMED.
6. WinForms 2003 C# GUI - Basics.
Visual C# - GUI and controls - 1
Overview of the IDE Visual Studio .NET is Microsoft’s Integrated Development Environment (IDE) for creating, running and debugging programs (also.
Presentation transcript:

V 1.0 Programming III. Comparison of GUI APIs WPF Hello World UI elements Content models Inheritance chains

V 1.0ÓE-NIK, 2014 Graphical User Interface APIs API: Application Programming Interface Usually we do not start the programming of a GUI from scratch –Exception: games, very often There are several APIs that give us some basic components/concepts/approaches –MFC(Windows/C++) –Windows Forms(Windows/.NET) –Java AWT/Swing(Java) –Cocoa(Mac OS X) –QT(Unix/Linux...) –GTK/GTK+(Unix/Linux...) –WPF(Windows/.NET) –Windows Runtime (Metro)(Windows/C#, C++) 2

V 1.0ÓE-NIK, 2014 GUI APIs / Windows Forms Available since.NET 1.0 (2002) –Provides managed access of the native Windows API elements –Windows API: from Windows 1.0 (1985) Simple, standard-looking user interfaces Functionality: only GUI, no logic/layering –Creation and management of windows –Basic controls/components –Dialog windows –Handling of mouse/keyboard input events –Various different APIs for different tasks 3

V 1.0ÓE-NIK, 2014 GUI APIs / WPF Since.NET 3.0 (2006) Designed to replace the old Windows Forms –Only half-success (as of 2014) Offers a standardized access and logical representation of (almost) every aspect of a Graphical application –Build-up of the user interface (similar to Windows Forms) –2D –3D –Multimedia/video –Document management –Input management 4

V 1.0ÓE-NIK, 2014 GUI APIs / Windows Runtime Metro: design principles, design language (Metro -> Modern -> Windows Store/Windows 8) Modal, fullscreen apps with simple graphical layout –Good for portable devices with smaller screens 5

V 1.0ÓE-NIK, 2014 Windows Forms vs. WPF 6 Windows FormsWPF For developing simple GUI appsFor developing „Rich desktop apps” with better graphics / multimedia content Usually restricted to one possible solution for a problem Usually multiple solutions are possible A typical program requires external (ms or non-ms) libraries that can be very different in their approaches and usage logics The same principles and usage logics can be used for lots of devices Very mature, the flaws are known and usually there is a known work- around for everything Under heavy development even nowadays, some known bugs/problems have no official / proven workarounds Easier to learnHARDER TO LEARN

V 1.0ÓE-NIK, 2014 Choose which one? windows-8/ (2013. február 22.) windows-8/ At the moment, WPF is the better way to develop desktop apps – use WinForms for quick prototyping or if it has to be used for compatibility / HR reasons 7

V 1.0ÓE-NIK, 2014 The future (as of 2014) ? The support for Windows Forms seems to be eternal, but it is no longer developed The future of WPF is not certain, its development is slow, and the developer tools are not mature enough The XAML is a technology that will surely live on 8

V 1.0ÓE-NIK, 2014 WPF Hello World 9

V 1.0ÓE-NIK, 2014 WPF Hello World 10

V 1.0ÓE-NIK, 2014 WPF Hello World View -> View -> Other Windows -> 11

V 1.0ÓE-NIK, 2014 WPF Hello World Window representation and the XAML designer 12

V 1.0ÓE-NIK, 2014 WPF Hello World Code-behind file of the MainWindow 13

V 1.0ÓE-NIK, 2014 WPF Hello World The properties of the selected UI element can be altered in the Properties window 14

V 1.0ÓE-NIK, 2014 WPF Hello World Project settings –Compile settings –Pre- and post-compile tasks –Command line arguments –User/app level configuration –Etc. External References –To ms or non-ms software libraries or web services App-level configuration files Window XAML and code- behind files 15

V 1.0ÓE-NIK, 2014 App, MainWindow App class: –App.xaml.cs + generated bin/obj/App.g.cs = App class –This is where the Main() is generated, which creates an instance of the Main window –The “Current” static property represents the currently running application. It has events/methods to detect/control the execution of the application (e.g. Startup, Exit events, or App.Current.Shutdown()) MainWindow class / other Window classes: –Represents windows / forms –MainWindow.xaml.cs + generated bin/obj/MainWindow.g.cs = MainWindow class –It contains the InitializeComponent() method that processes and loads the XAML 16

V 1.0ÓE-NIK, 2014 Toolbox Controls –For user input Simple graphical/UI elements “Window frame extensions” –Menus, toolbars, status bars… Content managers –Used for grouping and placement of other UI elements Etc 17

V 1.0ÓE-NIK, 2014 Simple controls Button –Content property to set the caption text (?) –Click event Label –Content property to set the caption text (?) CheckBox –Content property to set the caption text (?) –IsChecked property to get/set the checked state –Checked/Unchecked events RadioButton –Content property to set the caption text (?) –GroupName to define groups (or use a content manager) –IsChecked property –Checked/Unchecked events 18

V 1.0ÓE-NIK, 2014 Simple controls TextBlock (to display multiline or simple text) –Text property TextBox (input box) –Text property –TextChanged event GroupBox –Header property –Content property 19

V 1.0ÓE-NIK, 2014 List controls ListBox –Items property for the elements –SelectionChanged event ComboBox (drop-down list) –Items property for the elements –SelectionChanged event TreeView + TreeViewItem –Items property for the elements (if the elements are TreeViewItem instances, then each will have an Items property) 20

V 1.0ÓE-NIK, 2014 Content models ContentControl: –Can contain a single element (Content property  user controls?) HeaderedContentControl: one element + a header text. ItemsControl: –Can contain multiple elements (ItemsSource / Items properties) HeaderedItemsControl: multiple elements+headers. 21

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes System.Windows.Media.Visual: –Rendering, transformations, hit check, bounding box… System.Windows.UIElement: –Input, placement, focus management, event handling System.Windows.FrameworkElement: –Data binding 22

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes System.Windows.Controls.Control: –Mainly manages the styles of the different controls (Background, BorderThickness, BorderBrush, FontFamily, FontSize) – it’s possible to completely change the look of every control! –Important question: what can be on this control? (ContentControl vs ItemsControl)  descendant classes? 23

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes System.Windows.Controls.ContentControl: –Can contain only ONE element (Content property). It can be any type (Object), but it is usually a string or a UIElement descendant Encapsulating User Controls into each other is a common usage 24

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes ContentControl descendants : –Button –CheckBox –Label –RadioButton –… –Window 25

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes System.Windows.Controls.ItemsControl: –Can contain MULTIPLE elements (Items, ItemsSource property). –Items: ItemCollection – can store Object references –ItemsSource: IEnumerable –Only one of the two storage modes can be used!!! If we use the ItemsSource, then the Items will be read-only. If we set the Items property, then we cannot set the ItemsSource 26

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes ItemsControl descendants: –ComboBox –ListBox –ListView –Menu –TreeView –… 27

V 1.0ÓE-NIK, 2014 Placement of UI elements HorizontalAlignment VerticalAlignment Margin, Height, Width Every UI element is placed according to the combination of these values (e.g. …Alignment+Margin, Height+VerticalAlignment, Width+HorizontalAlignment…) 28

V 1.0ÓE-NIK, 2014 Content managers They are used to organize the placement and the resizing of the sub-elements – the content managers have no visual representation on their own Grid (helper row/column definitions) Canvas (strictly pixel-accurate placement) DockPanel (docked to left/right/top/bottom) StackPanel (Elements are stacked) WrapPanel (Elements are stacked + paginated/scrolled) Grid: StackPanel: 29

V 1.0ÓE-NIK, 2014 Inheritance of the GUI classes System.Windows.Controls.Panel: –Every content manager is the descendant of the Panel base class –Children: UIElementCollection typed property – can store UIElement references 30

V 1.0ÓE-NIK, 2014 WPF Hello World II. 31

V 1.0ÓE-NIK, 2014 WPF Hello World II. Event handling –The list of events can be accessed in the Properties window (“lightning” icon) –After double-clicking, a new event handler is created in the code-behind source, and the new method is added into the event- delegate –After deleting the reference in the Properties window, the association for the method is removed from the event- delegate (but the method itself is not deleted!) –We can also add an event handler to the “default event” of an element by double- clicking on the element itself 32

V 1.0ÓE-NIK, 2014 Exercise Tax checker. Input: income, tax percentage, prepaid tax... Evaluate the user input! 33