C#更改控制台文本的前景色和背景色

C#更改控制台文本的前景色和背景色关键字:C# NET 控制台 前景色 背景色地址:http://www.cnblogs.com/txw1958/archive/2012/12/07/csharp-console-color.htmlThis step-by-step article describes how to change

C#更改控制台文本的前景色和背景色"

关键字:C# NET 控制台 前景色 背景色
地址:http://www.cnblogs.com/txw1958/archive/2012/12/07/csharp-console-color.html

 

This step-by-step article describes how to change the foreground and background colors of the text that is written to the Console window by using Visual C#.

This article describes how to save the original settings of the Console window as the program starts, how to modify the color settings, and how to restore the colors to their original values as the program quits. 

Introduction

To change the foreground and background colors of text that the Console window displays, use the SetConsoleTextAttributeWin32 application programming interface (API) function. This function sets the attributes of the characters that are written to the screen buffer. 

When you change these attributes at run time, the changes are valid for as long as the Console window is open. If you close and reopen the Console window, the attributes are reset to their default values. If you execute the program from a command line in a Console window that is already running, changes that you make to the text attributes are valid for that Console window for as long as the window is open, even after your program quits. Therefore, an program should restore the original color attributes before the program quits. 

You can obtain the text attributes of the Console window by using the GetConsoleScreenBufferInfo API function. This function fills an instance of the CONSOLE_SCREEN_BUFFER_INFO structure with information about the current output buffer settings. ThewAttribute parameter of this structure contains the color information that defines the foreground and background colors of the text. The possible colors are any color combination that can be created by combining red, green, and blue.

   OriginalColors = ConsoleInfo.wAttributes;
   SetConsoleTextAttribute(hConsoleHandle, color);

You can use the ResetColor method to reset the output buffer attributes of the Console window to the original values that are captured when the program begins its execution.

   SetConsoleTextAttribute(hConsoleHandle, OriginalColors);

Step-by-Step Example

  1. In Visual Studio .NET or Visual Studio 2005, create an new Visual C# Console Application project.
  2. In Solution Explorer, right-click your project, click Add, and then select Add Class to add a new class to your program.
  3. Paste the following sample code in the class that is created. Verify that the sample code replaces all of existing the code in the class.
   using System;
   using System.Runtime.InteropServices;

   namespace ConsoleColor
   {
      /// Summary description for Class2.
      public class Class2
      {
         private int hConsoleHandle;
         private COORD ConsoleOutputLocation;
         private CONSOLE_SCREEN_BUFFER_INFO ConsoleInfo;
         private int OriginalColors;

         private const int  STD_OUTPUT_HANDLE = -11;

         [DllImport("kernel32.dll", EntryPoint="GetStdHandle", SetLastError=true,
                         CharSet=CharSet.Auto,
                         CallingConvention=CallingConvention.StdCall)]
        private static extern int GetStdHandle(int nStdHandle);

         [DllImport("kernel32.dll", EntryPoint="GetConsoleScreenBufferInfo",
                         SetLastError=true, CharSet=CharSet.Auto,
                         CallingConvention=CallingConvention.StdCall)]
        private static extern int GetConsoleScreenBufferInfo(int hConsoleOutput,
                         ref CONSOLE_SCREEN_BUFFER_INFO lpConsoleScreenBufferInfo);

         [DllImport("kernel32.dll", EntryPoint="SetConsoleTextAttribute",
                         SetLastError=true, CharSet=CharSet.Auto,
                         CallingConvention=CallingConvention.StdCall)]
        private static extern int SetConsoleTextAttribute(int hConsoleOutput,
                                 int wAttributes);
 
         public enum Foreground
         {            
            Blue = 0x00000001,
            Green = 0x00000002,
            Red = 0x00000004,
            Intensity = 0x00000008
         }

         public enum Background
         {
            Blue = 0x00000010,
            Green = 0x00000020,
            Red = 0x00000040,
            Intensity = 0x00000080
         }

         [StructLayout(LayoutKind.Sequential)] private struct COORD
         {
            short X;
            short Y;
         }
            
         [StructLayout(LayoutKind.Sequential)] private struct SMALL_RECT
         {
            short Left;
            short Top;
            short Right;
            short Bottom;
         }

         [StructLayout(LayoutKind.Sequential)] private struct CONSOLE_SCREEN_BUFFER_INFO
         {
            public COORD dwSize;
            public COORD dwCursorPosition;
            public int wAttributes;
            public SMALL_RECT srWindow;
            public COORD dwMaximumWindowSize;
         }

         // Constructor.
         public Class2()
         {
            ConsoleInfo = new CONSOLE_SCREEN_BUFFER_INFO();
            ConsoleOutputLocation = new COORD();
            hConsoleHandle = GetStdHandle(STD_OUTPUT_HANDLE);
            GetConsoleScreenBufferInfo(hConsoleHandle, ref ConsoleInfo);
            OriginalColors = ConsoleInfo.wAttributes;
         }        

         public void TextColor(int color)
         {
            SetConsoleTextAttribute(hConsoleHandle, color);
         }
        
         public void ResetColor()
         {
            SetConsoleTextAttribute(hConsoleHandle, OriginalColors);
         }
      }
   }

  4. Paste the following sample code in the class file that contains the Main function. Verify that the sample code replaces all of the existing code in the file.

  using System;

   namespace ConsoleColor
   {
      class Class1
      {
         [STAThread]
         static void Main(string[] args)
         {
            Class2 TextChange = new Class2();
            Console.WriteLine("Original Colors");
            Console.WriteLine("Press Enter to Begin");
            Console.ReadLine();
            TextChange.TextColor((int)Class2.Foreground.Green +
                                 (int)Class2.Foreground.Intensity);
            Console.WriteLine("THIS TEXT IS GREEN");
            Console.WriteLine("Press Enter to change colors again");
            Console.ReadLine();
            TextChange.TextColor((int)Class2.Foreground.Red +
                                 (int)Class2.Foreground.Blue +
                                 (int)Class2.Foreground.Intensity);
            Console.WriteLine("NOW THE TEXT IS PURPLE");
            Console.WriteLine("Press Enter to change colors again");
            Console.ReadLine();
            TextChange.TextColor((int)Class2.Foreground.Blue +
                                 (int)Class2.Foreground.Intensity +
                                 (int)Class2.Background.Green +
                                 (int)Class2.Background.Intensity);
            Console.WriteLine("NOW THE TEXT IS BLUE AND BACKGROUND OF IT IS GREEN");
            Console.WriteLine("Press Enter change everything back to normal");
            Console.ReadLine();
            TextChange.ResetColor();
            Console.WriteLine("Back to Original Colors");
            Console.WriteLine("Press Enter to Terminate");
            Console.ReadLine();
     }
      }
   }

 

今天的文章C#更改控制台文本的前景色和背景色分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/55300.html

(0)
编程小号编程小号
上一篇 2023-08-28
下一篇 2023-08-28

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注