Вы можете создать класс DateFormatChoice
, который содержит свойство для кода формата (например, "m" или "D") и свойство для текущей даты, отформатированной таким образом.
public class DateFormatChoice {
public string FormatCode { get; private set; }
public string CurrentDateExample {
get { return DateTime.Now.ToString( FormatCode ) }
}
public DateFormatChoice( string standardcode ) {
FormatCode = standardcode;
}
}
Вы связываете свой ComboBox с их коллекцией, используя CurrentDateExample
либо в DataTemplate
, либо в качестве DisplayMemberPath
ComboBox. Вы можете использовать эти объекты непосредственно с вашим классом выбора формата даты, и DatePicker
привязывается к свойству FormatCode
выбранного объекта DateFormatChoice
, или вы можете установить свойство ValueMemberPath
в исходном ComboBox на FormatCode
свойство и используйте SelectedValue
в ComboBox для получения / установки того, что выбрано. Не использовать ValueMember
может быть немного проще.
Вот более полный пример. Он использует DateFormatChoice
класс выше.
Во-первых, сбор данных.
public class DateFormatChoices : List<DateFormatChoice> {
public DateFormatChoices() {
this.Add( new DateFormatChoice( "m" ) );
this.Add( new DateFormatChoice( "d" ) );
this.Add( new DateFormatChoice( "D" ) );
}
}
Затем я сделал простую ViewModel для окна:
public class ViewModel : INotifyPropertyChanged {
public event PropertyChangedEventHandler PropertyChanged = ( s, e ) => {
}; // the lambda ensures PropertyChanged is never null
public DateFormatChoices Choices {
get;
private set;
}
DateFormatChoice _chosen;
public DateFormatChoice Chosen {
get {
return _chosen;
}
set {
_chosen = value;
Notify( PropertyChanged, () => Chosen );
}
}
public DateTime CurrentDateTime {
get {
return DateTime.Now;
}
}
public ViewModel() {
Choices = new DateFormatChoices();
}
// expression used to avoid string literals
private void Notify<T>( PropertyChangedEventHandler handler, Expression<Func<T>> expression ) {
var memberexpression = expression.Body as MemberExpression;
handler( this, new PropertyChangedEventArgs( memberexpression.Member.Name ) );
}
}
У меня не было элемента управления выбора даты, который принимал бы стандартные коды формата строки, поэтому я сделал довольно тупой UserControl (с сокращением многих углов) просто для демонстрации получения кода формата. Я дал ему свойство зависимости с именем DateFormatProperty
типа string
и указало значение измененного обратного вызова в UIPropertyMetadata
.
<Grid>
<TextBlock Name="datedisplayer" />
</Grid>
Обратный звонок:
private static void DateFormatChanged( DependencyObject obj, DependencyPropertyChangedEventArgs e ) {
var uc = obj as UserControl1;
string code;
if ( null != ( code = e.NewValue as string ) ) {
uc.datedisplayer.Text = DateTime.Now.ToString( code );
}
}
И вот как я все это связал в Окне.
<StackPanel>
<StackPanel.DataContext>
<local:ViewModel />
</StackPanel.DataContext>
<ComboBox
ItemsSource="{Binding Choices}" DisplayMemberPath="CurrentDateExample"
SelectedItem="{Binding Chosen, Mode=TwoWay}"/>
<local:UserControl1
DateFormatProperty="{Binding Chosen.FormatCode}" />
</StackPanel>