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

2179 0
Honkers 2022-11-5 08:35:17 | 显示全部楼层 |阅读模式
目录

    文章描述开发环境开发工具实现代码实现效果


文章描述

一般情况下,我们的日志文件是用来记录一些关键操作或者异常,并且是后台存储,并不对外开放的;但是也有些时候,特别是做一些小工具程序,需要将一些操作步骤、记录等直接显示在窗体上。以便于使用者能够知道执行进度等情况。
所以,我们可以简单封装一下,写个专门用来输出日志的控件;并且以不同的颜色表示不同的状态,让日志更直观明了。
如果将以下自定义控件放到控件库中(即在新建项目的时候选择Windows窗体控件库),在其他程序中使用起来就很方便了,只要将这个dll拖到工具箱面板中,就可以在工具箱中看到这个控件。使用的时候直接从工具箱中拖出来就可以了。



开发环境

.NET Framework版本:4.5

开发工具

Visual Studio 2013

实现代码
  1. public partial class ui_log : ListBox
  2.     {
  3.         public ui_log()
  4.         {
  5.             InitializeComponent();
  6.             this.DrawMode = DrawMode.OwnerDrawFixed;
  7.             this.BackColor = Color.Black;
  8.             this.Font = new Font("黑体", 12);
  9.         }
  10.         protected override void OnPaint(PaintEventArgs pe)
  11.         {
  12.             base.OnPaint(pe);
  13.         }
  14.         protected override void OnDrawItem(DrawItemEventArgs e)
  15.         {
  16.             base.OnDrawItem(e);
  17.             if (e.Index >= 0 && this.Items.Count>0)
  18.             {
  19.                 dynamic item = this.Items[e.Index];
  20.                 Brush brush = new SolidBrush(item.Color);
  21.                 e.Graphics.DrawString(item.Text, e.Font, brush, e.Bounds, StringFormat.GenericDefault);
  22.             }
  23.         }
  24.         public  void Log(string text, Color color)
  25.         {
  26.             if (this.InvokeRequired)
  27.             {
  28.                 this.Invoke(new Action(() => { Log(text, color); }));
  29.                 return;
  30.             }
  31.             this.Items.Add(new { Color = color, Text = text });
  32.             this.SelectedIndex = this.Items.Count - 1;
  33.         }
  34.         public void LogInfo(string text)
  35.         {
  36.             Log(text, Color.Green);
  37.         }
  38.         public void LogError(string text)
  39.         {
  40.             Log(text, Color.Red);
  41.         }
  42.         public void LogWarinig(string text)
  43.         {
  44.             Log(text, Color.Yellow);
  45.         }
  46.         public void ClearLog()
  47.         {
  48.             this.Items.Clear();
  49.         }
  50.     }
复制代码
  1. private void button1_Click(object sender, EventArgs e)
  2.         {
  3.             ui_log1.LogInfo("Info");
  4.             Thread.Sleep(300);
  5.             ui_log1.LogError("Error");
  6.             Thread.Sleep(300);
  7.             ui_log1.LogWarinig("Warinig");
  8.             Thread.Sleep(300);
  9.             ui_log1.Log("White", Color.White);
  10.         }
  11.         private void button2_Click(object sender, EventArgs e)
  12.         {
  13.             ui_log1.ClearLog();
  14.         }
复制代码
实现效果



代码解析:首先是写了一个自定义控件,继承自ListBox;然后设置下DrawMode属性,这个很重要,否则不会触发DrawItem;最后在DrawItem事件中,对数据进行重绘。
做完上述处理后,就不要直接使用Items.Add了,需要对Items.Add也进行一次封装,将颜色也传进去,即:this.Items.Add(new { Color = color, Text = text });
到此这篇关于C#实现UI控件输出日志的方法详解的文章就介绍到这了,更多相关C# UI控件输出日志内容请搜索中国红客联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持中国红客联盟!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Honkers

荣誉红客

关注
  • 4008
    主题
  • 36
    粉丝
  • 0
    关注
这家伙很懒,什么都没留下!

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行