如何将转换器用于日历的texblock?

时间:2019-01-04 12:31:05

标签: c# wpf data-binding

我正在尝试在日历控件中添加新列以添加星期数。我找到了一个可以完美运行的示例,问题很简单,它在后面使用代码,我想在另一个类中使用MVVM和转换器,而在后面的代码中不使用。

然后我发现的示例是这样:

<Window x:Class="CalendarioNumeroSemana.MainWindow"
        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"
        xmlns:local="clr-namespace:CalendarioNumeroSemana"
        xmlns:app="clr-namespace:CalendarioNumeroSemana"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <Calendar Grid.IsSharedSizeScope="True" HorizontalAlignment="Left" Margin="209,116,0,0" VerticalAlignment="Top">
            <Calendar.CalendarDayButtonStyle>
                <Style TargetType="{x:Type CalendarDayButton}">
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding Path=(Grid.Column),RelativeSource={RelativeSource Mode=Self}}" 
                                     Value="0">
                            <Setter Property="ContentTemplate">
                                <Setter.Value>
                                    <DataTemplate>
                                        <Grid HorizontalAlignment="Right">
                                            <Grid.ColumnDefinitions>
                                                <ColumnDefinition SharedSizeGroup="XX"/>
                                                <ColumnDefinition SharedSizeGroup="YY"/>
                                            </Grid.ColumnDefinitions>
                                            <Border  BorderThickness="0,0,0,0" BorderBrush="Black" Margin="-15,0,0,0">
                                                <TextBlock  Margin="0,0,2,0" FontWeight="Bold">
                                                    <TextBlock.Text>
                                                        <Binding Path="DataContext">
                                                            <Binding.Converter>
                                                                <app:WeekNumberConverter />
                                                            </Binding.Converter>
                                                            <Binding.RelativeSource>
                                                                <RelativeSource Mode="FindAncestor"
                                                                                AncestorType="{x:Type CalendarDayButton}"/>
                                                            </Binding.RelativeSource>
                                                        </Binding>
                                                    </TextBlock.Text>
                                                </TextBlock>
                                            </Border>
                                            <TextBlock Text="{Binding }" Grid.Column="1" HorizontalAlignment="Center"/>
                                        </Grid>
                                    </DataTemplate>
                                </Setter.Value>
                            </Setter>
                        </DataTrigger>
                    </Style.Triggers>

                </Style>
            </Calendar.CalendarDayButtonStyle>
        </Calendar>

    </Grid>
</Window>



namespace CalendarioNumeroSemana
{
    /// <summary>
    /// Lógica de interacción para MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
    }




    public class WeekNumberConverter : IValueConverter
    {
        public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            if (value is DateTime)
            {
                DateTime dt = (DateTime)value;
                return getNumeroSemenaIso8601(dt);
            }
            return value;

        }

        public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            throw new NotImplementedException();
        }





        private int getNumeroSemenaIso8601(DateTime paramFecha)
        {
            System.Globalization.Calendar miCalendario = CultureInfo.InvariantCulture.Calendar;

            DateTime miDtFechaBase = paramFecha;

            DayOfWeek miDiaSemana = miCalendario.GetDayOfWeek(paramFecha);


            if (miDiaSemana == DayOfWeek.Monday) { miDtFechaBase = miDtFechaBase.AddDays(3); }

            if (miDiaSemana == DayOfWeek.Tuesday) { miDtFechaBase = miDtFechaBase.AddDays(2); }

            if (miDiaSemana == DayOfWeek.Wednesday) { miDtFechaBase = miDtFechaBase.AddDays(1); }

            if (miDiaSemana == DayOfWeek.Friday) { miDtFechaBase = miDtFechaBase.AddDays(-1); }

            if (miDiaSemana == DayOfWeek.Saturday) { miDtFechaBase = miDtFechaBase.AddDays(-2); }

            if (miDiaSemana == DayOfWeek.Sunday) { miDtFechaBase = miDtFechaBase.AddDays(-3); }


            return miCalendario.GetWeekOfYear(miDtFechaBase, CalendarWeekRule.FirstFourDayWeek, DayOfWeek.Monday);
        }
    }
}

但是我想在我的应用程序中使用它,因为它使用了MVVM,并且我拥有转换器来获取另一个类中的星期数。

我的axml是这样的:

<Calendar Grid.IsSharedSizeScope="True" HorizontalAlignment="Left" Margin="5,5,5,5" Padding="0,0,0,0" VerticalAlignment="Top">
    <Calendar.CalendarDayButtonStyle>
        <Style TargetType="{x:Type CalendarDayButton}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding Path=(Grid.Column),RelativeSource={RelativeSource Mode=Self}}" 
                         Value="0">
                    <Setter Property="ContentTemplate">
                        <Setter.Value>
                            <DataTemplate>
                                <Grid HorizontalAlignment="Right">
                                    <Grid.ColumnDefinitions>
                                        <ColumnDefinition SharedSizeGroup="XX"/>
                                        <ColumnDefinition SharedSizeGroup="YY"/>
                                    </Grid.ColumnDefinitions>
                                    <Border  BorderThickness="0,0,0,0" BorderBrush="Black" Margin="-15,0,0,0">
                                        <TextBlock  Margin="0,0,2,0" FontWeight="Bold">
                                            <TextBlock.Text>
                                                <Binding Path="DataContext">
                                                    <Binding.Converter>
                                                        <app:WeekNumberConverter />
                                                    </Binding.Converter>
                                                    <Binding.RelativeSource>
                                                        <RelativeSource Mode="FindAncestor"
                                                                    AncestorType="{x:Type CalendarDayButton}"/>
                                                    </Binding.RelativeSource>
                                                </Binding>
                                            </TextBlock.Text>
                                        </TextBlock>
                                    </Border>
                                    <TextBlock Text="{Binding }" Grid.Column="1" HorizontalAlignment="Center"/>
                                </Grid>
                            </DataTemplate>
                        </Setter.Value>
                    </Setter>
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Calendar.CalendarDayButtonStyle>
</Calendar>

我的主要问题是我不知道如何更改binding.text的代码,后来,在TextBlock Text中,它使用Binding,但是我不知道这是什么绑定。

我尝试过类似的事情:

<TextBlock.Text>
                                                            <Binding Converter="{StaticResource NumeroSemanaValueConverter}"/>
                                                        </TextBlock.Text>

但是在转换器中,我没有看到日期,只有第一个按钮的日期。我需要日期。

那么我该如何适应原始代码?

谢谢。

1 个答案:

答案 0 :(得分:1)

这与MVVM无关。这是纯控制逻辑。该控件的模板使用转换器来获取星期数。转换器只是一个类,模板只是一个模板。

因此,您发现的示例一定可以在MVVM应用程序中使用。它只是带有自定义模板的内置控件。据我所知,没有涉及应该属于视图模型的视图模型或逻辑。