00. 目录

01. CHAR_INFO结构

指定Unicode或ANSI字符及其属性。控制台功能使用此结构来读取和写入控制台屏幕缓冲区。

类型声明

typedef struct _CHAR_INFO {
union {
WCHAR UnicodeChar;
CHAR AsciiChar;
} Char;
WORD Attributes;
} CHAR_INFO, *PCHAR_INFO;

UnicodeChar

屏幕缓冲区字符单元格的Unicode字符。

AsciiChar

屏幕缓冲区字符单元格的ANSI字符。

Attributes

字符属性。该成员可以是零或以下值的任意组合。

含义
FOREGROUND_BLUE 0x0001 文字颜色包含蓝色。
FOREGROUND_GREEN 0x0002 文字颜色包含绿色。
FOREGROUND_RED 0x0004 文字颜色包含红色。
FOREGROUND_INTENSITY 0x0008 文字颜色加强。
BACKGROUND_BLUE 0x0010 背景颜色包含蓝色。
BACKGROUND_GREEN 0x0020 背景颜色包含绿色。
BACKGROUND_RED 0x0040 背景颜色包含红色。
BACKGROUND_INTENSITY 0x0080 背景颜色加剧。
COMMON_LVB_LEADING_BYTE 0x0100 前导字节。
COMMON_LVB_TRAILING_BYTE 0x0200 尾随字节。
COMMON_LVB_GRID_HORIZONTAL 0x0400 顶部水平
COMMON_LVB_GRID_LVERTICAL 0x0800 左垂直。
COMMON_LVB_GRID_RVERTICAL 0x1000 正确的垂直。
COMMON_LVB_REVERSE_VIDEO 0x4000 反转前景和背景属性。
COMMON_LVB_UNDERSCORE 0x8000 下划线。

02. ScrollConsoleScreenBuffer函数

在屏幕缓冲区中移动数据块。通过指定剪切矩形可以限制移动的效果,因此剪切矩形外部的控制台屏幕缓冲区的内容不会改变。

函数声明:

BOOL WINAPI ScrollConsoleScreenBuffer(
_In_ HANDLE hConsoleOutput,
_In_ const SMALL_RECT *lpScrollRectangle,
_In_opt_ const SMALL_RECT *lpClipRectangle,
_In_ COORD dwDestinationOrigin,
_In_ const CHAR_INFO *lpFill
); 功能:
在屏幕缓冲区中移动数据块 参数:
hConsoleOutput 控制台屏幕缓冲区的句柄。句柄必须具有GENERIC_READ访问权限。
lpScrollRectangle 指定要移动的控制台屏幕缓冲区矩形的左上角和右下角坐标。
lpClipRectangle 指定受滚动影响的控制台屏幕缓冲区矩形的左上角和右下角坐标。该指针可以为NULL。
dwDestinationOrigin 它以字符为单位指定lpScrollRectangle内容新位置的左上角。
lpFill 指向CHAR_INFO结构的指针,该结构指定在填充lpScrollRectangle和lpClipRectangle交集中的单元格时使用的字符和颜色属性,这些属性由于移动而保留为空。 返回值:
如果函数成功,则返回值为非零值。
如果函数失败,则返回值为零。要获取扩展错误信息,请调用GetLastError。

官方参考手册: https://docs.microsoft.com/en-us/windows/console/char-info-str

03. 程序示例

参考代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h> #include <Windows.h>
#include <conio.h> int main()
{
//定义句柄变量
HANDLE hOut = NULL; //定义窗口信息变量
CONSOLE_SCREEN_BUFFER_INFO screenInfo; //定义移动区域
SMALL_RECT scroll; //移动位置
COORD pos = {8, 8}; //定义填充字符
CHAR_INFO chFill; //获取标准输出句柄
hOut = GetStdHandle(STD_OUTPUT_HANDLE); //获取窗口信息
GetConsoleScreenBufferInfo(hOut, &screenInfo); chFill.Char.AsciiChar = ' ';
chFill.Attributes = screenInfo.wAttributes; //输出字符串
printf("AAAAAAAAAAAAAAAAAAAAAAAAA\n");
printf("BBBBBBBBBBBBBBBBBBBBBBBBB\n");
printf("CCCCCCCCCCCCCCCCCCCCCCCCC\n");
printf("DDDDDDDDDDDDDDDDDDDDDDDDD\n"); //设置移动的区域
scroll.Left = 2;
scroll.Top = 2;
scroll.Right = 20;
scroll.Bottom = 4; //设置文本移动
ScrollConsoleScreenBuffer(hOut, &scroll, NULL, pos, &chFill); getchar(); //关闭句柄
CloseHandle(hOut); system("pause");
return 0;
}

执行结果

参考网址: https://blog.csdn.net/JZQT_T/article/details/30602349

04. 官方参考程序

#include <windows.h>
#include <stdio.h> int main(void)
{
HANDLE hStdout;
CONSOLE_SCREEN_BUFFER_INFO csbiInfo;
SMALL_RECT srctScrollRect, srctClipRect;
CHAR_INFO chiFill;
COORD coordDest;
int i; printf("\nPrinting 20 lines for reference. ");
printf("Notice that line 6 is discarded during scrolling.\n");
for (i = 0; i <= 20; i++)
printf("%d\n", i); hStdout = GetStdHandle(STD_OUTPUT_HANDLE); if (hStdout == INVALID_HANDLE_VALUE)
{
printf("GetStdHandle failed with %d\n", GetLastError());
return 1;
} // Get the screen buffer size. if (!GetConsoleScreenBufferInfo(hStdout, &csbiInfo))
{
printf("GetConsoleScreenBufferInfo failed %d\n", GetLastError());
return 1;
} // The scrolling rectangle is the bottom 15 rows of the
// screen buffer. srctScrollRect.Top = csbiInfo.dwSize.Y - 16;
srctScrollRect.Bottom = csbiInfo.dwSize.Y - 1;
srctScrollRect.Left = 0;
srctScrollRect.Right = csbiInfo.dwSize.X - 1; // The destination for the scroll rectangle is one row up. coordDest.X = 0;
coordDest.Y = csbiInfo.dwSize.Y - 17; // The clipping rectangle is the same as the scrolling rectangle.
// The destination row is left unchanged. srctClipRect = srctScrollRect; // Fill the bottom row with green blanks. chiFill.Attributes = BACKGROUND_GREEN | FOREGROUND_RED;
chiFill.Char.AsciiChar = (char)' '; // Scroll up one line. if (!ScrollConsoleScreenBuffer(
hStdout, // screen buffer handle
&srctScrollRect, // scrolling rectangle
&srctClipRect, // clipping rectangle
coordDest, // top left destination cell
&chiFill)) // fill character and color
{
printf("ScrollConsoleScreenBuffer failed %d\n", GetLastError());
return 1;
} getchar(); system("pause");
return 0;
}

【C语言】控制台窗口图形界面编程(五):文本移动的更多相关文章

  1. C语言控制台窗体图形界面编程(总结)

    本系列文章是笔者通过学习<C语言控制台窗体界面编程(修正版)>而写(关于此文档的很多其它信息请看本系列文章第一篇),旨在让大家更加清晰简洁easy地学习C语言控制台窗体界面的编程. 通过本 ...

  2. 【C语言】控制台窗口图形界面编程(二)窗口信息和填充缓冲区

    目录 00. 目录 01. COORD结构体 02. SMALL_RECT结构 03. CONSOLE_SCREEN_BUFFER_INFO结构体 04. GetConsoleScreenBuffer ...

  3. 【C语言】控制台窗口图形界面编程(一)句柄和文本属性

    目录 00. 目录 01. 句柄 02. GetStdHandle函数 03. CloseHandle函数 04. SetConsoleTextAttribute函数 05. 十进制颜色对照表 06. ...

  4. 【C语言】控制台窗口图形界面编程(八):键盘事件

    目录 00. 目录 01. INPUT_RECORD结构 02. KEY_EVENT_RECORD结构 03. ReadConsoleInput函数 04. 示例程序 00. 目录 01. INPUT ...

  5. 【C语言】控制台窗口图形界面编程(七):鼠标事件

    目录 00. 目录 01. INPUT_RECORD结构 02. MOUSE_EVENT_RECORD结构 03. ReadConsoleInput函数 04. 示例程序 00. 目录 01. INP ...

  6. 【C语言】控制台窗口图形界面编程(四):文本输出

    目录 00. 目录 01. FillConsoleOutputAttribute函数 02. FillConsoleOutputCharacter函数 03. WriteConsoleOutputCh ...

  7. 【C语言】控制台窗口图形界面编程(六):光标设置

    目录 00. 目录 01. CONSOLE_CURSOR_INFO结构 02. GetConsoleCursorInfo函数 03. SetConsoleCursorInfo函数 04. SetCon ...

  8. C语言控制台窗体图形界面编程(八):鼠标事件

           上次讲的是键盘事件,这次我们介绍鼠标事件. 以下先介绍下鼠标事件的结构体以及相关信息. typedef struct _MOUSE_EVENT_RECORD //鼠标事件结构体 { CO ...

  9. Linux C 程序 GTK+图形界面编程(22)

    GTK+图形界面编程 Linux大多是在字符界面,但也可以开发图形界面 目前已经存在多种Linux下开发图形界面的程序开发包:最常用的是Qt和GTK+ Qt是一个跨平台的图形界面开发库,不仅仅支持Li ...

随机推荐

  1. bzoj1426 (洛谷P4550) 收集邮票——期望

    题目:https://www.luogu.org/problemnew/show/P4550 推式子……:https://blog.csdn.net/pygbingshen/article/detai ...

  2. 洛谷P1527 矩阵乘法——二维树状数组+整体二分

    题目:https://www.luogu.org/problemnew/show/P1527 整体二分,先把所有询问都存下来: 然后二分一个值,小于它的加到二维树状数组的前缀和里,判断一遍所有询问,就 ...

  3. splay启发式合并

    3545: [ONTAK2010]Peaks Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1889  Solved: 501[Submit][Sta ...

  4. 关于netty的简单实现

    1. 新建两个maven项目, 分别为 netty-server: netty的服务端: 消息的消费者 netty-client: netty的客户端: 消息的生产者 2. 分别引入netty的mav ...

  5. Sql Server 查询重复记录

    参考网址:http://database.51cto.com/art/201103/250046.htm SQL Server数据库多种方式查找重复记录 select * from dbo.T0058 ...

  6. Ruby IO类

    更新: 2017/06/23   表格大小全部改为100%                             文件输入输出的File....系列函数的文件名参数是字符串! 更新: 2017/06 ...

  7. bzoj 2561: 最小生成树【最小割】

    看错题了以为多组询问吓得不行-- 其实还挺好想的,就是数据范围一点都不网络流.把U作为s,V作为t,以最小生成树为例,(U,V,L)要在最小生成树上,就要求所有边权比L小的边不能连通(U,V)所在的联 ...

  8. bzoj 4818: [Sdoi2017]序列计数【容斥原理+dp+矩阵乘法】

    被空间卡的好惨啊---- 参考:http://blog.csdn.net/coldef/article/details/70305596 容斥,\( ans=ans_{没有限制}-ans{没有质数} ...

  9. 【翻译】- EffectiveAkka-第一章

    第一章 Actor应用程序类型 在会议上发言时,我遇到的最多问题之一是“基于Actor的应用程序的用例是什么?”这取决于您要完成的任务,但是如果您想构建具有可管理的并发性.跨节点向外扩展性.并具有容错 ...

  10. Springboot整合elasticsearch以及接口开发

    Springboot整合elasticsearch以及接口开发 搭建elasticsearch集群 搭建过程略(我这里用的是elasticsearch5.5.2版本) 写入测试数据 新建索引book( ...