如何将组合框绑定替换为按钮

本文关键字:替换 按钮 绑定 组合 | 更新日期: 2023-09-27 18:33:59

我的代码在文件中定义的函数调用.cs生成面板。代码中使用了 ItemControl 来生成这些面板。每个面板都有它的TextboxSliderCombobox

每个面板的滑块和组合框都与 TextBox.Text 一起播放,如下所示:

  1. 用于增加文本框文本字体大小的滑块。

  2. 用于选择文本框文本对齐方式的组合框。

我想用带有内容Left的按钮替换组合框。因此,当我单击按钮时,它的内容必须更改为Right,同样地从Right更改为Left.,以更改Alignment

谁能解决我的问题?这里的代码是:

XAML 文件:

<ItemsControl x:Name="lstItemsClassM" >
        <ItemsControl.ItemTemplate>
            <DataTemplate>
                <StackPanel Orientation="Vertical">
                <ComboBox x:Name="cboOccupation" IsEditable="False" HorizontalAlignment="Left"
        Text="{Binding Path=Alignment, Mode=TwoWay}"
        Margin="4" Width="140">
                        <ComboBoxItem>Right</ComboBoxItem>
                        <ComboBoxItem>Left</ComboBoxItem>
                    </ComboBox>
                    <Button Content="{Binding Alignment, Mode=TwoWay}" Click="Button_Click" Tag="{Binding PKId}" SourceUpdated="Button_SourceUpdated" />
                    <TextBox x:Name="txtText" Width="300" Height="100" Text="{Binding Text;, Mode=TwoWay}" FontSize="{Binding FontSize, Mode=OneWay}" TextAlignment="{Binding Alignment, Mode=OneWay}"  />
                    <Slider Minimum="10" Maximum="30" Value="{Binding FontSize, Mode=TwoWay}" />
                </StackPanel>
            </DataTemplate>
        </ItemsControl.ItemTemplate>
    </ItemsControl>

.cs文件

 public partial class Window2 : Window
{
    protected ObservableCollection<ClassM> texts = new ObservableCollection<ClassM>();
    int dv;
    public Window2()
    {
        InitializeComponent();
        dv=1;
        texts.Add(new ClassM() { PKId=dv, Text = "Test 1" });
        dv=2;
        texts.Add(new ClassM() { PKId=dv, Text = "Test 2" });
        lstItemsClassM.ItemsSource = texts;
    }
    private void Button_Click(object sender, RoutedEventArgs e)
    {
        var myValue = ((Button)sender).Tag;
      foreach (var f in texts.ToList())
            {
                if (f.PKId.ToString() == myValue.ToString())
                {
                    f._alignment = "Right";
                    MessageBox.Show(f._alignment);
                }
            }
    }
    private void Button_SourceUpdated(object sender, DataTransferEventArgs e)
    {
        var myValue = ((Button)sender).Tag;
       foreach (var f in texts.ToList())
        {
            if (f.PKId.ToString() == myValue.ToString())
            {
                f._alignment = "Right";
                MessageBox.Show(f._alignment);
            }
        }
    }

}

public class ClassM : INotifyPropertyChanged
{
    private string _id;
    private int _pkid;
    private string _text;
    private double _fontSize = 10;
    public bool _isChecked { get; set; }
    public string _alignment="Left";
    public int PKId
    {
        get { return _pkid; }
        set
        {
            if (value != _pkid)
            {
                _pkid = value;
                NotifyPropertyChanged();
            }
        }
    }
    public string Id
    {
        get { return _id; }
        set
        {
            if (value != _id)
            {
                _id = value;
                NotifyPropertyChanged();
            }
        }
    }
    public bool IsChecked
    {
        get { return _isChecked; }
        set
        {
            if (value != _isChecked)
            {
                _isChecked = value;
                NotifyPropertyChanged();
            }
        }
    }
    public string Text
    {
        get { return _text; }
        set
        {
            if (value != _text)
            {
                _text = value;
                NotifyPropertyChanged();
            }
        }
    }
    public double FontSize
    {
        get { return _fontSize; }
        set
        {
            if (value != _fontSize)
            {
                _fontSize = value;
                NotifyPropertyChanged();
            }
        }
    }
    public string Alignment
    {
        get { return _alignment; }
        set
        {
            if (value != _alignment)
            {
                _alignment = value;
                NotifyPropertyChanged();
            }
        }
    }
    public event PropertyChangedEventHandler PropertyChanged;
    protected void NotifyPropertyChanged(String propertyName = "")
    {
        if (PropertyChanged != null)
        {
            PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }
    }
}

}

如何将组合框绑定替换为按钮

TextBox.TextAlignment 属性的枚举类型为 System.Windows.TextAlignment

如果你想绑定它而不必实现你自己的值转换器,那么你希望用实际的枚举值填充 ComboBox,而不仅仅是一个同名的字符串,如"左"和"右"......

以下是如何使组合框表示文本对齐:

<ComboBox>
    <ComboBox.Items>
        <TextAlignment>Left</TextAlignment>
        <TextAlignment>Right</TextAlignment>
    </ComboBox.Items>
</ComboBox>

现在,您可以将组合框的SelectedItem属性绑定到文本框的TextAlignment属性。

或者,在您的情况下,如果要将两者绑定到基础数据上下文,则需要更改以下内容:

private string _alignment = "Left";

对此:

private TextAlignment _alignment = TextAlignment.Left;