前面我们讲到了可以自定义输入汉字,然后用点阵字来展现,接下来我们挖掘下更有趣的玩法。想法来自于听歌时桌面动态歌词,我们的点阵字既然可以自定义输入识别,何不读取歌词文件随着歌曲播放动态显示呢?
下面介绍设计思路,截图如下
歌词lrc文件
玩过mp3的话对此应该不陌生,就是配在歌曲mp3文件边上后缀为lrc的文件。lrc是英文lyric即歌词的缩写。lrc文件可以用文本编辑器直接打开,其内容分为标识标签和时间标签,如图
标识标签指 [ti:歌曲名]、[ar:歌手名]、[al:专辑名]、 [offset:时间补偿值]这类介绍信息。
时间标签指[mm:ss.ff]加对应歌词,mm:ss.ff是分钟和精确到百分位的秒数,当歌曲播放到特定的时间点,根据时间标签读取对应的歌词文本,实现歌词同步、动态显示。
搞清lrc的格式,思路也就清晰了:读取文件中的时间标签,解析出我们需要的时间和对应的歌词文本,定时按文本内容打印输出点阵字。
读取时间标签
涉及到lrc文件的编码格式,直接读取会报错,引入codecs来读取文件。
读取文本我采用了readlines(),读取整个文件所有行,每行作为一个元素保存到一个列表list中。
学python的新手朋友可以回顾下读取文件read()、readline()和这里的readlines()的区别,这里选用readlines() 是因为lrc本身不大,直接读到列表中也方便后续