Cstyle的嵌入式之:那些年我们一起写过的单片机程序,世上最简单的单片机程序

    周末回家,正漫无目的的浏览着网站,突有一QQ消息弹出自称是大学学生因不熟悉单片机,老师催作业太急,需要求助,题目大概如下
正好闲着没事,就说我们也是那个时候过来的,就来随便写写,看下当初的东西是否都还给老师了,就打开了MDK开始敲起来,大概半小时终于完成了,小伙伴们来围观下,嘿嘿。虽然它的电路图漏洞百出,不过看起来应该是个示意图,所以我的程序也算是示意,逻辑大概通顺,没有编译调试过,也可能有语法错误不过这不影响我回忆单片机的心情。O(∩_∩)O
#include <at89c51.h>
static unsigned code char DecodeNum[16]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f};//需要调试,取字模,解码
#typedef ONE 1  //select the first LED
#typedef TWO 2  //select the second LED
#typedef THR 3  //select the third  LED
#typedef FOR 4  //select the four LED
#typedef Delay1MS 1
#typedef Delay100MS 100
#typedef Delay1S    100000
void Put8(unsigned char Data8,unsigned char Cs);
void Puts8(unsigned char *Data8,Unsigned char Length);
void Delay(unsigned int Time);
main()
{   
  //添加输出的任务
  //例子1:输出数字 5 到第三个LED上  
  //例子2:循环输出一串数字到四个LED上
  unsigned char data8[7]={1,2,3,4,5,6,7};
  Put8(5,3); //ext.1
  while(1)    //ext.2
{
  Puts8(data8,7);
  Delay(Delay1S); 
}
}
//output 8 bit date to port 0
void Out8(uniigned char Data8)
{
P0 = Data8;
}
//select one LED to show the data output from port0
void Cs(Unsigned char Data8)
{
switch(Data8)
{
case ONE:
{
P2^1=0;
break;
}
case TWO :
{
P2^2=0;
break;
}
case THR :
{
P2^3=0;
break;
}
case FOR :
{
P2^4=0;
break;
}
default break;
}
}
//show one data on the selected LED
void Put8(unsigned char Data8,unsigned char Cs)
{
Out8(DecodeNum[Data8]);
Cs(Cs);
}
//show a string on the for LED
void Puts8(unsigned char *Data8,Unsigned char Length)
{
unsigned int i;
for(i=0;i<Length;i++)
{
i=i%FOR;
Put8([*Data8++],i+1);
Delay(Delay100MS);
}
}
//Delay for a while
void Delay(unsigned int Time)
{
ungingned int i;
for(i=0;i<Time;i++)
}
先到这里。
转载请注明出处
Cstyle.z.zhou@gmail.com  //  http://blog.csdn.net/CStyle_0x007
图片

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这个单片机程序可以分为以下几个部分: 1. 初始化:包括引脚配置、定时器配置、串口配置等。 2. 超声波测距模块的配置:通过定时器和IO口,发出一定频率的超声波脉冲,然后接收回波并计算距离。 3. LEDO显示屏的配置:通过IO口控制LEDO显示屏的亮灭和显示内容,可以显示距离和其他信息。 4. 万历模块的配置:通过计算机内部时钟和日期寄存器,实现万历功能,可以显示当前的日期和时间。 下面是一个简单程序框架,可以根据具体的硬件和需求进行修改: ```c #include <reg52.h> #define TRIG P1_0 // 超声波发射引脚 #define ECHO P1_1 // 超声波接收引脚 #define LEDO P2 // LEDO显示屏引脚 #define RTC_ADDR 0xD0 // 万历模块地址 void init(); void ultrasonic(); void display(int distance); void calendar(); void main() { init(); while (1) { ultrasonic(); display(distance); calendar(); } } void init() { // 引脚配置 P1M0 = 0x01; // P1_0为推挽输出 P1M1 = 0x00; P1M0 = 0x00; // P1_1为开漏输入 P1M1 = 0x01; P2M0 = 0x00; // P2为推挽输出 P2M1 = 0x00; // 定时器配置 TMOD = 0x10; // 定时器1为模式1 TH1 = 0xFD; // 波特率为9600 TL1 = 0xFD; TR1 = 1; // 启动定时器1 // 串口配置 SCON = 0x50; // 串口模式1 ES = 1; // 开启串口中断 EA = 1; // 开启总中断 } void ultrasonic() { // 发送超声波 TRIG = 1; delay_us(10); TRIG = 0; // 接收回波 while (!ECHO); // 等待高电平 TH0 = 0; TL0 = 0; TR0 = 1; // 启动定时器0 while (ECHO); // 等待低电平 TR0 = 0; // 停止定时器0 distance = TH0 * 256 + TL0; // 计算距离 distance = distance / 58; // 转换为厘米 } void display(int distance) { // 在LEDO上显示距离 LEDO = 0xFF; // 全亮 delay_ms(500); LEDO = 0x00; // 全灭 delay_ms(500); if (distance < 10) { LEDO = 0x01; // 仅第一位亮 } else if (distance < 100) { LEDO = 0x03; // 前两位亮 } else if (distance < 1000) { LEDO = 0x07; // 前三位亮 } else { LEDO = 0x0F; // 四位都亮 } delay_ms(500); } void calendar() { // 获取当前时间 unsigned char year, month, day, hour, minute, second; I2C_Start(); I2C_SendByte(RTC_ADDR); I2C_SendByte(0x00); I2C_Start(); I2C_SendByte(RTC_ADDR + 1); second = I2C_ReadByte(); minute = I2C_ReadByte(); hour = I2C_ReadByte(); day = I2C_ReadByte(); month = I2C_ReadByte(); year = I2C_ReadByte(); I2C_Stop(); // 在LEDO上显示日期和时间 LEDO = 0x10; // 第一位亮表示日期 LEDO = month / 10 << 4 | month % 10; // 显示月份 delay_ms(500); LEDO = day / 10 << 4 | day % 10; // 显示日期 delay_ms(500); LEDO = 0x20; // 第二位亮表示时间 LEDO = hour / 10 << 4 | hour % 10; // 显示小时 delay_ms(500); LEDO = minute / 10 << 4 | minute % 10; // 显示分钟 delay_ms(500); } void delay_us(unsigned int n) { while (n--) { _nop_(); _nop_(); _nop_(); _nop_(); } } void delay_ms(unsigned int n) { while (n--) { delay_us(1000); } } void I2C_Start() { SDA = 1; SCL = 1; delay_us(5); SDA = 0; delay_us(5); SCL = 0; } void I2C_Stop() { SDA = 0; SCL = 1; delay_us(5); SDA = 1; delay_us(5); } void I2C_SendByte(unsigned char dat) { unsigned char i; for (i = 0; i < 8; i++) { SDA = dat & 0x80; SCL = 1; delay_us(5); SCL = 0; dat <<= 1; } SDA = 1; SCL = 1; delay_us(5); SCL = 0; } unsigned char I2C_ReadByte() { unsigned char i, dat = 0; SDA = 1; for (i = 0; i < 8; i++) { SCL = 1; delay_us(5); dat = dat << 1 | SDA; SCL = 0; delay_us(5); } return dat; } void UART_SendByte(unsigned char dat) { SBUF = dat; while (!TI); TI = 0; } void UART_SendString(unsigned char *str) { while (*str) { UART_SendByte(*str++); } } void UART_ISR() interrupt 4 { if (RI) { unsigned char dat = SBUF; // 处理串口接收到的数据 RI = 0; } if (TI) { // 处理串口发送完成的中断 TI = 0; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值