<p> Chapter 6 - Layout Controls</p><p>CHAPTER 6 - LAYOUT CONTROLS</p><p>WPF provides many (too many?) ways to layout controls in a window or document; the rest of this chapter covers the main ones in more detail.</p><p>6.1 StackPanel Controls</p><p>The StackPanel control allow you to display controls in a vertical column or horizontal row. Here is an example of how you can use StackPanel controls to build a window:</p><p>Start with a StackPanel with vertical Insert a StackPanel with horizontal orientation: orientation.</p><p> a) Start with a stack panel to arrange controls in a column (the orientation will be vertical).</p><p> b) Within this, add a StackPanel with horizontal orientation.</p><p> c) Within the horizontal StackPanel, insert 4 StackPanels with vertical orientation. </p><p>The XAML for this window <!—- main panel: textbox, images and another text box --> (with lots of formatting - <StackPanel Orientation="Vertical" Margin="10"> especially margin settings - <TextBlock … Text="Each person …" /> omitted). This is not the best way to achieve this, as we’ve <!—- stack panel containing images from left to right --> had to include more or less <StackPanel Orientation="Horizontal" … > identical StackPanels for each WOTCHA category. <!—- for each image, the image followed by a textbox --> <StackPanel Orientation="Vertical" … > <Border BorderThickness="1" BorderBrush="Black"> <Image Source="intelligence.jpg" Height="100" /> </Border> <TextBlock Text="Intelligence" … /> </StackPanel></p><p><!—- 3 similar StackPanels should appear here --> <…></p><p></StackPanel> <TextBlock TextAlignment="Left" … Text="You can … " /></p><p>© Copyright 2018 Page 39 Chapter 6 - Layout Controls</p><p>6.2 WrapPanel and UniformGrid Controls</p><p>WrapPanel Controls</p><p>Use WrapPanel (as opposed to StackPanel) controls when it is more important for a user to see all of the items listed than it is for each item to be in an exact position:</p><p>With a StackPanel control, when you make the window too narrow, you lose some of the images. A WrapPanel control wraps images inside the panel.</p><p>UniformGrid Controls</p><p>A UniformGrid works in almost exactly the same way as a WrapPanel:</p><p>The difference with a UniformGrid is that the images will always be displayed from left to right and top to bottom (and hence there is no Orientation property).</p><p><!-- the 2x2 grid for the images --> <UniformGrid Margin="10,0,10,10" Rows="2" Columns="2" HorizontalAlignment="Stretch" ></p><p><!-- vertical panel per image --> <StackPanel Orientation="Vertical"> <Border … > <Image … /> </Border> <TextBlock Text="Intelligence" /> </StackPanel> You could miss out the number or rows and columns for this example and still get the same effect, since then <!— other 3 images follow here --> Visual Studio will divide the 4 items into a sensible 2x2 < … > rectangle.</p><p>© Copyright 2018 Page 40 Chapter 6 - Layout Controls</p><p>6.3 Single-Cell Grid and Canvas Controls</p><p>Single Cell Grids</p><p>Single-cell grids are the default way to arrange controls in a window or document. Whenever you create a window, you get a Grid by default:</p><p>A window can only contain a single control; but if this control is a Grid, you can then position as many controls as you like inside it.</p><p>Controls that you add to a single-cell grid are positioned relative to its top left corner. Here’s an example of a grid, to get the initial pink border round our WOTCHA cards:</p><p><Window x:Class="TopTrumps.TopTrumpCard" … ></p><p><!-- grid containing everything --> <Grid Name="grdMain" Background="#FFF2E2E2"></p><p><!-- rounded border --> <Border BorderThickness="1" Margin="20" Padding="10" MinWidth="0" MinHeight="0" CornerRadius="10" BorderBrush="#FF721212" Background="#FFFCF9F9"> The grid contains a single border The grid has a pink control, within which the rest of the background, but no window fits. other attributes.</p><p>Grids can have multiple rows and columns, but chessboard grids like this are covered in a separate chapter, and are used for different purposes.</p><p>Canvas Controls</p><p>A Canvas superficially appears just like a single-cell grid: it creates a rectangle into which you can add controls. However canvases are far less useful:</p><p>The Canvas control goes against all the principles of flow layout for WPF windows and documents. For the example above, if you used a Canvas instead of a Grid and didn’t include a width and height, this is what you would get.</p><p>For much more on the difference between single-cell Grid controls and Canvas controls, and why you should use the former, see: http://msdn.microsoft.com/en-us/magazine/ff646962.aspx WiseWise Owl’s Owl’s HintHint</p><p>© Copyright 2018 Page 41 Chapter 6 - Layout Controls</p><p>6.4 DockPanel Controls</p><p>A DockPanel control attaches the controls it contains (its “children”) to the edge specified by their respective DockPanel.Dock properties:</p><p><!—- show rectangle filled with image on left --> <DockPanel Margin="0,20,0,20" Height="200"></p><p><!-- put border round rectangle with image --> <Border DockPanel.Dock="Left" BorderThickness="1" BorderBrush="Black" Width="150"> <Rectangle> <Rectangle.Fill> <ImageBrush ImageSource="BillGates.jpg" Stretch="UniformToFill" /> </Rectangle.Fill> </Rectangle> </Border></p><p><!-- now put a border round grid of scores --> <Border BorderThickness="1" BorderBrush="Black" Margin="20,0,0,0"> The picture is docked to the left edge of the <Grid> DockPanel control; the table fills the rest of it. … </Grid></p><p>The DockPanel to achieve this effect contains 2 Border controls. The one on the left is docked to the left edge of the dock panel, and contains a picture; the one on the right contains the table of ratings by category.</p><p>The LastChildFill Property</p><p>When all but the last child element of a DockPanel has been accounted for, what should happen to the rest of the space? The answer is determined by the LastChildFill property:</p><p>If set to False, there will sometimes be a If set to True, the last child will expand to space beside/above/below the last child. fill any remaining gap.</p><p>© Copyright 2018 Page 42 Chapter 6 - Layout Controls</p><p>6.5 Controls to Conserve Space</p><p>To avoid creating huge windows (which might not fit onto a screen) you can use ScrollViewer, TabControl, ViewBox or Expander controls, as shown below.</p><p>ScrollViewer Controls</p><p>A ScrollView control displays its single child inside a scrollable region:</p><p>Here we’ve include most of the window inside a ScrollViewer, with visible horizontal and vertical scroll bars.</p><p>The relevant XAML is:</p><p>If you set the CanContentScroll property to True the ScrollView scrolls jerkily, since WPF is taking account of the items the ScrollView contains. The default False setting gives much smoother scrolling.</p><p><!-- grid containing everything --> <Grid Name="grdMain" Background="#FFF2E2E2"></p><p><!-- rounded border containing scrollable region --> <Border BorderBrush="#FF721212" BorderThickness="1" Margin="20" Padding="0"> <ScrollViewer Width="350" Height="250" VerticalScrollBarVisibility="Auto" Background="#FFFCF9F9" CanContentScroll="False" HorizontalScrollBarVisibility="Auto"></p><p>The vertical and horizontal scroll bar visibility properties can be set to one of the following 4 values:</p><p>Value What it means Auto The scroll bar is visible when you need it, and hidden otherwise. Visible The scroll bar is visible all of the time, even when not needed. Disabled The scroll bar does not appear even when needed. There are subtle differences between these two properties which are only ever likely to be of interest if Hidden you’re using ListBox controls.</p><p>© Copyright 2018 Page 43 Chapter 6 - Layout Controls</p><p>TabControl Controls</p><p>TabControl controls are badly named (why do they repeat the word Control?), and are a throwback to WinForms, VBA and VB6 applications:</p><p><!-- grid containing everything --> Each TabControl contains a number of tab <Grid Name="grdMain" Background="#FFF2E2E2"> items, corresponding to the tabs along the top of the control. The Header property of each <!-- tab control with one page per card --> TabItem controls what displays on it. <TabControl Margin="20" Foreground="Green" Background="LightBlue" BorderBrush="red" BorderThickness="3" SelectedIndex="0" TabStripPlacement="Top"></p><p><!-- tab for first person --> <TabItem Header="Bill Gates"> Here there are 3 tabs, but the first one (with index number 0) is selected. <!-- all details for person here--> … </p><p><!-- finish off Bill Gates --> </TabItem></p><p><!-- empty tabs for other 2 cards for now --> <TabItem Header="Sergei Brin" /> <TabItem Header="Larry Page" /></p><p>The following are the main properties that you can set for TabControl controls:</p><p>Property Notes Background The background colour for each page in the control (above we’ve used blue). SelectedIndex The page initially selected (here it’s the first one, hence number 0). TabStripPlacement Whether the tabs appear at the top, bottom, left or right of the TabControl. Here’s what Left looks like:</p><p>Items The different pages or tabs in the control (you can type these in, or use the build button to create them).</p><p>© Copyright 2018 Page 44 Chapter 6 - Layout Controls</p><p>ViewBox Controls</p><p>ViewBox controls shrink or expand contents to fit a given width and height:</p><p>Here the ViewBox has a fixed width and height. Because the Stretch method is Fill (see below), the contents have been distorted: <!-- view box with given dimensions --> <Viewbox Margin="20" Stretch="Fill" Width="300" Height="200"></p><p>A ViewBox’s main properties are as follows:</p><p>Property Notes Stretch How you can stretch the contents of the ViewBox to fill it. The possible values are None – you can’t stretch contents at all Fill – the contents will fill the ViewBox exactly, but may be distorted Uniform – the contents will fill the ViewBox in one dimension, but the aspect ratio (the ratio between width and height) will be preserved to prevent distortion UniformToFill – as for Uniform, but part of the contents may not be visible (in effect, the contents are stretched too far in one dimension).</p><p>Stretch- Whether you can shrink or expand the contents (UpOnly Direction means you can expand but not shrink them; DownOnly means you can shrink but not expand).</p><p>© Copyright 2018 Page 45 Chapter 6 - Layout Controls</p><p>Expander Controls</p><p>An Expander control is similar to a TabControl:</p><p>When you The first Expander is for Bill Gates, and contains a click on the StackPanel giving all of his card details. icon in an Expander …</p><p>… it reveals its contents! <!-- rounded border containing StackPanel --> <Border … ></p><p><!-- stack panel containing 3 expanders --> <StackPanel Name="grdMain" Margin="10"></p><p><!-- Expander for Bill Gates --> <Expander Header="Bill Gates" Background="LightBlue"></p><p><!-- details for Bill --> <StackPanel … > … </StackPanel></p><p></Expander></p><p><!—- empty expanders for other 2 --> <Expander Header="Sergei Brin" Background="LightBlue"></Expander> <Expander Header="Larry Page" Background="LightBlue"></Expander> </p><p>Here are the main properties for the Expander:</p><p>Property Notes IsExpanded Whether the Expander is currently expanded! Expand- The direction in which the Expander will Direction grow (expansion to the left, for example, looks odd). Header The text which appears next to the icon (if any).</p><p>© Copyright 2018 Page 46</p>
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages8 Page
-
File Size-