点阵汉字的字模读取与显示

实验一 串口文件传输
1、串口连接
将两个USB转TTL模块的RX和TX交叉相连,分别插入两台电脑的USB口上
2、传输文件
设置波特率为115200bps
打开串口助手,发送文件,结果如下图所示
在这里插入图片描述
总结:
理论传输时间=(文件大小×8)÷波特率
实际传输时间为六分钟,与理论传输时间相差较大

实验二 点阵汉字的字模读取与显示**
实验步骤
(1)创建一个logo.txt文件,将姓名与学号输入其中
在这里插入图片描述
(2)在Ubuntu中创建一个文件夹document
在这里插入图片描述
将压缩包中的Asci0816.zf、HZKF2424.hz、以及创建的logo.txt和图片photo.jpg放入该文件夹中
在这里插入图片描述
(3)进入该文件夹,使用gedit命令创建name.cpp文件
在这里插入图片描述
编写代码
在这里插入图片描述
具体代码如下

#include<iostream>
#include<opencv/cv.h>
#include"opencv2/opencv.hpp"
#include<opencv/cxcore.h>
#include<opencv/highgui.h>
#include<math.h>
using namespace cv;
using namespace std;

void paint_chinese(Mat& image,int x_offset,int y_offset,unsigned long offset);
void paint_ascii(Mat& image,int x_offset,int y_offset,unsigned long offset);
void put_text_to_image(int x_offset,int y_offset,String image_path,char* logo_path);

int main(){
   
    String image_path="/home/zls/code/1.jpg";
    char* logo_path=(char*)"/home/zls/code/logo.txt";
    put_text_to_image(450,750,image_path,logo_path);//安排文字从图片像素坐标(450,750)开始显示
    return 0;
}
//在图片上绘制文字的起点坐标
void paint_ascii(Mat& image,int x_offset,int y_offset,unsigned long offset){
   
	Point p;
	p.x = x_offset;
	p.y = y_offset;
	//存放ascii字膜
	char buff[16];           
	//打开ascii字库文件
	FILE *ASCII;
	if 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
字模是将汉字、英文字母等字符转换为点阵数据的过程,其实现方式因不同的字库和控制器而异。以下是一个简单的示例,假设使用的是16*16的字库,字库数据存储在ROM中,并通过8位并口接口的LCD进行显示,对应的RS、RW、E、D0-D7引脚分别为P0.0-P0.7: ```c // 定义一个16*16的数组,存储取出的汉字点阵数据 unsigned char matrix[16][16]; // 从ROM中取出汉字点阵数据,存储到matrix数组中(假设ROM地址为0x1000) unsigned char* font_rom = (unsigned char*)0x1000; // 假设字库数据存储在0x1000地址处 unsigned char* matrix_ptr = &matrix[0][0]; unsigned char character = '中'; // 要取模的字符 unsigned int offset = (character - 0x80) * 32; // 计算字库数据在ROM中的偏移量 for(int i = 0; i < 16; i++) { for(int j = 0; j < 2; j++) { unsigned char byte = font_rom[offset++]; // 从ROM中读取一个字节的数据 for(int k = 0; k < 8; k++) { *matrix_ptr++ = (byte & (1 << k)) ? 1 : 0; // 将字节中的每一位转换为0或1,并存储到matrix数组中 } } } // 将matrix数组中的点阵数据显示到LCD上 for(int wordl = 0; wordl < 16; wordl++) { for(int wordc = 0; wordc < 8; wordc++){ unsigned char data = 0; for(int k = 0; k < 8; k++) { data |= (matrix[wordl][wordc * 8 + k] << k); // 将matrix数组中的8个点阵数据合并成一个字节 } LCD_RS = 1; // RS为高,表示传输的是数据而非指令 LCD_RW = 0; // RW为低,表示写入数据 LCD_E = 1; // 使能LCD控制器 P0 = data; // 将数据写入Data口 LCD_E = 0; // 结束数据传输 } } ``` 以上代码仅供参考,实际使用时需要根据具体的字库和LCD控制器进行相应的修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值