C#实现UI控件输出日志的方法详解

作者:Csharp小记 时间:2021-10-07 02:45:41 

文章描述

一般情况下,我们的日志文件是用来记录一些关键操作或者异常,并且是后台存储,并不对外开放的;但是也有些时候,特别是做一些小工具程序,需要将一些操作步骤、记录等直接显示在窗体上。以便于使用者能够知道执行进度等情况。

所以,我们可以简单封装一下,写个专门用来输出日志的控件;并且以不同的颜色表示不同的状态,让日志更直观明了。

如果将以下自定义控件放到控件库中(即在新建项目的时候选择Windows窗体控件库),在其他程序中使用起来就很方便了,只要将这个dll拖到工具箱面板中,就可以在工具箱中看到这个控件。使用的时候直接从工具箱中拖出来就可以了。

C#实现UI控件输出日志的方法详解

开发环境

.NET Framework版本:4.5

开发工具

Visual Studio 2013

实现代码

public partial class ui_log : ListBox
   {
       public ui_log()
       {
           InitializeComponent();

this.DrawMode = DrawMode.OwnerDrawFixed;
           this.BackColor = Color.Black;
           this.Font = new Font("黑体", 12);
       }

protected override void OnPaint(PaintEventArgs pe)
       {
           base.OnPaint(pe);
       }

protected override void OnDrawItem(DrawItemEventArgs e)
       {
           base.OnDrawItem(e);

if (e.Index >= 0 && this.Items.Count>0)
           {
               dynamic item = this.Items[e.Index];
               Brush brush = new SolidBrush(item.Color);
               e.Graphics.DrawString(item.Text, e.Font, brush, e.Bounds, StringFormat.GenericDefault);
           }
       }

public  void Log(string text, Color color)
       {
           if (this.InvokeRequired)
           {
               this.Invoke(new Action(() => { Log(text, color); }));
               return;
           }
           this.Items.Add(new { Color = color, Text = text });
           this.SelectedIndex = this.Items.Count - 1;
       }
       public void LogInfo(string text)
       {
           Log(text, Color.Green);
       }
       public void LogError(string text)
       {
           Log(text, Color.Red);
       }
       public void LogWarinig(string text)
       {
           Log(text, Color.Yellow);
       }

public void ClearLog()
       {
           this.Items.Clear();
       }
   }
private void button1_Click(object sender, EventArgs e)
       {
           ui_log1.LogInfo("Info");
           Thread.Sleep(300);
           ui_log1.LogError("Error");
           Thread.Sleep(300);
           ui_log1.LogWarinig("Warinig");
           Thread.Sleep(300);
           ui_log1.Log("White", Color.White);
       }

private void button2_Click(object sender, EventArgs e)
       {
           ui_log1.ClearLog();
       }

实现效果

C#实现UI控件输出日志的方法详解

代码解析:首先是写了一个自定义控件,继承自ListBox;然后设置下DrawMode属性,这个很重要,否则不会触发DrawItem;最后在DrawItem事件中,对数据进行重绘。

做完上述处理后,就不要直接使用Items.Add了,需要对Items.Add也进行一次封装,将颜色也传进去,即:this.Items.Add(new { Color = color, Text = text });

来源:https://mp.weixin.qq.com/s/jhH3Ov6kZDdfWdAci6vV3w

标签:C#,UI控件,输出,日志
0
投稿

猜你喜欢

  • SSM框架中测试单元的使用 spring整合Junit过程详解

    2022-07-01 14:46:48
  • 使用java为pdf添加书签的方法(pdf书签制作)

    2022-03-07 14:59:11
  • Java微信支付-微信红包

    2023-11-01 01:07:05
  • 一起来学习Java IO的转化流

    2023-11-26 20:38:30
  • SpringMVC实现表单验证功能详解

    2023-09-24 09:07:28
  • Spring Cloud动态配置刷新RefreshScope使用示例详解

    2022-05-23 15:05:32
  • 详解基于java的Socket聊天程序——初始设计(附demo)

    2023-02-01 06:46:21
  • Java流程控制语句之If选择结构

    2023-11-11 04:02:29
  • c#多线程的应用全面解析

    2023-03-03 21:15:02
  • Mybatis-Plus 多表联查分页的实现代码

    2023-11-25 04:59:07
  • JVM垃圾收集器详解

    2022-10-06 10:46:00
  • Java事件监听机制讲解

    2022-09-18 00:41:11
  • bool当成函数参数错误理解

    2021-07-30 09:27:18
  • Java多线程wait()和notify()方法详细图解

    2021-09-19 20:27:32
  • SpringBoot JPA实现增删改查、分页、排序、事务操作等功能示例

    2023-06-27 23:54:05
  • Java设计模式之动态代理模式实例分析

    2022-07-07 17:55:07
  • java中JSONObject转换为HashMap(方法+main方法调用实例)

    2023-08-10 04:04:08
  • 深入理解Spring中bean的生命周期介绍

    2023-02-08 17:21:37
  • Java 详解循环屏障CyclicBarrier如何实现多线程分段等待执行完成

    2022-02-16 04:50:49
  • BeanDefinitionRegistryPostProcessor如何动态注册Bean到Spring

    2023-11-24 12:56:16
  • asp之家 软件编程 m.aspxhome.com