单片机实验(一)

前言

实验一:用单片机控制多只数码管(屏)分别左、右滚动显示自己完整的学号;
实验二:用单片机控制LED16×16点阵交替正序、逆序显示自己的中文姓名。

参考链接:

LED数码管的静态显示与动态显示(Keil+Proteus)-CSDN博客

LED点阵显示原理(取字模软件+Keil+Proteus)-CSDN博客

C51单片机笔记(动态数码管与8*8点阵) - 知乎 (zhihu.com)

实验一

keil

我不知道这个是不是我理解的那个意思,如果不需要实现同时点亮八个数码管的话(不知道能不能实现),就是每次点亮一个的话,这个滚动就只需要修改循环和增加数组里面的元素即可。

只需要修改keil,不需要修改proteus的原理图。

原理:P0口根据共阳极的码来确定输出什么数字,P2来确定在哪一个地方输出,可以用到移位函数方便一点。

左移滚动

#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned intuchar code dis_code[]={0xA4,0xC0,0xA4,0xF9,0x99,0xC0,0xA4,0xC0,0xC0,0xF9,0xA4,0x82};//202140200126(共阳极段码表)//延时
void delay(uint t){uchar i;while(t--)for(i=0;i<200;i++);
}void main(){uchar i,j=0x01;while(1){for(i=0;i<12;i++){j=_cror_(j,1);//循环移位函数,将j循环右移1位P0=dis_code[i];//P0口输出段码P2=j;//P2口输出位控码delay(123);//延时P0=0x00;}}
}

 右移滚动

下面两种都可以,前者就是修改了最开始输出的位置j和移位函数,后者将输出反过来,将数组反过来了,总之前者更加简便一点。

#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned intuchar code dis_code[]={0xA4,0xC0,0xA4,0xF9,0x99,0xC0,0xA4,0xC0,0xC0,0xF9,0xA4,0x82};//202140200126(共阳极段码表)//延时
void delay(uint t){uchar i;while(t--)for(i=0;i<200;i++);
}void main(){uchar i,j=0x01;while(1){for(i=0;i<12;i++){j=_cror_(j,1);//循环移位函数,将j循环右移1位P0=dis_code[i];//P0口输出段码P2=j;//P2口输出位控码delay(123);//延时P0=0x00;}}
}
#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned intuchar code dis_code[]={0x82,0xA4,0xF9,0xC0,0xC0,0xA4,0xC0,0x99,0xF9,0xA4,0xC0,0xA4};//621002041202//延时
void delay(uint t){uchar i;while(t--)for(i=0;i<200;i++);
}void main(){uchar i,j=0x01;while(1){for(i=0;i<12;i++){j=_cror_(j,1);//循环移位函数,将j循环右移1位P0=dis_code[11-i];//P0口输出段码P2=j;//P2口输出位控码delay(123);//延时P0=0x00;}}
}

35f409fb449948e18399a4bbd6e58761.png

576678ae973a400e8d105f79d9050f54.png

实验二

keil

这个只需要修改keil的代码,不需要改Proteus中的原理图。

keil修改部分就是修改数组和循环,修改数组表示你要输出什么,修改循环表示你要输出几个字,

如果姓名一起只有两个字,就需要把循环改成四次,把数组里面的元素之前是顺序排列了一次,如今增加逆序的部分。

原理:通过P1口控制当前扫描的行,通过P0口和P2来确定当前行哪些地方需要点亮,当扫描的速度过快的时候就让人感觉是整个汉字一起打印的,所以数组里面装着就是你姓名对应的16*16点阵码。

#include <reg51.h>
#define uchar unsigned char
#define uint unsigned int 
#define out0 P0
#define out1 P1
#define out2 P2void delay(uint y) //延时函数
{uchar x=250;for(;y>0;y--){while(--x);x=100;}
}uchar code string[]=
{
/*--  文字:  刘  --*/
/*--  宋体12;  此字体下对应的点阵为:宽x高=16x16   --*/
0x08,0x20,0x10,0x20,0x10,0x20,0xFF,0x25,0x40,0x24,0x42,0x24,0x44,0x24,0x28,0x24,
0x28,0x24,0x10,0x24,0x10,0x24,0x28,0x24,0x24,0x20,0x42,0x20,0x41,0x28,0x00,0x10,/*--  文字:  健  --*/
/*--  宋体12;  此字体下对应的点阵为:宽x高=16x16   --*/
0x08,0x04,0x08,0x04,0x08,0x3F,0x74,0x24,0xC4,0x7F,0x46,0x24,0x26,0x3F,0x25,0x04,
0x74,0x3F,0x44,0x04,0x44,0x04,0xD4,0x7F,0x24,0x04,0x64,0x04,0x94,0x7F,0x0C,0x00,/*--  文字:  健  --*/
/*--  宋体12;  此字体下对应的点阵为:宽x高=16x16   --*/
0x08,0x04,0x08,0x04,0x08,0x3F,0x74,0x24,0xC4,0x7F,0x46,0x24,0x26,0x3F,0x25,0x04,
0x74,0x3F,0x44,0x04,0x44,0x04,0xD4,0x7F,0x24,0x04,0x64,0x04,0x94,0x7F,0x0C,0x00,/*--  文字:  刘  --*/
/*--  宋体12;  此字体下对应的点阵为:宽x高=16x16   --*/
0x08,0x20,0x10,0x20,0x10,0x20,0xFF,0x25,0x40,0x24,0x42,0x24,0x44,0x24,0x28,0x24,
0x28,0x24,0x10,0x24,0x10,0x24,0x28,0x24,0x24,0x20,0x42,0x20,0x41,0x28,0x00,0x10,}  ;
void main()
{	uchar i,j,n;while(1){for(j=0;j<4;j++)	//共显示4个汉字{for(n=0;n<40;n++)//每个汉字整屏扫描40次{for(i=0;i<15;i++)//逐行扫描16行{out1=i%15;//输出行码out0=string[i*2+j*32];//输出列码C0~C7out2=string[i*2+1+j*32];//输出列码C8~C15delay(4);//每一行之间的延时//out0=0xff;//out2=0xff;}}}}
}

94fd774ce3d44e2c877344fa92effc29.png 

运行结果

14b3f9f8c5814c269976bcfc5de9dddd.png

总结

继续努力

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/180205.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C语言 | 数组】C语言数组详解(经典,超详细)

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

【LeetCode:307. 区域和检索 - 数组可修改 | 树状数组 or 线段树】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

保姆级教程之SABO-VMD-CNN-SVM的分类诊断,特征可视化

今天出一期基于SABO-VMD-CNN-SVM的分类诊断。 依旧是采用经典的西储大学轴承数据。基本流程如下&#xff1a; 首先是以最小包络熵为适应度函数&#xff0c;采用SABO优化VMD的两个参数。其次对每种状态的数据进行特征向量的求取&#xff0c;并为每组数据打上标签。然后将数据送入…

VN5620以太网测试——DoIP配置

文章目录 前言一、DoIP简介二、Vector Hardware Configuration三、Diagnostics/ISO TP Configuration四、Diagnostic Console五、添加Ethernet Packet Builder前言 CANoe(CAN open environment)VN5620 :是一个紧凑而强大的接口,用于以太网网络的分析、仿真、测试和验证。 V…

Go 理解零值

在 Go 语言中&#xff0c;零值&#xff08;Zero Value&#xff09;是指在声明变量但没有显式赋值的情况下&#xff0c;变量会被自动赋予一个默认值。这个默认值取决于变量的类型&#xff0c;不同类型的变量会有不同的零值。零值是 Go 语言中的一个重要概念&#xff0c;因为它确…

低代码编辑平台后台实现

背景 之前做过一个前端低代码编辑平台&#xff0c;可以实现简单的移动端页面组件拖拽编辑&#xff1a; https://github.com/li-car-fei/react-visual-design 最近基于C的oatpp框架实现了一下后台。使用oatpp框架做web后台开发时&#xff0c;发现按照官方的示例使用的话&#…

设计模式(4)-行为型模式

行为型模式 行为型模式用于描述程序在运行时复杂的流程控制&#xff0c;即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务&#xff0c;它涉及算法与对象间职责的分配。 行为型模式分为类行为模式和对象行为模式&#xff0c;前者采用继承机制来在类间…

基于模拟退火算法的TSP问题建模求解(Python)

基于模拟退火算法的TSP问题建模求解&#xff08;Python&#xff09; 一、模拟退火算法&#xff08;Simulated Annealing Algorithm&#xff0c;SAA&#xff09;工程背景模拟退火算法用于优化问题求解原理 二、旅行商问题&#xff08;Travelling salesman problem&#xff0c;TS…

Linux脚本shell中将Windos格式字符转换为unix

众所周知&#xff0c;windos的文档直接复制到linux服务器上去&#xff0c;是需要进行格式转换的&#xff0c;否则可能出现以下报错&#xff1a; 解决方法&#xff1a; vim 脚本 输入 :set ff ##会显示字符格式 :set ffunix ##转换为unix格式 :wq ##保存退出

蓝眼开源云盘部署全过程(手动安装)

环境概述&#xff1a; 系统-Centos7.4 数据库-MySQL8 云盘系统-Tank4.0.1 前提&#xff1a;操作系统已完成安装&#xff0c;有外部网络。 一.安装数据库 cd到合适的目录进行下载安装操作&#xff0c;期间不要切换出去。 wget https://dev.mysql.com/get/mysql80-community-r…

WPF程序给按钮增加不同状态的图片

首先我们在资源里添加几个图片&#xff0c;Up&#xff0c;Over和Down状态。 然后我们创建一个Style。默认我们的背景设置成Up 然后在Triggers里添加代码&#xff0c;当Property&#xff1a;IsMouseOver为True的时候更换成Over&#xff1b;当Property&#xff1a;IsPressed为Tr…

如何在 Nginx Proxy Manager(NPM)上部署静态网站

前言 众所周知&#xff0c;我们在之前介绍过 Nginx Proxy Manager&#xff08;以下简称 NPM) 这个反向代理的神器&#xff0c;对于一些 Docker 搭建的 Web 项目&#xff0c;NPM 能够很轻松地给他们做反向代理。 然而对于一些静态网站&#xff0c;小伙伴们可能不知道怎么用 NP…