溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Silverlight中ViewBox組件如何使用

發(fā)布時(shí)間:2021-07-19 15:52:10 來(lái)源:億速云 閱讀:120 作者:Leah 欄目:編程語(yǔ)言

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)Silverlight中ViewBox組件如何使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

組件所在命名空間:

System.Windows.Controls

組件常用屬性:

Child:獲取或設(shè)置一個(gè)ViewBox元素的單一子元素。

Stretch:獲取或設(shè)置拉伸模式以決定該組件中的內(nèi)容以怎樣的形式填充該組件的已有空間。

StretchDirection:獲取或設(shè)置該組件的拉伸方向以決定該組件中的內(nèi)容將以何種形式被延展。

實(shí)例:

詳細(xì)的說(shuō)明在代碼注釋中給出。

MainPage.xaml文件代碼:

<UserControl xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"   xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"   mc:Ignorable="d" xmlns:controlsToolkit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Toolkit" x:Class="SilverlightClient.MainPage" d:DesignWidth="320" d:DesignHeight="240"> <Grid x:Name="LayoutRoot" Width="320" Height="240" Background="White"> <Slider x:Name="HSlider" Minimum="0" Maximum="100"  Height="24" Margin="79,0,91,42" VerticalAlignment="Bottom" Width="150"/> <Slider x:Name="VSlider" Minimum="0" Maximum="100" HorizontalAlignment="Right" Margin="0,24,57,66" Width="30" Orientation="Vertical" Height="150"/> <Border Margin="79,24,91,66" BorderBrush="Black" BorderThickness="1"> <Grid x:Name="theContainer" Background="AntiqueWhite"> <controlsToolkit:Viewbox x:Name="sampleViewBox" Margin="0,0,-2,-2"> <!--放入ViewBox中的按鈕對(duì)象--> <Button Width="101" Content="Button"/> </controlsToolkit:Viewbox> </Grid> </Border> <ComboBox x:Name="cbStretch" Height="21" HorizontalAlignment="Left" Margin="8,0,0,8" VerticalAlignment="Bottom" Width="139"/> <ComboBox x:Name="cbStretchDirection" Height="21" HorizontalAlignment="Right" Margin="0,0,8,8" VerticalAlignment="Bottom" Width="139"/> <TextBlock Height="16" HorizontalAlignment="Left" Margin="9,0,0,33" VerticalAlignment="Bottom" Width="66" Text="拉伸模式:" TextWrapping="Wrap"/> <TextBlock Height="16" HorizontalAlignment="Right" Margin="0,0,8,33" VerticalAlignment="Bottom" Width="56" Text="拉伸方向:" TextWrapping="Wrap"/> </Grid> </UserControl>

MainPage.xaml.cs文件代碼:

using System;  using System.Collections.Generic;  using System.Linq;  using System.Net;  using System.Windows;  using System.Windows.Controls;  using System.Windows.Documents;  using System.Windows.Input;  using System.Windows.Media;  using System.Windows.Media.Animation;  using System.Windows.Shapes;  namespace SilverlightClient  {  //輔助類StretchHelper  public class StretchHelper  {  public string StretchModeName { get; set; }  public Stretch theStretchMode { get; set; }  }  //輔助類StretchDirectionHelper  public class StretchDirectionHelper  {  public string StretchDirectionName { get; set; }  public StretchDirection theStretchDirection { get; set; }  }  public partial class MainPage : UserControl  {  //定義cbStretch與cbStretchDirection的數(shù)據(jù)源  List<StretchHelper> cbStretchList = new List<StretchHelper>();  List<StretchDirectionHelper> cbStretchDirectionList = new List<StretchDirectionHelper>();  public MainPage()  {  InitializeComponent();  //注冊(cè)事件觸發(fā)  this.Loaded += new RoutedEventHandler(MainPage_Loaded);  this.cbStretch.SelectionChanged += new SelectionChangedEventHandler(cbStretch_SelectionChanged);  this.cbStretchDirection.SelectionChanged += new SelectionChangedEventHandler(cbStretchDirection_SelectionChanged);  this.HSlider.ValueChanged += new RoutedPropertyChangedEventHandler<double>(HSlider_ValueChanged);  this.VSlider.ValueChanged += new RoutedPropertyChangedEventHandler<double>(VSlider_ValueChanged);  }  void VSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)  {  sampleViewBox.Height = theContainer.ActualHeight * VSlider.Value / 100.0;  }  void HSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)  {  sampleViewBox.Width = theContainer.ActualWidth * HSlider.Value / 100.0;  }  void cbStretchDirection_SelectionChanged(object sender, SelectionChangedEventArgs e)  {  if (cbStretchDirection.SelectedItem != null)  {  sampleViewBox.StretchDirection = (cbStretchDirection.SelectedItem as StretchDirectionHelper).theStretchDirection;  }  }  void cbStretch_SelectionChanged(object sender, SelectionChangedEventArgs e)  {  if (cbStretch.SelectedItem != null)  {  sampleViewBox.Stretch = (cbStretch.SelectedItem as StretchHelper).theStretchMode;  }  }  void MainPage_Loaded(object sender, RoutedEventArgs e)  {  //填充各ComboBox內(nèi)容  cbStretchList.Add(new StretchHelper() { StretchModeName = "Fill", theStretchMode = Stretch.Fill });  cbStretchList.Add(new StretchHelper() { StretchModeName = "None", theStretchMode = Stretch.None });  cbStretchList.Add(new StretchHelper() { StretchModeName = "Uniform", theStretchMode = Stretch.Uniform });  cbStretchList.Add(new StretchHelper() { StretchModeName = "UniformToFill", theStretchMode = Stretch.UniformToFill });  cbStretch.ItemsSource = cbStretchList;  cbStretch.DisplayMemberPath = "StretchModeName";  cbStretchDirectionList.Add(new StretchDirectionHelper() { StretchDirectionName = "DownOnly", theStretchDirection = StretchDirection.DownOnly });  cbStretchDirectionList.Add(new StretchDirectionHelper() { StretchDirectionName = "UpOnly", theStretchDirection = StretchDirection.UpOnly });  cbStretchDirectionList.Add(new StretchDirectionHelper() { StretchDirectionName = "Both", theStretchDirection = StretchDirection.Both });  cbStretchDirection.ItemsSource = cbStretchDirectionList;  cbStretchDirection.DisplayMemberPath = "StretchDirectionName";  }  }  }

最終效果圖:

Silverlight中ViewBox組件如何使用 

上述就是小編為大家分享的Silverlight中ViewBox組件如何使用了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI