找回密码
 立即注册
楼主: 陈家乐

用软件IIC驱动的PCF8563实时时钟芯片

[复制链接]
  • 打卡等级:以坛为家I
  • 打卡总天数:300
  • 最近打卡:2025-05-04 08:21:10
已绑定手机

4

主题

339

回帖

1620

积分

金牌会员

积分
1620
发表于 2024-7-20 17:27:09 | 显示全部楼层
_奶*** 发表于 2024-7-20 14:40
跳数啥意思,,走着走着 7 下一个变成9然后 然后把8跳了?

每次到17再加就变10
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:435
  • 最近打卡:2025-04-30 08:43:23

33

主题

2351

回帖

4860

积分

论坛元老

积分
4860
发表于 2024-7-20 17:41:49 | 显示全部楼层
haiya*** 发表于 2024-7-20 17:27
每次到17再加就变10

啊?那应该是你的程序逻辑问题啊。。虽然不知道你是怎么配置的,,我这里是如果进入配置模式的话 秒针就不动了,直到退出配置模式。
参考例程并不是对技术参 考手册的补充,而是对技术参 考手册的解释。
技术参 考手册不应该需要参考例程作为补充,而是解释成了参考例程的样子
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:300
  • 最近打卡:2025-05-04 08:21:10
已绑定手机

4

主题

339

回帖

1620

积分

金牌会员

积分
1620
发表于 2024-7-21 09:50:27 | 显示全部楼层
_奶*** 发表于 2024-7-20 17:41
啊?那应该是你的程序逻辑问题啊。。虽然不知道你是怎么配置的,,我这里是如果进入配置模式的话 秒针就 ...

走时是正常的 就是调整时有点问题,继续找问题
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:404
  • 最近打卡:2025-05-03 12:51:38
已绑定手机

51

主题

138

回帖

1502

积分

金牌会员

积分
1502
发表于 2024-7-21 12:12:03 | 显示全部楼层
_奶*** 发表于 2024-7-20 12:40
跳数啥意思,,走着走着 7 下一个变成9然后 然后把8跳了?

这么说的话,难不成是调整参数的按键处理的不太妥当?
用尽STC单片机的资源是我的梦想
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:404
  • 最近打卡:2025-05-03 12:51:38
已绑定手机

51

主题

138

回帖

1502

积分

金牌会员

积分
1502
发表于 2024-7-21 12:12:48 | 显示全部楼层

你可以私下加我,我给你看看?还是你可以给我发个视频,咱俩瞅瞅啥问题?
用尽STC单片机的资源是我的梦想
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:524
  • 最近打卡:2025-05-04 02:13:29

10

主题

1161

回帖

5133

积分

论坛元老

积分
5133
发表于 2024-7-21 12:22:59 | 显示全部楼层
这个是用硬件I2C 给这个单片机STC8A8K64D4

  1. /*---------------------------------------------------------------------*/
  2. /* --- STC MCU Limited ------------------------------------------------*/
  3. /* --- STC 1T Series MCU Demo Programme -------------------------------*/
  4. /* --- Mobile: (86)13922805190 ----------------------------------------*/
  5. /* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*/
  6. /* --- Tel: 86-0513-55012928,55012929,55012966 ------------------------*/
  7. /* --- Web: www.STCMCU.com --------------------------------------------*/
  8. /* --- Web: www.STCMCUDATA.com  ---------------------------------------*/
  9. /* --- QQ:  800003751 -------------------------------------------------*/
  10. /* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序            */
  11. /*---------------------------------------------------------------------*/
  12. /*************  本程序功能说明  **************
  13. 读写RTC, IC为PCF8563.
  14. 用STC的MCU的IO方式驱动8位数码管。
  15. 使用Timer0的16位自动重装来产生1ms节拍,程序运行于这个节拍下, 用户修改MCU主时钟频率时,自动定时于1ms.
  16. 8位数码管显示时间(小时-分钟-秒).
  17. 行列扫描按键键码为17~32.
  18. 按键只支持单键按下, 不支持多键同时按下, 那样将会有不可预知的结果.
  19. 键按下超过1秒后,将以10键/秒的速度提供重键输出. 用户只需要检测KeyCode是否非0来判断键是否按下.
  20. 调整时间键:
  21. 键码17: 小时+.
  22. 键码18: 小时-.
  23. 键码19: 分钟+.
  24. 键码20: 分钟-.
  25. 下载时, 选择时钟 24MHZ (用户可自行修改频率).
  26. ******************************************/
  27. #include    "reg51.h"       //包含此头文件后,里面声明的寄存器不需要再手动输入,避免重复定义
  28. #include    "intrins.h"
  29. #define     MAIN_Fosc       24000000L   //定义主时钟
  30. typedef     unsigned char   u8;
  31. typedef     unsigned int    u16;
  32. typedef     unsigned long   u32;
  33. //手动输入声明"reg51.h"头文件里面没有定义的寄存器
  34. sfr TH2  = 0xD6;
  35. sfr TL2  = 0xD7;
  36. sfr IE2   = 0xAF;
  37. sfr INT_CLKO = 0x8F;
  38. sfr AUXR = 0x8E;
  39. sfr AUXR1 = 0xA2;
  40. sfr P_SW1 = 0xA2;
  41. sfr P_SW2 = 0xBA;
  42. sfr S2CON = 0x9A;
  43. sfr S2BUF = 0x9B;
  44. sfr P4   = 0xC0;
  45. sfr P5   = 0xC8;
  46. sfr P6   = 0xE8;
  47. sfr P7   = 0xF8;
  48. sfr P1M1 = 0x91;    //PxM1.n,PxM0.n     =00--->Standard,    01--->push-pull
  49. sfr P1M0 = 0x92;    //                  =10--->pure input,  11--->open drain
  50. sfr P0M1 = 0x93;
  51. sfr P0M0 = 0x94;
  52. sfr P2M1 = 0x95;
  53. sfr P2M0 = 0x96;
  54. sfr P3M1 = 0xB1;
  55. sfr P3M0 = 0xB2;
  56. sfr P4M1 = 0xB3;
  57. sfr P4M0 = 0xB4;
  58. sfr P5M1 = 0xC9;
  59. sfr P5M0 = 0xCA;
  60. sfr P6M1 = 0xCB;
  61. sfr P6M0 = 0xCC;
  62. sfr P7M1 = 0xE1;
  63. sfr P7M0 = 0xE2;
  64. sbit P00 = P0^0;
  65. sbit P01 = P0^1;
  66. sbit P02 = P0^2;
  67. sbit P03 = P0^3;
  68. sbit P04 = P0^4;
  69. sbit P05 = P0^5;
  70. sbit P06 = P0^6;
  71. sbit P07 = P0^7;
  72. sbit P10 = P1^0;
  73. sbit P11 = P1^1;
  74. sbit P12 = P1^2;
  75. sbit P13 = P1^3;
  76. sbit P14 = P1^4;
  77. sbit P15 = P1^5;
  78. sbit P16 = P1^6;
  79. sbit P17 = P1^7;
  80. sbit P20 = P2^0;
  81. sbit P21 = P2^1;
  82. sbit P22 = P2^2;
  83. sbit P23 = P2^3;
  84. sbit P24 = P2^4;
  85. sbit P25 = P2^5;
  86. sbit P26 = P2^6;
  87. sbit P27 = P2^7;
  88. sbit P30 = P3^0;
  89. sbit P31 = P3^1;
  90. sbit P32 = P3^2;
  91. sbit P33 = P3^3;
  92. sbit P34 = P3^4;
  93. sbit P35 = P3^5;
  94. sbit P36 = P3^6;
  95. sbit P37 = P3^7;
  96. sbit P40 = P4^0;
  97. sbit P41 = P4^1;
  98. sbit P42 = P4^2;
  99. sbit P43 = P4^3;
  100. sbit P44 = P4^4;
  101. sbit P45 = P4^5;
  102. sbit P46 = P4^6;
  103. sbit P47 = P4^7;
  104. sbit P50 = P5^0;
  105. sbit P51 = P5^1;
  106. sbit P52 = P5^2;
  107. sbit P53 = P5^3;
  108. sbit P54 = P5^4;
  109. sbit P55 = P5^5;
  110. sbit P56 = P5^6;
  111. sbit P57 = P5^7;
  112. #define I2CCFG          (*(unsigned char volatile xdata *)0xfe80)
  113. #define I2CMSCR         (*(unsigned char volatile xdata *)0xfe81)
  114. #define I2CMSST         (*(unsigned char volatile xdata *)0xfe82)
  115. #define I2CSLCR         (*(unsigned char volatile xdata *)0xfe83)
  116. #define I2CSLST         (*(unsigned char volatile xdata *)0xfe84)
  117. #define I2CSLADR        (*(unsigned char volatile xdata *)0xfe85)
  118. #define I2CTXD          (*(unsigned char volatile xdata *)0xfe86)
  119. #define I2CRXD          (*(unsigned char volatile xdata *)0xfe87)
  120. #define I2CMSAUX        (*(unsigned char volatile xdata *)0xfe88)
  121. sbit SDA = P1^4;
  122. sbit SCL = P1^5;
  123. /***********************************************************/
  124. #define DIS_DOT     0x20
  125. #define DIS_BLACK   0x10
  126. #define DIS_        0x11
  127. #define SLAW    0xA2
  128. #define SLAR    0xA3
  129. /****************************** 用户定义宏 ***********************************/
  130. #define Timer0_Reload   (65536UL -(MAIN_Fosc / 1000))       //Timer 0 中断频率, 1000次/秒
  131. /*****************************************************************************/
  132. /*************  本地常量声明    **************/
  133. u8 code t_display[]={                       //标准字库
  134. //   0    1    2    3    4    5    6    7    8    9    A    B    C    D    E    F
  135.     0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71,
  136. //black  -     H    J    K    L    N    o   P    U     t    G    Q    r   M    y
  137.     0x00,0x40,0x76,0x1E,0x70,0x38,0x37,0x5C,0x73,0x3E,0x78,0x3d,0x67,0x50,0x37,0x6e,
  138.     0xBF,0x86,0xDB,0xCF,0xE6,0xED,0xFD,0x87,0xFF,0xEF,0x46};    //0. 1. 2. 3. 4. 5. 6. 7. 8. 9. -1
  139. u8 code T_COM[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};      //位码
  140. /*************  本地变量声明    **************/
  141. u8  LED8[8];        //显示缓冲
  142. u8  display_index;  //显示位索引
  143. bit B_1ms;          //1ms标志
  144. u8 IO_KeyState, IO_KeyState1, IO_KeyHoldCnt;    //行列键盘变量
  145. u8  KeyHoldCnt; //键按下计时
  146. u8  KeyCode;    //给用户使用的键码
  147. u8  cnt50ms;
  148. u8  hour,minute,second; //RTC变量
  149. u16 msecond;
  150. /*************  本地函数声明    **************/
  151. void    IO_KeyScan(void);   //50ms call
  152. void    WriteNbyte(u8 addr, u8 *p, u8 number);
  153. void    ReadNbyte( u8 addr, u8 *p, u8 number);
  154. void    DisplayRTC(void);
  155. void    ReadRTC(void);
  156. void    WriteRTC(void);
  157. /**********************************************/
  158. void main(void)
  159. {
  160.     u8  i;
  161.     P0M1 = 0x00;   P0M0 = 0x00;   //设置为准双向口
  162.     P1M1 = 0x00;   P1M0 = 0x00;   //设置为准双向口
  163.     P2M1 = 0x00;   P2M0 = 0x00;   //设置为准双向口
  164.     P3M1 = 0x00;   P3M0 = 0x00;   //设置为准双向口
  165.     P4M1 = 0x00;   P4M0 = 0x00;   //设置为准双向口
  166.     P5M1 = 0x20;   P5M0 = 0x00;   //设置为准双向口, 设置P5.5(蜂鸣器)高阻输入
  167.     P6M1 = 0x00;   P6M0 = 0x00;   //设置为准双向口
  168.     P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口
  169.    
  170.     display_index = 0;
  171.    
  172.     for(i=0; i<8; i++)  LED8[i] = 0x10; //上电消隐
  173.    
  174.     AUXR = 0x80;    //Timer0 set as 1T, 16 bits timer auto-reload,
  175.     TH0 = (u8)(Timer0_Reload / 256);
  176.     TL0 = (u8)(Timer0_Reload % 256);
  177.     ET0 = 1;    //Timer0 interrupt enable
  178.     TR0 = 1;    //Tiner0 run
  179.     P_SW2 |= 0x80;
  180.     I2CCFG = 0xe0;                  //使能I2C主机模式
  181.     I2CMSST = 0x00;
  182.     EA = 1;     //打开总中断
  183.    
  184.     ReadRTC();
  185.     F0 = 0;
  186.     if(second >= 60)    F0 = 1; //错误
  187.     if(minute >= 60)    F0 = 1; //错误
  188.     if(hour   >= 24)    F0 = 1; //错误
  189.     if(F0)  //有错误, 默认12:00:00
  190.     {
  191.         second = 0;
  192.         minute = 0;
  193.         hour  = 12;
  194.         WriteRTC();
  195.     }
  196.     DisplayRTC();
  197.     LED8[2] = DIS_;
  198.     LED8[5] = DIS_;
  199.     KeyHoldCnt = 0; //键按下计时
  200.     KeyCode = 0;    //给用户使用的键码
  201.     IO_KeyState = 0;
  202.     IO_KeyState1 = 0;
  203.     IO_KeyHoldCnt = 0;
  204.     cnt50ms = 0;
  205.     while(1)
  206.     {
  207.         if(B_1ms)   //1ms到
  208.         {
  209.             B_1ms = 0;
  210.             if(++msecond >= 1000)   //1秒到
  211.             {
  212.                 msecond = 0;
  213.                 ReadRTC();
  214.                 DisplayRTC();
  215.             }
  216.             if(++cnt50ms >= 50)     //50ms扫描一次行列键盘
  217.             {
  218.                 cnt50ms = 0;
  219.                 IO_KeyScan();
  220.             }
  221.             
  222.             if(KeyCode != 0)        //有键按下
  223.             {
  224.                 if(KeyCode == 17)   //hour +1
  225.                 {
  226.                     if(++hour >= 24)    hour = 0;
  227.                     WriteRTC();
  228.                     DisplayRTC();
  229.                 }
  230.                 if(KeyCode == 18)   //hour -1
  231.                 {
  232.                     if(--hour >= 24)    hour = 23;
  233.                     WriteRTC();
  234.                     DisplayRTC();
  235.                 }
  236.                 if(KeyCode == 19)   //minute +1
  237.                 {
  238.                     second = 0;
  239.                     if(++minute >= 60)  minute = 0;
  240.                     WriteRTC();
  241.                     DisplayRTC();
  242.                 }
  243.                 if(KeyCode == 20)   //minute -1
  244.                 {
  245.                     second = 0;
  246.                     if(--minute >= 60)  minute = 59;
  247.                     WriteRTC();
  248.                     DisplayRTC();
  249.                 }
  250.                 KeyCode = 0;
  251.             }
  252.         }
  253.     }
  254. }
  255. /********************** 显示时钟函数 ************************/
  256. void    DisplayRTC(void)
  257. {
  258.     if(hour >= 10)  LED8[0] = hour / 10;
  259.     else            LED8[0] = DIS_BLACK;
  260.     LED8[1] = hour % 10;
  261.     LED8[2] = DIS_;
  262.     LED8[3] = minute / 10;
  263.     LED8[4] = minute % 10;
  264.     LED8[6] = second / 10;
  265.     LED8[7] = second % 10;
  266. }
  267. /********************** 读RTC函数 ************************/
  268. void    ReadRTC(void)
  269. {
  270.     u8  tmp[3];
  271.     ReadNbyte(2, tmp, 3);
  272.     second = ((tmp[0] >> 4) & 0x07) * 10 + (tmp[0] & 0x0f);
  273.     minute = ((tmp[1] >> 4) & 0x07) * 10 + (tmp[1] & 0x0f);
  274.     hour   = ((tmp[2] >> 4) & 0x03) * 10 + (tmp[2] & 0x0f);
  275. }
  276. /********************** 写RTC函数 ************************/
  277. void    WriteRTC(void)
  278. {
  279.     u8  tmp[3];
  280.     tmp[0] = ((second / 10) << 4) + (second % 10);
  281.     tmp[1] = ((minute / 10) << 4) + (minute % 10);
  282.     tmp[2] = ((hour / 10) << 4) + (hour % 10);
  283.     WriteNbyte(2, tmp, 3);
  284. }
  285. /*****************************************************
  286.     行列键扫描程序
  287.     使用XY查找4x4键的方法,只能单键,速度快
  288.    Y     P04      P05      P06      P07
  289.           |        |        |        |
  290. X         |        |        |        |
  291. P00 ---- K00 ---- K01 ---- K02 ---- K03 ----
  292.           |        |        |        |
  293. P01 ---- K04 ---- K05 ---- K06 ---- K07 ----
  294.           |        |        |        |
  295. P02 ---- K08 ---- K09 ---- K10 ---- K11 ----
  296.           |        |        |        |
  297. P03 ---- K12 ---- K13 ---- K14 ---- K15 ----
  298.           |        |        |        |
  299. ******************************************************/
  300. u8 code T_KeyTable[16] = {0,1,2,0,3,0,0,0,4,0,0,0,0,0,0,0};
  301. void IO_KeyDelay(void)
  302. {
  303.     u8 i;
  304.     i = 60;
  305.     while(--i)  ;
  306. }
  307. void IO_KeyScan(void)    //50ms call
  308. {
  309.     u8  j;
  310.     j = IO_KeyState1;   //保存上一次状态
  311.     P0 = 0xf0;  //X低,读Y
  312.     IO_KeyDelay();
  313.     IO_KeyState1 = P0 & 0xf0;
  314.     P0 = 0x0f;  //Y低,读X
  315.     IO_KeyDelay();
  316.     IO_KeyState1 |= (P0 & 0x0f);
  317.     IO_KeyState1 ^= 0xff;   //取反
  318.    
  319.     if(j == IO_KeyState1)   //连续两次读相等
  320.     {
  321.         j = IO_KeyState;
  322.         IO_KeyState = IO_KeyState1;
  323.         if(IO_KeyState != 0)    //有键按下
  324.         {
  325.             F0 = 0;
  326.             if(j == 0)  F0 = 1; //第一次按下
  327.             else if(j == IO_KeyState)
  328.             {
  329.                 if(++IO_KeyHoldCnt >= 20)   //1秒后重键
  330.                 {
  331.                     IO_KeyHoldCnt = 18;
  332.                     F0 = 1;
  333.                 }
  334.             }
  335.             if(F0)
  336.             {
  337.                 j = T_KeyTable[IO_KeyState >> 4];
  338.                 if((j != 0) && (T_KeyTable[IO_KeyState& 0x0f] != 0))
  339.                     KeyCode = (j - 1) * 4 + T_KeyTable[IO_KeyState & 0x0f] + 16;    //计算键码,17~32
  340.             }
  341.         }
  342.         else    IO_KeyHoldCnt = 0;
  343.     }
  344.     P0 = 0xff;
  345. }
  346. /********************** 显示扫描函数 ************************/
  347. void DisplayScan(void)
  348. {   
  349.     P7 = ~T_COM[7-display_index];
  350.     P6 = ~t_display[LED8[display_index]];
  351.     if(++display_index >= 8)    display_index = 0;  //8位结束回0
  352. }
  353. /********************** Timer0 1ms中断函数 ************************/
  354. void timer0 (void) interrupt 1
  355. {
  356.     DisplayScan();  //1ms扫描显示一位
  357.     B_1ms = 1;      //1ms标志
  358. }
  359. void Wait()
  360. {
  361.     while (!(I2CMSST & 0x40));
  362.     I2CMSST &= ~0x40;
  363. }
  364. void Start()
  365. {
  366.     I2CMSCR = 0x01;                         //发送START命令
  367.     Wait();
  368. }
  369. void SendData(char dat)
  370. {
  371.     I2CTXD = dat;                           //写数据到数据缓冲区
  372.     I2CMSCR = 0x02;                         //发送SEND命令
  373.     Wait();
  374. }
  375. void RecvACK()
  376. {
  377.     I2CMSCR = 0x03;                         //发送读ACK命令
  378.     Wait();
  379. }
  380. char RecvData()
  381. {
  382.     I2CMSCR = 0x04;                         //发送RECV命令
  383.     Wait();
  384.     return I2CRXD;
  385. }
  386. void SendACK()
  387. {
  388.     I2CMSST = 0x00;                         //设置ACK信号
  389.     I2CMSCR = 0x05;                         //发送ACK命令
  390.     Wait();
  391. }
  392. void SendNAK()
  393. {
  394.     I2CMSST = 0x01;                         //设置NAK信号
  395.     I2CMSCR = 0x05;                         //发送ACK命令
  396.     Wait();
  397. }
  398. void Stop()
  399. {
  400.     I2CMSCR = 0x06;                         //发送STOP命令
  401.     Wait();
  402. }
  403. void WriteNbyte(u8 addr, u8 *p, u8 number)  /*  WordAddress,First Data Address,Byte lenth   */
  404. {
  405.     Start();                                //发送起始命令
  406.     SendData(SLAW);                         //发送设备地址+写命令
  407.     RecvACK();
  408.     SendData(addr);                         //发送存储地址
  409.     RecvACK();
  410.     do
  411.     {
  412.         SendData(*p++);
  413.         RecvACK();
  414.     }
  415.     while(--number);
  416.     Stop();                                 //发送停止命令
  417. }
  418. void ReadNbyte(u8 addr, u8 *p, u8 number)   /*  WordAddress,First Data Address,Byte lenth   */
  419. {
  420.     Start();                                //发送起始命令
  421.     SendData(SLAW);                         //发送设备地址+写命令
  422.     RecvACK();
  423.     SendData(addr);                         //发送存储地址
  424.     RecvACK();
  425.     Start();                                //发送起始命令
  426.     SendData(SLAR);                         //发送设备地址+读命令
  427.     RecvACK();
  428.     do
  429.     {
  430.         *p = RecvData();
  431.         p++;
  432.         if(number != 1) SendACK();          //send ACK
  433.     }
  434.     while(--number);
  435.     SendNAK();                              //send no ACK       
  436.     Stop();                                 //发送停止命令
  437. }
  438. /****************************/
复制代码
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:300
  • 最近打卡:2025-05-04 08:21:10
已绑定手机

4

主题

339

回帖

1620

积分

金牌会员

积分
1620
发表于 2024-7-22 07:55:36 | 显示全部楼层
陈*** 发表于 2024-7-21 12:12
你可以私下加我,我给你看看?还是你可以给我发个视频,咱俩瞅瞅啥问题? ...

找到问题了 ,就是调整时间时 ,读取时间函数中断有影响,禁掉就好了
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:404
  • 最近打卡:2025-05-03 12:51:38
已绑定手机

51

主题

138

回帖

1502

积分

金牌会员

积分
1502
发表于 2024-7-22 09:38:05 | 显示全部楼层
haiya*** 发表于 2024-7-22 05:55
找到问题了 ,就是调整时间时 ,读取时间函数中断有影响,禁掉就好了

好好好,这么整哈哈
用尽STC单片机的资源是我的梦想
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:324
  • 最近打卡:2025-05-04 09:44:01
已绑定手机

21

主题

487

回帖

1049

积分

金牌会员

积分
1049
发表于 2024-7-22 09:52:35 | 显示全部楼层
STC自带的RTC功能还未使用过,简单了解下,以后用到了再仔细学学
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家II
  • 打卡总天数:404
  • 最近打卡:2025-05-03 12:51:38
已绑定手机

51

主题

138

回帖

1502

积分

金牌会员

积分
1502
发表于 2024-7-23 10:14:26 | 显示全部楼层
lly*** 发表于 2024-7-22 07:52
STC自带的RTC功能还未使用过,简单了解下,以后用到了再仔细学学

可以的没问题,用过之后再进行对比
用尽STC单片机的资源是我的梦想
回复 支持 反对

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2025-5-4 10:30 , Processed in 0.216880 second(s), 116 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表