下面介紹幾個用於控制台窗口操作的API函數,如下:
//獲取控制台窗口信息 GetConsoleScreenBufferInfo(); //獲取控制台窗口標題 GetConsoleTitle(); //更改指定緩沖區大小 SetConsoleScreenBufferSize(); //設置控制台窗口標題 SetConsoleTitle(); //設置控制台窗口信息 SetConsoleWindowInfo();
下面的示例程序用於說明此類函數的使用:
#include <stdio.h> #include <stdlib.h> #include <Windows.h> #include <conio.h> #define N 255 int main() { HANDLE handle_out; //定義一個句柄 CONSOLE_SCREEN_BUFFER_INFO scbi; //定義一個窗口緩沖區信息結構體 COORD size = {80, 25}; //定義一個坐標結構體 char strtitle[N]; handle_out = GetStdHandle(STD_OUTPUT_HANDLE); //獲得標准輸出設備句柄 GetConsoleScreenBufferInfo(handle_out, &scbi); //獲得窗口緩沖區信息 GetConsoleTitle(strtitle, N); //獲得當前窗口標題 printf("當前窗口標題為:%s\n", strtitle); _getch(); SetConsoleTitle("控制台窗口操作"); //設置窗口標題為“控制台窗口操作” GetConsoleTitle(strtitle, N); //獲得當前窗口標題 printf("當前窗口標題為:%s\n", strtitle); _getch(); SetConsoleScreenBufferSize(handle_out, size); // 重新設置緩沖區大小 _getch(); SMALL_RECT rc = {0, 0, 80-1, 25-1}; // 重置窗口位置和大小 SetConsoleWindowInfo(handle_out, 1, &rc); CloseHandle(handle_out); //關閉標准輸出設備句柄 return 0; }
其中,SetConsoleScreenBufferSize函數指定新的控制台屏幕緩沖區的大小,以字符列和行為單位。指定的寬度和高度不能小於控制台屏幕緩沖區窗口的寬度和高度。指定的大小也不能小於系統允許的最小大小。這個最低取決於控制台當前的字體大小 (由用戶選定)。
另外,GetConsoleTitle函數的具體實現取是否宏定義了UNICODE(與文件編碼形式有關),所以在部分IDE中可能這段示例編譯不通過,換一個別的編譯器或IDE就行了。本樣例在Code::Blocks 13.12編譯通過。
本欄目