【C語言】控制台窗口圖形界面編程(六):光標設置


00. 目錄

01. CONSOLE_CURSOR_INFO結構

包含有關控制台光標的信息。

typedef struct _CONSOLE_CURSOR_INFO {
  DWORD dwSize;
  BOOL  bVisible;
} CONSOLE_CURSOR_INFO, *PCONSOLE_CURSOR_INFO;

dwSize
光標填充的字符單元格的百分比。該值介於1和100之間。光標外觀會發生變化,從完全填充單元格到顯示為單元格底部的水平線。

注意 雖然dwSize值通常介於1和100之間,但在某些情況下,可能會返回該范圍之外的值。例如,如果在注冊表中將CursorSize設置為0,則返回的dwSize值將為0。

bVisible
光標的可見性。如果光標可見,則此成員為TRUE

02. GetConsoleCursorInfo函數

獲取有關指定控制台屏幕緩沖區的光標大小和可見性的信息。

類型聲明

BOOL WINAPI GetConsoleCursorInfo(
  _In_  HANDLE               hConsoleOutput,
  _Out_ PCONSOLE_CURSOR_INFO lpConsoleCursorInfo
);

功能:
	獲取光標相關信息
參數:
	hConsoleOutput 控制台屏幕緩沖區的句柄。句柄必須具有GENERIC_READ訪問權限。
	lpConsoleCursorInfo 指向CONSOLE_CURSOR_INFO結構的指針,該結構接收有關控制台游標的信息。

返回值:
	如果函數成功,則返回值為非零值。
	如果函數失敗,則返回值為零。要獲取擴展錯誤信息,請調用GetLastError。

參考程序

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

#include <Windows.h>
#include <conio.h>


int main(void)
{
	//定義句柄變量
	HANDLE hOut = NULL;

	//光標信息變量
	CONSOLE_CURSOR_INFO cursorInfo;

	//獲取標准輸出句柄
	hOut = GetStdHandle(STD_OUTPUT_HANDLE);

	//獲取當前光標信息
	GetConsoleCursorInfo(hOut, &cursorInfo);

	printf("光標默認大小: %d 光標是否可見: %d\n", cursorInfo.dwSize, cursorInfo.bVisible);


	//關閉句柄
	CloseHandle(hOut);

	system("pause");
	return 0;
}

執行結果

03. SetConsoleCursorInfo函數

設置指定控制台屏幕緩沖區的光標大小和可見性。

函數聲明:

BOOL WINAPI SetConsoleCursorInfo(
  _In_       HANDLE              hConsoleOutput,
  _In_ const CONSOLE_CURSOR_INFO *lpConsoleCursorInfo
);
功能:
	設置光標的屬性
參數:
	hConsoleOutput 控制台屏幕緩沖區的句柄。句柄必須具有GENERIC_READ訪問權限。
	lpConsoleCursorInfo 指向CONSOLE_CURSOR_INFO結構的指針,該結構為控制台屏幕緩沖區的游標提供新規范。

返回值:
	如果函數成功,則返回值為非零值。
	如果函數失敗,則返回值為零。要獲取擴展錯誤信息,請調用GetLastError。

參考程序

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

#include <Windows.h>
#include <conio.h>


int main(void)
{
	//定義句柄變量
	HANDLE hOut = NULL;

	//光標信息變量
	CONSOLE_CURSOR_INFO cursorInfo;

	//獲取標准輸出句柄
	hOut = GetStdHandle(STD_OUTPUT_HANDLE);

	//獲取當前光標信息
	GetConsoleCursorInfo(hOut, &cursorInfo);
	printf("光標默認大小: %d 光標是否可見: %d\n", cursorInfo.dwSize, cursorInfo.bVisible);

	getchar();
	//設置光標的尺寸為20
	cursorInfo.dwSize = 5;
	SetConsoleCursorInfo(hOut, &cursorInfo);

	getchar();

	//設置光標的尺寸為50
	cursorInfo.dwSize = 50;
	SetConsoleCursorInfo(hOut, &cursorInfo);

	getchar();

	//設置光標的尺寸為100
	cursorInfo.dwSize = 100;
	SetConsoleCursorInfo(hOut, &cursorInfo);

	getchar();

	//設置光標不可見
	cursorInfo.dwSize = 25;
	cursorInfo.bVisible = 0;
	SetConsoleCursorInfo(hOut, &cursorInfo);

	getchar();

	//關閉句柄
	CloseHandle(hOut);

	system("pause");
	return 0;
}

執行結果

04. SetConsoleCursorPosition函數

設置指定控制台屏幕緩沖區中的光標位置。

函數聲明:

BOOL WINAPI SetConsoleCursorPosition(
  _In_ HANDLE hConsoleOutput,
  _In_ COORD  dwCursorPosition
);

功能:
	設置光標的位置
	
參數:
	hConsoleOutput 控制台屏幕緩沖區的句柄。句柄必須具有GENERIC_READ訪問權限。
	dwCursorPosition 用於指定新的光標位置(以字符為單位)。坐標是屏幕緩沖區字符單元格的列和行。坐標必須位於控制台屏幕緩沖區的邊界內。
	
返回值:
	如果函數成功,則返回值為非零值。
	如果函數失敗,則返回值為零。要獲取擴展錯誤信息,請調用GetLastError。

參考程序;

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

#include <Windows.h>
#include <conio.h>


int main(void)
{
	//定義句柄變量
	HANDLE hOut = NULL;

	COORD pos;

	//獲取標准輸出句柄
	hOut = GetStdHandle(STD_OUTPUT_HANDLE);

	pos.X = 8;
	pos.Y = 8;
	//設置光標的位置
	SetConsoleCursorPosition(hOut, pos);
	printf("hello itcast1");

	pos.X = 18;
	pos.Y = 16;
	//設置光標的位置
	SetConsoleCursorPosition(hOut, pos);
	printf("hello itcast2");


	//關閉句柄
	CloseHandle(hOut);

	system("pause");
	return 0;
}

測試結果:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM