【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;
}
相关推荐
ChoSeitaku7 小时前
线代强化NO7|秩|矩阵的秩|向量组的秩|极大线性无关组|公式
线性代数·矩阵·概率论
不穿格子的程序员14 小时前
从零开始写算法——二分-搜索二维矩阵
线性代数·算法·leetcode·矩阵·二分查找
dingzd9514 小时前
跨平台账号矩阵高效协同术
线性代数·矩阵·web3·facebook·tiktok·instagram·clonbrowser
小龙报15 小时前
《嵌入式成长系列之51单片机 --- Keil5创建工程》
c语言·开发语言·c++·单片机·嵌入式硬件·51单片机·学习方法
今夜有雨.17 小时前
51单片机--DHT11温湿度传感器实验代码
单片机·嵌入式硬件·51单片机
一勺汤18 小时前
YOLO12 改进、魔改|秩增强线性注意力RALA,通过增强 KV 缓冲与输出特征的矩阵秩,增强 YOLO 对小目标、复杂场景目标的识别能力
线性代数·yolo·矩阵·yolov12·yolo12·yolo12改进·小目标
资深web全栈开发19 小时前
力扣2536子矩阵元素加1-差分数组解法详解
算法·leetcode·矩阵·golang·差分数组
西西弗Sisyphus1 天前
线性代数 - 理解求解矩阵特征值的特征方程
线性代数·矩阵·特征值·特征向量
Tisfy2 天前
LeetCode 2536.子矩阵元素加 1:二维差分数组
算法·leetcode·矩阵
醒过来摸鱼2 天前
多重组合问题与矩阵配额问题
线性代数·矩阵·概率论