【ARM】s3c2440裸机之RTC数字时钟

简介:

功能

   裸机程序,实现LCD显示数字时钟



主要代码


1)背景绘制

1
2
3
4
5
6
7
8
9
10
11
void  Brush_ U32  c)
{
     int  x,y ;
     for  ( y = 0 ; y < LCD_HEIGHT ; y++ )
     {
         for  ( x = 0 ; x < LCD_WIDTH ; x++ )
         {
             LCD_BUFFER[y][x] = c ;
         }
     }
}



2)文字绘制

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
void  Draw_Text16(U32 x,U32 y,U32 color,U32 backColor, const  unsigned  char  ch[])
{
     unsigned  short  int  i,j;
     unsigned  char  mask,buffer;
     /*一个汉字16行*/
     for  (i=0;i<16;i++)
     {
         /*汉字左半部分*/
         mask=0x80;                         //从bit7开始判断
         buffer=ch[i*2];                    //提取一行的第一个字节
         /*一个字节有8个位,每一位代表字模数据对应的点是否描颜色*/
         for  (j=0;j<8;j++)
         {
             if  (buffer&mask)
             {
                 PutPixel(x+j,y+i,color);   //为笔画上色
             }
             else
             {
                 PutPixel(x+j,y+i,backColor);  //背景色
             }
             mask=mask>>1;                  //移位,为判断下一位作准备
         }
         /*汉字右半部分*/
         mask=0x80;                         //从bit7开始判断
         buffer=ch[i*2+1];                  //提取一行的第二个字节
         /*一个字节有8个位,每一位代表字模数据对应的点是否描颜色*/
         for  (j=0;j<8;j++)
         {
             if  (buffer&mask)
             {
                 PutPixel(x+j+8,y+i,color);  //为笔画上色
             }
             else
             {
                 PutPixel(x+j+8,y+i,backColor); //背景色
             }
             mask=mask>>1;                  //移位,为判断下一位作准备
         }
     }
}



3)时钟设置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
void  RTC_Time_Set(  void  )
{
     /*RTC读写使能,选择BCD时钟、计数器,无复位,1/32768*/
     rRTCCON = 1 ;  
     rBCDYEAR = 0x13;         /*年*/
     rBCDMON  = 0x05;         /*月*/
     rBCDDATE = 0x09;         /*日*/
     rBCDDAY  = 0x04;         /*星*/
     rBCDHOUR = 0x10;         /*小时*/
     rBCDMIN  = 0x57;         /*分*/
     rBCDSEC  = 0x20;         /*秒*/
     /*关读写使能*/
     rRTCCON &= ~1 ;
}



4)数字绘制

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
void  Draw_Text_8_16(U32 x,U32 y,U32 color,U32 backColor, const  unsigned  char  *chs)
{
     U32 i=0;
     while  (*chs !=  '\0' )
     {    //汉字内码都是大于0xa0
         if  (*chs > 0xa0)
         {
             /*查汉字表*/
             for  (i=0 ;i < GB16_NUM();i++)
             {
                 /*换行*/
                 if (x>235)
                 {
                     x=0;
                     y=y+16;
                 }
                 /*判断汉字是否匹配*/
                 if  ((*chs == hz_index[i]) && (*(chs+1) == hz_index[i+1]))
                 {
                     /*写汉字*/
                     Draw_Text16(x,y,color,backColor,&hz[16*(i)]);
                     /*增加X坐标值,为写下一个汉字或字符作准备*/
                     x +=16;
                     break ;
                 }
             }
             /*字符串指针加2,一个汉字编译后内码占两个字节*/
             chs+=2;
         }
         /*如果是字符*/
         else
         {
             /*换行*/
             if (x>230)
             {
                 x=0;
                 y=y+16;
             }
             /*查字符表*/
             for  (i=0 ;i < ASCII_NUM();i++)
             {
                 /*判断字符是否匹配*/
                 if  (*chs == zf_index[i])
                 {
                     /*写字符*/
                     Draw_ASCII(x,y,color,backColor,&zf[16*i]);
                     /*增加X坐标值,为写下一个汉字或字符作准备*/
                     x += 8;
                     break ;
                 }
             }
             /*字符串指针加1,一个字符编译后内码占1个字节*/
             chs++;
         }
     }
}



5)时钟显示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
void  rtc_display_lcd( void )
  {
                           //0   1   2   3   4
      unsigned  char  time []={ '2' , '0' , '1' , '3' , '-' ,
                           //5   6   7   8   9  10
                            '0' , '5' , '-' , '0' , '9' , ' ' ,
                           //11  12  13  14  15  16  17  18
                            '1' , '5' , ':' , '2' , '1' , ':' , '5' , '9' ,
                            '\0' };
      time [2]=rBCDYEAR/16+ '0' ;    //年十位,16进制
      time [3]=rBCDYEAR%16+ '0' ;    //年个位
      time [5]=rBCDMON/16+ '0' ;     //月十位
      time [6]=rBCDMON%16+ '0' ;     //月个位
      time [8]=rBCDDATE/16+ '0' ;    //天十位
      time [9]=rBCDDATE%16+ '0' ;    //天个位
      time [11]=rBCDHOUR/16+ '0' ;    //时十位
      time [12]=rBCDHOUR%16+ '0' ;    //时个位
      time [14]=rBCDMIN/16+ '0' ;     //分十位
      time [15]=rBCDMIN%16+ '0' ;     //分个位
      time [17]=rBCDSEC/16+ '0' ;    //秒十位
      time [18]=rBCDSEC%16+ '0' ;    //秒个位
      /*调用LCD显示时间程序*/
      if ( time [18]%2==1)
      {
       time [16]= ':' ;
      }
      else
      {
       time [16]= ' ' ;
      }
      Draw_Text_8_16(50,220,0x0,0xffff,( const  unsigned  char  * ) time );  
}



6)实时刷新

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
     while  (1)
     {
         /*读取时间,并LCD显示*/                      
         rtc_display_lcd();
         for (r=0;r<3;r++)
     {
         for (a=0;a<(2*PI);)
         {
             X=( int )(r* cos (a)+120);
             Y=( int )(r* sin (a)+120);
             LCD_BUFFER[Y][X]=0X00;
             a=a+(PI/360);
         }
     }
/************秒指针的显示*************/
         n=(rBCDSEC/16)*10+(rBCDSEC%16);
         if (secondbit!=n)
         {
             for (w=0;w<66;w++) //清前一秒秒表指针,必须要清掉     
             {
                 X=( int )(w* cos ((3*PI/2)+secondbit*(PI/30))+120);
                 Y=( int )(w* sin ((3*PI/2)+secondbit*(PI/30))+120);
                 LCD_BUFFER[Y][X]=0Xffff;
             }
             for (w=0;w<66;w++)     //显示当前秒表指针
             {
                 X=( int )(w* cos ((3*PI/2)+n*(PI/30))+120);
                 Y=( int )(w* sin ((3*PI/2)+n*(PI/30))+120);
                 LCD_BUFFER[Y][X]=0X00;
             }
         }
/************分指针的显示*************/
         m=(rBCDMIN/16)*10+(rBCDMIN%16);
         if (minbit!=m||m==secondbit)
         {
             for (w=0;w<55;w++) //清前一秒分钟指针   
             {
                 X=( int )(w* cos ((3*PI/2)+minbit*(PI/30))+120);
                 Y=( int )(w* sin ((3*PI/2)+minbit*(PI/30))+120);
                 LCD_BUFFER[Y][X]=0Xffff;     
             }
             for (w=0;w<55;w++)     //显示当前分钟指针
             {    
                 X=( int )(w* cos ((3*PI/2)+m*(PI/30))+120);
                 Y=( int )(w* sin ((3*PI/2)+m*(PI/30))+120);
                 LCD_BUFFER[Y][X]=0X00;
             }
         }
/************小时指针的显示*************/
         h=(rBCDHOUR/16)*10+(rBCDHOUR%16);
         if (h>12)
         h-=12;
         if (hourbit!=h||h==(minbit/5)||h==(secondbit/5))
         {
             for (w=0;w<38;w++) //清前一小时指针    
             {
                 X=( int )(w* cos ((3*PI/2)+hourbit*(PI/30))+120);
                 Y=( int )(w* sin ((3*PI/2)+hourbit*(PI/30))+120);
                 LCD_BUFFER[Y][X]=0xffff;
             }
             for (w=0;w<38;w++)     //显示当前小时指针
             {    
                 X=( int )(w* cos ((3*PI/2)+h*(PI/6))+120);
                 Y=( int )(w* sin ((3*PI/2)+h*(PI/6))+120);
                 LCD_BUFFER[Y][X]=0X00;
             }
         }
         hourbit   = h;
         minbit    = m;
         secondbit = n;
     }



时钟效果



本文转自infohacker 51CTO博客,原文链接:http://blog.51cto.com/liucw/1197253


相关文章
ARM | STM32F10xxx课堂学习笔记(时钟 & 高级控制定时器)
时钟 STM32F10xxx参考手册中文版 6.2 时钟 peripheral n.外部设备PCLK1 低速外设时钟PCLK2 高速外设时钟RC 阻容.
1688 0
ARM Linux系统的时钟机制
1. Linux下有两类时钟: 1.1 实时钟RTC     它由板上电池驱动的“Real Time Clock”也叫做RTC或者叫CMOS时钟,硬件时钟。当操作系统关机的时候,用这个来记录时间,但是对于运行的系统是不用这个时间的。
1481 0
阿里云服务器ECS架构区别及选择参考:X86计算、ARM计算等架构介绍
在我们选购阿里云服务器的时候,云服务器架构有X86计算、ARM计算、GPU/FPGA/ASIC、弹性裸金属服务器、高性能计算可选,有的用户并不清楚他们之间有何区别,本文主要简单介绍下这些架构各自的主要性能及适用场景,以便大家了解不同类型的架构有何不同,主要特点及适用场景有哪些。
阿里云服务器架构有啥区别?X86计算、Arm、GPU异构、裸金属和高性能计算对比
阿里云ECS涵盖x86、ARM、GPU/FPGA/ASIC、弹性裸金属及高性能计算等多种架构。x86架构采用Intel/AMD处理器,适用于广泛企业级应用;ARM架构低功耗,适合容器与微服务;GPU/FPGA/ASIC专为AI、图形处理设计;弹性裸金属提供物理机性能;高性能计算则针对大规模并行计算优化。
110 7
阿里云服务器Arm计算架构解析:Arm计算架构云服务器租用收费标准价格参考
阿里云服务器架构分为X86计算、Arm计算、高性能计算等多种架构,其中Arm计算架构以其低功耗、高效率的特点受到广泛关注。本文将深入解析阿里云Arm计算架构云服务器的技术特点、适用场景以及包年包月与按量付费的收费标准与最新活动价格情况,以供选择参考。