STM32电子时钟1602显示仿真加程序

发布者:星尘散落最新更新时间:2020-07-24 来源: 51hei关键字:STM32  电子时钟  1602显示 手机看文章 扫描二维码
随时随地手机看文章

#include "stm32f4xx.h"
#include "delay.h"

#include "seg.h"

#include "timer.h"
unsigned int nian = 2020;
char yue = 7;
char ri = 16;
char shi = 9;
char fen = 31;
char miao = 30;
u8  bs=0;//存储时间的变量
u8 date[8]={0,0,0,0,0,0,0,0};//数据
u16 address[8]={0x0101,0x0102,0x0104,0x0108,0x0110,0x0120,0x0140,0x0180};//位码
char wendu[] = "Date:";
char shidu[] = "Time:";
       
#define LCD_DATA_PORT GPIOC

#define        LCD_RS_Set()        GPIO_SetBits(GPIOB, GPIO_Pin_8)
#define        LCD_RS_Clr()        GPIO_ResetBits(GPIOB, GPIO_Pin_8)

#define        LCD_RW_Set()        GPIO_SetBits(GPIOB, GPIO_Pin_9)
#define        LCD_RW_Clr()        GPIO_ResetBits(GPIOB, GPIO_Pin_9)

#define        LCD_EN_Set()        GPIO_SetBits(GPIOB, GPIO_Pin_10)
#define        LCD_EN_Clr()        GPIO_ResetBits(GPIOB, GPIO_Pin_10)

#define        DATAOUT(x)        GPIO_Write(GPIOC, x)

#define u8  unsigned char

void GPIO_Configuration(void);     
void LCD1602_Wait_Ready(void);        //判忙                              
void LCD1602_Write_Cmd(u8 cmd);             //写命令                     
void LCD1602_Write_Dat(u8 dat);              //写数据                     
void LCD1602_ClearScreen(void);              //清屏                     
void LCD1602_Set_Cursor(u8 x, u8 y);              
void LCD1602_Show_Str(u8 x, u8 y, char *str);    //显示                     
void LCD1602_Init(void);                        //初始化   
void GPIO_Configuration(void)
{
        GPIO_InitTypeDef        GPIO_InitStructure;
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);
       
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC, ENABLE);

       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;                           
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;       
        GPIO_Init(LCD_DATA_PORT, &GPIO_InitStructure);                               
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10;   
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;                           
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;       
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;       
        GPIO_InitStructure.GPIO_PuPd=GPIO_PuPd_UP;          //上拉
        GPIO_Init(GPIOB, &GPIO_InitStructure);                               
}

void LCD1602_Wait_Ready(void)   //检测忙
{
        int8_t sta=0;
       
        DATAOUT(0xff);      //PC全置1
        LCD_RS_Clr();       //RS 0
        LCD_RW_Set();       //RW 1
        do
        {
                LCD_EN_Set();   //EN 1
                delay_ms(10);
                sta = GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_7); //读取状态字   
                LCD_EN_Clr();   //EN 0
        }while(sta & 0x80);
}

void LCD1602_Write_Cmd(u8 cmd)    //写入指令
{
        LCD1602_Wait_Ready();     //判忙
        LCD_RS_Clr();   
        LCD_RW_Clr();
        DATAOUT(cmd);  
        delay_us(10);
        LCD_EN_Set();
        LCD_EN_Clr();

}

void LCD1602_Write_Dat(u8 dat)
{
        LCD1602_Wait_Ready();
        LCD_RS_Set();   
        LCD_RW_Clr();   
        DATAOUT(dat);
    delay_us(10);       
        LCD_EN_Set();  
        LCD_EN_Clr();

       
}

void LCD1602_ClearScreen(void)  //清屏
{
        LCD1602_Write_Cmd(0x01);
       
}

void LCD1602_Set_Cursor(u8 x, u8 y)   //光标设置位置
{
        u8 addr;
       
        if (y == 0)
                addr = 0x00 + x;
        else
                addr = 0x40 + x;
        LCD1602_Write_Cmd(addr | 0x80);
}

void LCD1602_Show_Str(u8 x, u8 y, char *str)//字符串
{
        LCD1602_Set_Cursor(x, y);
        while(*str != '')
        {
                LCD1602_Write_Dat(*str++);
        }
}

void LCD1602_Init(void)//初始化
{
        GPIO_Configuration();
        LCD1602_Write_Cmd(0x38);       
        LCD1602_Write_Cmd(0x0C);       
        LCD1602_Write_Cmd(0x06);       
        LCD1602_Write_Cmd(0x01);       
}


int main(void)
{


        TIM3_Int_Init(15-1,2100-1);        //定时器3初始化
        LCD1602_Init();
        LCD1602_Show_Str(0,0,wendu);          //日期显示
        LCD1602_Show_Str(0,2,shidu);           //时间显示
        while(1)
        {
       
        get_time(); //计时
              LCD1602_Write_Cmd( 0x80+5 );
                                LCD1602_Write_Dat( nian/1000 + 0x30 );//显示年
                                LCD1602_Write_Dat( nian%1000/100 + 0x30 );
                                LCD1602_Write_Dat( nian%100/10 + 0x30 );
                                LCD1602_Write_Dat( nian%10 + 0x30 );
                                LCD1602_Write_Dat( '-' );
                                LCD1602_Write_Dat( yue/10 + 0x30 );//显示月
                                LCD1602_Write_Dat( yue%10 + 0x30 );
                          LCD1602_Write_Dat( '-' );
                                LCD1602_Write_Dat( ri/10 + 0x30 );//显示日
                                LCD1602_Write_Dat( ri%10 + 0x30 );
               
                               
                                LCD1602_Write_Cmd( 0x80 +0x40+5);
                       
                                LCD1602_Write_Dat( shi/10 + 0x30 ); //显示时
                                LCD1602_Write_Dat( shi%10 + 0x30 );
                                LCD1602_Write_Dat( ':' );
                                LCD1602_Write_Dat( fen/10 + 0x30 );//显示分
                                LCD1602_Write_Dat( fen%10 + 0x30 );
                                LCD1602_Write_Dat( ':' );
                                LCD1602_Write_Dat( miao/10 + 0x30 );//显示秒
                                LCD1602_Write_Dat( miao%10 + 0x30 );
        }
}

[1] [1]
关键字:STM32  电子时钟  1602显示 引用地址:STM32电子时钟1602显示仿真加程序

上一篇:一款DAC模块(TLV5608&TLV5610)STM32源程序
下一篇:STM32用DAC播放WAV数据源程序

推荐阅读最新更新时间:2024-11-17 06:33

STM32实战四 定时器和按键
这一章编写定时器,包括定时器基类 Timer 和派生的通用定时器 GeneralTimer。基类对定时器参数进行封装,通用定时器封装一些定时应用,对应PLC的一些功能,包括: 1ms定时中断 100个32位数字时间继电器,最小1ms,最大0xffffffff,大约50天。 一个高精度回调函数,微秒级误差,最小定时间隔1ms。 按键抖动和干扰过滤,并产生按键上升沿和下降沿。 代码中有详细的说明,这里只解释几个知识点,其它文档介绍按键防抖和延时的时候一般都是死循环,官方文档也是这么用,如果有很多按键和延时就会一个一个等,效率很低。我这里用了另外一种高效的方法,就是模仿时间继电器,100个计数器同时工作,直到计数为0时执行对应操作,
[单片机]
STM32家族新成员—STM32WB双核无线芯片
STM32家族新成员—STM32WB双核无线芯片 2018年10月12日,意法半导体在北京召开媒体发布会,隆重发布并介绍了STM32系列的第12个新成员—STM32WB。STM32WB的发布对STM32来说有着重大的意义,正如意法半导体中国区微控制器事业部市场及应用总监曹锦东所说“未来整个产业的发展是面向物联网产业的,物联网产业里不能缺少无线的产品线,STM32产品更不能缺乏跟无线产品相关的IP,STM32WB的发布将会帮助STM32进入无线领域,并加强STM32在物联网市场的影响力。” 意法半导体中国微控制器事业部市场及应用总监 曹锦东 正在本次发布会中,意法半导体STM32超低功耗和网络微控制器市场经
[单片机]
<font color='red'>STM32</font>家族新成员—STM32WB双核无线芯片
stm32的RTC操作
分为两个文件: rtc.c /******************************************************************************* * 文件名 :rtc.c * 描述 :wit_yuan * 论坛 : **********************************************************************************/ #include rtc.h #include stdio.h #include misc.h uint8_t const *WEEK_STR = { 日 , 一 , 二 , 三 , 四 , 五
[单片机]
一个关于STM32 CAN出错恢复的话题
最近有个STM32 用户咨询: 最近在使用stm32f105做双can通信,can驱动芯片使用的TJA1042,发现将canH canL 短路再放开以后,can出错恢复不回来?之前在K40上使用的时候没有这个问题,不知道这个情况大家有什么指导建议啊? 另外,他还附上了基于STM32CUBEMX工具配置的相关代码如下: hcan1.Instance = CAN1; hcan1.Init.Prescaler = 2; hcan1.Init.Mode = CAN_MODE_NORMAL; hcan1.Init.SJW = CAN_SJW_1TQ; hcan1.Init.BS1 = CAN_BS1_8TQ; hc
[单片机]
一个关于<font color='red'>STM32</font> CAN出错恢复的话题
STM32的定时器有两种捕获模式——PWM输入模式和普通输入模式
一个定时器最多能同时捕获几路PWM波? 我只需要得到PWM的高电平宽度,PWM的频率是50HZ STM32的定时器有两种捕获模式 PWM输入模式和普通输入模式 在PWM输入模式下,一个定时器只能同时捕获一路PWM波 在普通输入模式下,理论上是可以同时捕获4路PWM波 即,在定时器中断中改变触发模式(上升沿、下降沿) 然后寄存器两次的差值即近似为高电平长度
[单片机]
STM32如何使用内部时钟源当系统时钟
由于最近老师让做一个项目,要用到STM32但是考虑成本问题,决定不用外部时钟,所以在网上搜集整理了一些资料,加上自己的一些想法。 参考资料: http://bbs.ednchina.com/BLOG_ARTICLE_3011869.HTM http://bbs.21ic.com/icview-587714-1-1.html 首先在主程序中注释掉SystemInit(); 然后使用下面的函数做为系统时钟的初始化函数 void RCC_Configuration(void) { RCC_DeInit();//将外设 RCC寄存器重设为缺省值 RCC_HSICmd(ENABLE);//使能HSI
[单片机]
<font color='red'>STM32</font>如何使用内部时钟源当系统时钟
STM32:DMA实例之串口(USART)通信
硬件平台:stm32f10xZET6 开发环境:keil MDK uVision v4.10 开发语言:C、ST_lib_3.5固件库 /* 代码演示 main.c */ #include stm32f10x.h #include bsp_usart1.h #include bsp_led.h extern uint8_t SendBuff ; static void Delay(__IO u32 nCount); /** * @brief 主函数 */ int main(void) { /* USART1 config 115200 8-N-1 */
[单片机]
STM32的CAN总线中继器设计及应用
引言 CAN总线是一种多主方式的串行通信总线,具有优良的稳定性、实时性、远程通信能力以及超强的硬件CRC纠错等特性;CAN总线技术的应用不再仅限于汽车行业,而是扩展到了机械、纺织、控制等行业,并被公认为是最有前途的现场总线之一。然而由于受制于CAN收发器,CAN总线通信距离和网络中节点数被分别限制在10 km和110个之内。但是在稍大型的CAN总线系统中,这往往是不够的,这时就需要用CAN总线中继器对CAN总线网络进行扩展。 CAN中继器是系统组网的关键技术设备之一,使用中继器可以提高网络设计的灵活性,并且通过中继器还可以连接两个不同波特率的CAN总线网络;在两个网络间进行数据转发,极大地扩展其使用范围。基于此,本文设计出
[单片机]
<font color='red'>STM32</font>的CAN总线中继器设计及应用
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved