【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;
}
相关推荐
_Itachi__6 小时前
LeetCode 热题 100 74. 搜索二维矩阵
算法·leetcode·矩阵
不忘不弃6 小时前
计算矩阵A和B的乘积
线性代数·算法·矩阵
不爱写代码的玉子6 小时前
HALCON透视矩阵
人工智能·深度学习·线性代数·算法·计算机视觉·矩阵·c#
SY师弟12 小时前
51单片机基础部分——矩阵按键检测
嵌入式硬件·矩阵·51单片机
Yxh1813778455413 小时前
抖去推--短视频矩阵系统源码开发
人工智能·python·矩阵
Psycho_MrZhang18 小时前
高等数学基础(矩阵基本操作转置和逆矩阵)
线性代数·矩阵
Bruce_Liuxiaowei1 天前
文件上传漏洞深度解析:检测与绕过技术矩阵
安全·矩阵·文件上传漏洞
天宫风子1 天前
线性代数小述(一)
线性代数·算法·矩阵·抽象代数
老歌老听老掉牙2 天前
使用 SymPy 进行向量和矩阵的高级操作
python·线性代数·算法·矩阵·sympy
sz66cm2 天前
LeetCode刷题 -- 542. 01矩阵 基于 DFS 更新优化的多源最短路径实现
leetcode·矩阵·深度优先