17、nodeMCU学习笔记--u8glib模块·二

oled  spi  esp8266  nodeMCU

图片发自简书App

闲言碎语

接着上一篇,继续来说u8glib模块。上回文末说到使用drawStr()函数显示字符串,坐标(x,y)并不是字符串左上角的坐标。在u8glib官方wiki中的Font and String Handling提到了一些与字符串有关的内容,其中有个就提到了坐标问题。另外,找到了之前例子中,液晶头部10个像素左右的高度不显示的原因。

这篇文章就不细讲API,直接来实践。

实践一下

先来看字符串对齐的。模块为字符串对齐提供了4种方案:

这几个方案的区别在于Y坐标与baseline的关系,默认使用第一种方案。

来自官方wiki

图片中的横虚线就是指baseline了。而31和-9则分别表示u8g.disp:getFontAscent()u8g.disp:getFontDescent()两个函数的返回值。

但是,这两个函数的返回值还和另外的函数有关系:

这三个函数使用了三种不同的计算算法,使得上面两个函数的返回值不一样。具体的区别可以看这里,有图示,一看便知,┏ (゜ω゜)=☞

下面来看个简单的例子,当做开胃菜。以(2, 1)为顶点坐标,显示一段字符串。以(0, 0)为顶点坐标画一个方框,圈住字符串。

cs  = 8 
dc  = 2 -- D2
res = 0 -- D0
spi.setup(1, spi.MASTER, spi.CPOL_LOW, spi.CPHA_LOW, 8, 8)
gpio.mode(8, gpio.INPUT, gpio.PULLUP)
disp = u8g.ssd1306_128x64_hw_spi(cs, dc, res)
disp:setFont(u8g.font_6x10)
disp:setFontPosTop()
disp:setFontRefHeightExtendedText()

str = "Hello NodeMCU!"
h = disp:getFontAscent() - disp:getFontDescent()
w = disp:getStrWidth(str)

function draw()     
    disp:setDefaultForegroundColor()
    disp:drawStr(2, 1, str)
    disp:drawFrame(0, 0, w + 2, h + 2)
end

disp:begin()
disp:firstPage()
repeat 
    draw()
    print("draw")
until (disp:nextPage() ~= true)

首先,设置成PosTop,将参照设置成为顶点,这样.drawStr()函数的坐标就变成字符串的顶点坐标了。接着,在用函数得到字符串的宽度和高度。最后画一个frame和显示一个字符串。

另外,修复了一个显示上的bug。u8glib是分区域刷新屏幕的,.nextPage()会将缓存设置成下一个区域。因此,这里的picture loop应该使用 do while循环才合适。在lua中,有个repeat until与do while循环对应。改用循环后,便可以解决先前显示的问题。

除了上面的几个函数,u8glib还有其他有趣的函数,配合着使用实现一些高级效果。比如u8g.disp:setDefaultBackgroundColor()u8g.disp:setDefaultForegroundColor()。从名字看,前者是背景色,后者是前景色。说得更简单一点,在只有单色的液晶里面,前者可以擦除像素,后者可以点亮像素。配合着使用可以实现反显效果。只需要把上面例子的draw函数改一改就可以了。

function draw()     
    disp:setDefaultForegroundColor()
    disp:drawStr(2, 1, str)
    disp:drawFrame(0, 0, w + 2, h + 2)

    disp:drawBox(0, 20, w + 2, h + 2)    
    disp:setDefaultBackgroundColor()
    disp:drawStr(2, 21, str)
end

这里画了一个Box,然后设置成背景色,再显示字符串(实际上是 )。效果如开头的图标所显示的那样。

在多行文本的环境下,设置下一行文本的Y坐标总是要计算才能知道。u8glib提供了两个函数可以快速得到行距。分别是u8g.disp:setFontLineSpacingFactor()u8g.disp:getFontLineSpacing()。前者用于设置行距缩放因子,后者返回行距。如果放大因子是1倍的话,返回的行距等于上例子中的h值。

还有两个函数也有点意思,u8g.disp:setScale2x2()u8g.disp:undoScale()将像素放大。需要注意的是,disp:getHeight()getWidth()返回的屏幕大小会比实际的小一倍。但是disp:getFontLineSpacing()的返回值还是一样的。所以这个放大可以理解为,在屏幕物理大小没变化的情况下,改变像素的物理大小。

function draw()     
    disp:setScale2x2()
    disp:drawStr(2, 0, str)
    disp:undoScale()
    disp:drawStr(2, 20, str)
end
放大,没拍清晰

上面啰啰嗦嗦的介绍了几个函数,内容有些零散。最后来看一个复杂一点的例子——实现一个菜单。原理其实很简单,就是利用第二个例子,实现对选中选进行反显。

menu = {"nodeMCU", "Xiemingmin", "u8glib"}
ls = disp:getFontLineSpacing()
w = disp:getWidth()
function draw(index)     
    for i, v in ipairs(menu)
    do
        disp:setDefaultForegroundColor()
        if index == i then
            disp:drawBox(0, (i - 1)*ls + 16, w, ls)
            disp:setDefaultBackgroundColor()
        end
        disp:drawStr(10, (i - 1)*ls + 16, v)
    end
end
local select = 1
disp:begin()
tmr.alarm(0, 2000, tmr.ALARM_AUTO, function()
    disp:firstPage()
    print(select)
    repeat 
        draw(select)
    until (disp:nextPage() ~= true)
    if select ~= 3 then
        select = select + 1
    else
        select = 1
    end    
end)

代码有点长,隐去了驱动和初始化设置。draw函数用于描绘菜单项,正常下使用前景色来显示字符串。选中项,则先绘制一个Box,再设置背景色显示字符串。简书知道怎么上动态图,这里就不上图了。直接下载进去看效果吧。

更多内容

↑ 点击上面的标题可用查看同文集的其它文章。

简书评论不能贴图, 如有需要可以到我的GitHub上提issues

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容