Presentation is loading. Please wait.

Presentation is loading. Please wait.

Rujchai Ung-arunyawee Department of Computer Engineering Khon Kaen University.

Similar presentations


Presentation on theme: "Rujchai Ung-arunyawee Department of Computer Engineering Khon Kaen University."— Presentation transcript:

1 Rujchai Ung-arunyawee Department of Computer Engineering Khon Kaen University

2 Layout History.NET 1.0 Coordinate-based layout only Anchoring and Docking.NET 2.0 Coordinate-based layout is standard Flow-based layout is optional FlowLayoutPanel and TableLayoutPanel.NET 3.0 and greater Flow-based layout is standard Coordinate-based layout is optional Developers can now create resolution-independent, size-independent interfaces that scale well on different monitors.

3 The WPF Layout Philosophy WPF window can hold only a single element. You need to place a container in your window and then add other elements to that container. Elements (like controls) should not be explicitly sized. Elements do not indicate their position with screen coordinates. Layout containers can be nested.

4 The Layout Containers All the WPF layout containers are panels Panel class has 3 public properties: Background, Children, and IsItemHost.

5 NameDescription StackPanelPlaces elements in a horizontal or vertical stack. This layout container is typically used for small sections of a larger, more complex window. WrapPanelPlaces elements in a series of wrapped lines. In horizontal orientation, the WrapPanel lays items out in a row from left to right and then onto subsequent lines. In vertical orientation, the WrapPanel lays out items in a top-to-bottom column and then uses additional columns to fit the remaining items. DockPanelAligns elements against an entire edge of the container. GridArranges elements in rows and columns according to an invisible table. This is one of the most flexible and commonly used layout containers. UniformGridPlaces elements in an invisible table but forces all cells to have the same size. This layout container is used infrequently. CanvasAllows elements to be positioned absolutely using fixed coordinates. This layout container is the most similar to traditional Windows Forms, but it doesn’t provide anchoring or docking features. As a result, it’s an unsuitable choice for a resizable window unless you’re willing to do a fair bit of work.

6 StackPanel one of the simplest layout containers simply stacks its children in a single row or column.

7 Arrange elements horizontally

8 Layout Properties: Alignment

9 Layout Properties: Margin To make an extra space between elements Same margin for all sides Different margins for each side of a control in the order left, top, right, bottom:

10

11 How Margins are combined

12 Element Properties: Padding Inserts space between the edges of the control and the edges of the content

13 WrapPanel

14 DockPanel

15

16 Nesting Layout Containers

17 Grid The most powerful layout container in WPF Used by Visual Studio when creating a new XAML file. Separates elements into an invisible grid of rows and columns More than one element can be placed in a single cell Element may itself be another layout container that organizes its own group of contained controls: Nesting Layout.

18 Creating a Grid-based layout 2-step process First, choose the number of columns and rows that you want

19 Creating a Grid-based layout Second, place individual elements into a cell using the attached Row and Column properties You can place more than one element into a cell If you don’t specify the Grid.Row or Grid.Column property, the Grid assumes that it’s 0.

20 Example Grid

21 Sizing Rows and Columns The Grid supports three sizing strategies Absolute sizes Automatic sizes Proportional sizes

22 Spanning Rows and Columns Make an element stretch over several cells There are 2 attached properties Grid.RowSpan Grid.ColumnSpan Examples:

23 The Sample Dialog

24 Splitter In WPF, Splitter bars are represented by the GridSplitter class and are a feature of the Grid Provides the ability to resize rows or columns Always resizes entire rows or columns (not single cells) The GridSplitter must be placed in a Grid cell Horizontal splitter resizes rows Set HorizontalAlignment to Stretch and VerticalAlignment to Center Vertical splitter resizes columns Set VerticalAlignment to Stretch and HorizontalAlignment to Center

25

26

27 Multiple splitters A Grid usually contains no more than a single GridSplitter Use Nested Grid, each Grid has its own GridSplitter

28 UniformGrid Simply set the Rows and Columns properties to set its size Each cell is always the same size

29 Canvas

30 Z-Order To control how they are layered by setting the attached Canvas.ZIndex property when there are more than one overlapping elements. By default, all elements have the same ZIndex – 0 When having the same ZIndex, elements are displayed on the order they’re defined in the XAML With Zindex setting, the higher ZIndex elements always appear over the lower ZIndex elements

31 Z-Order in Code-Behind Useful if you need to change the position of an element Programmatically. Call Canvas.SetZIndex() Pass in the element you want to modify and the new ZIndex you want to apply.

32 InkCanvas

33 InkCanvas: EditingMode NameDescription InkThis is the default mode. When the user draws with the mouse or stylus, a stroke is drawn. SelectTo select an element, the user must click it or drag a selection “lasso” around it. Once an element is selected, it can be moved, resized, or deleted. GestureOnlyDraw stroke annotations but pays attention to specific predefined gestures InkAndGestureThe InkCanvas allows the user to draw stroke annotations and also recognizes predefined gestures. EraseByStrokeThe InkCanvas erases a stroke when it’s clicked. EraseByPointThe InkCanvas erases a portion of a stroke (a point in a stroke) when that portion is clicked. NoneThe InkCanvas ignores mouse and stylus input.

34 InkCanvas: Select Mode

35


Download ppt "Rujchai Ung-arunyawee Department of Computer Engineering Khon Kaen University."

Similar presentations


Ads by Google