简体   繁体   English

WPF-为什么无法选择我的自定义文本框?

[英]WPF- Why can't my custom textbox be selected?

I have this custom textbox that I am working on and I can use it in xaml, but when I run my app I cannot select it or type in it. 我有一个正在使用的自定义文本框,可以在xaml中使用它,但是当我运行我的应用程序时,无法选择它或输入它。 Here is my code: 这是我的代码:

public class ModdedTextBox : TextBox
{
    private bool selectionStartChangeFromUI;
    private bool selectionLengthChangeFromUI;
    private bool selectedTextChangeFromUI;

    static ModdedTextBox()
    {
        DefaultStyleKeyProperty.OverrideMetadata(typeof(ModdedTextBox), new FrameworkPropertyMetadata(typeof(ModdedTextBox)));
        //this.SelectionChanged += this.OnSelectionChanged;
        //PropertyDescriptor VerticalOffsetProperty = TypeDescriptor.GetProperties(typeof(ModdedTextBox))["VerticalOffset"];
        //VerticalOffsetProperty.AddValueChanged(this, this.OnVerticalOffsetChanged);
    }
    public static readonly DependencyProperty BindableSelectionStartProperty =
    DependencyProperty.Register(
    "BindableSelectionStart",
    typeof(int),
    typeof(ModdedTextBox),
    new PropertyMetadata(OnBindableSelectionStartChanged));

    public static readonly DependencyProperty BindableSelectionLengthProperty =
        DependencyProperty.Register(
        "BindableSelectionLength",
        typeof(int),
        typeof(ModdedTextBox),
        new PropertyMetadata(OnBindableSelectionLengthChanged));

    public static readonly DependencyProperty BindableSelectedTextProperty =
        DependencyProperty.Register(
        "BindableSelectedText",
        typeof(string),
        typeof(ModdedTextBox),
        new PropertyMetadata(OnBindableSelectedTextChanged));
    public static readonly DependencyProperty DelayedTextProperty =
        DependencyProperty.Register(
        "DelayedText",
        typeof(string),
        typeof(ModdedTextBox),
        new PropertyMetadata(OnDelayedTextChanged));

    public int BindableSelectionStart
    {
        get
        {
            return (int)this.GetValue(BindableSelectionStartProperty);
        }

        set
        {
            this.SetValue(BindableSelectionStartProperty, value);
        }
    }

    public int BindableSelectionLength
    {
        get
        {
            return (int)this.GetValue(BindableSelectionLengthProperty);
        }

        set
        {
            this.SetValue(BindableSelectionLengthProperty, value);
        }
    }
    public string BindableSelectedText
    {
        get
        {
            return (string)this.GetValue(BindableSelectedTextProperty);
        }

        private set
        {
            this.SetValue(BindableSelectedTextProperty, value);
        }
    }
    public string DelayedText
    {
        get
        {
            return (string)this.GetValue(DelayedTextProperty);
        }

        private set
        {
            this.SetValue(DelayedTextProperty, value);
        }
    }

    private static void OnBindableSelectionStartChanged(DependencyObject dependencyObject, DependencyPropertyChangedEventArgs args)
    {
        var textBox = dependencyObject as ModdedTextBox;

        if (!textBox.selectionStartChangeFromUI)
        {
            int newValue = (int)args.NewValue;
            textBox.SelectionStart = newValue;
        }
        else
        {
            textBox.selectionStartChangeFromUI = false;
        }
    }

    private static void OnBindableSelectionLengthChanged(DependencyObject dependencyObject, DependencyPropertyChangedEventArgs args)
    {
        var textBox = dependencyObject as ModdedTextBox;

        if (!textBox.selectionLengthChangeFromUI)
        {
            int newValue = (int)args.NewValue;
            textBox.SelectionLength = newValue;
        }
        else
        {
            textBox.selectionLengthChangeFromUI = false;
        }
    }
    private static void OnBindableSelectedTextChanged(DependencyObject dependencyObject, DependencyPropertyChangedEventArgs args)
    {
        var textBox = dependencyObject as ModdedTextBox;

        if (!textBox.selectedTextChangeFromUI)
        {
            string newValue = (string)args.NewValue;
            textBox.BindableSelectedText = newValue;
        }
        else
        {
            textBox.selectedTextChangeFromUI = false;
        }
    }
    private static void OnDelayedTextChanged(DependencyObject dependencyObject, DependencyPropertyChangedEventArgs args)
    {
    }
    private void OnSelectionChanged(object sender, RoutedEventArgs e)
    {
        if (this.BindableSelectionStart != this.SelectionStart)
        {
            this.selectionStartChangeFromUI = true;
            this.BindableSelectionStart = this.SelectionStart;
        }

        if (this.BindableSelectionLength != this.SelectionLength)
        {
            this.selectionLengthChangeFromUI = true;
            this.BindableSelectionLength = this.SelectionLength;
        }
        if (this.BindableSelectedText != this.SelectedText)
        {
            this.selectedTextChangeFromUI = true;
            this.BindableSelectedText = this.SelectedText;
        }
    }
    private void OnVerticalOffsetChanged(object sender, EventArgs e)
    {
        MessageBox.Show("hello the vertical offset works");
    }
}

your control needs a style to display itself. 您的控件需要一种样式来显示自己。 comment out this one line from the constructor, to use default style 从构造函数中注释掉这一行,以使用默认样式

DefaultStyleKeyProperty.OverrideMetadata(typeof(ModdedTextBox), new FrameworkPropertyMetadata(typeof(ModdedTextBox)));

Done! 做完了!

edit: Alternatively this will explicitly make your control use TextBox style 编辑:或者,这将显式使您的控件使用TextBox样式

DefaultStyleKeyProperty.OverrideMetadata(
    typeof(ModdedTextBox),
    new FrameworkPropertyMetadata(typeof(TextBox)));

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM