μcGUI学习笔记之三文本显示与数值显示

简介:  μc/GUI学习笔记之三文本显示与数值显示3.1      文本显示3.1.1   显示支持控制字符文本显示支持的ASCII字符如图3.1。
 

μc/GUI学习笔记之三文本显示与数值显示

3.1      文本显示

3.1.1   显示支持控制字符

文本显示支持的ASCII字符如图3.1。

图3.1  显示支持的ASCII控制字符

字符

C字符

功能

LF

\n

换行符。当前的文本显示位置更改到下一行。类似于C语言中的换行

CR

\r

类似于C语言的回车。不换行,仅回车,X坐标设置为0

3.1.2   文本显示API

主要的文本显示API如下:

l  void GUI_DispChar(U16 c):在当前窗口的当前的文本位置使用当前字体显示一个字符;如果字体不支持,则不会显示;

l  void GUI_DispCharAt(U16 c, I16P x, I16P y):在当前窗口的指定文本位置使用当前字体显示一个字符;如果字体不支持,则不会显示。指定的坐标为显示的字符的左上角坐标;

l  void GUI_DispChars(U16 c, int Cnt):在当前窗口的当前的文本位置使用当前字体显示Cnt个同一字符;如果字体不支持,则不会显示;

l  void GUI_DispNextLine(void):移动光标至下一行行首,相当于换行;

l  void GUI_DispString(const char GUI_FAR *s):在当前窗口的当前的文本位置使用当前字体显示一个字符串,可支持’\n’控制字符;如果字体不支持,则不会显示;

l  void GUI_DispStringLen(const char GUI_FAR *s, int Len); 在当前窗口的当前的文本位置使用当前字体显示一个字符;如果字体不支持,则不会显示.如果字符串长度较短,以空格填充,否则将只显示一部分;

l  void GUI_DispStringAt(const char GUI_FAR *s, int x, int y):在当前窗口的指定的文本位置使用当前字体显示一个字符串,可支持’\n’控制字符;如果字体不支持,则不会显示;

l  GUI_DispStringAtCEOL():显示字符串,并清除至显示串尾至对应行行末的显示内容;

l  void GUI_DispStringHCenterAt(const char GUI_FAR *s, int x, int y): 在当前窗口的以(x,y)为横向居中的位置用当前字体显示一个字符串(文本居中显示);如果字体不支持,则不会显示;

l  void GUI_DispStringInRect(const char GUI_FAR *s, const GUI_RECT *pRect, int Align):在在当前窗口中指定的矩形框内以当前字体显示一个字符串.。坐标的基准为字符串中部位置。对齐方式Align可选值为:

u  GUI_TA_TOP, GUI_TA_BOTTOM, GUI_TA_VCENTER for vertical alignment.;

u  GUI_TA_LEFT, GUI_TA_RIGHT, GUI_TA_HCENTER for horizontal alignment。

选择在矩形框内的对齐方式。如果矩形框太小,则有可能无法显示所有内容。

l  void GUI_DispStringInRectEx(const char GUI_UNI_PTR *s,GUI_RECT* pRect,int TextAlign,int MaxLen,const GUI_ROTATION * pLCD_Api); 在在当前窗口中指定的矩形框内以当前字体显示一个字符串.MaxLen-最大字符串长度。pLCD_Api取值GUI_ROTATE_0,GUI_ROTATE_CCW顺时针旋转90度。

注:上面的API函数主要可分为几类:单个字符的显示、换行、字符串的普通显示、矩形框内的字符串显示。附加的功能是设计显示对齐方式、文本样式。

3.1.3   文本模式的选择

1.   支持四种文本模式

l  GUI_TEXTMODE_NORMAL:普通文本模式,写入文本将覆盖原有LCD上的点;

l  GUI_TEXTMODE_REVERSE:反转模式,显示的文本颜色将反转;前景色与背景色反转;

注:这个暂不清楚功能如何。

l  GUI_TEXTMODE_TRANS:透明模式,写入文本将在原有的图形顶层显示;

l  GUI_TEXTMODE_XOR:异或模式。

注:这个暂不清楚功能如何。

2.   文本模式相关API

l  int GUI_GetTextMode(void):获取显示的文本模式;

l  int GUI_SetTextMode(int TextMode):设置显示的文本模式;

l  char GUI_SetTextStyle(char Style):设置显示的文本样式,主要样式有:

n  GUI_TS_NORMAL;

n  GUI_TS_UNDERLINE;

n  GUI_TS_STRIKETHRU;

n  GUI_TS_OVERLINE。

注:文本样式,有意思!

3.1.4   文本对齐方式:

l  int GUI_GetTextAlign(void):获取文本对齐方式;

l  int GUI_SetTextAlign(int TextAlign):设置文本的对齐方式;主要对齐方式:

n  GUI_TA_LEFT-GUI_TA_HCENTER-GUI_TA_RIGHT;

n  GUI_TA_TOP-GUI_TA_VCENTER-GUI_TA_BOTTOM。

l  void GUI_SetLBorder(int x):设置显示的左边距。

注:这个应该是设置了变量,然后在调用显示函数时使用。对齐方式应该是用于显示函数参数包含指定坐标的函数,如GUI_DispStringAt()。相应的坐标指定显示对齐用的基准坐标。见程序清单3.1中的左对齐与居中对齐效果。

3.1.5   当前文本位置:

每个任务都对应着一个文本位置,位置相对于窗口的(0,0)坐标而言。用于决定输出文本的当前位置。

l  char GUI_GotoXY(int x, int y);

l  char GUI_GotoX(int x);

l  char GUI_GotoY(int y);

l  int GUI_GetDispPosX(void);

l  int GUI_GetDispPosY(void)。

注:我觉得这里的文本显示位置应该是相对于的活动窗口而言,不是相对于整个液晶屏。当输入一个字符时,显示的起始位置对应于字模图像的左上角的坐标。

3.1.6   窗口的完全与部分清除

l  void GUI_Clear(void):清除当前窗口。如果没有指定当前窗口,则清除整个屏幕;

l  void GUI_DispCEOL(void):从当前窗口的当前位置以当前字体的高度清除文本至当前行行尾。

程序清单3.1文本显示测试程序

 

#include "gui.h"

 

void         MainTask( void )

{

                GUI_RECT rect = { 0, 50, 10, 250 };

 

                GUI_Init();             

                GUI_DispChars( 'C', 20 );                      /* 显示20个字符C                                               */

                GUI_DispNextLine();                                             /* 换行                                                    */

                GUI_DispChars( 'D', 10 );                      /* 显示10个字符D                                              */

 

                GUI_DispString( "Hello, uc/GUI\n" );

                GUI_DispStringLen("Hello,uc/GUI\n", 7 );           /* 显示指定长度的字符                        */

 

                GUI_DispStringHCenterAt( "Hello,uc/GUI!", 0, 0 ); /* 文本居中位置显示                       */

                GUI_SetTextStyle( GUI_TS_UNDERLINE | GUI_TS_OVERLINE );/* 设置文本样式   */

                GUI_DispStringInRect( "Hello,uc/GUI!", &rect, GUI_TA_HCENTER );

 

                /* ------------------------ 文本串显示------------------------------ */

                GUI_SetTextAlign( GUI_TA_HCENTER );                         /* 居中对齐                            */

                GUI_DispStringAt( "GUI_TA_HCENTER!!!", 10, 100 );

 

                GUI_SetTextAlign( GUI_TA_LEFT );                  /* 左对齐                                                */

                GUI_DispStringAt( "GUI_TA_LEFT!!!", 0, 200 );             

 

                GUI_SetColor(GUI_RED);

                GUI_DrawLine(80, 10, 240, 90);

                GUI_DrawLine(80, 90, 240, 10);

                GUI_SetBkColor(GUI_BLACK);

                GUI_SetColor(GUI_RED);

                GUI_SetTextMode(GUI_TM_NORMAL);                           /* 普通显示                            */

                GUI_DispStringHCenterAt("GUI_TM_NORMAL" , 160, 10);

                GUI_SetTextMode(GUI_TM_REV);

                GUI_DispStringHCenterAt("GUI_TM_REV" , 160, 26);

                GUI_SetTextMode(GUI_TM_TRANS);                               /* 透明显示                            */

                GUI_DispStringHCenterAt("GUI_TM_TRANS" , 160, 42);

                GUI_SetTextMode(GUI_TM_XOR);

                GUI_DispStringHCenterAt("GUI_TM_XOR" , 160, 58);

                GUI_SetTextMode(GUI_TM_TRANS | GUI_TM_REV);

                GUI_DispStringHCenterAt("GUI_TM_TRANS | GUI_TM_REV", 160, 74);   

                while( 1 )

                {

                                GUI_Delay( 100 );

                }

}

3.2      数值显示API

3.2.1   十进制数显示支持

l  void GUI_DispDec(I32 v, U8 Len):显示十进制数,最大长度为9;如果数为负数,则显示时会添加负号。若实际的长度小于Len,则显示时将填0被充;

l  void GUI_DispDecAt(I32 v, I16P x, I16P y, U8 Len):在指定位置显示十进制数,同GUI_DispDec();

l  void GUI_DispDecMin(I32 v); 以最小长度的串显示一个十进制数;

l  void GUI_DispDecShift(I32 v, U8 Len, U8 Shift):指定从右边起有多少位表示小数部分。Len指定显示的串的长度;

l  void DispDecSpace(I32 v, U8 MaxDigits);

l  void GUI_DispSDec(I32 v, U8 Len):显示有符号十进制数;同GUI_DispDec(),但是总是包含+/-符号;

l  void GUI_DispSDecShift(I32 v, U8 Len, U8 Shift)。

注:如果需要指定len,若len较长,则显示将以空格或字符0补空;如len较小,则显示可能会出现不正确。使用GUI_DispDecMin()自动决定显示多长。Shift用于移位,本来是显示整数的,但现在可显示小数。最大支持显示9个字符长度。支持正负号显示。

3.2.2   浮点数显示支持:

l  void GUI_DispFloat(float v, char Len):显示符点数,小数点符号计入显示的符号数;

l  void GUI_DispFloatFix (float v, char Len, char Decs):显示浮点数,len-总长;Decs小数部分的位数;

l  void GUI_DispFloatMin(float f, char Fract):如果Fract值为负,则添加负号。Fract显示最少用的字符长度,并不是必需,实际显示时会根据需要选择最小值;

l  void GUI_DispSFloatFix(float v, char Len, char Decs):

l  void GUI_DispSFloatMin(float f, char Fract);指定显示的小数部分位数;总是在显示值前面显示+/-符号。

注:部分同上。但显示时是在后面补0。

3.2.3   二进制数显示支持:

l  void GUI_DispBin(U32 v, U8 Len):

l  void DispBinAt(U32 v, I16P y, I16P x, U8 Len)。

3.2.4   十六进制数显示支持

l  void GUI_DispHex(U32 v, U8 Len):

l  void GUI_DispHexAt(U32 v, I16P x, I16P y, U8 Len)。

注:没有附加的“0x”字符串显示,且不支持正负符号显示。

3.2.5   测试程序

程序清单3.2  数值显示测试程序

#include "gui.h"

 

void    MainTask( void )

{

    GUI_RECT rect = { 0, 50, 10, 250 };

 

    GUI_Init();

   

    /* ---------- 十进制显示支持 ---------------*/

    GUI_DispString("Disp Dec:\n");

    GUI_DispDec( -32, 9 );              /* 显示负号,以零补空  */

    GUI_DispNextLine();

    GUI_DispDec( 56, 9 );               /* 不显正号,以零补空  */

    GUI_DispNextLine();

    GUI_DispDec( 51, 1 );               /* 不显正号,以零补空  */

    GUI_DispNextLine();

 

    GUI_DispDecMin( -32 );              /* 最小数量显示        */

    GUI_DispNextLine();

    GUI_DispDecMin( 54 );          

    GUI_DispNextLine();

 

    GUI_DispDecShift( -3212, 8, 1 );      /* 1位小数             */

    GUI_DispNextLine();

    GUI_DispDecShift( -3212, 8, 2 );      /* 2位小数             */

    GUI_DispNextLine();

 

    GUI_DispDecSpace( -3212, 9 );       /* 以空格补空          */

 

    /* ---------- 浮点数显示支持 ---------------*/

    GUI_DispNextLine();

    GUI_DispFloat( -3.1232, 9 );        /* 普通浮点显示支持     */

    GUI_DispNextLine();

    GUI_DispFloatFix( -3.14159, 9, 2 );  /* 最大9个字符,2个小数部分*/

    GUI_DispNextLine();

 

    /* ---------- 二进制数显示支持 ---------------*/

    GUI_DispBin( 0xfe, 8 );

    GUI_DispNextLine();

 

    /* ---------- 十六进制数显示支持 ---------------*/

    GUI_DispHex( 0xfe, 4 );

    GUI_DispNextLine();

 

    while( 1 )

    {

        GUI_Delay( 100 );

    }

}

 

By:lstzixing

Mail:blievethink@gmail.com

Blog:http://blog.ednchina.com/lstzixing

2010-5-7

目录
相关文章
|
测试技术 C语言 Perl
内存优化-使用tcmalloc分析解决内存泄漏和内存暴涨问题
其实我一直很想写关于tcmalloc的内存泄漏检测的文章,只是一直记不起来该如何下笔,有时项目太忙,在整理这方便的思考过少,另外遇到的问题也不是很多,直到最近用tcmalloc帮A项目排查...
|
7月前
|
JSON 数据格式 Python
X86架构属于国产化架构吗
在信息时代,处理器架构至关重要。本文通过简单流程和代码示例,帮助初学者理解X86架构是否属于国产化架构。首先明确国产化架构指本土研发的处理器架构,如龙芯、飞腾等。X86架构由Intel设计,主要由外资公司开发,通常不被视为国产架构。文章提供了一个判断X86架构是否国产化的流程图,并用Python代码实现判断过程。Architecture类描述架构来源和类型,App类负责获取和判定架构信息。通过这些步骤,初学者可以更好地掌握相关知识并提升开发技能。
590 5
|
SQL JSON 关系型数据库
SqlAlchemy 2.0 中文文档(五)(5)
SqlAlchemy 2.0 中文文档(五)
169 4
WK
|
10月前
|
数据可视化 开发者 容器
QWidget类
QWidget 是 Qt 框架中的基础类,用于创建用户界面的可视化组件。它是所有 UI 组件的基类,提供绘制、布局、事件处理、样式设置和部件通信等功能。常见子类包括 QMainWindow、QDialog、QPushButton 等,支持灵活的窗口管理和丰富的用户交互。
WK
189 3
|
Java Maven 开发者
"揭秘IDEA的神奇助手:Maven Helper插件,让你轻松驾驭复杂依赖,告别冲突噩梦!"
【8月更文挑战第20天】Maven Helper是一款提升Java开发者工作效率的IDEA插件,它能直观展示项目依赖关系并协助管理。主要功能包括依赖树视图、冲突检测与解决及依赖排除。安装简便,重启IDEA后即用。借助其“Dependencies”面板,开发者可以清晰了解依赖详情,快速定位并解决冲突问题,有效优化项目结构,提升开发效率。
914 0
|
算法 安全 Java
浅析五种最常用的Java加密算法,以后可以直接拿来用了
信息加密是现在几乎所有项目都需要用到的技术,身份认证、单点登陆、信息通讯、支付交易等场景中经常会需要用到加密算法,所谓加密算法,就是将原本的明文通过一系列算法操作变成密文。接下来就介绍一下目前比较常用的一些加密算法,本期不涉及算法底层,以应用介绍和代码展示为主。 如果只想了解原理,可跳过代码部分,代码可直接拿来使用。
2953 0
|
Rust Prometheus Cloud Native
你应该知晓的Rust Web 框架(二)
你应该知晓的Rust Web 框架(二)
471 1
|
资源调度 JavaScript
vite 教程
首先先介绍一下vite,vite这个名字起源于法语就是很快的意思。应为他是冷服务不打包 用es6 import 来引入对应 的js。其次就是使用rollup 去打包。开发中有热更新等。
459 0
vite 教程
|
Kubernetes 供应链 安全
Docker Desktop 向大公司宣告收费,网友大呼:是时候弃用了
在容器引擎 Docker 诞生的 8 年间,其与开源的容器编排 Kubernetes 共同推动容器技术在云计算领域的应用,也让自身在全球范围内受到了广泛的关注。可以说,做过云计算开发的程序员,十有八有学过 Docker 技术。 不过,近日 Docker 官方宣布一项新的动作,即将产品订阅划分为个人、专业、团队和商业不同版本,对于这样做的原因,官方称是为开发者所依赖的生产力和协作提供了业务所需的规模、安全性和可信内容,由此以可持续性的方式为 Docker 提供服务。
xfs_repair命令xfs文件系统修复工具
xfs_repair命令xfs文件系统修复工具
4216 0