【51单片机LCD1602显示矩阵键盘原始键值】2023-6-1

缘由https://ask.csdn.net/questions/7955623

cpp 复制代码
#include "reg52.h"
sbit  LCD1602_RS = P3^5;//RS端数据命令选择(H/L)
sbit  LCD1602_RW = P3^6;//RW端读写选择(H/L)
sbit  LCD1602_EN = P3^7;//EN端使能信号上升沿25ns
void PanDuan1602(/*LCD1602忙判断*/)
{ 
	LCD1602_RS = 0;/*根据规定,RS为低电平,RW为高电平时,可以读状态*/
	LCD1602_RW = 1;
	P0 = 0xFF;
	while(P0 & 0x80){LCD1602_EN = 0;P0 = 0xFF;LCD1602_EN = 1;}
}
void Xie_MinLin_ShuJu(unsigned char MinLin_ShuJu,bit XZ)/*LCD1602写入8位命令/数据函数*/
{
	unsigned char y=0;
	PanDuan1602();/*忙则等待*/
	LCD1602_RS = XZ;
	LCD1602_RW = 0;
	while(++y<47);//地址建立时间
	P0 = MinLin_ShuJu;/*写入命令*/
	LCD1602_EN = 1;/*拉高使能端 数据被传输到LCD1602内*/
	LCD1602_EN = 0;/*拉低使能以便于下一次产生上升沿*/
}	
void Xie_String(unsigned char *ShuJu,unsigned char w,bit x)/*LCD1602写入8位字符串数据子函数*/
{
	 Xie_MinLin_ShuJu((x?0xC0:0x80) + w, 0);//1表示第二行0表示第一行     
	 while (*ShuJu != '\0') Xie_MinLin_ShuJu(*ShuJu++, 1);         
}
void LCD1602ChuShiHua(/*LCD1602初始化子程序*/)	   
{
	LCD1602_RS = LCD1602_RW = LCD1602_EN = 0;
	Xie_MinLin_ShuJu(0x38, 0);/*显示模式设置16*2显示,5*7点阵,8位数据接口*/ 
	Xie_MinLin_ShuJu(0x06, 0);/*显示光标移动设置读写一字节后地址指针加1*/
	Xie_MinLin_ShuJu(0x0C, 0);/*显示开及光标设置*/
	Xie_MinLin_ShuJu(0x01, 0);/*显示清屏*/
}
unsigned char JianPanShaoMiao(/*使用行列反转扫描法*/)
{    
    unsigned char H=15,L=240;static unsigned char Ys=0;
    P1=15;
    if(P1!=15&&++Ys==0)
    {        
		H=P1;
		P1=240;
		L=P1;
		while(P1!=240);
	}
    P1 = 255;
    return (H+L);
}
void main()
{//缘由https://ask.csdn.net/questions/7955623
	unsigned char jz=0,sj[8]={"   "};
	LCD1602ChuShiHua();
	Xie_String("Key Values:",0,0);Xie_String("HJ7447",4,1);
	while(1)
	{
			jz=JianPanShaoMiao();
			if(jz!=255)
			{
				sj[0]=jz/100+'0';
				sj[1]=jz/10%10+'0';
				sj[2]=jz%10+'0';
				Xie_String(sj,11,0);
			}
	}
}
cpp 复制代码
unsigned char duli16()
{//缘由http://www.51hei.com/bbs/dpj-229608-1.html
	unsigned char jz=255;
	static unsigned char Ys=0;
	P1=239;
	if(P1!=239&&++Ys==0){jz=P1;while(P1!=239);}
	else P1=223;
	if(P1!=223&&++Ys==0){jz=P1;while(P1!=223);}
	else P1=191;
	if(P1!=191&&++Ys==0){jz=P1;while(P1!=191);}
	else P1=127;
	if(P1!=127&&++Ys==0){jz=P1;while(P1!=127);}
	P1 = 255;
	return jz;
}
相关推荐
covco11 小时前
AI 原生全域矩阵系统:智能任务调度与资源负载均衡技术实现
人工智能·矩阵·负载均衡
JoyCong199812 小时前
玩3D游戏、做三维设计时视角乱跳?ToDesk“3D鼠标”功能了解一下!
游戏·3d·计算机外设·远程工作·远程操作
05候补工程师13 小时前
【矩阵代数】伴随矩阵、逆矩阵与秩的逻辑关系全梳理
笔记·线性代数·考研·矩阵
开开心心就好14 小时前
免费开源的网课教学屏幕画板工具
windows·eureka·计算机外设·word·excel·etcd·csdn开发云
covco14 小时前
端云协同架构下:AI 原生矩阵系统端侧推理与离线生产技术实践
人工智能·矩阵·架构
covco1 天前
矩阵管理系统指南:拆解星链引擎的架构设计与全链路落地实践
大数据·人工智能·矩阵
covco1 天前
分布式架构实战:全平台矩阵管理系统的技术实现与性能优化
分布式·矩阵·架构
森屿~~1 天前
CMA-ES:从搜索分布自适应到协方差矩阵学习
学习·elasticsearch·矩阵
covco1 天前
全域矩阵运营系统多租户权限体系架构设计与轻量化落地实践
微服务·矩阵·权限管控
三维重建-光栅投影1 天前
最小二乘中的矩阵求导基础总结
线性代数·机器学习·矩阵