zoukankan      html  css  js  c++  java
  • WPF之AvalonEdit实现MVVM双向绑定

    AvalonEdit简介

    AvalonEdit是基于WPF开发的代码显示控件,默认支持多种不同语言的关键词高亮,并且可以自定义高亮配置。所以通过AvalonEdit可以快速开发出自己想要的代码编辑器。

    通过Nuget安装AvalonEdit,并在页面添加控件

     <avalonEdit:TextEditor
                            xmlns:avalonEdit="http://icsharpcode.net/sharpdevelop/avalonedit"
                            Name="TextEditor"
                            SyntaxHighlighting="C#"
                            FontFamily="Consolas"
                            FontSize="14"
                            WordWrap ="True"
                            LineNumbersForeground="#FF2B91AF"
                            ShowLineNumbers="True">
         <avalonEdit:TextEditor.Options>
             <avalonEdit:TextEditorOptions ShowSpaces="True" WordWrapIndentation="4" InheritWordWrapIndentation="true">
                 <avalonEdit:TextEditorOptions.ColumnRulerPosition>
                     <system:Int32>10</system:Int32>
                 </avalonEdit:TextEditorOptions.ColumnRulerPosition>
             </avalonEdit:TextEditorOptions>
         </avalonEdit:TextEditor.Options>
    </avalonEdit:TextEditor>
    

    参数含义

    • xmlns:avalonEdit:命名空间,也可以直接写在调用该控件的窗体内

    • SyntaxHighlighting:设置高亮

    • ShowLineNumbers:是否显示行号

    • LineNumbersForeground:设置编辑器行号颜色

    • ShowSpaces:是否显示空格

    • WordWrapIndentation:换行缩进距离

    • InheritWordWrapIndentation:是否继承上一行的换行缩进

    自定义高亮配置

    比如AvalonEdit默认支持的sql语法高亮不够强大或者不符合要求,可以自定义配置注册进行。

    首先,在项目中引入一个.xshd文件,具体规则可以参考官网介绍。这里提供一个sql.xshd文件,描述了对SQL语法的高亮支持。

    在程序启动的时候读取该配置文件,并注册到AvalonEdit中。

    using (var stream = Assembly.GetExecutingAssembly().GetManifestResourceStream(Assembly.GetExecutingAssembly().GetName().Name + ".sql.xshd"))
    {
        using (var reader = new System.Xml.XmlTextReader(stream))
        {
            var sqlDefinition = HighlightingLoader.Load(reader, HighlightingManager.Instance);
            HighlightingManager.Instance.RegisterHighlighting("SQL", new string[] { ".sql" }, sqlDefinition);
    	}
    }
    

    ps:这里是将sql.xshd的生成操作设置为了嵌入的资源,也可以将其输出到目录再读取内容。

    如果需要在项目运行过程中,切换高亮语法支持,可以这么做

    textEditor.SyntaxHighlighting = HighlightingManager.Instance.GetDefinition("SQL");
    

    看下高亮效果:

    MVVM绑定AvalonEdit文本内容

    当我尝试直接将ViewModel中的字符串直接绑定到Text上时,编辑器就报错了,因为Text属性并不是可以直接绑定的依赖属性。

    Object of type 'System.Windows.Data.Binding' cannot be converted to type 'System.String'.

    最后鼓捣一通后的解决方案是使用Microsoft.Xaml.Behaviors包(其实是微软以前System.Windows.Interactivity的开源版)。

    xaml代码

    <avalonEdit:TextEditor Name="TextEditor">
        <i:Interaction.Behaviors>
            <local:AvalonEditBehaviour InputText="{Binding InputString}"/>
        </i:Interaction.Behaviors>
    </avalonEdit:TextEditor>
    

    后端代码

    public sealed class AvalonEditBehaviour : Behavior<TextEditor>
    {
        public static readonly DependencyProperty InputTextProperty =
            DependencyProperty.Register("InputText", typeof(string), typeof(AvalonEditBehaviour),
            new FrameworkPropertyMetadata(default(string), FrameworkPropertyMetadataOptions.BindsTwoWayByDefault, null));
    
        public string InputText
        {
            get { return (string)GetValue(InputTextProperty); }
            set { SetValue(InputTextProperty, value); }
        }
    
        protected override void OnAttached()
        {
            base.OnAttached();
            if (AssociatedObject != null)
            {
                AssociatedObject.TextChanged += AssociatedObjectOnTextChanged;
            }
        }
    
        protected override void OnDetaching()
        {
            base.OnDetaching();
            if (AssociatedObject != null)
            {
                AssociatedObject.TextChanged -= AssociatedObjectOnTextChanged;
            }
        }
    
        private void AssociatedObjectOnTextChanged(object sender, EventArgs eventArgs)
        {
            var textEditor = sender as TextEditor;
            if (textEditor != null)
            {
                if (textEditor.Document != null)
                {
                    InputText = textEditor.Document.Text;
                }
            }
        }
    }
    

    最后看一下实际效果吧

    项目Demohttps://github.com/fxhui/DatabaseManagement

  • 相关阅读:
    MS SQL float转nvarchar
    RDLC添加页码
    RDLC报表分页显示标题
    程序员必读书单
    SQL查询结果增加序号列
    SQL字符串分组聚合(分组后的数据查询后用逗号隔开)
    现在有一列是int的,把它变成5位的字符串,左边不够的补0
    oracle客户端精简绿色版-环境变量配置
    DISTINCT后按照DISTINCT之前的某列进行排序
    设计模式之代理模式
  • 原文地址:https://www.cnblogs.com/cplemom/p/15753168.html
Copyright © 2011-2022 走看看