OTSMeasureOutputNlog.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. using NLog;
  2. using NLog.Config;
  3. using NLog.Targets;
  4. //using OTS.WinFormsUI.Docking;
  5. using System;
  6. using System.Collections;
  7. using System.ComponentModel;
  8. using System.Data;
  9. using System.Drawing;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Forms;
  14. namespace OxfordTest
  15. {
  16. public partial class OTSMeasureOutputNlog: Form
  17. {
  18. //OTSSysMgrTools.Language lan;
  19. //Hashtable table;
  20. protected static NLog.Logger log;
  21. public OTSMeasureOutputNlog()
  22. {
  23. InitializeComponent();
  24. }
  25. private void OTSMeasureOutputNlog_Load(object sender, EventArgs e)
  26. {
  27. combox_NlogType.Items.Add("Trace");
  28. combox_NlogType.Items.Add("Debug");
  29. combox_NlogType.Items.Add("Info");
  30. combox_NlogType.Items.Add("Warn");
  31. combox_NlogType.Items.Add("Error");
  32. combox_NlogType.Items.Add("Fatal");
  33. combox_NlogType.SelectedIndex = 0;
  34. log = NLog.LogManager.GetCurrentClassLogger();
  35. //国际
  36. //lan = new OTSSysMgrTools.Language(this);
  37. //table = lan.GetNameTable(this.Name);
  38. //label1.Text = table["label1"].ToString();
  39. //button_Clear.Text = table["button_clear"].ToString();
  40. }
  41. private void button1_Click(object sender, EventArgs e)
  42. {
  43. log.Trace("Trace");
  44. log.Debug("Debug");
  45. log.Info("Info");
  46. log.Warn("Warn");
  47. log.Error("Error");
  48. log.Fatal("Fatal THIS IS A LOG WHICH USED TO TEST THE LOG LENTH FIT TO THE FORM!");
  49. }
  50. private void button_Clear_Click(object sender, EventArgs e)
  51. {
  52. richTextBox_Nlog.Clear();
  53. }
  54. private void combox_NlogType_SelectedIndexChanged(object sender, EventArgs e)
  55. {
  56. if (null == combox_NlogType.SelectedItem) return;
  57. String str = combox_NlogType.SelectedItem.ToString(); // 获取日志级别.
  58. LogLevel lv = LogLevel.Info; // 若选择的值无效, 则当作 Info级.
  59. lv = LogLevel.FromString(str);
  60. LoggingRule lr = LogManager.Configuration.LoggingRules.FirstOrDefault(
  61. r => r.Targets.Any(
  62. t => "control" == t.Name
  63. )
  64. );
  65. if (lr != null)
  66. {
  67. lr.SetLoggingLevels(lv, LogLevel.Fatal);
  68. LogManager.ReconfigExistingLoggers(); // 使配置生效.
  69. }
  70. }
  71. private void button_stop_Click(object sender, EventArgs e)
  72. {
  73. if (button_stop.Text == "Stop")
  74. {
  75. LoggingRule lr = LogManager.Configuration.LoggingRules.FirstOrDefault(
  76. r => r.Targets.Any(
  77. t => "control" == t.Name
  78. )
  79. );
  80. LogManager.Configuration.LoggingRules.Remove(lr);
  81. LogManager.ReconfigExistingLoggers();
  82. button_stop.Text = "Start";
  83. }
  84. else
  85. {
  86. if (null == combox_NlogType.SelectedItem) return;
  87. String str = combox_NlogType.SelectedItem.ToString();
  88. LogManager.Configuration.AddRule(LogLevel.FromString(str), LogLevel.Fatal, "control");
  89. LogManager.ReconfigExistingLoggers(); // 使配置生效.
  90. button_stop.Text = "Stop";
  91. }
  92. }
  93. }
  94. }