OTSMeasureOutputNlog.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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 OxfordExtenderWrapper
  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. private void button1_Click(object sender, EventArgs e)
  37. {
  38. log.Trace("Trace");
  39. log.Debug("Debug");
  40. log.Info("Info");
  41. log.Warn("Warn");
  42. log.Error("Error");
  43. log.Fatal("Fatal THIS IS A LOG WHICH USED TO TEST THE LOG LENTH FIT TO THE FORM!");
  44. }
  45. private void button_Clear_Click(object sender, EventArgs e)
  46. {
  47. richTextBox_Nlog.Clear();
  48. }
  49. private void combox_NlogType_SelectedIndexChanged(object sender, EventArgs e)
  50. {
  51. if (null == combox_NlogType.SelectedItem) return;
  52. String str = combox_NlogType.SelectedItem.ToString(); // 获取日志级别.
  53. LogLevel lv = LogLevel.Info; // 若选择的值无效, 则当作 Info级.
  54. lv = LogLevel.FromString(str);
  55. LoggingRule lr = LogManager.Configuration.LoggingRules.FirstOrDefault(
  56. r => r.Targets.Any(
  57. t => "control" == t.Name
  58. )
  59. );
  60. if (lr != null)
  61. {
  62. lr.SetLoggingLevels(lv, LogLevel.Fatal);
  63. LogManager.ReconfigExistingLoggers(); // 使配置生效.
  64. }
  65. }
  66. private void button_stop_Click(object sender, EventArgs e)
  67. {
  68. if (button_stop.Text == "Stop")
  69. {
  70. LoggingRule lr = LogManager.Configuration.LoggingRules.FirstOrDefault(
  71. r => r.Targets.Any(
  72. t => "control" == t.Name
  73. )
  74. );
  75. LogManager.Configuration.LoggingRules.Remove(lr);
  76. LogManager.ReconfigExistingLoggers();
  77. button_stop.Text = "Start";
  78. }
  79. else
  80. {
  81. if (null == combox_NlogType.SelectedItem) return;
  82. String str = combox_NlogType.SelectedItem.ToString();
  83. LogManager.Configuration.AddRule(LogLevel.FromString(str), LogLevel.Fatal, "control");
  84. LogManager.ReconfigExistingLoggers(); // 使配置生效.
  85. button_stop.Text = "Stop";
  86. }
  87. }
  88. }
  89. }