.NET 5 WPF 如何开启控制台界面用于实时输出日志

编程开发
431
WPF
.NET5
cefsharp
开启控制台
实时输出日志

.NET 5 WPF 如何开启控制台界面用于实时输出日志 这两天升级博客程序之余也做了些附加程序 其中一个是WPF集成cefsharp浏览器控件(.NET 5 更新支持了WPF 这就很棒) 做了个网页自动化定时任务程序,但由于界面空间全给了浏览器控件导致没有足够的位置来显示日志给我自己看

WPF启用控制台窗口

想着以前做.net framework开发时 wpf 是可以直接开启控制台模式的 只需要把属性里的输出类型改为控制台 启动就可以兼顾界面和控制台,如下图设置 (通过控制台实时看日志配合wpf界面配置可视化操作 还是挺方便的)

.NET 5 WPF 如何开启控制台界面用于实时输出日志

WinAPI实现文本输出

有了控制台页面输出 但此时的控制台是无法直接通过Console.Write() 代码来输出文本的,.NET 5 还需要另外调用WinAPI 才能实现文本日志的输出。

核心效果实现代码:

    public static class ConsoleManager
    {
        private const string Kernel32_DllName = "kernel32.dll";
        [DllImport(Kernel32_DllName)]
        private static extern bool AllocConsole();
        [DllImport(Kernel32_DllName)]
        private static extern bool FreeConsole();
        [DllImport(Kernel32_DllName)]
        private static extern IntPtr GetConsoleWindow();
        [DllImport(Kernel32_DllName)]
        private static extern int GetConsoleOutputCP();
        public static bool HasConsole
        {
            get { return GetConsoleWindow() != IntPtr.Zero; }
        }
            get { return GetConsoleWindow() != IntPtr.Zero; }
        }
        /// Creates a new console instance if the process is not attached to a console already.  
        public static void Show()
        {

            if (!HasConsole)
            {
                AllocConsole();
                InvalidateOutAndError();
            }

#if DEBUG
            if (!HasConsole)
            {
                AllocConsole();
                InvalidateOutAndError();
            }
#endif
        }
        /// If the process has a console attached to it, it will be detached and no longer visible. Writing to the System.Console is still possible, but no output will be shown.   
        public static void Hide()
        {
#if DEBUG
            if (HasConsole)
            {
                SetOutAndErrorNull();
                FreeConsole();
            }
#endif
        }
        public static void Toggle()
        {
            if (HasConsole)
            {
                Hide();
            }
            else
            {
                Show();
            }
        }
        static void InvalidateOutAndError()
        {
            Type type = typeof(System.Console);
            System.Reflection.FieldInfo _out = type.GetField("_out",
                System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);
            System.Reflection.FieldInfo _error = type.GetField("_error",
                System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);
            System.Reflection.MethodInfo _InitializeStdOutError = type.GetMethod("InitializeStdOutError",
                System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.NonPublic);
            //Debug.Assert(_out != null);
            //Debug.Assert(_error != null);
            //Debug.Assert(_InitializeStdOutError != null);
            //_out.SetValue(null, null);
            //_error.SetValue(null, null);
            //_InitializeStdOutError.Invoke(null, new object[] { true });
        }
        static void SetOutAndErrorNull()
        {
            Console.SetOut(TextWriter.Null);
            Console.SetError(TextWriter.Null);
        }
    }

最终代码调用实例

 ConsoleManager.Show();//开启控制台

最后程序启动的时候调用一次即可

.NET5 webApi项目接收HttpPost文本流数据
WPF实现窗体接收鼠标拖拽的文件例子
一次使用AutoResetEvent的经历:在Task并发环境下导致UI线程卡死 内存一直上涨
.NET5框架下使用HttpListener类实现http接口监听替代OWIN自我寄宿
Cefrsharp实现自动模拟采集网页
WPF桌面程序开发怎么实现鼠标窗体穿透点击桌面
在.NET CORE\.NET 5 下WPF如何实现托盘图标功能
WPF中某一个控件绑定其他指定UI控件的属性值
.NET程序系统托盘运行出现多个同样的托盘图标的解决方法
CefSharp 运行缓存数据量过大占完系统磁盘空间
Windows桌面开发优秀的WPF界面开源UI组件 MahApps.Metro
WPF 设置程序不允许同一类程序多开进程
暂无相关内容...
C#+WPF实现模仿实现的网易云音乐客户端源码
WPF实现的自定义工作大日历排班Calendar控件模板的例子源码
wpf实现大屏幕弹幕播放效果特效源码新手可参考下.rar
[人脸检测]基于C#OpenCvSharp+haarcascade人脸、人眼模型实现人脸检测源码
WPF实现读取USB摄像头实时视频展示以及导出实时截图的C#源码例子
免责声明 部分转载分享内容若侵犯您的权益,还请 邮件联系 侵删