【51单片机4个IO实现16按键可扩展独立按键64矩阵驱动显示矩阵原值】2023-5-8

缘由

cpp 复制代码
#include "reg52.h"
sbit L1=P2^2;
sbit L2=P2^3;
sbit L3=P2^4;
unsigned char code ShuMaGuan[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00,0X80,64};//0~9隐.小数点-号
void ShuMaXianShi(unsigned char s,unsigned char w,unsigned char d)
{
	P0=L1=L2=L3=0;
	switch(w)
	{
		case 2:{L1=0;L2=L3=1;}break;//011
		case 3:{L2=0;L1=L3=1;}break;//101
		case 4:{L1=L2=0;L3=1;}break;//001
		case 5:{L1=L2=1;L3=0;}break;//110
		case 6:{L1=L3=0;L2=1;}break;//010
		case 7:{L1=1;L2=L3=0;}break;//100
		case 8:{L1=L2=L3=0;}break;//000
		case 1:{L1=L2=L3=1;}break;//111
		default:{L1=L2=L3=0;}break;
	}//d显示小数点11,10关闭
	P0=ShuMaGuan[s]|ShuMaGuan[d];
}
unsigned char DuLlJuZhen(/*独立416矩阵*/)
{//1 2 4 8
	unsigned char H=15,L=240,Ys=0,zhi=H+L;
	P1=15;
	if(P1!=15){while(++Ys);if(P1!=15)zhi=P1;while(P1!=zhi);return zhi;}
	P1=14;
	if(P1!=14){while(++Ys);if(P1!=14)zhi=P1;while(P1!=zhi);return zhi;}
	P1=13;
	if(P1!=13){while(++Ys);if(P1!=13)zhi=P1;while(P1!=zhi);return zhi;}
	P1=11;
	if(P1!=11){while(++Ys);if(P1!=11)zhi=P1;while(P1!=zhi);return zhi;}
	P1=7;
	if(P1!=7){while(++Ys);if(P1!=7)zhi=P1;while(P1!=zhi);return zhi;}
	P1 = 0;
	return (H+L);
}
void main()
{
	unsigned char jz=0,ys=0,xs=0,sm=0;
	while(1)
	{
		
		if(++ys==0)
		{jz=DuLlJuZhen();if(jz!=255)sm=jz;
			if(++xs>3)xs=1;
			if(xs==1)ShuMaXianShi(sm%10,8,10);
			else if(xs==2)ShuMaXianShi(sm/10%10,7,10);
//			else if(xs==3)ShuMaXianShi(sm/100,6,10);
		}
	}
}
相关推荐
晚会者荣6 小时前
C++11_3:包装器,智能指针
c++
员宇宙6 小时前
k8s学习笔记
笔记·学习·kubernetes
手写码匠6 小时前
手写 AI Prompt Injection 防护系统:从零实现 LLM 安全边界
人工智能·深度学习·算法·aigc
薇茗6 小时前
【初阶数据结构】 升沉有序的平仄 排序
c语言·数据结构·算法·排序算法
handler016 小时前
TCP(传输控制协议)核心机制与底层原理
linux·网络·c++·笔记·网络协议·tcp/ip·操作系统
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串综合】:遍历问题
c++·字符串·csp·高频考点·信奥赛
yoyo_zzm6 小时前
五大编程语言对比:PHP、C、C++、C#、易语言
c语言·c++·php
杰之行6 小时前
Fast-DDS Transport 层架构详解
c++·人工智能
运维全栈笔记6 小时前
Harbor生产级部署实战:PostgreSQL+Redis+MinIO全解耦架构详解
linux·运维·服务器·笔记·架构·kubernetes·k8s
_深海凉_6 小时前
LeetCode热题100-对称二叉树
算法·leetcode·职场和发展