【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;
}
相关推荐
yanlingyun02109 小时前
Leetcode100-春招-矩阵题类
数据结构·算法·矩阵
sda423423424239 小时前
4.【线性代数】——矩阵的LU分解
线性代数·矩阵·矩阵分解·lu
aaasssdddd969 小时前
鸡兔同笼问题
c语言·线性代数·算法·矩阵·解释器
余:185381628009 小时前
矩阵系统源码搭建之多种剪辑功能技术开发,支持OEM
线性代数·矩阵
@ V:ZwaitY0913 小时前
TikTok 多账号管理与自动化运营:矩阵系统功能全解析
人工智能·矩阵
IPython_J21 小时前
LeetCodeHot100(普通数组和矩阵篇)
算法·leetcode·矩阵
Y1nhl21 小时前
力扣hot100_矩阵_python版本
python·leetcode·矩阵
新晨单片机设计21 小时前
【097】基于51单片机排队叫号系统【Keil程序+报告+原理图】
单片机·嵌入式硬件·51单片机·ad原理图
fengyuzhe131 天前
STC 51单片机63——关于STC8H的ADC通道切换问题
单片机·嵌入式硬件·51单片机
不忘不弃1 天前
求矩阵对角线元素的最大值
线性代数·矩阵