zoukankan      html  css  js  c++  java
  • windows控制台中使用不同颜色显示不同类型的日志

    主要是使用函数”SetConsoleTextAttribute“来实现不同类型的日志,采用不同的颜色来打印日志内容。

    BOOL SetConsoleTextAttribute( HANDLE hConsoleOutput, // handle to console screen buffer 

                WORD wAttributes // text and background colors);

    该函数对调用之后日志有效。

    HANDLE hConsoleOutput    -- 输出窗口句柄

    WORD wAttributes             -- 属性设置   可通过逻辑或运算符(|)连接各个属性分量

    ++++++++++++++++++++++

    FOREGROUND_BLUE                              文字蓝色

    FOREGROUND_GREEN                            文字绿色

    FOREGROUND_RED                               文字红色

    FOREGROUND_INTENSITY                      加亮文字颜色(提高亮度)

    BACKGROUND_BLUE                              背景蓝色

    BACKGROUND_GREEN                            背景绿色

    BACKGROUND_RED                               背景红色

    BACKGROUND_INTENSITY                     加亮背景颜色(提高亮度)

    COMMON_LVB_GRID_HORIZONTAL         为打印文字添加上划线

    COMMON_LVB_UNDERSCORE                 为打印文字添加下划线


    通过组合这些属性可以产生不同的颜色(加法三原色原理)

    如:FOREGROUND_INTENSITY | FOREGROUND_GREEN | FOREGROUND_BLUE      青色加亮

    (1)加法三原色

    (2)前景色(FOREGROUND)和背景色(BACKGROUND)

        前景色:画笔的颜色,这儿指文字的颜色。

        背景色:画布的颜色,这儿指控制台背景的颜色。

    控制台打印日志示例code:

    1 #pragma once
    2
    3 typedef enum errorLev
    4 {
    5 TRACE_LEV = 0,
    6 INFO_LEV,
    7 WARNNING_LEV,
    8 ERROR_LEV,
    9 FAULT_LEV
    10 }errorLev;
    11
    12  const char* err_headers[] =
    13 {
    14 "TRACE: ",
    15 "INFO: ",
    16 "WARNNING: ",
    17 "ERROR: ",
    18 "FAULT: "
    19 };
    20
    21
    22
    23  void println(const char* msg, errorLev err_lev=ERROR_LEV)
    24 {
    25 intptr_t handle= (intptr_t)GetStdHandle(STD_OUTPUT_HANDLE);
    26 switch (err_lev)
    27 {
    28 case TRACE_LEV:
    29 // 文字绿色
    30   SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_GREEN);
    31 break;
    32 case INFO_LEV:
    33 // 文字青色
    34 SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_GREEN | FOREGROUND_BLUE);
    35 break;
    36 case WARNNING_LEV:
    37 // 文字黄色
    38 SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_RED | FOREGROUND_GREEN);
    39 break;
    40 case ERROR_LEV:
    41 // 文字品红色
    42 SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_RED | FOREGROUND_BLUE);
    43 break;
    44 case FAULT_LEV:
    45 // 文字红色
    46 SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_RED);
    47 break;
    48 default:
    49 // 文字白色
    50 SetConsoleTextAttribute((HANDLE)handle, FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE);
    51 break;
    52 }
    53 printf("%s%s\n", err_headers[err_lev], msg);
    54 }
  • 相关阅读:
    小程序云开发(一)
    原来你是这样的"layui"啊
    记个笔记(项目中遇到的关于input的一些操作)
    vue的学习之路 vue-cli与axios
    小程序 上传图片
    文字滚动
    css 隐藏滚动条
    linux基础
    接口测试
    整理python循环,列表,字典笔记
  • 原文地址:https://www.cnblogs.com/kekec/p/1918066.html
Copyright © 2011-2022 走看看