いくつかの DependencyProperty を使用して CustomControl を構築しています。これは、パスを参照する単純なコントロールであり、ラベル、テキスト ボックス、およびボタンが含まれています。
ラベル、テキストボックス、ボタンの幅を別々に設定したいと思います。そこで、それらのためにいくつかの DependencyProperty を追加しました。
namespace DDD.AutoRadio.General.UserControls
{
/// <summary>
/// Interaction logic for PathBrowser.xaml
/// </summary>
public partial class PathBrowser : UserControl
{
public PathBrowser() { InitializeComponent(); }
public static DependencyProperty labelContent = DependencyProperty.Register("LabelContent", typeof(string), typeof(PathBrowser));
public static DependencyProperty labelWidth = DependencyProperty.Register("LabelWidth", typeof(GridLength), typeof(PathBrowser),
new FrameworkPropertyMetadata(GridLength.Auto, FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public static DependencyProperty buttonContent = DependencyProperty.Register("ButtonContent", typeof(string), typeof(PathBrowser),
new FrameworkPropertyMetadata("Blader",FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public static DependencyProperty buttonWidth = DependencyProperty.Register("ButtonWidth", typeof(GridLength), typeof(PathBrowser),
new FrameworkPropertyMetadata(default(GridLength), FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public static DependencyProperty textBoxText = DependencyProperty.Register("UrlPath", typeof(string), typeof(PathBrowser),
new FrameworkPropertyMetadata("", FrameworkPropertyMetadataOptions.BindsTwoWayByDefault,null,null,false,UpdateSourceTrigger.PropertyChanged));
public static DependencyProperty textBoxWidth = DependencyProperty.Register("UrlPathWidth", typeof(GridLength), typeof(PathBrowser),
new FrameworkPropertyMetadata(GridLength.Auto, FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public static DependencyProperty typeBrowser = DependencyProperty.Register("TypeBrowser", typeof(BrowserType), typeof(PathBrowser),
new FrameworkPropertyMetadata(BrowserType.Directory, FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public enum BrowserType { Directory,File}
public string LabelContent
{
get { return (string)GetValue(labelContent); }
set { SetValue(labelContent, value); }
}
public GridLength LabelWidth
{
get { return (GridLength)GetValue(labelWidth); }
set { SetValue(labelWidth, value); }
}
public string ButtonContent
{
get { return (string)GetValue(buttonContent); }
set { SetValue(buttonContent, value); }
}
public GridLength ButtonWidth
{
get { return (GridLength)GetValue(buttonWidth); }
set { SetValue(buttonWidth, value); }
}
public string UrlPath
{
get { return (string)GetValue(textBoxText); }
set { SetValue(textBoxText, value); }
}
public GridLength UrlPathWidth
{
get { return (GridLength)GetValue(textBoxWidth); }
set { SetValue(textBoxWidth, value); }
}
public BrowserType TypeBrowser
{
get { return (BrowserType)GetValue(typeBrowser); }
set { SetValue(typeBrowser, value); }
}
private void Button_Click(object sender, RoutedEventArgs e)
{
if (TypeBrowser == BrowserType.Directory)
{
System.Windows.Forms.FolderBrowserDialog op = new System.Windows.Forms.FolderBrowserDialog();
op.SelectedPath = UrlPath;
if (op.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
UrlPath = System.IO.Path.GetFullPath(op.SelectedPath);
}
}
if (TypeBrowser==BrowserType.File)
{
System.Windows.Forms.OpenFileDialog fd = new System.Windows.Forms.OpenFileDialog();
try { fd.InitialDirectory = System.IO.Path.GetDirectoryName(UrlPath); } catch { }
fd.Multiselect = false;
if (fd.ShowDialog()== System.Windows.Forms.DialogResult.OK)
{
UrlPath = System.IO.Path.GetFullPath(fd.FileName);
}
}
}
}
そして、これが私の CustomControl の XML コードです。
<UserControl x:Class="DDD.AutoRadio.General.UserControls.PathBrowser"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:DDD.AutoRadio.General.UserControls"
mc:Ignorable="d" Name="Root"
d:DesignHeight="24" d:DesignWidth="300">
<DockPanel LastChildFill="True">
<Label DockPanel.Dock="Left" Padding="2" Margin="3" Content="{Binding LabelContent,ElementName=Root}"
Width="{Binding LabelWidth,ElementName=Root}"/>
<Button DockPanel.Dock="Right" Padding="2" Margin="3" Content="{Binding ButtonContent,ElementName=Root}"
Width="{Binding ButtonWidth,ElementName=Root}" Click="Button_Click"/>
<TextBox Padding="2" Margin="3" Text="{Binding UrlPath,ElementName=Root}" Width="{Binding UrlPathWidth,ElementName=Root}" />
</DockPanel>
</UserControl>
文字列型の DependencyProperty を持つすべてのバインディングは完璧に機能していますが、Width プロパティの値は "auto" のままです。コンバーターでテストしたところ、DP "LabelWidth" に設定された "200" の値が {200} として表示されました (コンバーターでブレークポイントにヒットしたときにマウスを 'value' に重ねたとき) が、ラベルの幅は変わりません.
に変更GridLength
するDouble
と、設定できませんAuto