I am building a CustomControl with some DependencyProperty's. It's a simple Control to browse for a path, and contains a label, a textbox and a button.
I would like to set the width of the label, the textbox and the button sepperately. So I added some DependencyProperty's for them.
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);
}
}
}
}
And here is the XML code of my CustomControl:
<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>
All the bindings with the DependencyProperty of type string are working perfect but the Width property's stays with value "auto".
I tested with a converter, and a value of "200" set to DP "LabelWidth" came in as {200} (when I mouse-over 'value' when breakpoint hit in the converter) but the width of the label does not change.
When I change GridLength
to Double
I can't set it to Auto
I finally found the answer.
I needed to add the atribute
[TypeConverterAttribute(typeof(LengthConverter))]
before the propertyWidth
.Then I changed the
DependencyProperty
to:Than I can set the LabelWidth to
Auto
: