搜索
bottom↓
回复: 3

求个LCD12864.H的液晶模块驱动包。求大神们帮助。

[复制链接]

出0入0汤圆

发表于 2012-10-26 16:17:43 | 显示全部楼层 |阅读模式
求个LCD12864.H的液晶模块驱动包。  

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

发表于 2012-10-26 16:30:25 | 显示全部楼层
这个不如直接问液晶的厂商。   不同品牌,会有出入;用途功能不同,也会有不同的写法。

出0入0汤圆

发表于 2012-10-26 16:44:18 | 显示全部楼层
  1. /**************************************************************************************
  2. 程序名称:
  3.            时间 温度控制系统(128*64LCD+ds1302+ds18b20)
  4. 主要功能:
  5.            温度计 时钟 闹铃 密码锁 篮球器 计算器 温度控制 键盘锁 系统设置等。
  6. 主要说明:
  7.            程序全部定义在一个C文件中。
  8. 作者:   
  9.            LiJH
  10. 时间:   
  11.            2008.6.20
  12. 版本:   
  13.            LiJH-V1.0
  14. **************************************************************************************

  15. 本图文菜单系统技术交流
  16. 网址:21单片机开发实验室
  17. http://www.21mcuel.com
  18. QQ:978710555
  19. **************************************************************************************/


  20. #include    <at89s53.h>
  21. #include    <intrins.h>               
  22. #define     uchar        unsigned char
  23. #define     uint         unsigned int
  24. #define     time_count   0x3cb0
  25. #define     close        1
  26. #define     open         0

  27. /*============ 状态控制及温感器总线定义 ==============*/

  28. #define     b20_io       P0_0                // DS18B20总线          
  29. #define     pw_oc        P3_7                // 密码锁开启控制(黄灯)
  30. #define     buzzer       P0_5                 // 蜂鸣器
  31. #define     lcd_bl       P0_6                // 背光控制口
  32. #define     als_th       P0_4                // 上限温度警报(红灯)
  33. #define     als_tl       P3_6                // 下限温度警报(绿灯)
  34. #define            keyboard     P1                        // 键盘数据口


  35. /*================= ST7920LCD 定义 ===================*/

  36. #define     comm         0                        // lcd指令
  37. #define     dat          1                        // lcd数据
  38. #define     lcd_rst      P0_7                // lcd复位
  39. #define     lcd_e        P3_0                // lcd使能
  40. #define     lcd_rw       P3_1                // lcd读写
  41. #define     lcd_rs       P3_2                // lcd数据命令
  42. #define     busy         P2_7       // 忙碌位
  43. #define     lcd_data     P2                        // lcd(8bit)数据传输

  44.   
  45. /*=============== DS1302 寄存器地址定义 ===============*/

  46. #define                d02_rst      P0_1                // DS1302使能
  47. #define                d02_data     P0_2                // DS1302数据线
  48. #define                d02_sclk     P0_3                // DS1302脉冲
  49. #define     d02_wrc      0x8e                // 1302读写RAM控制(1允许 0禁止)
  50. #define     d02_year         0x8c                // 年
  51. #define     d02_weeks         0x8a                // 星期
  52. #define     d02_month         0x88                // 月
  53. #define     d02_day                 0x86                // 日
  54. #define     d02_hour         0x84                // 时
  55. #define     d02_minute         0x82                // 分
  56. #define     d02_second         0x80                // 秒
  57. #define     d02_signs         0xc0                // 系统状态(记录设置标记)
  58. #define     d02_passw         0xc2                // 密码寄存器首位(有3位下位地址加2,初始值为:741456)
  59. #define     d02_alm                 0xc8                // 闹铃时间小时位(下位为分钟位加2)
  60. #define     d02_temp         0xcc                // 温度上限警报(有两位下位位下限加2)
  61. #define     d02_initsi   0xd4                // 1302初始化标记(为0xb4时,说明已经初始化)
  62. #define     ret_ds1302()    d02_rst=0;d02_sclk=0;d02_rst=1        // 1302读写复位
  63. #define     end_ds1302()    d02_sclk=1;d02_rst=0                        // 1302读写结束



  64. /*================================= 全局变量定义 ==================================*/


  65. typedef        struct                        // 定义时间类型
  66. {
  67.   uchar        hour;
  68.   uchar        minute;
  69.   uchar        second;
  70. }time;

  71. typedef        struct                        // 定义日期类型
  72. {
  73.   uchar        year;
  74.   uchar        month;
  75.   uchar        day;
  76.   uchar        week;
  77. }date;

  78. typedef union                     // 定义温度类型
  79. {
  80.   int temp_data;
  81.   uchar t_data[2];
  82. }trdata;

  83. trdata  bdata  temp;             // 温度警报值暂存       
  84. date    idata  today={'8',1,1,1};         // 日期暂存
  85. time    idata  now={0x12,0,0} , save_time={0x12,0,0};
  86.               // 时间暂存(now是读出时间暂存 save_time上一时间暂存)
  87. uchar   idata  time_tick=20,time_tick1=20,alarm_time[2],als_temp[2],
  88.               // T0中断数,     T1中断数,     闹铃时间,   警报温度
  89.                bl_delay=15,temp_delay=5,opera[2][12],resu[12],
  90.                           // 背光时间,  温度更新时间, 计算器数据寄存, 结果寄存
  91.                            i,j,save1,temp_min=0;
  92.                            // 计算器i/j下标,中间暂存,温度更新(分)



  93. uchar  bdata   signs=0;                 // 系统标记寄存器
  94.   sbit bl1=signs^7;                  // bl1,bl0背光选择位(00 延时,01 常开,10 关闭)
  95.   sbit bl0=signs^6;                       
  96.   sbit di1=signs^5;                         // di1,di0显示模式(00模式1,01模式2,10模式3)
  97.   sbit di0=signs^4;                       
  98.   sbit meu=signs^3;                         // 菜单显示方式(0 图片,1 文字)
  99.   sbit keb=signs^2;                         // 键盘锁(0 无锁,1加锁)
  100.   sbit alm=signs^1;                         // 闹钟启动位(0 关闭,1开启)
  101.   sbit als=signs^0;                         // 报警启动位(0 启动,1关闭)



  102. uint   bdata   run_signs=0;     // 运行标记寄存器
  103.   sbit ds18b20=run_signs^0;                // 温感器存在标记(0不存在,1存在)
  104.   sbit temp_pn=run_signs^1;                // 温度正负号标记(0正,1负)
  105.   sbit temprun=run_signs^2;                // 温感器运行标记(0否,1启动)
  106.   sbit nba_tim=run_signs^3;           // 篮球计时器标记(0关闭,1启动)
  107.   sbit adju_si=run_signs^4;                // 数字更改连续标记(1连续)
  108.   sbit cal_del=run_signs^5;     // 计算器显示点标记(0没有显示)
  109.   sbit cal_run=run_signs^6;            // 计算完毕标记(1有效)
  110.   sbit oth_run=run_signs^7;     // 其他标记
  111.   sbit alm_run=run_signs^8;     // 闹钟时间到达标记(1有效)
  112.   sbit dis_sig=run_signs^9;     // 显示时间标记(1有效)
  113.   sbit lock_op=run_signs^10;    // 关锁时间到标记(1有效)
  114.   sbit b20time=run_signs^11;    // 温感器重新读温度标记(1有效)
  115.   sbit t0_isr =run_signs^12;    // TO中断标记(1有效(1s)
  116.   sbit thl_als=run_signs^13;        // 温度警报标记
  117.   sbit init_d2=run_signs^14;        // 模式2初始显示
  118.   sbit buzstop=run_signs^15;        // 蜂鸣器停止标记




  119. /*================================= 字体显示代码 ==================================*/

  120. uchar code weeks[7][2]={"一","二","三","四","五","六","日"}; // 星期                                //图片中文
  121. uchar code menu_cn[6][8]={"调    整","工    具","设    置","保    密","版    本","退    出"};
  122. uchar code menu_cn_2[6][6]={"调  整","工  具","设  置","保  密","版  本","退  出"};// 菜单文字
  123. uchar code selected[2][16]={{"进入【      】\x04 "},{"设置【    】\x10 \x04 "}}; // 选框
  124. uchar code secrets_menu[4][6]={"开  锁","更  改","初始化","退  出"};           // 保密菜单中文
  125. uchar code tool_menu[5][6]={"计算器","温度计","闹  铃","篮球器","退  出"};           // 工具菜单中文
  126. uchar code char_num[10]={"0123456789"};         // 数字显示代码                                                         // 每月天数
  127. uchar code dayofmonth[12]={0x31,0x28,0x31,0x30,0x31,0x30,0x31,0x31,0x30,0x31,0x30,0x31};
  128. uchar code key_code[]={0xD7,0x7E,0x7D,0x7B,0xBE,0xBD,0xBB,0xDE,0xDD,0xDB,0xB7,0x77,0xEE,0xED,0xEB,0xE7};
  129. uchar code ksp[4]={0x7F,0xBF,0xDF,0xEF};         // 按键扫描代码
  130. uchar code tool_cal[4][2]={"+ ","- ","* ","/ "}; // 运算符号
  131. uchar code alm_sign[2][2]={"关","开"};                         // 闹铃开关
  132. uchar code set_bl_dm[2][3][4]={{"30秒","常开","关闭"},{"模01","模02","模03"}};
  133. uchar code set_mka[3][2][4]={{"图片","文字"},{"解锁","加锁"},{"开启","关闭"}};
  134. uchar code nba_oppo[8][2]={"红","白","蓝","绿","紫","灰","黄","黑"};
  135. uchar code set_menu[6][4]={"背光","显示","菜单","键盘","警报","退出"};


  136. uchar code version[10][14]={   // 版本信息
  137.                             {"清远职业技术学"},
  138.                                                         {"  信息科技学院"},
  139.                                                 {"08届毕业设计  "},
  140.                                                 {"  —05电子02班"},
  141.                                         {"作者:李锦华  "},
  142.                                                 {"指导:李祖明  "},
  143.                                                 {"版本:LIJH-V1.0"},
  144.                                                 {"    2008/06/19"},
  145.                                                 {"谢谢你的使用!"},
  146.                                                 {"         (ok)\x10"}};


  147. uchar code timer_tips[12][16]={ // 篮球器使用说明
  148.                             {"使用方法:      "},
  149.                                                         {"  (+)(-)与(*)(/)"},
  150.                                                         {"分别是两方的分数"},
  151.                                                         {"加与减,(7)键回退"},
  152.                                                         {"一秒,(8)键24秒复"},
  153.                                                         {"位,(9)键暂停与开"},
  154.                                                         {"始;暂停状态下:"},
  155.                                                         {"按两次(OK)键可返"},
  156.                                                         {"回时钟模式-2界面"},
  157.                                                         {",(OK)键返回程序"},
  158.                                                         {"界面,(./S)键两次"},
  159.                                                         {"退出程序.      \x1f"}};



  160. /*================================= 操作导航代码 ==================================*/


  161. typedef struct                        // 定义主菜单操作索引
  162. {
  163.   uchar shaft_num;
  164.   uchar left_num;
  165.   uchar right_num;
  166. }menu_index;

  167. typedef struct                        // 定义导航更改索引
  168. {
  169.   uchar lnum;
  170.   uchar rnum;
  171. }index;

  172. menu_index code index_m[6]={{3,5,1},{4,0,2},{5,1,3},{0,2,4},{1,3,5},{2,4,0}}; // 菜单导航
  173. index code index_t[6]={{4,1},{0,2},{1,3},{2,4},{3,0}};       // 工具导航
  174. index code index_p[5]={{3,1},{0,2},{1,3},{2,0}};             // 保密导航
  175. index code index_s[6]={{5,1},{0,2},{1,3},{2,4},{3,5},{4,0}}; // 设置导航
  176. index code index_a[7]={{0x81,0x91},{0x83,0x91},{0x85,0x91},{0x89,0x81},
  177.                                 {0x8b,0x81},{0x8d,0x81},{0x8f,0x91}};       // 调整下的坐标
  178. index code index_temp_set[3]={{0x8b,0x81},{0x8b,0x91},{0x8f,0x91}}; // 温度设定下的坐标
  179. index code index_alm[3]={{0x8c,0x81},{0x8e,0x81},{0x8f,0x91}};            // 闹铃更改坐标       
  180. index code index_cal[3]={{0x86,0x90},{0x8e,0x80},{0x8e,0x90}};            // 计算器操作坐标
  181. uchar code index_nba[4]={0x93,0x97,0x8b,0x8f};                                            // 篮球器设置导航





  182. /*========================== 菜单图片(宽度x高度=32*24)=============================*/

  183. uchar code menu_pic[6][96]={
  184.         {// 调整
  185.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x40,0x00,0x00,0x02,
  186.          0x40,0x00,0x00,0x82,0x47,0xFF,0xE1,0xC2,0x47,0xFF,0xF3,0xE2,0x47,0x38,0x68,0x02,
  187.          0x46,0xDF,0x68,0x82,0x46,0xDF,0x69,0xC2,0x46,0xDE,0xE8,0x82,0x46,0xDD,0xE8,0x02,
  188.          0x46,0xDD,0xE8,0x02,0x47,0x3D,0xE8,0x02,0x47,0xFF,0xE8,0x02,0x47,0xFF,0xE9,0xC2,
  189.          0x42,0x00,0x18,0x02,0x41,0xFF,0xF3,0xE2,0x40,0x00,0x01,0xC2,0x40,0x00,0x00,0x82,
  190.          0x40,0x00,0x00,0x02,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00},
  191.        
  192.         {// 工具                                       
  193.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x40,0x00,0x03,0x82,
  194.          0x41,0xF0,0x07,0xC2,0x43,0xFF,0xCF,0xE2,0x47,0x3F,0xFE,0x02,0x47,0x3F,0xFE,0x02,
  195.          0x43,0xFF,0xCF,0xE2,0x41,0xF0,0x0F,0xC2,0x40,0x00,0x03,0x82,0x40,0x00,0x00,0x02,
  196.          0x40,0x00,0x03,0xC2,0x40,0x00,0x03,0xC2,0x41,0x80,0x01,0x82,0x43,0xFF,0xF3,0xC2,
  197.          0x47,0xFF,0xFF,0xE2,0x47,0xFF,0xFF,0xE2,0x43,0xFF,0xF3,0xC2,0x41,0x80,0x01,0x82,
  198.          0x40,0x00,0x01,0x82,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00},
  199.        
  200.         {// 设置
  201.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x43,0x18,0x00,0x02,
  202.          0x44,0xA4,0x0E,0x02,0x44,0xA4,0x1F,0x02,0x43,0x24,0x3F,0x02,0x40,0x00,0x7F,0x02,
  203.          0x40,0xF0,0xFC,0x02,0x43,0xF9,0xF0,0x02,0x43,0x03,0xE0,0x02,0x46,0x77,0x80,0x02,
  204.          0x46,0x7F,0x00,0x02,0x46,0x7E,0x00,0x02,0x46,0x7C,0x00,0x02,0x47,0x3D,0x00,0x02,
  205.          0x43,0x1D,0x81,0x22,0x43,0x81,0xB2,0x42,0x41,0xC3,0x4F,0xE2,0x40,0xFE,0x4A,0x42,
  206.          0x40,0x3C,0x32,0x42,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00},
  207.        
  208.         {// 保密
  209.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x40,0xFC,0x03,0x02,
  210.          0x41,0xFE,0x1F,0x02,0x43,0x87,0x03,0x82,0x43,0x03,0x03,0x02,0x43,0x03,0x03,0x02,
  211.          0x43,0x03,0x0F,0x02,0x43,0x03,0x03,0x02,0x43,0x03,0x03,0x02,0x47,0xFF,0x83,0x02,
  212.          0x47,0xFF,0x83,0x02,0x47,0xCF,0x83,0x02,0x47,0x87,0x83,0x02,0x47,0xCF,0x83,0x02,
  213.          0x47,0xCF,0x87,0x82,0x47,0xCF,0x8F,0xC2,0x47,0xCF,0x9C,0xE2,0x47,0xFF,0x8F,0xC2,
  214.          0x43,0xFF,0x07,0x82,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00},
  215.        
  216.         {// 版本
  217.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x40,0x00,0x00,0x02,
  218.          0x40,0x0F,0x00,0x62,0x40,0x1D,0x80,0xF2,0x40,0x38,0x41,0xF2,0x40,0x70,0x23,0xE2,
  219.          0x40,0xE2,0x17,0xC2,0x41,0xE4,0x4F,0x82,0x41,0xF0,0x9F,0x02,0x41,0x59,0x16,0x02,
  220.          0x42,0x4C,0x1D,0x02,0x42,0x46,0x20,0x82,0x42,0x47,0x00,0x42,0x44,0x43,0x80,0xC2,
  221.          0x44,0x44,0xC1,0xC2,0x44,0xC8,0x63,0x82,0x45,0x50,0x37,0x02,0x46,0x60,0x1E,0x02,
  222.          0x40,0x40,0x0C,0x02,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00},
  223.        
  224.         {// 退出
  225.          0x00,0x00,0x00,0x00,0x7F,0xFF,0xFF,0xFE,0x40,0x00,0x00,0x02,0x40,0x40,0xFF,0xE2,
  226.          0x40,0x60,0x80,0x62,0x43,0xF0,0x80,0xA2,0x43,0xF0,0x81,0x22,0x40,0x60,0x82,0x22,
  227.          0x40,0x40,0x84,0x22,0x40,0x00,0x88,0x22,0x40,0x00,0x88,0x22,0x47,0xFF,0xF8,0x22,
  228.          0x47,0xFF,0xF8,0x22,0x46,0x2A,0x2A,0x22,0x46,0xE3,0x78,0x22,0x46,0x77,0x78,0x22,
  229.          0x46,0xE3,0x78,0x62,0x46,0x2A,0x38,0x82,0x47,0xFF,0xF9,0x02,0x47,0xFF,0xFA,0x02,
  230.          0x40,0x00,0x0C,0x02,0x40,0x00,0x00,0x02,0x7F,0xFF,0xFF,0xFE,0x00,0x00,0x00,0x00,}};




  231. /*================ 显示模式2数字及温度符号图片(宽度x高度=16*32)=====================*/

  232. uchar code mode_2num[11][64]={
  233.         {// 图片数字0
  234.          0x00,0x00,0x3F,0xFC,0x5F,0xFA,0x6F,0xF6,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  235.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x60,0x06,0x40,0x02,0x00,0x00,
  236.          0x40,0x02,0x60,0x06,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  237.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x6F,0xF6,0x5F,0xFA,0x3F,0xFC,0x00,0x00,0x00,0x00},
  238.        
  239.         {// 图片数字1
  240.          0x00,0x00,0x00,0x20,0x00,0x60,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,
  241.      0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0x60,0x00,0x20,0x00,0x00,0x00,0x20,
  242.          0x00,0x60,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0xE0,
  243.          0x00,0xE0,0x00,0xE0,0x00,0xE0,0x00,0x60,0x00,0x20,0x00,0x00,0x00,0x00,0x00,0x00},
  244.    
  245.         {// 图片数字2
  246.          0x00,0x00,0x3F,0xFC,0x1F,0xFA,0x0F,0xF6,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  247.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x06,0x1F,0xFA,0x3F,0xFC,
  248.          0x5F,0xF8,0x60,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,
  249.          0x70,0x00,0x70,0x00,0x70,0x00,0x6F,0xF8,0x5F,0xFC,0x3F,0xFE,0x00,0x00,0x00,0x00},
  250.        
  251.         {// 图片数字3
  252.          0x00,0x00,0x7F,0xFC,0x3F,0xFA,0x1F,0xF6,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  253.      0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x06,0x1F,0xFA,0x3F,0xFC,
  254.      0x1F,0xFA,0x00,0x06,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  255.      0x00,0x0E,0x00,0x0E,0x00,0x0E,0x1F,0xF6,0x3F,0xFA,0x7F,0xFC,0x00,0x00,0x00,0x00},
  256.        
  257.         {// 图片数字4
  258.          0x00,0x00,0x40,0x02,0x60,0x06,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  259.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x60,0x06,0x5F,0xFA,0x3F,0xFC,
  260.          0x1F,0xFA,0x00,0x06,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  261.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x06,0x00,0x02,0x00,0x00,0x00,0x00},
  262.        
  263.         {// 图片数字5
  264.          0x00,0x00,0x3F,0xFC,0x5F,0xF8,0x6F,0xF0,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,
  265.          0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x60,0x00,0x5F,0xF8,0x3F,0xFC,
  266.          0x1F,0xFA,0x00,0x06,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  267.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x0F,0xF6,0x1F,0xFA,0x3F,0xFC,0x00,0x00,0x00,0x00},
  268.        
  269.         {// 图片数字6
  270.          0x00,0x00,0x3F,0xFC,0x5F,0xF8,0x6F,0xF0,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,
  271.          0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x70,0x00,0x60,0x00,0x5F,0xF8,0x3F,0xFC,
  272.          0x5F,0xFA,0x60,0x06,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  273.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x6F,0xF6,0x5F,0xFA,0x3F,0xFC,0x00,0x00,0x00,0x00},
  274.        
  275.         {// 图片数字7
  276.          0x00,0x00,0x7F,0xFC,0x3F,0xFA,0x1F,0xF6,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  277.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x06,0x00,0x02,0x00,0x00,
  278.          0x00,0x02,0x00,0x06,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  279.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x06,0x00,0x02,0x00,0x00,0x00,0x00},
  280.        
  281.         {// 图片数字8
  282.          0x00,0x00,0x3F,0xFC,0x5F,0xFA,0x6F,0xF6,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  283.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x60,0x06,0x5F,0xFA,0x3F,0xFC,
  284.          0x5F,0xFA,0x60,0x06,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  285.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x6F,0xF6,0x5F,0xFA,0x3F,0xFC,0x00,0x00,0x00,0x00},
  286.        
  287.         {// 图片数字9
  288.          0x00,0x00,0x3F,0xFC,0x5F,0xFA,0x6F,0xF6,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,
  289.          0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x70,0x0E,0x60,0x06,0x5F,0xFA,0x3F,0xFC,
  290.          0x1F,0xFA,0x00,0x06,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,0x00,0x0E,
  291.          0x00,0x0E,0x00,0x0E,0x00,0x0E,0x1F,0xF6,0x3F,0xFA,0x7F,0xFC,0x00,0x00,0x00,0x00},
  292.        
  293.         {// 温度符号
  294.      0x00,0x00,0x00,0x00,0x70,0xE0,0x53,0xF0,0x77,0xFA,0x0E,0x0E,0x0C,0x06,0x18,0x06,
  295.      0x18,0x02,0x38,0x02,0x30,0x00,0x30,0x00,0x70,0x00,0x60,0x00,0x60,0x00,0x60,0x00,
  296.      0x60,0x00,0x60,0x00,0x70,0x00,0x30,0x00,0x30,0x00,0x38,0x00,0x18,0x02,0x18,0x02,
  297.      0x0C,0x06,0x0E,0x06,0x07,0x0E,0x03,0xFA,0x00,0xF0,0x00,0x60,0x00,0x00,0x00,0x00}};





  298. /*===================== 显示模式3数字图片(宽度x高度=24*32)=========================*/

  299. uchar code mode_3num[10][96]={
  300.         {// 图片数字0
  301.          0x00,0x7E,0x00,0x01,0xE7,0x80,0x03,0xC3,0xC0,0x07,0x81,0xE0,0x0F,0x80,0xF0,0x0F,
  302.          0x00,0xF0,0x1F,0x00,0xF8,0x1E,0x00,0xF8,0x3E,0x00,0x78,0x3E,0x00,0x7C,0x3E,0x00,
  303.          0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,
  304.          0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,
  305.          0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x78,0x1E,0x00,0xF8,0x1F,0x00,0xF8,0x0F,0x00,
  306.          0xF0,0x0F,0x81,0xF0,0x07,0x81,0xE0,0x03,0xC3,0xC0,0x01,0xE7,0x80,0x00,0x7E,0x00},

  307.         {// 图片数字1
  308.          0x00,0x0C,0x00,0x00,0x1C,0x00,0x00,0x7C,0x00,0x07,0xFC,0x00,0x00,0x3C,0x00,0x00,
  309.          0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,
  310.          0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,
  311.          0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,
  312.          0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,
  313.          0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3E,0x00,0x00,0x7F,0x00,0x07,0xFF,0xF0},
  314.                           
  315.         {// 图片数字2
  316.          0x00,0xFF,0x00,0x03,0xC7,0xC0,0x07,0x01,0xE0,0x0E,0x00,0xF0,0x1E,0x00,0xF8,0x1E,
  317.          0x00,0xF8,0x3E,0x00,0x78,0x3E,0x00,0x78,0x3F,0x00,0x78,0x3F,0x00,0x78,0x1F,0x00,
  318.      0xF8,0x00,0x00,0xF8,0x00,0x00,0xF0,0x00,0x01,0xF0,0x00,0x03,0xE0,0x00,0x03,0xC0,
  319.          0x00,0x07,0x80,0x00,0x0F,0x00,0x00,0x1E,0x00,0x00,0x3C,0x00,0x00,0x78,0x00,0x00,
  320.          0xF0,0x00,0x01,0xE0,0x00,0x03,0xC0,0x00,0x07,0x80,0x1C,0x07,0x00,0x1C,0x0E,0x00,
  321.          0x38,0x1C,0x00,0x38,0x3C,0x00,0x78,0x3F,0xFF,0xF8,0x3F,0xFF,0xF8,0x3F,0xFF,0xF8},

  322.         {// 图片数字3
  323.          0x00,0xFE,0x00,0x07,0x87,0x80,0x0F,0x03,0xC0,0x1E,0x01,0xE0,0x1E,0x01,0xF0,0x1E,
  324.          0x01,0xF0,0x1F,0x00,0xF0,0x1F,0x00,0xF0,0x1E,0x00,0xF0,0x00,0x00,0xF0,0x00,0x01,
  325.          0xF0,0x00,0x01,0xF0,0x00,0x03,0xE0,0x00,0x03,0xC0,0x00,0x0F,0x00,0x00,0xFE,0x00,
  326.          0x00,0x07,0x80,0x00,0x01,0xE0,0x00,0x00,0xF0,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,
  327.          0x00,0x78,0x00,0x00,0x7C,0x1E,0x00,0x7C,0x3F,0x00,0x7C,0x3F,0x00,0x7C,0x3F,0x00,
  328.          0x78,0x3E,0x00,0xF8,0x1E,0x00,0xF0,0x0F,0x01,0xE0,0x07,0x87,0xC0,0x01,0xFF,0x00},

  329.         {// 图片数字4
  330.          0x00,0x03,0xC0,0x00,0x03,0xC0,0x00,0x07,0xC0,0x00,0x0F,0xC0,0x00,0x0F,0xC0,0x00,
  331.          0x1F,0xC0,0x00,0x3F,0xC0,0x00,0x3F,0xC0,0x00,0x77,0xC0,0x00,0x77,0xC0,0x00,0xE7,
  332.          0xC0,0x01,0xC7,0xC0,0x01,0xC7,0xC0,0x03,0x87,0xC0,0x07,0x07,0xC0,0x07,0x07,0xC0,
  333.          0x0E,0x07,0xC0,0x1E,0x07,0xC0,0x1C,0x07,0xC0,0x38,0x07,0xC0,0x38,0x07,0xC0,0x7F,
  334.          0xFF,0xFE,0x7F,0xFF,0xFE,0x00,0x07,0xC0,0x00,0x07,0xC0,0x00,0x07,0xC0,0x00,0x07,
  335.          0xC0,0x00,0x07,0xC0,0x00,0x07,0xC0,0x00,0x07,0xC0,0x00,0x07,0xE0,0x00,0x7F,0xFE},

  336.         {// 图片数字5
  337.          0x0F,0xFF,0xF8,0x0F,0xFF,0xF8,0x0F,0xFF,0xF8,0x0E,0x00,0x00,0x0E,0x00,0x00,0x0E,
  338.          0x00,0x00,0x0E,0x00,0x00,0x0E,0x00,0x00,0x0E,0x00,0x00,0x0E,0x00,0x00,0x0E,0x00,
  339.          0x00,0x0E,0x7F,0x00,0x0D,0xFF,0xC0,0x0F,0xC3,0xE0,0x1F,0x01,0xF0,0x1E,0x00,0xF8,
  340.          0x1E,0x00,0xF8,0x00,0x00,0x78,0x00,0x00,0x7C,0x00,0x00,0x7C,0x00,0x00,0x7C,0x00,
  341.          0x00,0x7C,0x1E,0x00,0x7C,0x3F,0x00,0x7C,0x3F,0x00,0x78,0x3F,0x00,0x78,0x3E,0x00,
  342.          0xF8,0x1E,0x00,0xF0,0x1E,0x01,0xF0,0x0E,0x01,0xE0,0x07,0x87,0xC0,0x00,0xFF,0x00},

  343.         {// 图片数字6
  344.          0x00,0x3F,0xC0,0x00,0xF1,0xE0,0x03,0xC1,0xF0,0x07,0x81,0xF8,0x07,0x01,0xF8,0x0F,
  345.          0x00,0xF0,0x1F,0x00,0x00,0x1E,0x00,0x00,0x1E,0x00,0x00,0x3E,0x00,0x00,0x3E,0x00,
  346.          0x00,0x3E,0x00,0x00,0x3E,0x3F,0x80,0x3E,0xFF,0xE0,0x3F,0xE3,0xF0,0x3F,0x80,0xF8,
  347.          0x3F,0x00,0xF8,0x3F,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x7C,0x3E,0x00,0x3C,0x3E,
  348.          0x00,0x3C,0x3E,0x00,0x3C,0x3E,0x00,0x3C,0x3E,0x00,0x7C,0x1E,0x00,0x7C,0x1F,0x00,
  349.          0x78,0x0F,0x00,0x78,0x0F,0x80,0xF0,0x07,0xC0,0xE0,0x03,0xE3,0xC0,0x00,0xFF,0x00},

  350.         {// 图片数字7
  351.          0x1F,0xFF,0xFC,0x1F,0xFF,0xFC,0x1F,0xFF,0xF8,0x1F,0x00,0x38,0x1C,0x00,0x70,0x1C,
  352.          0x00,0xE0,0x38,0x00,0xE0,0x38,0x01,0xC0,0x00,0x01,0xC0,0x00,0x03,0x80,0x00,0x03,
  353.          0x80,0x00,0x07,0x80,0x00,0x07,0x00,0x00,0x0F,0x00,0x00,0x0E,0x00,0x00,0x1E,0x00,
  354.          0x00,0x1E,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x3C,0x00,0x00,0x7C,0x00,0x00,
  355.          0x78,0x00,0x00,0x78,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF8,
  356.          0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0x78,0x00},

  357.         {// 图片数字8
  358.          0x00,0xFF,0x00,0x07,0xC3,0xC0,0x0F,0x00,0xE0,0x1E,0x00,0xF0,0x1E,0x00,0x78,0x3C,
  359.          0x00,0x78,0x3C,0x00,0x78,0x3C,0x00,0x7C,0x3E,0x00,0x78,0x3E,0x00,0x78,0x1F,0x00,
  360.          0x78,0x1F,0x80,0xF0,0x0F,0xE1,0xE0,0x07,0xFB,0xC0,0x01,0xFF,0x80,0x01,0xFF,0x80,
  361.          0x07,0xBF,0xC0,0x0F,0x0F,0xE0,0x1E,0x03,0xF0,0x3E,0x01,0xF8,0x3C,0x00,0xF8,0x3C,
  362.          0x00,0x7C,0x7C,0x00,0x7C,0x78,0x00,0x3C,0x78,0x00,0x3C,0x7C,0x00,0x3C,0x3C,0x00,
  363.          0x78,0x3C,0x00,0x78,0x1E,0x00,0x70,0x0F,0x00,0xE0,0x07,0xC3,0xC0,0x01,0xFF,0x00},

  364.         {// 图片数字9
  365.          0x01,0xFE,0x00,0x07,0xC7,0x80,0x0F,0x01,0xE0,0x1E,0x01,0xE0,0x1E,0x00,0xF0,0x3E,
  366.          0x00,0xF8,0x3C,0x00,0x78,0x3C,0x00,0x78,0x7C,0x00,0x7C,0x7C,0x00,0x7C,0x7C,0x00,
  367.          0x7C,0x7C,0x00,0x7C,0x7C,0x00,0x7C,0x3C,0x00,0xFC,0x3E,0x00,0xFC,0x3E,0x01,0xFC,
  368.      0x1F,0x03,0xFC,0x1F,0x8F,0xFC,0x0F,0xFF,0x7C,0x03,0xFC,0x7C,0x00,0x00,0x7C,0x00,
  369.      0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF8,0x00,0x00,0xF0,0x00,0x01,0xF0,0x0F,0x01,
  370.          0xE0,0x1F,0x01,0xE0,0x1F,0x03,0xC0,0x1F,0x07,0x80,0x0F,0x9F,0x00,0x03,0xFC,0x00}};




  371. /*========================== 标记及点图片(宽度x高度=16*16)===========================*/


  372. uchar code running[7][32]={
  373.      {// 警报标记16*16
  374.           0x00,0x00,0x00,0x39,0x00,0x7B,0x00,0xFE,0x01,0xDC,0x0F,0x98,0x0F,0x18,0x0C,0x1F,
  375.       0x0C,0x1F,0x0F,0x18,0x0F,0x98,0x01,0xDC,0x00,0xFE,0x00,0x7B,0x00,0x39,0x00,0x00,},
  376.          {// 闹铃开启标记16*16
  377.           0x00,0x00,0x00,0x40,0x00,0xE0,0x01,0xB0,0x01,0xB0,0x03,0x18,0x03,0x18,0x06,0x0C,
  378.       0x0C,0x06,0x0C,0xE6,0x1B,0x1B,0x0C,0x06,0x06,0x0C,0x03,0xF8,0x00,0xE0,0x00,0x00},
  379.          {// 键盘锁标记16*16
  380.       0x00,0x00,0x01,0xF8,0x03,0xFC,0x03,0x0C,0x03,0x0C,0x03,0x0C,0x03,0xFC,0x06,0x96,
  381.       0x0E,0xA7,0x0E,0xC7,0x0E,0xA7,0x0E,0x97,0x07,0xFE,0x03,0xFC,0x01,0xF8,0x00,0x00,},
  382.          {// 温度计标记16*16
  383.           0x00,0x00,0x1F,0xF8,0x1F,0xF8,0x01,0x80,0x01,0x80,0x01,0x80,0x01,0x80,0x01,0x80,
  384.       0x01,0x90,0x01,0x98,0x01,0x9C,0x01,0x9E,0x01,0x9C,0x00,0x18,0x00,0x10,0x00,0x00},
  385.          {// 模式3点16*16
  386.           0x00,0x00,0x00,0x00,0x00,0x00,0x03,0xC0,0x03,0xC0,0x03,0xC0,0x03,0xC0,0x03,0xC0,
  387.       0x03,0xC0,0x03,0xC0,0x03,0xC0,0x03,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},
  388.          {// 模式2点16*16
  389.           0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x03,0xC0,0x03,0xC0,0x03,0xC0,0x03,0xC0,
  390.       0x03,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},          
  391.          {// 篮球器运行标记16*16
  392.           0x00,0x00,0x00,0x00,0x00,0x00,0x1F,0xF8,0x1F,0xF8,0x01,0x80,0x01,0x80,0x01,0x90,
  393.       0x01,0x98,0x01,0x9C,0x01,0x9E,0x01,0x9C,0x01,0x98,0x01,0x90,0x00,0x00,0x00,0x00}};


  394. /*========================== 菜单按钮图片(宽度x高度=16*8)============================*/

  395. uchar code menu_key[]=
  396.          {//菜单按钮
  397.           0x7F,0xFE,0x81,0x81,0x83,0xC1,0x87,0xE1,0x8F,0xF1,0x9F,0xF9,0x80,0x01,0x7F,0xFE};





  398. /*=====================================================================================
  399. 函数名称:定时器中断处理与初始化,延时
  400. 功能描述:时钟更新、篮球器计时
  401. 全局变量:time_tick、time_tick1、resu[2]、resu[3]、resu[4]、temp_delay、temp_min
  402. 参数说明:无
  403. 返回说明:t0_isr(中断标记)、b20time(温度更新标记)
  404. 设 计 人:LIJH
  405. 版    本:1.0
  406. 说    明:
  407. ======================================================================================*/


  408. /*延时(一次10个机器周期不等) 参数格式:延时数*/
  409. void delay(unsigned int det)
  410. {
  411.   while(det--);
  412. }



  413. /*1s延时*/
  414. void delay_pw()
  415. {
  416.   delay(60000);
  417.   delay(60000);
  418. }


  419. /*6个周期  6us */
  420. void  delay_b20(uchar n)
  421. {  
  422.   while(n--);
  423. }



  424. /*主时钟中断处理*/
  425. void time0_isr(void) interrupt  TF0_VECTOR  using 1
  426. {
  427.   TR0=0;
  428.   TL0=(time_count&0x00FF);
  429.   TH0=(time_count>>8);
  430.   TR0=1;
  431.   if(--time_tick)  return;
  432.   time_tick=20;
  433.   t0_isr=1;
  434.   if(nba_tim&!oth_run)           // 当在篮球器界面时 nba_tim==1、oth_run==0
  435.   {
  436.     if(resu[3]==0)
  437.         {
  438.           resu[3]=59;
  439.           if(resu[2]>0)        resu[2]--;
  440.         }
  441.         else resu[3]--;
  442.         if(resu[2]==0&resu[3]==0)  // 比赛时间到后停止
  443.         {
  444.           TR0=0;TR1=0;EA=0;
  445.         }
  446.         return;
  447.   }
  448.   if((++temp_min)==60)          // 实现温度的更新
  449.   {
  450.     temp_min=0;
  451.     temp_delay--;
  452.         if(temp_delay==0)
  453.     {
  454.           b20time=1;temp_delay=5;
  455.         }
  456.   }       
  457. }


  458. /*24时钟中断处理*/
  459. void time1_isr(void) interrupt  TF1_VECTOR  using 2
  460. {
  461.   TR1=0;
  462.   TL1=(time_count&0x00FF);
  463.   TH1=(time_count>>8);
  464.   TR1=1;
  465.   if(--time_tick1) return;
  466.   time_tick1=20;
  467.   if(resu[4]>0)resu[4]--;          //  篮球器24秒中断
  468.   t0_isr=1;
  469.   if(resu[4]==0)
  470.   { TR0=0;TR1=0;EA=0;}
  471. }


  472. /*定时器初始化*/
  473. void time_init()                       
  474. {
  475.   EA=0;
  476.   TR0=0;
  477.   TR1=0;
  478.   TMOD=0x11;
  479.   TL0=(time_count&0x00FF);
  480.   TH0=(time_count>>8);
  481.   TL1=(time_count&0x00FF);
  482.   TH1=(time_count>>8);
  483.   IE=0;
  484.   ET0=1;
  485.   ET1=1;
  486. }



  487. /*=====================================================================================
  488. 函数名称:LCD驱动
  489. 功能描述:基本驱动(写1个字节、清屏、初始化)
  490. 全局变量:无
  491. 参数说明:dat_comm(0:命令 1:数据),content(数值)
  492. 返回说明:无返回值
  493. 设 计 人:LIJH
  494. 版    本:1.0
  495. 说    明:
  496. ======================================================================================*/


  497. /*检查忙碌位*/
  498. void chk_busy (void)
  499. {
  500.   lcd_data = 0xff;
  501.   lcd_rs = 0;    // 命令
  502.   lcd_rw = 1;         // 读
  503.   lcd_e = 1;
  504.   while(busy==1);
  505.   lcd_e = 0;
  506. }


  507. /*写LCD 参数格式:0:命令,1:数值 ,数据*/
  508. void wr_lcd (uchar dat_comm,uchar content)
  509. {
  510.   chk_busy ();
  511.   lcd_rs=dat_comm;
  512.   lcd_rw = 0;         // 写
  513.   lcd_data=content;   // 输出数据或命令
  514.   lcd_e=1;            
  515.   lcd_e=0;
  516. }


  517. /*清绘图*/
  518. void clrgdram(void)
  519. {
  520.   uchar i,j;
  521.   for(j=0;j<32;j++)
  522.   {
  523.     wr_lcd(comm,0x34);
  524.     wr_lcd(comm,0x80+j);
  525.     wr_lcd(comm,0x80);
  526.     wr_lcd(comm,0x30);
  527.     for(i=0;i<32;i++)
  528.       wr_lcd(dat,0x00);  // 写入0x00
  529.    }
  530.   wr_lcd(comm,0x36);
  531. }


  532. /*清除显示*/
  533. void clear_dis(void)
  534. {
  535.   wr_lcd(comm,0x30);
  536.   wr_lcd(comm,0x01);  // 清屏,地址指针指向00H
  537.   clrgdram();                  // 请绘图RAM
  538. }



  539. /*开机LCD初始化*/
  540. void init_lcd (void)
  541. {
  542.   lcd_rst=1;
  543.   wr_lcd(comm,0x30);  // 30---基本指令动作  
  544.   wr_lcd(comm,0x06);  // 光标的移动方向
  545.   wr_lcd(comm,0x0c);  // 开显示,关游标
  546.   clear_dis();
  547. }





  548. /*=====================================================================================
  549. 函数名称:DS1302驱动
  550. 功能描述:基本驱动(读写数据、读写日期,时间、初始化)
  551. 全局变量:无
  552. 参数说明:w_adder(写地址),r_adder(读地址),w_data(写入数据)
  553. 返回说明:返回读取的数据
  554. 设 计 人:LIJH
  555. 版    本:1.0
  556. 说    明:上升沿写入数值,下降沿读出数值,没用设立后背电池充电
  557. ======================================================================================*/


  558. /*向1302写数据 参数格式:地址,数据*/
  559. void w1302(uchar w_adder,uchar w_data)
  560. {
  561.   uchar d;
  562.   ret_ds1302();
  563.   for(d=0;d<16;d++)
  564.   {
  565.     if(d==8) w_adder=w_data;
  566.         d02_data=(bit)(w_adder&0x01);
  567.     d02_sclk=0;                 // 上升沿
  568.     w_adder>>=1;
  569.     d02_sclk=1;
  570.   }
  571.   end_ds1302();   
  572. }



  573. /*接收1302一个字节的数据 参数格式:读地址*/
  574. uchar r1302(uchar r_adder)
  575. {
  576.   uchar d=0;
  577.   ret_ds1302();
  578.   for(d=0;d<8;d++)         // 写地址
  579.   {
  580.     d02_data=(bit)(r_adder&0x01);
  581.     d02_sclk=0;
  582.     r_adder>>=1;
  583.     d02_sclk=1;
  584.   }
  585.   r_adder=0;
  586.   for(d=0;d<8;d++)         // 读数据
  587.   {
  588.         d02_data=1;
  589.         d02_sclk=1;                 // 下降沿
  590.         r_adder>>=1;
  591.         d02_sclk=0;
  592.         if(d02_data) r_adder|=0x80;
  593.   }
  594.   end_ds1302();
  595.   return(r_adder);
  596. }



  597. /*写入时间与日期*/
  598. void wds1302_time_date(void)
  599. {
  600.   w1302(d02_wrc,0x00);                            // 写允许
  601.   w1302(0x90,0xa5);                  // 单二极管2K电阻充电
  602.   w1302(d02_year,today.year);            // 年
  603.   w1302(d02_weeks,today.week);           // 星期
  604.   w1302(d02_month,today.month);            // 月
  605.   w1302(d02_day,today.day);                    // 日
  606.   w1302(d02_hour,0x7f&now.hour);            // 时
  607.   w1302(d02_minute,now.minute);            // 分
  608.   w1302(d02_second,0x7f&now.second); // 秒
  609.   w1302(d02_wrc,0x80);                                  // 写禁止
  610. }




  611. /*初始化写DS1302 RAM*/
  612. void init_wds1302_ram(void)
  613. {
  614.   w1302(d02_wrc,0x00);
  615.   w1302(0x90,0xa5);         // 单二极管2K电阻充电
  616.   w1302(d02_signs,0x00);           // 状态寄存
  617.   w1302(d02_passw,0x74);           // 密码储存首位
  618.   w1302(d02_passw+2,0x14);  // 初始值为:741456
  619.   w1302(d02_passw+4,0x56);  // 密码最后一位
  620.   w1302(d02_alm,0x12);           // 闹铃时(12小时)
  621.   w1302(d02_alm+2,0x00);           // 闹铃分(0分)
  622.   w1302(d02_temp,0xff);           // 温度上限(255为关闭)          
  623.   w1302(d02_temp+2,0xff);   // 温度下限(关闭)
  624.   w1302(d02_initsi,0xb4);   // 是否要初始化标记(0xb4为已经初始化)
  625.   w1302(d02_wrc,0x80);
  626. }

  627. /*写DS1302一字节的RAM*/
  628. void wds1302_data(uchar adder,uchar _data)
  629. {
  630.   w1302(d02_wrc,0x00);
  631.   w1302(adder,_data);
  632.   w1302(d02_wrc,0x80);
  633. }


  634. /*读取日期*/
  635. void rds1302_date(void)
  636. {
  637.   
  638.   today.year=r1302(d02_year+1);          
  639.   today.week=r1302(d02_weeks+1);
  640.   today.month=r1302(d02_month+1);
  641.   today.day=r1302(d02_day+1);  
  642. }


  643. /*读取时间*/
  644. void rds1302_time(void)
  645. {
  646.   now.hour=(r1302(d02_hour+1));
  647.   now.minute=r1302(d02_minute+1);
  648.   now.second=r1302(d02_second+1);
  649.   if(now.hour==alarm_time[0]&&now.minute==alarm_time[1]) alm_run=1;
  650.   else                                                                                 // 闹铃时间比较
  651.   {
  652.     alm_run=0;buzstop=0;buzzer=close;
  653.   }
  654. }                                       

  655. /*开机读数据*/
  656. void rds1302_data(void)
  657. {
  658.   signs=r1302(d02_signs+1);
  659.   alarm_time[0]=r1302(d02_alm+1);
  660.   alarm_time[1]=r1302(d02_alm+3);
  661.   als_temp[0]=r1302(d02_temp+1);
  662.   als_temp[1]=r1302(d02_temp+3);                  
  663. }


  664. /*DS1302初始化*/
  665. void init_ds1302(void)
  666. {
  667.   wds1302_time_date();
  668.   init_wds1302_ram();
  669. }


  670. /*=====================================================================================
  671. 函数名称:DS18b20驱动
  672. 功能描述:基本驱动(读写数据、数据转换、初始化)
  673. 全局变量:无
  674. 参数说明:无
  675. 返回说明:返回读取的数据
  676. 设 计 人:LIJH
  677. 版    本:1.0
  678. 说    明:调试中。。。
  679. ======================================================================================*/



  680. /*18B20初始化*/
  681. void init_ds18b20()
  682. {
  683.   b20_io=1;
  684.   b20_io=0;
  685.   delay_b20(120);                // 延时≥480us
  686.   b20_io=1;
  687.   delay_b20(12);            // 拉高为高电平后在15—60us出现低电平,并维持60—240us
  688.   ds18b20=~b20_io;
  689.   delay_b20(40);       
  690. }


  691. /*向18B20发送一个字节*/
  692. void send18b20_byte(uchar data_send)
  693. {
  694.   uchar d=0;
  695.   for (d=0;d<8;d++)
  696.   {
  697.         b20_io=0;                                        // 拉低电平后向总线写入一个位,15us后18B20接收  
  698.     b20_io=data_send&0x01;            
  699.     delay_b20(10);                                // 延时60us后完成一次
  700.     b20_io=1;
  701.     data_send>>=1;                            // 下位开始
  702.   }
  703. }


  704. /*从18B20读出温度值 12位分辨率*/  
  705. void receive18b20(void)
  706. {
  707.   uchar n=1,d;
  708.   for (d=0;d<16;d++)
  709.   {
  710.         if(d==8) n=0;
  711.         b20_io=0;                                          // 拉低总线
  712.         temp.t_data[n]>>=1;            
  713.         b20_io=1;                     // 拉高总线
  714.         if(b20_io)                                          // 读入总线数值
  715.       temp.t_data[n]|=0x80;
  716.     delay_b20(10);                                  // 等待60us
  717.   }
  718. }


  719. /*数据转化*/
  720. void conversion_t(void)
  721. {
  722.   uchar save=0,save1=0;
  723.   if(temp.temp_data<0)                  // 判断数值符号
  724.     {temp_pn=1;temp.temp_data=~temp.temp_data+1;}
  725.   else temp_pn=0;
  726.   if(temp.t_data[1]&0x01==1) save+=6;            // 小数点后的值转变
  727.   if((temp.t_data[1]>>1)&0x01==1) save+=12;
  728.   if((temp.t_data[1]>>2)&0x01==1) save+=25;
  729.   if((temp.t_data[1]>>3)&0x01==1) save+=50;
  730.   temp.temp_data>>=4;
  731.   save1=temp.temp_data&0x00ff;                                // 整数部分数值
  732.   temp.t_data[0]=save1;
  733.   temp.t_data[1]=save;
  734.   thl_als=1;
  735.   if(save1>=(als_temp[0]&0x7f))      // 温度比较
  736.   {
  737.         if(!temp_pn||(temp_pn&(als_temp[0]&0x80)!=0)){ als_th=open;als_tl=close;}
  738.   }
  739.   else if(save1<(als_temp[1]&0x7f)&&als_temp[1]!=255)
  740.   {
  741.     if(!temp_pn||(temp_pn&(als_temp[1]&0x80)!=0)) {als_tl=open;als_th=close;}
  742.   }
  743.   else {als_th=als_tl=close;thl_als=0;buzstop=0;buzzer=close;}
  744. }



  745. /*18b20功能*/
  746. void ds18b20_func(void)
  747. {
  748.   EA=0;
  749.   TR0=0;
  750.   temp.temp_data=0;
  751.   init_ds18b20();
  752.   send18b20_byte(0xcc); // 跳过ROM
  753.   send18b20_byte(0x44); // 温度转换
  754.   delay_pw();
  755.   init_ds18b20();
  756.   send18b20_byte(0xcc);
  757.   send18b20_byte(0xbe); // 读RAM
  758.   receive18b20();                // 读取温度值
  759.   conversion_t();                // 数值转换
  760.   EA=1;
  761.   TR0=1;
  762. }



  763. /*=====================================================================================
  764. 函数名称:画面构造
  765. 功能描述:界面1、2、3,图片菜单,反白,标头,16*16(32)图片
  766. 全局变量:无
  767. 参数说明:函数说明
  768. 返回说明:无
  769. 设 计 人:LIJH
  770. 版    本:1.0
  771. 说    明:X坐标每一格每次16点
  772. ======================================================================================*/


  773. /*反白或显示图片 参数格式:(H)8bit数据,(L)8bit数据,X0坐标(16bit),Y0坐标(1bit),X坐标(16bit),Y坐标(1bit)*/
  774. void con_disp (uchar data1,uchar data2,uchar x0,uchar y0,uchar xl,uchar yl)
  775. {
  776.   uchar i,j;
  777.   for(j=0;j<yl;j++)
  778.   {
  779.     for(i=0;i<xl;i++)
  780.     {
  781.       wr_lcd(comm,0x34);     // 扩展功能
  782.       wr_lcd(comm,y0+j);         // 写Y坐标
  783.       wr_lcd(comm,x0+i);         // 写X坐标
  784.       wr_lcd(comm,0x30);         // 普通功能
  785.       wr_lcd(dat,data1);
  786.       wr_lcd(dat,data2);
  787.     }
  788.   }
  789.   wr_lcd(comm,0x36);                 // 开绘图显示
  790. }



  791. /*显示字体 参数格式: 显示位置(0x80-0x9f),显示个数,显示内容指针*/
  792. void display_cnasc(uchar dis_bit,uchar num,uchar *cnasc)
  793. {
  794.   wr_lcd(comm,0x30);             // 普通功能
  795.   wr_lcd(comm,dis_bit);             // 写地址
  796.   while(num>0)
  797.   {
  798.     wr_lcd(dat,*(cnasc++));
  799.     wr_lcd(dat,*(cnasc++));
  800.         num--;
  801.   }
  802. }



  803. /*导航标头显示*/
  804. void dis_title(void)
  805. {
  806.   display_cnasc(0x80,1,"\x15 ");
  807.   display_cnasc(0x90,1,"┏");
  808.   display_cnasc(0x97,1,"┓");
  809.   display_cnasc(0x98,1,"┗");
  810.   display_cnasc(0x9f,1,"┛");
  811.   display_cnasc(0x92,1,"\x1e ");
  812.   display_cnasc(0x9a,1,"\x1f ");
  813.   con_disp(0xff,0xff,0x80,0x80,3,16);
  814.   con_disp(0xef,0xef,0x83,0x80,1,16);
  815.   con_disp(0xde,0xf7,0x84,0x80,1,16);
  816.   con_disp(0x76,0xdb,0x85,0x80,1,16);
  817.   con_disp(0x55,0x55,0x86,0x80,1,16);
  818.   con_disp(0x55,0x55,0x87,0x80,1,16);       
  819. }


  820. /*图片显示标头*/
  821. void dis_title_pic(void)
  822. {
  823.   display_cnasc(0x80,2,"〓〓");
  824.   display_cnasc(0x86,2,"〓〓");
  825. }


  826. /*功能实现显示标头*/
  827. void dis_title_e(void)
  828. {
  829.   display_cnasc(0x80,1," \x15");
  830.   con_disp(0xff,0xff,0x80,0x80,1,16);
  831.   con_disp(0xff,0xc7,0x81,0x80,1,16);
  832.   con_disp(0xff,0xff,0x82,0x80,3,16);
  833.   con_disp(0xe3,0xff,0x85,0x80,1,16);
  834.   con_disp(0xff,0xff,0x86,0x80,2,16);
  835. }



  836. /*显示菜单图片  格式:图片反显(1)或正常显示(0),显示图片的号码*/
  837. void anti_nor_pic (uchar cpl_sign,uchar menu_num)
  838. {
  839.   uchar i,j,x,y;
  840.   x=menu_num*3;           // 计算图片显示坐标
  841.   if(x>6) x--;
  842.   if(menu_num<3) y=16;        // 上下半屏显示
  843.   else y=8;
  844.   if(cpl_sign==1) display_cnasc(0x82,4,menu_cn[menu_num]);
  845.   for(j=0;j<24;j++)
  846.   {
  847.    for(i=0;i<2;i++)
  848.    {
  849.      wr_lcd(comm,0x34);
  850.      wr_lcd(comm,0x80+y);
  851.      wr_lcd(comm,0x80+x+i);  // 分两次显示 16bit
  852.      wr_lcd(comm,0x30);
  853.      if(cpl_sign==1)              // 图片反选
  854.      {
  855.            wr_lcd(dat,~menu_pic[menu_num][j*4+i*2]);
  856.        wr_lcd(dat,~menu_pic[menu_num][j*4+i*2+1]);
  857.          }
  858.      else                                          // 正常显示
  859.      {
  860.            wr_lcd(dat,menu_pic[menu_num][j*4+i*2]);
  861.        wr_lcd(dat,menu_pic[menu_num][j*4+i*2+1]);
  862.          }
  863.    }
  864.    y++;
  865.    if(y==32&&menu_num<3) {x+=8;y=0;}  // 上下屏切换
  866.   }
  867.   wr_lcd(comm,0x36);
  868. }




  869. /*状态16*16图片  格式:反色(1)或正常0,X坐标,Y坐标,状态编码(16*16)*/
  870. void dis_run_state(uchar cpl,uchar x0,uchar y0,uchar state_num)
  871. {
  872.   uchar j;
  873.   for(j=0;j<16;j++)
  874.   {
  875.     wr_lcd(comm,0x34);  // 扩展功能
  876.     wr_lcd(comm,y0++);        // 写Y地址
  877.     wr_lcd(comm,x0);        // 写X地址
  878.     wr_lcd(comm,0x30);        // 普通功能
  879.         if(cpl==1)                        // 写数据
  880.     {
  881.           wr_lcd(dat,~running[state_num][j*2]);
  882.       wr_lcd(dat,~running[state_num][j*2+1]);
  883.         }
  884.         else
  885.         {
  886.           wr_lcd(dat,running[state_num][j*2]);
  887.       wr_lcd(dat,running[state_num][j*2+1]);
  888.         }
  889.   }
  890.   wr_lcd(comm,0x36);
  891. }



  892. /*显示菜单按钮  参数格式:反色(1)或正常(0)*/
  893. void dis_menu_key(uchar d)
  894. {
  895.   if(d==1)
  896.   {
  897.     for(d=0;d<8;d++)                                                                  // 显示菜单按钮
  898.       con_disp(~menu_key[d*2],~menu_key[d*2+1],0x9f,0x97+d,1,1);
  899.   }
  900.   else
  901.   {
  902.     for(d=0;d<8;d++)                                                                  // 显示菜单按钮
  903.       con_disp(menu_key[d*2],menu_key[d*2+1],0x9f,0x97+d,1,1);
  904.   }
  905. }




  906. /*显示模式3的界面*/
  907. void dis_mode3(void)
  908. {
  909.   uchar i,j,h,l,x_0=0x80,y_0=0x90;
  910.   h=now.hour>>4;       // 分离十位 个位
  911.   l=now.hour&0x0f;
  912.   for(j=0;j<2;j++)
  913.   {
  914.     for(i=0;i<32;i++)  // 十位个位一起读入
  915.     {
  916.       wr_lcd(comm,0x34);
  917.       wr_lcd(comm,y_0++);
  918.       wr_lcd(comm,x_0);
  919.       wr_lcd(comm,0x30);
  920.       wr_lcd(dat,mode_3num[h][i*3]);  // 连续写数据,X坐标自动加1
  921.       wr_lcd(dat,mode_3num[h][i*3+1]);
  922.       wr_lcd(dat,mode_3num[h][i*3+2]);
  923.       wr_lcd(dat,mode_3num[l][i*3]);
  924.       wr_lcd(dat,mode_3num[l][i*3+1]);
  925.       wr_lcd(dat,mode_3num[l][i*3+2]);
  926.       if(y_0==0xa0){x_0=x_0+8;y_0=0x80;}
  927.     }
  928.     x_0=0x84,y_0=0x90;
  929.     h=now.minute>>4;   // 分离十位 个位
  930.     l=now.minute&0x0f;
  931.   }
  932.   dis_run_state(0,0x83,0x90,4); // 显示点
  933.   dis_run_state(0,0x8b,0x80,4);                                          
  934.   y_0=0x80;                           // 显示状态标记
  935.   if(keb) {dis_run_state(0,0x87,y_0,2);y_0+=16;}
  936.   if(alm) {dis_run_state(0,0x87,y_0,1);y_0+=16;}
  937.   if(y_0<0xa0&&!als){dis_run_state(0,0x87,y_0,0);}
  938.   if(y_0==0xa0&&!als){dis_run_state(0,0x8f,0x80,0);}
  939.   dis_menu_key(0);
  940. }




  941. /*显示模式1和2的共用部分*/
  942. void mode1_2_union(void)
  943. {
  944.   uchar x=0x9b;
  945.   display_cnasc(0x98,2,"星期");
  946.   if(nba_tim) dis_run_state(0,x,0x90,6);
  947.   if(keb) {dis_run_state(0,x,0x90,2);x++;}    // 显示标记
  948.   if(alm) {dis_run_state(0,x,0x90,1);x++;}
  949.   if(!als){dis_run_state(0,x,0x90,0);}
  950.   dis_menu_key(0);                           // 显示菜单按钮
  951. }


  952. /*显示模式2的日期*/
  953. void dis_date_mode2(uchar d)
  954. {
  955.   uchar save[2];
  956.   display_cnasc(d+2,1,"年");
  957.   display_cnasc(d+4,1,"月");
  958.   display_cnasc(d+6,1,"日");
  959.   display_cnasc(0x9a,1,weeks[today.week]);  // 显示星期
  960.   save[0]=char_num[today.year>>4];                // 将显示的数值存到数组中
  961.   save[1]=char_num[today.year&0x0f];
  962.   display_cnasc(d+1,1,save);
  963.   save[0]=char_num[today.month>>4];
  964.   save[1]=char_num[today.month&0x0f];
  965.   display_cnasc(d+3,1,save);
  966.   save[0]=char_num[today.day>>4];
  967.   save[1]=char_num[today.day&0x0f];
  968.   display_cnasc(d+5,1,save);
  969. }

  970. /*显示模式2的时间数字显示  16*32*/
  971. void num2_asc_dis(uchar num,uchar x_0)
  972. {
  973.   uchar i,y_0=0x90;
  974.   for(i=0;i<32;i++)  // 十位个位一起读入
  975.   {
  976.     wr_lcd(comm,0x36);
  977.     wr_lcd(comm,y_0++);
  978.     wr_lcd(comm,x_0);
  979.     wr_lcd(comm,0x30);
  980.     wr_lcd(dat,mode_2num[num][i*2]);
  981.     wr_lcd(dat,mode_2num[num][i*2+1]);
  982.         if(i==15){x_0+=8;y_0=0x80;}
  983.   }
  984.   wr_lcd(comm,0x36);
  985. }

  986. /*显示模式2的时间*/
  987. void dis_time_mode2(void)
  988. {
  989.   uchar h,l;
  990.   if(now.hour!=save_time.hour||init_d2)
  991.   {
  992.     h=now.hour>>4;    // 分离十位 个位
  993.     l=now.hour&0x0f;
  994.     num2_asc_dis(h,0x80);
  995.         num2_asc_dis(l,0x80+1);
  996.   }
  997.   if(now.minute!=save_time.minute||init_d2)
  998.   {
  999.     h=now.minute>>4;    // 分离十位 个位
  1000.     l=now.minute&0x0f;
  1001.     num2_asc_dis(h,0x83);
  1002.         num2_asc_dis(l,0x83+1);
  1003.   }
  1004.   if(now.second!=save_time.second||init_d2)
  1005.   {
  1006.     h=now.second>>4;    // 分离十位 个位
  1007.     l=now.second&0x0f;
  1008.     num2_asc_dis(h,0x86);
  1009.         num2_asc_dis(l,0x86+1);
  1010.   }
  1011.   if(init_d2)
  1012.   {
  1013.     dis_run_state(0,0x82,0x90,5); // 显示点
  1014.     dis_run_state(0,0x8a,0x80,5);
  1015.     dis_run_state(0,0x85,0x90,5); // 显示点
  1016.     dis_run_state(0,0x8d,0x80,5);
  1017.   }       
  1018. }


  1019. /*显示模式2的界面*/
  1020. void dis_mode2(void)
  1021. {
  1022.   dis_date_mode2(0x81);              // 显示日期
  1023.   display_cnasc(0x81,1,"20");
  1024.   dis_time_mode2();                          // 显示时间
  1025.   mode1_2_union();
  1026. }


  1027. /*显示模式1的日期*/
  1028. void dis_date_mode1(void)
  1029. {
  1030.   uchar save[2];
  1031.   display_cnasc(0x80,3,"日期:");
  1032.   display_cnasc(0x90,3,"时间:");
  1033.   display_cnasc(0x88,3,"温度:");
  1034.   display_cnasc(0x9a,1,weeks[today.week]);  // 显示星期
  1035.   display_cnasc(0x83,1,"20");
  1036.   save[0]=char_num[today.year>>4];                          
  1037.   save[1]=char_num[today.year&0x0f];
  1038.   display_cnasc(0x84,1,save);
  1039.   save[0]='/';
  1040.   save[1]=char_num[today.month>>4];
  1041.   display_cnasc(0x85,1,save);
  1042.   save[0]=char_num[today.month&0x0f];
  1043.   save[1]='/';
  1044.   display_cnasc(0x86,1,save);
  1045.   save[0]=char_num[today.day>>4];
  1046.   save[1]=char_num[today.day&0x0f];
  1047.   display_cnasc(0x87,1,save);
  1048.   mode1_2_union();
  1049. }


  1050. /*显示模式1的时间*/
  1051. void dis_time_mode1(void)
  1052. {
  1053.   uchar save[2];
  1054.   save[0]=char_num[now.hour>>4];
  1055.   save[1]=char_num[now.hour&0x0f];
  1056.   display_cnasc(0x93,1,save);
  1057.   save[0]=':';
  1058.   save[1]=char_num[now.minute>>4];
  1059.   display_cnasc(0x94,1,save);
  1060.   save[0]=char_num[now.minute&0x0f];
  1061.   save[1]=':';
  1062.   display_cnasc(0x95,1,save);
  1063.   save[0]=char_num[now.second>>4];
  1064.   save[1]=char_num[now.second&0x0f];
  1065.   display_cnasc(0x96,1,save);
  1066. }


  1067. /*显示模式1的温度*/
  1068. void dis_temp_mode1(void)
  1069. {
  1070.   uchar save[2];
  1071.   if(ds18b20)
  1072.   {
  1073.          if(temp.t_data[0]>99)
  1074.          {
  1075.             save[0]=char_num[temp.t_data[0]/100];
  1076.                 save[1]=char_num[(temp.t_data[0]/10)%10];
  1077.                 display_cnasc(0x8b,1,save);
  1078.                 save[0]=char_num[temp.t_data[0]%10];
  1079.                 save[1]='.';
  1080.                 display_cnasc(0x8c,1,save);
  1081.                 save[0]=char_num[temp.t_data[1]/10];
  1082.                 save[1]=' ';
  1083.                 display_cnasc(0x8d,1,save);
  1084.                 display_cnasc(0x8e,1,"℃");
  1085.           }
  1086.           else
  1087.           {
  1088.         if(temp_pn) display_cnasc(0x8a,1,":-");
  1089.             else  display_cnasc(0x8a,1,":");
  1090.                 save[0]=char_num[temp.t_data[0]/10];
  1091.                 save[1]=char_num[temp.t_data[0]%10];
  1092.                 display_cnasc(0x8b,1,save);
  1093.                 save[0]='.';
  1094.                 save[1]=char_num[temp.t_data[1]/10];
  1095.                 display_cnasc(0x8c,1,save);
  1096.                 display_cnasc(0x8d,1,"℃");
  1097.           }
  1098.         }
  1099.   else display_cnasc(0x8b,3,"FF.F℃");
  1100. }



  1101. /*显示模式1的界面*/
  1102. void dis_mode1(void)
  1103. {
  1104.   dis_date_mode1();
  1105.   dis_time_mode1();
  1106.   dis_temp_mode1();
  1107. }



  1108. /*篮球器时间显示*/
  1109. void nba_dis_time(void)
  1110. {
  1111.   uchar d,dis[2];
  1112.   for(d=2;d<4;d++)
  1113.   {
  1114.         dis[0]=char_num[resu[d]/10];
  1115.         dis[1]=char_num[resu[d]%10];
  1116.         display_cnasc(0x81+d*2,1,dis);
  1117.   }
  1118.   display_cnasc(0x86,1,": ");
  1119.   if(resu[0]==1)
  1120.   {
  1121.         dis[0]='\x07';
  1122.         dis[1]=char_num[resu[4]/10];
  1123.         display_cnasc(0x93,1,dis);
  1124.         dis[1]='\x07';
  1125.         dis[0]=char_num[resu[4]%10];
  1126.         display_cnasc(0x94,1,dis);
  1127.   }
  1128. }


  1129. /*=====================================================================================
  1130. 函数名称:键盘扫描
  1131. 功能描述:读取键盘操作数据及部分状态的实现
  1132. 全局变量:dis_sig  t0_isr  temprun  b20time  alm_run als_temp         buzstop  als
  1133.            lock_op  nba_tim
  1134. 参数说明:无
  1135. 返回说明:键盘锁与密码锁时间到达后返回 255
  1136. 设 计 人:LIJH
  1137. 版    本:1.0
  1138. 说    明:
  1139. ======================================================================================*/

  1140. /*扫描键盘*/
  1141. uchar  keypad_scan()
  1142. {
  1143.   uchar key,dis[2];
  1144.   keyboard=0xf0;
  1145.           }
  1146.     }
  1147.   }                       
  1148.   save=keypad_scan();            // 扫描键盘
  1149.   if(save==255)        return 255;        // 要求输入键盘锁密码或延时时间到达
  1150.   for (n=0;n<16;n++)
  1151.   {  
  1152.         if(save==key_code[n])
  1153.            return(n);
  1154.   }
  1155.   return(20);
  1156. }



  1157. /*=====================================================================================
  1158. 函数名称:导航
  1159. 功能描述:主菜单 工具导航  保存提示
  1160. 全局变量:无
  1161. 参数说明:
  1162. 返回说明:无
  1163. 设 计 人:LIJH
  1164. 版    本:1.0
  1165. 说    明:
  1166. ======================================================================================*/


  1167. /*按键按下显示 参数格式:k 按钮的显示地址*/
  1168. void key_dis(uchar k)
  1169. {
  1170.   display_cnasc(k,1,"\x04 ");
  1171.   delay(10000);
  1172.   if(k==0x92||k==0x96) display_cnasc(k,1,"\x1e ");
  1173.   else display_cnasc(k,1,"\x1f ");
  1174. }



  1175. /*确定按键按下显示*/
  1176. void enter_dis(void)
  1177. {
  1178.   display_cnasc(0x8f,1," \x09");
  1179.   delay(15000);
  1180. }



  1181. /*主菜单导航*/
  1182. uchar dis_menu(void)
  1183. {
  1184.   uchar d,save,key;
  1185.   if(meu)
  1186.   {  
  1187.     display_cnasc(0x81,2,"菜单");
  1188.         dis_title();
  1189.         display_cnasc(0x88,8,selected[0]);
  1190.         con_disp(0xff,0xff,0x8a,0x80,5,16);
  1191.   }
  1192.   else          // 显示图片菜单
  1193.   {
  1194.     dis_title_pic();
  1195.         for(d=0;d<6;d++)  
  1196.       anti_nor_pic(0,d);
  1197.         anti_nor_pic(1,0);
  1198.   }      
  1199.   save=d=0;
  1200.   do
  1201.   {
  1202.         if(meu)          // 操作指示更新
  1203.         {          
  1204.           display_cnasc(0x93,3,menu_cn_2[index_m[save].left_num]);
  1205.           display_cnasc(0x8b,3,menu_cn_2[save]);
  1206.           display_cnasc(0x9b,3,menu_cn_2[index_m[save].right_num]);
  1207.     }
  1208.         else
  1209.         {
  1210.           anti_nor_pic(0,d);     
  1211.           anti_nor_pic(1,save);
  1212.         }
  1213.         d=save;                              // 保存上一索引
  1214.         while(1)
  1215.         {
  1216.           key=gotkey();
  1217.           if(key==11||(key==3&&meu))
  1218.           {
  1219.             if(meu) enter_dis();
  1220.                 break;
  1221.           }
  1222.           else if(meu)
  1223.           {
  1224.             if(key==2)
  1225.                 {
  1226.                   save=index_m[d].right_num;
  1227.                   key_dis(0x9a);
  1228.                   break;
  1229.                 }
  1230.             if(key==5)
  1231.                 {
  1232.                   save=index_m[d].left_num;
  1233.                   key_dis(0x92);
  1234.                   break;
  1235.                 }
  1236.                 if((key==1&&meu))
  1237.             {
  1238.               d=5;
  1239.                   break;
  1240.             }
  1241.           }
  1242.           else
  1243.           {
  1244.             if(key==3){save=index_m[d].right_num; break;} // 根据导航键寻找索引
  1245.             if(key==1){save=index_m[d].left_num; break;}
  1246.                 if(key==2||key==5){save=index_m[d].shaft_num; break;}  
  1247.       }
  1248.         }
  1249.         if(key==11||((key==1|key==3)&&meu)) break;
  1250.   }while(1);
  1251.   return d;
  1252. }



  1253. /*工具导航*/
  1254. uchar tool_func(void)
  1255. {
  1256.   uchar save,d,key;
  1257.   display_cnasc(0x81,2,"工具");
  1258.   dis_title();
  1259.   display_cnasc(0x88,8,selected[0]);
  1260.   con_disp(0xff,0xff,0x8a,0x80,5,16);
  1261.   d=0;
  1262.   save=0;
  1263.   do
  1264.   {          
  1265.         display_cnasc(0x93,3,tool_menu[index_t[save].lnum]);
  1266.         display_cnasc(0x8b,3,tool_menu[save]);
  1267.         display_cnasc(0x9b,3,tool_menu[index_t[save].rnum]);
  1268.         d=save;
  1269.         while(1)
  1270.         {
  1271.           key=gotkey();
  1272.           if(key==1){ d=4;break;}                                // 根据按键寻找索引
  1273.           if(key==11||key==3){enter_dis();break;}
  1274.           if(key==2){save=index_t[d].rnum; key_dis(0x9a);break;}
  1275.           if(key==5){save=index_t[d].lnum; key_dis(0x92);break;}
  1276.     }
  1277.         if(key==11||key==3||key==1) break;
  1278.   }while(1);
  1279.   return d;
  1280. }




  1281. /*更改后提示保存*/
  1282. void save_y_or_n(void)
  1283. {
  1284.   uchar key;
  1285.   clear_dis();
  1286.   oth_run=0;          
  1287.   display_cnasc(0x92,5,"是否保存? ");
  1288.   display_cnasc(0x89,6,"Y(OK)\\N(./S)");
  1289.   while(1)
  1290.   {
  1291.         key=gotkey();
  1292.         if(key==11)
  1293.         {
  1294.           display_cnasc(0x9a,5,"保存成功! ");
  1295.           delay(50000);
  1296.           oth_run=1;         // 要求保存时oth_run标记为1
  1297.           return;
  1298.         }
  1299.         if(key==10) return;
  1300.   }
  1301. }


  1302. /*=====================================================================================
  1303. 函数名称:调整功能
  1304. 功能描述:时间日期调整
  1305. 全局变量:today  now
  1306. 参数说明:见函数
  1307. 返回说明:无
  1308. 设 计 人:LIJH
  1309. 版    本:1.0
  1310. 说    明:
  1311. ======================================================================================*/


  1312. /*调整功能显示时间*/
  1313. void asjust_time()
  1314. {
  1315.   uchar save[2];
  1316.   display_cnasc(0x8a,1,"时");
  1317.   display_cnasc(0x8c,1,"分");
  1318.   display_cnasc(0x8e,1,"秒");
  1319.   save[0]=char_num[now.hour>>4];
  1320.   save[1]=char_num[now.hour&0x0f];
  1321.   display_cnasc(0x89,1,save);
  1322.   save[0]=char_num[now.minute>>4];
  1323.   save[1]=char_num[now.minute&0x0f];
  1324.   display_cnasc(0x8b,1,save);
  1325.   save[0]=char_num[now.second>>4];
  1326.   save[1]=char_num[now.second&0x0f];
  1327.   display_cnasc(0x8d,1,save);
  1328. }


  1329. /*调整功能月天数比较*/
  1330. uchar monthday(uchar year,uchar month)
  1331. {
  1332.   if(month==2&&year%4==0)
  1333.     return(29);
  1334.   else
  1335.   {        year=month&0x0f;
  1336.     month>>=4;
  1337.         month=month*10+year;       
  1338.     return(dayofmonth[month-1]);}
  1339. }



  1340. /*星期推算*/
  1341. void weeks_day()
  1342. {
  1343.   uchar d,buffer,day=4;
  1344.   if(today.month>1)
  1345.   {
  1346.     buffer=(today.month>>4);   // 将BCD码转为十进制
  1347.         buffer=buffer*10;
  1348.         buffer+=(today.month&0x0f);
  1349.         for(d=0;d<buffer-1;d++)
  1350.         {
  1351.           today.week=(dayofmonth[d]>>4);
  1352.           today.week=today.week*10;
  1353.           today.week+=(dayofmonth[d]&0x0f);
  1354.       day+=(today.week%7);
  1355.         }
  1356.   }
  1357.   buffer=(today.year>>4);
  1358.   buffer*=10;
  1359.   buffer+=(today.year&0x0f);
  1360.   if(today.year!=0)
  1361.   {
  1362.         day+=((buffer-1)/4)+buffer+1;
  1363.   }
  1364.   if(buffer%4==0&&today.month>2) day++;
  1365.   buffer=today.day>>4;
  1366.   buffer*=10;
  1367.   buffer+=(today.day&0x0f);
  1368.   today.week=(day+buffer)%7;
  1369. }



  1370. /*调整功能*/
  1371. void adjust_func(void)
  1372. {
  1373.   uchar d,save,b=0;
  1374.   dis_title_e();
  1375.   display_cnasc(0x82,3,menu_cn_2[0]);
  1376.   rds1302_date();
  1377.   rds1302_time();
  1378.   dis_date_mode2(0x90);
  1379.   display_cnasc(0x9a,1,"  ");
  1380.   asjust_time();
  1381.   display_cnasc(0x9f,1,"→");
  1382.   display_cnasc(0x90,1,"『");
  1383.   display_cnasc(0x8f,1,"』");
  1384.   d=0;save=0;
  1385.   adju_si=0;
  1386.   do
  1387.   {
  1388.     con_disp(0x00,0x00,index_a[d].lnum,index_a[d].rnum,1,13);
  1389.     con_disp(0xff,0xff,index_a[save].lnum,index_a[save].rnum,1,13);
  1390.         d=save;
  1391.         while(1)
  1392.         {
  1393.           save=gotkey();
  1394.           if(save>=0&&save<10)
  1395.           {
  1396.             switch(d)
  1397.             {
  1398.               case 0: if(adju_si) // adju_si==1时两次输入连成一个数
  1399.                           {
  1400.                                     today.year<<=4;
  1401.                                 today.year+=save;adju_si=0;
  1402.                                   }
  1403.                       else
  1404.                               {
  1405.                                 today.year=save;adju_si=1;
  1406.                               }
  1407.                           break;
  1408.                   case 1: if(adju_si)
  1409.                           {
  1410.                                     today.month<<=4;today.month+=save;
  1411.                             if(today.month>0x12) today.month=save;
  1412.                     else adju_si=0;
  1413.                                   }
  1414.                                   else  
  1415.                                   {
  1416.                                     today.month=save;adju_si=1;
  1417.                                   }
  1418.                                   break;
  1419.                   case 2: if(adju_si)
  1420.                           {
  1421.                                     today.day<<=4;today.day+=save;  // 月天数比较
  1422.                                         if(today.year%4==0&&today.month==2&&today.day==29) ;
  1423.                             else if(today.day>monthday(today.year,today.month))
  1424.                                           today.day=save;
  1425.                                         else adju_si=0;
  1426.                                   }
  1427.                                   else  {today.day=save;adju_si=1;}
  1428.                                   break;
  1429.                   case 3: if(adju_si)
  1430.                           {
  1431.                                     now.hour<<=4;now.hour+=save;
  1432.                                           if(now.hour>0x23) now.hour=save;
  1433.                                         else adju_si=0;
  1434.                                   }
  1435.                                   else  {now.hour=save;adju_si=1;}
  1436.                                   break;
  1437.                   case 4: if(adju_si)
  1438.                           {
  1439.                                     now.minute<<=4;now.minute+=save;
  1440.                                           if(now.minute>0x59) now.minute=save;
  1441.                                         else adju_si=0;
  1442.                                   }
  1443.                                   else  {now.minute=save;adju_si=1;}
  1444.                                   break;
  1445.                   case 5: if(adju_si)
  1446.                           {
  1447.                                     now.second<<=4;now.second+=save;
  1448.                                           if(now.second>0x59) now.second=save;
  1449.                                         else adju_si=0;
  1450.                                   }
  1451.                                   else  {now.second=save;adju_si=1;}
  1452.                                   break;
  1453.                 }
  1454.                 if(today.day>monthday(today.year,today.month)) today.day=1;        // 更改月份时判断天数
  1455.                 if(today.month==0) today.month=1;
  1456.                 if(today.day==0) today.day=1;
  1457.                 if(d<3) dis_date_mode2(0x90);         // 更新显示
  1458.         else asjust_time();
  1459.                 display_cnasc(0x9a,1,"  ");                // 消去星期显示
  1460.       }
  1461.           if(save==11){save=d+1;adju_si=0;break;}
  1462.           if(save==10&&d!=0){save=d-1;adju_si=0;break;}
  1463.         }
  1464.     if(save==7&d==6) break;
  1465.   }while(1);
  1466.   weeks_day();          // 计算星期
  1467.   save_y_or_n();  // 需要保存时oth_run设为1
  1468.   if(oth_run) wds1302_time_date();
  1469. }




  1470. /*=====================================================================================
  1471. 函数名称:计算器功能
  1472. 功能描述:10位带符号数的加减乘除运算
  1473. 全局变量:opera  resu  i  j
  1474. 参数说明:见函数
  1475. 返回说明:无
  1476. 设 计 人:LIJH
  1477. 版    本:1.0
  1478. 说    明:
  1479. ======================================================================================*/



  1480. /*清寄存器  参数格式:m=2时结果寄存器,当m=1时操作数1,当m=0时操作数0(1),
  1481.                         n=1时,只清寄存器不清显示, 0两清*/
  1482. void removal_data(uchar m,uchar n)
  1483. {
  1484.   uchar l;                // 当n=1时,只清寄存器不清显示, 0两清
  1485.   if(m==2)                // 当m=2时结果寄存器
  1486.   {                            // 当m=1时操作数1
  1487.     if(n==0)        // 当m=0时操作数0 ,1
  1488.           for(l=0;l<6;l++)
  1489.             display_cnasc(0x98+l,1,"  ");
  1490.     for(l=0;l<12;l++)
  1491.       resu[l]=0;
  1492.   }
  1493.   while(m<2)
  1494.   {
  1495.     if(n==0)
  1496.         {
  1497.           if(m==0)
  1498.           {  
  1499.             for(l=0;l<6;l++)
  1500.               display_cnasc(0x90+l,1,"  ");
  1501.                   display_cnasc(0x95,1," 0");
  1502.           }       
  1503.           else
  1504.              for(l=0;l<6;l++)
  1505.                 display_cnasc(0x88+l,1,"  ");
  1506.         }
  1507.     for(l=0;l<12;l++)
  1508.       opera[m][l]=0;
  1509.         m++;
  1510.   }
  1511. }




  1512. /*显示数值  参数格式:显示首地址*/
  1513. void dis_cdata(uchar ass)
  1514. {
  1515.   uchar p,d,save[2];
  1516.   if(i==0&&opera[0][0]==1)                 // 显示符号
  1517.   {
  1518.     if(cal_run)  display_cnasc(0x98,1,"=-");
  1519.     else  display_cnasc(0x90,1," -");
  1520.   }
  1521.   d=opera[i][11];                                // 计算位数
  1522.   if(opera[i][10]!=0&&opera[i][10]!=opera[i][11]+1) d++;
  1523.   save[0]=d/2;ass=ass-save[0]+5;        // 计算显示的开始位置
  1524.   p=1;
  1525.   cal_del=0;                                        // 显示点标记 (0为没有显示)
  1526.   if(d%2==1)                                        // 对位数位奇数先处理首位
  1527.   {
  1528.     save[0]=' ';
  1529.     save[1]=char_num[opera[i][1]];
  1530.         display_cnasc(ass,1,save);
  1531.         p++;
  1532.   }
  1533.   ass++;                                                // 显示地址加一
  1534.   while(p<=opera[i][11])
  1535.   {                                                                       
  1536.     if(opera[i][10]==p&&(!cal_del)) {   // 显示点且作标记
  1537.           save[0]='.';cal_del=1;}
  1538.     else {
  1539.           save[0]=char_num[opera[i][p]]; p++;}
  1540.     if(opera[i][10]==p&&(!cal_del)) {
  1541.           save[1]='.';cal_del=1;}
  1542.     else{
  1543.           save[1]=char_num[opera[i][p]];p++;}
  1544.     display_cnasc(ass,1,save);
  1545.     ass++;
  1546.   }
  1547. }   


  1548. /*从键盘中写入数据*/   
  1549. char input_data()
  1550. {
  1551.   uchar save=20,c;
  1552.   for(;i<2;i++)
  1553.   {
  1554.     while(1)
  1555.     {
  1556. pp:   save=gotkey();        // 读键盘
  1557.           if(save==20) continue;
  1558.           if(save==11)                // 按键为确定时,选择计算或删除
  1559.           {
  1560.             c=save=0;
  1561.                 while(1)                // 反色选择
  1562.             {
  1563.                   con_disp (0x00,0x00,index_cal[save].lnum,index_cal[save].rnum,2,16);
  1564.                   con_disp (0xff,0xff,index_cal[c].lnum,index_cal[c].rnum,2,16);       
  1565.                   save=gotkey();
  1566.                   if(save==10)
  1567.                   {
  1568.                     save=c;
  1569.                         if(++c==3) c=0;
  1570.                   }
  1571.                   else if(save==11)
  1572.                   {
  1573.             if(c==0) save=11;
  1574.                     else if(c==1) save=16;
  1575.                         else  return 0;
  1576.                     break;
  1577.                   }
  1578.                   else break;
  1579.         }
  1580.                 con_disp (0x00,0x00,index_cal[c].lnum,index_cal[c].rnum,2,16);            
  1581.           }
  1582.       if(save>=0&&save<=9&&j<10)
  1583.           {
  1584.             if(i==1&&opera[1][0]==15&&j>8) goto pp;
  1585.         if(j==2&&opera[i][1]==0&&opera[i][10]==0)
  1586.           opera[i][1]=save;                // 防止小数位不在时首位为零
  1587.             else{
  1588.                   opera[i][j]=save;opera[i][11]=j;j++;}
  1589.                 if(i==0)                                // 显示
  1590.                   dis_cdata(0x90);
  1591.                 else
  1592.                   dis_cdata(0x88);
  1593.           }
  1594.       else if(save==10&&j<10)       
  1595.       {
  1596.             if(opera[i][10]==0)                // 小数点空时保存
  1597.             {
  1598.                   if(opera[i][11]==0) {opera[i][10]=2;j++;}
  1599.               else  opera[i][10]=j;
  1600.             }
  1601.           }
  1602.           else if(save==16)       
  1603.           {                           // 删除数据
  1604.         removal_data(i,0);j=1;
  1605.                 if(i!=0){i--;j=10;}
  1606.       }
  1607.           else if(i==1&&opera[1][11]!=0&&save>11&&save<16)
  1608.       { save1=save;break; }                   // 连续计算时保存运算符
  1609.       else if(save==11&&opera[1][11]==0) continue;// 操作数1为0时不理会
  1610.           else if(save==11&&opera[1][11]!=0)  break;
  1611.           else if((i==0||i==1&&j==1)&&save>11&&save<16){i=0; break;}   
  1612.        // 当操作数0由运算符结束输入,再按符号键更改
  1613.           else continue;
  1614.     }
  1615.     if(opera[i][10]>opera[i][11]||opera[i][10]==0)
  1616.       opera[i][10]=opera[i][11]+1;        // 整数时小数位保存到最后
  1617.     while(opera[i][11]>=opera[i][10]&&opera[i][opera[i][11]]==0)
  1618.       opera[i][11]--;                                // 去除小数点后多余的0
  1619.     if(i==0)
  1620.     {
  1621.       opera[1][0]=save;                        // 保存运算符并显示
  1622.       display_cnasc(0x88,1,tool_cal[save-12]);
  1623.     }
  1624.     if(opera[0][11]==0) display_cnasc(0x95,1," 0");
  1625.     j=1;
  1626.     while(j<=opera[i][11]&&opera[i][j]==0) j++;//判断是否操作数是否全为0
  1627.     j--;
  1628.     if(j==opera[i][11]) opera[i][11]=0;
  1629.     j=1;
  1630.   }
  1631.   return 1;
  1632. }


  1633. /****************************************************************************************
  1634. 功能:  乘法运算
  1635. 描述:  结果由右到左保存
  1636. 参数:  i , j , opera[i][j],p,q,r,k,save1
  1637. 返回值:1(成功),0(结果位0),-1(溢出)
  1638. /****************************************************************************************/

  1639. char multiplication()
  1640. {
  1641.   uchar p,q,r,k,save1=0; // p指向操作数0 ,q指向操作数1,r指向结果
  1642.   if(opera[0][11]==0||opera[1][11]==0) return 0;
  1643.   resu[10]=opera[0][11]+opera[1][11]-opera[0][10]-opera[1][10]+2; // RESU记录小数点后的位数
  1644.   q=opera[1][11];                                        // 记录操1的位数
  1645.   r=9;
  1646.   opera[1][11]=1;
  1647.   k=1;
  1648.   while(opera[1][k]==0) {opera[1][11]=opera[1][11]+1;k++;}        // 去除前端的0
  1649.   k=1;
  1650.   while(opera[0][k]==0) k++;                        // 去除前端的0
  1651.   resu[11]=9;
  1652.   for(resu[0]=9;q>=opera[1][11];q--,resu[0]--)
  1653.   {
  1654.     if(opera[1][q]==0) continue;                // 操1此位数为0时直接比较
  1655.     for(p=opera[0][11],r=resu[0];p>=k;p--)
  1656.     {
  1657.       save1=opera[0][p]*opera[1][q];                // 将相乘后的数保存
  1658.       resu[r]+=(save1%10);//将缓存中的数取余后加到结果中R指向的位
  1659.       save1/=10;
  1660.       save1=save1+(resu[r]/10);                        // 保存进位的数
  1661.       resu[r]%=10;                                        // 重新写入
  1662.           if(r==1)        //结果有溢出时移位
  1663.           {
  1664.             if(save1==0&&p==k) break;        // 计算到最后位且没进位跳出
  1665.             else if(resu[10]>0)                // 要求有小数存在
  1666.         {
  1667.               for(r=9;r>1;r--) resu[r]=resu[r-1];
  1668.               r=1;
  1669.           resu[r]=save1;
  1670.               resu[11]=1;
  1671.               resu[10]--;
  1672.               resu[0]++;
  1673.         }   
  1674.             else   return -1;                         // 否则溢出
  1675.           }
  1676.           if(r>1&&(r-1)<resu[11])                        // 保存结果位的最高位
  1677.           {
  1678.             if(save1!=0) resu[11]=r-1;
  1679.             else resu[11]=r;
  1680.           }
  1681.           if(r>1){ r--;resu[r]+=save1;}// 当R为1时只需要移位记录结果
  1682.     }
  1683.   }
  1684.   while(resu[resu[11]]==0) resu[11]++;         // 去除前端的0
  1685.   resu[0]=opera[0][0];                                // 保存符号位
  1686.   removal_data(0,1);                                        // 清数据不清显示
  1687.   if(resu[10]>8)   //如果小数点后的数有9 位或以上时,需后移到使小数点放到2的位置  
  1688.   {
  1689.     save1=resu[10]-10+resu[11];                 // 记录后移位数
  1690.     if(save1>7)  return 0;          //当后移的数大于有效数字的位数时结果为0
  1691.     else         // 否则按需移位
  1692.     {
  1693.       for(p=save1+2,r=resu[11];p<10;p++,r++) opera[0][p]=resu[r];
  1694.           opera[0][10]=2;opera[0][11]=9;opera[0][0]=resu[0];
  1695.     }                // 因有效数小于小数点后的数,所以首位为0  
  1696.   }       
  1697.   else          //如果小数点后的数在8位以内时分两种情况
  1698.   {       
  1699.     opera[0][0]=resu[0];  
  1700.     save1=10-resu[11];         // 记录有效位数
  1701.     if(resu[10]>=save1)         // 小数的在有效数字的左边
  1702.     {       
  1703.           for(p=resu[10]+1,r=9;r>=resu[11];p--,r--)
  1704.         opera[0][p]=resu[r];        // 从小数点的最后一位开始
  1705.       opera[0][10]=2;opera[0][11]=resu[10]+1;
  1706.     }
  1707.     else                                  // 小数点在有效数字内
  1708.     {  
  1709.           for(p=1,r=resu[11];r<10;p++,r++) opera[0][p]=resu[r];
  1710.             opera[0][11]=10-resu[11];
  1711.           if(resu[10]==0) opera[0][10]=opera[0][11]+1;
  1712.           else opera[0][10]=opera[0][11]-resu[10]+1;
  1713.     }
  1714.   }
  1715.   while(opera[0][11]>=opera[0][10]&&opera[0][opera[0][11]]==0)
  1716.     opera[0][11]--;          // 去除小数点后多余的0
  1717.   return 1;
  1718. }


  1719. /****************************************************************************************
  1720. 功能:  除法运算
  1721. 描述:  结果由左到右保存
  1722. 参数:  i , j , opera[i][j]
  1723. p,q,r, remainde, divisor, decimal
  1724. 返回值:1(成功),0(结果位0),-1(溢出)
  1725. *****************************************************************************************/

  1726. char divider()
  1727. {
  1728.   unsigned long int divisor=0,remainder=0;
  1729.   uchar p,q,r;
  1730.   char decimal=0;
  1731.   if(opera[1][11]==0) return -1;
  1732.   if(opera[0][11]==0) return 0;
  1733.   for(r=1;r<12;r++)                // 判断两数是否相等
  1734.   {
  1735.     if(opera[0][r]!=opera[1][r]) break;
  1736.   }
  1737.   if(r==12)
  1738.   {
  1739.     p=opera[0][0];
  1740.     removal_data(0,1);
  1741.     opera[0][0]=r;
  1742.     opera[0][1]=1;
  1743.     opera[0][10]=2;
  1744.     opera[0][11]=1;
  1745.     return 1;
  1746.   }  
  1747.   decimal=(opera[0][11]-opera[0][10])-(opera[1][11]-opera[1][10]);
  1748.   // 记录两操作数小数点后位数的差
  1749.   if(decimal>0)                // 若操0大于操1时重新记录小数点的位置
  1750.   {
  1751.     opera[0][10]=opera[0][11]-decimal+1;
  1752.     resu[10]=opera[0][10];
  1753.   }
  1754.   else          // 否则小数点后没有数,记录有效数的位数
  1755.   {       
  1756.     opera[0][11]-=decimal;
  1757.     opera[0][10]=opera[0][11]+1;
  1758.     resu[10]=opera[0][10];
  1759.   }
  1760.   q=1;
  1761.   divisor=0;
  1762.   while(q<=opera[1][11]) // 将操1的数整形化
  1763.   {
  1764.     divisor=divisor*10+opera[1][q];q++;
  1765.   }
  1766.   if(divisor==1)   
  1767.   {
  1768.     if(resu[10]>10)        return -1;
  1769.         else return 1;
  1770.   }
  1771.   r=1;p=1;
  1772.   remainder=(unsigned long int)opera[0][1]; // 先对余数寄存器附初值
  1773.   do
  1774.   {   
  1775.         if(r>9)  // 结果位已经到达最后1位
  1776.         {  
  1777.             if(resu[1]==0&&resu[10]!=2) // 判断是否有得移位
  1778.           {        
  1779.             for(r=1;r<9;r++) resu[r]=resu[r+1];       
  1780.             resu[9]=0;
  1781.             if(resu[10]!=0) resu[10]--;
  1782.             r=9;
  1783.           }
  1784.       else if(p>=opera[0][11]||p>=opera[0][10])  break; // 如果计算到最后一位,或者有小数点存在时结束
  1785.       else return -1; // 否则错误
  1786.         }
  1787.         resu[r]=(uchar)(remainder/divisor);        // 保存结果
  1788.     remainder=(remainder%divisor);                // 重新写入余数
  1789.         p++;r++;         
  1790.     if(p>opera[0][11]&&remainder==0) break; // 除尽后跳出
  1791.     else if(p<=opera[0][11]&&p<10)                // 余数*10后加后一位
  1792.       {remainder=remainder*10+opera[0][p];}
  1793.     else   remainder=remainder*10;         //超出后余数*10
  1794.   }while(1);
  1795.   resu[11]=r-1;
  1796.   resu[0]=opera[0][0];
  1797.   removal_data(0,1);
  1798.   r=1;   
  1799.   while(resu[r]==0&&resu[10]!=(r+1)&&r<resu[11]) r++;
  1800. //去除结果前端的0
  1801.   if(r==resu[11]) return 0;
  1802.   resu[10]=resu[10]-r+1;
  1803.   p=1;
  1804.   while(r<=resu[11]){opera[0][p]=resu[r];r++;p++;}
  1805.   opera[0][0]=resu[0];opera[0][10]=resu[10];opera[0][11]=p-1;
  1806.   while(opera[0][11]>=opera[0][10]&&opera[0][opera[0][11]]==0)
  1807.     opera[0][11]--;
  1808.   return 1;
  1809. }


  1810. /****************************************************************************************
  1811. 功能:  加法运算
  1812. 描述:  以小数点位中心两边相加
  1813. 参数:  i , j , opera[i][j],p,q,r
  1814. 返回值:1(成功),0(结果位0),-1(溢出)
  1815. /****************************************************************************************/

  1816. char adder()
  1817. {
  1818.   uchar p,q,r;
  1819.   if(opera[0][11]==0&&opera[1][11]==0)   return 0;
  1820.   else if(opera[0][11]==0)
  1821.     {for(q=0;q<12;q++) opera[0][q]=opera[1][q];return 1;}
  1822.   else if(opera[1][11]==0) return 1;
  1823.   else
  1824.   {
  1825.     p=opera[0][10]-1;
  1826.     q=opera[1][10]-1;
  1827.     p>q?(r=p):(r=q);
  1828.     resu[10]=r+1;                // 小数点位保存
  1829.     resu[0]=opera[0][0];        // 保存符号位
  1830.     while(r>0)                        // 将小数点前的数相应相加后放到结果中
  1831.     {
  1832.       if(p>0&&q>0){resu[r]=opera[0][p]+opera[1][q];p--;q--;}
  1833.       else if(p>0&&q==0){resu[r]=opera[0][p];p--;}
  1834.       else        {resu[r]=opera[1][q];q--;}
  1835.       r--;
  1836.     }
  1837.     r=resu[10];
  1838.     p=opera[0][10];
  1839.     q=opera[1][10];
  1840.     while(r<10)                        // 将小数点后的数放到结果中
  1841.     {
  1842.       if(p>opera[0][11]&&q>opera[1][11]) break;
  1843.       else if(p<=opera[0][11]&&q<=opera[1][11])
  1844.         {resu[r]=opera[0][p]+opera[1][q];p++;q++;}
  1845.       else if(p<=opera[0][11]&&q>opera[1][11])
  1846.         {resu[r]=opera[0][p];p++;}
  1847.       else        {resu[r]=opera[1][q];q++;}
  1848.       r++;
  1849.     }
  1850.     r--;
  1851.     resu[11]=r;
  1852.     p=0;
  1853.     while(r>0)                        // 由右到左将大于9的数进位
  1854.     {
  1855.       resu[r]+=p;                        // p为进位标记
  1856.       p=0;
  1857.       if(resu[r]>9) {resu[r]-=10;p=1;}
  1858.       r--;
  1859.     }
  1860.     if(p==1)                                // 溢出移位
  1861.     {
  1862.       if(resu[10]==10) return -1;
  1863.       else {
  1864.         for(r=9;r>1;r--) resu[r]=resu[r-1];
  1865.         resu[1]=1;resu[10]++;}
  1866.     }
  1867.    removal_data(0,1);
  1868.    r=0;
  1869.    while(r<12){opera[0][r]=resu[r];r++;}
  1870.    while(opera[0][11]>=opera[0][10]&&opera[0][opera[0][11]]==0)
  1871.      opera[0][11]--;
  1872.    return 1;
  1873.   }
  1874. }

  1875. /****************************************************************************************
  1876. 功能:  减法运算
  1877. 描述:  先比较两操作数的大小用one ,two互换
  1878. 参数:  i , j , opera[i][j],p,q,r,one,two
  1879. 返回值:1(成功),0(结果位0),-1(溢出)
  1880. /****************************************************************************************/

  1881. char subtraction()
  1882. {
  1883.   uchar p,q,r,one,two;
  1884.   if(opera[0][11]==0&&opera[1][11]==0)   return 0;
  1885.   else if(opera[0][11]==0)
  1886.   {
  1887.     for(q=1;q<12;q++)
  1888.     opera[0][q]=opera[1][q];
  1889.         opera[0][0]=!opera[0][0];return 1;
  1890.   }
  1891.   else if(opera[1][11]==0) return 1;
  1892.   else
  1893.   { // 比较大小(大放到one)
  1894.     if(opera[0][10]>opera[1][10]){one=0;two=1;}
  1895.     else if(opera[1][10]>opera[0][10]) {one=1;two=0;}
  1896.     else
  1897.     {
  1898.       r=1;
  1899.           while(r<10&&opera[0][r]==opera[1][r]) r++;
  1900.           if(r==10) {removal_data(0,1);return 0;}
  1901.       opera[0][r]>opera[1][r]?(one=0,two=1):(one=1,two=0);
  1902.     }
  1903.     p=opera[one][10]-1;
  1904.     q=opera[two][10]-1;
  1905.     r=p;                        // 保存小数点前的数
  1906.     resu[10]=r+1;        // 保存小数点位
  1907.     resu[0]=0;                // 用作借位标记
  1908.     while(r>0)                // 小数点前相减
  1909.     {
  1910.       if(p>0&&q>0)
  1911.           {
  1912.             opera[two][q]+=resu[0];
  1913.         resu[0]=0;
  1914.         if(opera[one][p]>=opera[two][q])
  1915.           resu[r]=opera[one][p]-opera[two][q];
  1916.             else
  1917.             {
  1918.                   resu[0]=1;
  1919.                   resu[r]=10+opera[one][p]-opera[two][q];
  1920.             }
  1921.             p--;q--;
  1922.           }
  1923.           else
  1924.           {            
  1925.         if(opera[one][p]<resu[0])
  1926.           {resu[r]=10+opera[one][p]-resu[0];}
  1927.             else
  1928.                   {resu[r]=opera[one][p]-resu[0];resu[0]=0;p--;}
  1929.           }
  1930.       r--;
  1931.     }
  1932.     r=resu[10];
  1933.     p=opera[one][10];
  1934.     q=opera[two][10];
  1935.     while(r<10)                // 将小数点后的数放到结果中
  1936.     {
  1937.       if(p>opera[one][11]&&q>opera[two][11]) break;
  1938.       else if(p<=opera[one][11]&&q<=opera[two][11])
  1939.           {
  1940.         if(opera[one][p]>=opera[two][q])  resu[r]=opera[one][p]-opera[two][q];
  1941.             else
  1942.             {
  1943.               resu[r]=10+opera[one][p]-opera[two][q];
  1944.               resu[0]=r;
  1945.               for(r-=1;r>0;r--) // 向前借位
  1946.                   {
  1947.                 if(resu[r]==0) resu[r]=9;
  1948.                     else{resu[r]-=1;break;}
  1949.                   }
  1950.                   r=resu[0];       
  1951.             }
  1952.             p++;q++;
  1953.           }                                           
  1954.       else if(p<=opera[one][11]&&q>opera[two][11])
  1955.         {resu[r]=opera[one][p];p++;}
  1956.       else       
  1957.           {
  1958.             resu[r]=10-opera[two][q];  
  1959.             resu[0]=r;
  1960.             for(r-=1;r>0;r--)
  1961.         {
  1962.                   if(resu[r]==0) resu[r]=9;
  1963.               else{ resu[r]-=1;break;}
  1964.                 }
  1965.             r=resu[0];
  1966.             q++;       
  1967.           }
  1968.       if(r==9)                 // 结果溢出移位
  1969.           {
  1970.             if(resu[1]==0&&resu[10]!=2)
  1971.         {
  1972.           for(r=1;r<9;r++) resu[r]=resu[r+1];
  1973.                   resu[10]--;resu[9]=0;r=8;
  1974.         }
  1975.           }
  1976.       r++;
  1977.     }
  1978.     r--;
  1979.     resu[11]=r;
  1980.     if(one==0)resu[0]=opera[0][0];        // 符号位写入
  1981.     else resu[0]=!opera[0][0];
  1982.     removal_data(0,1);
  1983.     r=1;
  1984.     while(resu[r]==0&&resu[10]!=(r+1)) r++; // 去除前端0
  1985.     resu[10]=resu[10]-r+1;                        // 重新写入小数点
  1986.     p=1;
  1987.     while(r<=resu[11]){opera[0][p]=resu[r];r++;p++;}
  1988.     opera[0][0]=resu[0];opera[0][10]=resu[10];opera[0][11]=p-1;
  1989.     while(opera[0][11]>=opera[0][10]&&opera[0][opera[0][11]]==0) opera[0][11]--;
  1990.     return 1;
  1991.   }
  1992. }


  1993. /****************************************************************************************
  1994. 功能:  计算器主函数
  1995. 描述:  根据符号位,运算符调用函数
  1996. 参数:  state,save
  1997. 返回值:无
  1998. ****************************************************************************************/


  1999. void calculator(void)
  2000. {
  2001.   char data state;
  2002.   uchar data save;
  2003.   save1=0;
  2004.   dis_title_e();
  2005.   display_cnasc(0x82,3,tool_menu[0]);
  2006.   display_cnasc(0x96,2,"等于");
  2007.   display_cnasc(0x8e,2,"删除");
  2008.   display_cnasc(0x9e,2,"退出");
  2009.   removal_data(2,0);         // 0为清除显示
  2010.   removal_data(0,0);
  2011.   i=0;j=1;
  2012.   while(1)
  2013.   {       
  2014.     cal_run=0;
  2015.     state=input_data();
  2016.     if(state==1)  // 根据opera[1][0]的数值调用程序
  2017.     {
  2018.       if(opera[1][0]==12&&opera[0][0]==0||opera[1][0]==13&&opera[0][0]==1)
  2019.             state=adder();
  2020.       else if(opera[1][0]==12&&opera[0][0]==1||opera[1][0]==13&&opera[0][0]==0)
  2021.             state=subtraction();
  2022.       else if(opera[1][0]==14) state=multiplication();
  2023.       else state=divider();
  2024.     }
  2025.         if(state==0)  return;
  2026.     i=0;j=1;
  2027.     cal_run=1;
  2028.     switch(state)
  2029.     {
  2030.       case -1:                                                 // 结果溢出
  2031.                   removal_data(2,0);
  2032.               removal_data(0,0);  
  2033.                       display_cnasc(0x8a,3,"溢出!!");
  2034.                       save1=0;
  2035.                           break;
  2036.       case  0:                                                // 结果为零
  2037.                           if(save1==0)
  2038.                           {
  2039.                             removal_data(2,1);
  2040.                                 removal_data(0,1);
  2041.                             display_cnasc(0x98,1,"= ");
  2042.                             display_cnasc(0x9d,1," 0");
  2043.                           }
  2044.                           break;                                // 结果显示
  2045.       case  1:
  2046.                           if(save1==0)
  2047.                           {
  2048.                             cal_run=1;
  2049.                             display_cnasc(0x98,1,"= ");
  2050.                 dis_cdata(0x98);
  2051.                           }
  2052.                         }
  2053.         else if(save>=0&&save<10&&state==1)
  2054.         {
  2055.           removal_data(2,0);
  2056.           removal_data(0,0);
  2057.           opera[0][1]=save;
  2058.           opera[0][11]++;
  2059.           dis_cdata(0x90);
  2060.           i=0;j=2;
  2061.         }
  2062.         else if(save==10)
  2063.         {  
  2064.           removal_data(2,0);
  2065.           removal_data(0,0);
  2066.       opera[i][10]=2;
  2067.           opera[i][11]=1;
  2068.       j=2;
  2069.         }
  2070.         else
  2071.         {
  2072.           removal_data(2,0);
  2073.           removal_data(0,0);
  2074.         }
  2075.   }                                                                                       
  2076. }
  2077.   

  2078. /*=====================================================================================
  2079. 函数名称:温度功能
  2080. 功能描述:连续检查温度
  2081. 全局变量:temprun  oth_run  als_temp  adju_si
  2082. 参数说明:见函数
  2083. 返回说明:无
  2084. 设 计 人:LIJH
  2085. 版    本:1.0
  2086. 说    明:
  2087. ======================================================================================*/


  2088. /*温度显示*/
  2089. uchar temp_func_dis(void)
  2090. {
  2091.   uchar save[2],k;
  2092.   clear_dis();
  2093.   dis_title_e();
  2094.   display_cnasc(0x82,3,"温度计");  
  2095.   display_cnasc(0x98,3,"设定");
  2096.   display_cnasc(0x9e,3,"退出");
  2097.   display_cnasc(0x8e,1," \x1f");
  2098.   num2_asc_dis(10,0x85);
  2099.   temprun=1;
  2100.   while(1)
  2101.   {
  2102.         if(ds18b20)
  2103.     {
  2104.       if(temp.t_data[0]>99)          // 温度值大于99时
  2105.           {
  2106.             save[0]=temp.t_data[0]/100;
  2107.         save[1]=(temp.t_data[0]/10)%10;
  2108.         num2_asc_dis(save[0],0x80);
  2109.             num2_asc_dis(save[1],0x81);
  2110.             save[0]=char_num[temp.t_data[0]%10];
  2111.             num2_asc_dis(save[0],0x82);
  2112.       }
  2113.           else                                         // 温度小于100
  2114.           {
  2115.         con_disp(0x00,0x00,0x80,0x90,1,16);
  2116.                 con_disp(0x00,0x00,0x88,0x90,1,16);
  2117.                 if(temp_pn) con_disp(0x3f,0xfc,0x80,0x9d,1,3);
  2118.             else  con_disp(0x00,0x00,0x80,0x9d,1,3);
  2119.             save[0]=temp.t_data[0]/10;
  2120.             save[1]=temp.t_data[0]%10;
  2121.             num2_asc_dis(save[0],0x81);
  2122.             num2_asc_dis(save[1],0x82);
  2123.           }
  2124.           save[0]='.';
  2125.           save[1]=char_num[temp.t_data[1]/10];
  2126.           display_cnasc(0x8b,1,save);
  2127.           save[0]=char_num[temp.t_data[1]%10];
  2128.           if(save[0]=='1') save[1]='2';                   // 补偿精度
  2129.           else if(save[0]=='7') save[1]='5';
  2130.           else if(save[0]=='8'||save[0]=='1') save[1]='7';
  2131.           else save[1]='0';
  2132.           display_cnasc(0x8c,1,save);
  2133.     }
  2134.         else
  2135.         {
  2136.       clear_dis();
  2137.       display_cnasc(0x92,4,"没有发现");
  2138.       display_cnasc(0x8c,4,"温感器!");
  2139.           delay_pw();
  2140.           temprun=0;
  2141.           return 0;
  2142.         }
  2143.         k=gotkey();
  2144.         if(k==2)         // 进入设置菜单
  2145.         {
  2146.           display_cnasc(0x8e,1," \x04");
  2147.           delay(35000);
  2148.           display_cnasc(0x8e,1," \x1e");
  2149.           display_cnasc(0x9a,4,"\x11 (ok) \x10");
  2150.           return 1;
  2151.         }
  2152.   }
  2153. }

  2154. /*警报温度设置*/
  2155. uchar temp_func_set(void)
  2156. {
  2157.   uchar save[2];
  2158.   temprun=0;
  2159.   oth_run=0;
  2160.   rds1302_data();
  2161.   while(1)
  2162.   {  
  2163.         if(oth_run)
  2164.         {
  2165.           con_disp (0x00,0x00,0x88,0x90,2,16);
  2166.           con_disp (0xff,0xff,0x8e,0x90,2,16);
  2167.         }
  2168.         else
  2169.         {
  2170.           con_disp (0xff,0xff,0x88,0x90,2,16);
  2171.           con_disp (0x00,0x00,0x8e,0x90,2,16);
  2172.         }       
  2173.         save[0]=gotkey();
  2174.         if(save[0]==1||save[0]==3) oth_run=!oth_run;
  2175.         if(save[0]==5) return 1;
  2176.         if(save[0]==11)
  2177.         {  
  2178.           if(oth_run) return 0;
  2179.           else  
  2180.           {
  2181.                 clear_dis();
  2182.                 dis_title_e();
  2183.                 save[1]=save[0]=0;
  2184.                 oth_run=0;
  2185.             dis_title_e();
  2186.         display_cnasc(0x82,3,"设  定");
  2187.             display_cnasc(0x90,5,"警报温度:");
  2188.                 display_cnasc(0x88,7,"高于【    】℃");
  2189.                 display_cnasc(0x98,8,"低于【    】℃ \x10");
  2190.                 while(1)
  2191.                 {
  2192.                   if(save[1]==2) con_disp(0x00,0x00,index_temp_set[save[1]].lnum,index_temp_set[save[1]].rnum,2,13);
  2193.                   else con_disp(0x00,0x00,index_temp_set[save[1]].lnum,index_temp_set[save[1]].rnum,2,13);
  2194.                   if(save[0]==2) con_disp(0x0f,0xff,index_temp_set[save[0]].lnum,index_temp_set[save[0]].rnum,1,13);
  2195.           else con_disp(0xff,0xff,index_temp_set[save[0]].lnum,index_temp_set[save[0]].rnum,2,13);
  2196.               save[1]=save[0];
  2197.           adju_si=0;
  2198.                   oth_run=0;
  2199.                   while(1)
  2200.                   {
  2201.                     for(i=0;i<2;i++)
  2202.                     {
  2203.                       j=0x8b+i*16;
  2204.                           if(als_temp[i]==255) display_cnasc(j,2," off"); // 255值为关闭值
  2205.                       else
  2206.                           {
  2207.                             save1=save[1];
  2208.                             if(als_temp[i]>127)         // 当数值大于127时温度值为负数
  2209.                             {
  2210.                                   display_cnasc(j,1,"- ");
  2211.                                   save[0]=char_num[(als_temp[i]-128)/10];
  2212.                                   save[1]=char_num[(als_temp[i]-128)%10];
  2213.                                   display_cnasc(j+1,1,save);
  2214.                             }
  2215.                             else
  2216.                             {
  2217.                                   save[0]=' ';
  2218.                                   save[1]=char_num[als_temp[i]/100];
  2219.                                   if(save[1]=='0') save[1]=' ';
  2220.                                   display_cnasc(j,1,save);
  2221.                                   save[0]=char_num[als_temp[i]/10%10];
  2222.                                   save[1]=char_num[als_temp[i]%10];
  2223.                                   display_cnasc(j+1,1,save);
  2224.                             }
  2225.                             save[1]=save1;
  2226.                           }
  2227.                     }               
  2228.                         save[0]=gotkey();
  2229.                         do                   // 输入符号等待数值输入或下一位
  2230.                         {
  2231.                           if(save[0]==13){ oth_run=1;display_cnasc(0x8b+save[1]*16,2,"-   ");}
  2232.                           else if(save[0]==12){ oth_run=0;display_cnasc(0x8b+save[1]*16,2,"    ");}
  2233.                           else break;
  2234.                           save[0]=gotkey();
  2235.                           if(save[0]>=0&&save[0]<10||save[0]==11) break;
  2236.                         }while(1);
  2237.                         if(save[0]==14){ als_temp[save[1]]=255;}  // 乘号直接将警报温度关闭
  2238.                         if(save[0]>=0&&save[0]<10&&save[1]<2)
  2239.                     {
  2240.                           if(adju_si)
  2241.                       {
  2242.                             adju_si=0;
  2243.                             if(oth_run) als_temp[save[1]]&=0x7f;  // 消去符号位
  2244.                                 if(als_temp[save[1]]>24&&!oth_run) als_temp[save[1]]=240;
  2245.                         else als_temp[save[1]]=als_temp[save[1]]*10+save[0];
  2246.                                 if(oth_run&&als_temp[save[1]]>50) als_temp[save[1]]=50;                
  2247.                                 if(!oth_run&&als_temp[save[1]]>120) als_temp[save[1]]=120;
  2248.                                 if(!oth_run&&als_temp[save[1]]<100) adju_si=1;        // 根据数值打开连写
  2249.                                 if(oth_run&&als_temp[save[1]]<10)  adju_si=1;
  2250.                           }
  2251.                           else
  2252.                           {
  2253.                             als_temp[save[1]]=save[0];
  2254.                                 adju_si=1;
  2255.                           }
  2256.                           if(oth_run) als_temp[save[1]]=als_temp[save[1]]|0x80;         // 写入符号
  2257.                           else als_temp[save[1]]=als_temp[save[1]]&0x7f;
  2258.                         }                       
  2259.                         if(save[0]==11)
  2260.                         {
  2261.                           if(als_temp[1]!=255&&als_temp[0]!=255)           // 上下限温度调整
  2262.                           {
  2263.                              if(save[1]==0&&als_temp[0]<als_temp[1]){als_temp[0]=als_temp[1];}
  2264.                             if(save[1]==1&&als_temp[1]>als_temp[0]){als_temp[1]=als_temp[0];}
  2265.                           }
  2266.                           save[0]=save[1]+1;adju_si=0;break;}
  2267.                 if(save[0]==10&&save[1]!=0) {save[0]=save[1]-1;adju_si=0;break;}
  2268.                   }
  2269.                   oth_run=0;
  2270.                   if(save[0]==3&&save[1]==2) break;
  2271.                 }
  2272.                 save_y_or_n();
  2273.                 if(oth_run)
  2274.                 {
  2275.                   wds1302_data(d02_temp,als_temp[0]);
  2276.                   wds1302_data(d02_temp+2,als_temp[1]);
  2277.                 }
  2278.                 return 1;
  2279.           }
  2280.         }
  2281.   }
  2282. }                  
  2283.                                   
  2284.                  
  2285. /*温度计主函数*/                 
  2286. void temp_func(void)
  2287. {                 
  2288.   uchar t;       
  2289.   while(1)
  2290.   {
  2291.     oth_run=1;
  2292.         t=temp_func_dis();
  2293.     if(t==1)
  2294.         {
  2295.           t=temp_func_set();
  2296.           if(t==0) return;
  2297.         }
  2298.     else return;
  2299.   }
  2300. }
  2301. /*=====================================================================================
  2302. 函数名称:闹铃功能
  2303. 功能描述:设定闹铃
  2304. 全局变量:alarm_time adju_si
  2305. 参数说明:见函数
  2306. 返回说明:无
  2307. 设 计 人:LIJH
  2308. 版    本:1.0
  2309. 说    明:
  2310. ======================================================================================*/


  2311. void alarm_func(void)
  2312. {
  2313.   uchar save[2],a,d;
  2314.   clear_dis();
  2315.   dis_title_e();
  2316.   display_cnasc(0x82,3,"闹  钟");  
  2317.   display_cnasc(0x91,6,"状态:\x11    \x10");
  2318.   display_cnasc(0x89,3,"闹铃:");
  2319.   display_cnasc(0x9f,1,"→");
  2320.   display_cnasc(0x90,1,"『");
  2321.   display_cnasc(0x8f,1,"』");
  2322.   adju_si=0;
  2323.   a=0;d=0;
  2324.   save[0]=char_num[alarm_time[0]>>4];
  2325.   save[1]=char_num[alarm_time[0]&0x0f];
  2326.   display_cnasc(0x8c,1,save);
  2327.   display_cnasc(0x8d,1,": ");
  2328.   save[0]=char_num[alarm_time[1]>>4];
  2329.   save[1]=char_num[alarm_time[1]&0x0f];       
  2330.   display_cnasc(0x8e,1,save);
  2331.   do
  2332.   {
  2333.     if(a==0)
  2334.         {   
  2335.           display_cnasc(0x95,1,alm_sign[alm]);
  2336.       display_cnasc(0x94,1,"\x11 ");
  2337.       display_cnasc(0x96,1," \x10");
  2338.           con_disp(0x00,0x00,index_alm[d-1].lnum,index_alm[d-1].rnum,1,14);
  2339.         }
  2340.     if(a>0&&a<4)
  2341.         {
  2342.           if(d==0)
  2343.           {
  2344.                 display_cnasc(0x94,1,"  ");
  2345.         display_cnasc(0x96,1,"  ");
  2346.           }
  2347.           else
  2348.            con_disp(0x00,0x00,index_alm[d-1].lnum,index_alm[d-1].rnum,1,14);
  2349.          con_disp(0xff,0xff,index_alm[a-1].lnum,index_alm[a-1].rnum,1,14);       
  2350.     }                   
  2351.         d=a;
  2352.         while(1)
  2353.         {
  2354.           a=gotkey();
  2355.           if((a==1||a==3)&&d==0)
  2356.           {
  2357.             alm=!alm;
  2358.                 if(a==1) display_cnasc(0x94,1,"\x09 ");
  2359.                 else display_cnasc(0x96,1," \x09");
  2360.                 delay(35000);
  2361.                 if(a==1) display_cnasc(0x94,1,"\x11 ");
  2362.         else display_cnasc(0x96,1," \x10");
  2363.                 display_cnasc(0x95,1,alm_sign[alm]);
  2364.           }
  2365.           if(d>0&&d<3&&a>=0&&a<10)
  2366.           {
  2367.             if(adju_si)
  2368.                 {
  2369.                   alarm_time[d-1]<<=4;alarm_time[d-1]+=a;
  2370.                   if(d==1&&alarm_time[0]>0x23) alarm_time[0]=a;
  2371.                   else if(d==2&&alarm_time[1]>0x59) alarm_time[1]=a;
  2372.                   else adju_si=0;
  2373.                 }
  2374.             else  
  2375.                 {
  2376.                   alarm_time[d-1]=a;adju_si=1;
  2377.                 }
  2378.                 save[0]=char_num[alarm_time[d-1]>>4];
  2379.             save[1]=char_num[alarm_time[d-1]&0x0f];
  2380.             display_cnasc(0x8c+(d-1)*2,1,save);
  2381.           }
  2382.           if(a==11){a=d+1;break;}
  2383.           if(a==10&&d!=0){a=d-1;break;}
  2384.         }
  2385.         adju_si=0;
  2386.         if(a==4)
  2387.         {
  2388.           save_y_or_n();
  2389.           wds1302_data(d02_signs,signs);
  2390.           wds1302_data(d02_alm,alarm_time[0]);
  2391.           wds1302_data(d02_alm+2,alarm_time[1]);
  2392.           return;
  2393.         }
  2394.   }while(1);
  2395. }



  2396. /*=====================================================================================
  2397. 函数名称:篮球器功能
  2398. 功能描述:分数  时间  24秒  
  2399. 全局变量:resu  opera
  2400. 参数说明:见函数
  2401. 返回说明:无
  2402. 设 计 人:LIJH
  2403. 版    本:1.0
  2404. 说    明:
  2405. ======================================================================================*/

  2406. /*比赛设置*/
  2407. void nba_set(void)
  2408. {
  2409.   uchar nba,save1,key,save[2];
  2410.   clear_dis();
  2411.   dis_title_e();
  2412.   if(resu[7]==1) display_cnasc(0x82,3,"加  时");
  2413.   else  
  2414.   {
  2415.     display_cnasc(0x82,3,"设  定");
  2416.     opera[0][0]=0;
  2417.     opera[1][0]=1;
  2418.   }
  2419.   resu[6]=0;        // 赋初值
  2420.   resu[0]=1;
  2421.   resu[1]=4;
  2422.   resu[2]=12;
  2423.   resu[3]=0;
  2424.   resu[4]=24;
  2425.   display_cnasc(0x90,7,"队1:红  队2:白");
  2426.   display_cnasc(0x88,7,"24秒:Y  节数:4");
  2427.   display_cnasc(0x98,8,"每节时间: 12分钟");
  2428.   save1=0;nba=0;
  2429.   while(1)
  2430.   {
  2431.     if(save1==4) display_cnasc(0x9c,1,":");
  2432.         else display_cnasc(index_nba[save1],1,"  ");
  2433.         if(nba==4)  display_cnasc(0x9c,1,":\x10");
  2434.         else display_cnasc(index_nba[nba],1,"\x11 ");
  2435.         save1=nba;
  2436.         key=gotkey();       
  2437.         if(key==1||key==3)
  2438.         {          
  2439.           switch(nba)     // 导航更改数据
  2440.           {
  2441.             case 0:                            
  2442.                 case 1:
  2443.                         if(key==1){if(opera[nba][0]>0) opera[nba][0]--;
  2444.                                            else opera[nba][0]=7;}
  2445.                                 if(key==3){if(opera[nba][0]<7) opera[nba][0]++;
  2446.                                            else opera[nba][0]=0;}
  2447.                                 display_cnasc(index_nba[nba]-1,1,nba_oppo[opera[nba][0]]);
  2448.                                 break;
  2449.                 case 2:
  2450.                                 if(resu[0]>0) resu[0]=0;
  2451.                                 else resu[0]=1;
  2452.                                 if(resu[0]>0)         display_cnasc(0x8a,1,":Y");
  2453.                                 else display_cnasc(0x8a,1,":N");
  2454.                                 break;
  2455.                 case 3:
  2456.                                 if(key==1){if(resu[1]>1) resu[1]--;
  2457.                                             else  resu[1]=4;}
  2458.                             if(key==3){if(resu[1]<4) resu[1]++;
  2459.                                        else resu[1]=1;}
  2460.                                 save[0]=':';
  2461.                                 save[1]=char_num[resu[1]];
  2462.                                display_cnasc(0x8e,1,save);
  2463.                                 break;
  2464.                 case 4:
  2465.                                 if(key==1){if(resu[2]>0) resu[2]--;
  2466.                                             else  resu[2]=60;}
  2467.                             if(key==3){if(resu[2]<60) resu[2]++;
  2468.                                        else resu[2]=0;}
  2469.                                 save[0]=char_num[resu[2]/10];
  2470.                                 save[1]=char_num[resu[2]%10];
  2471.                                display_cnasc(0x9d,1,save);
  2472.                                 resu[5]=resu[2];
  2473.                                 break;
  2474.       }
  2475.         }
  2476.         if(key==11)
  2477.         {
  2478.           nba++; if(nba==5) return;                          
  2479.         }
  2480.         if(key==10&&nba!=0)  nba--;
  2481.   }
  2482. }



  2483. /*界面其他元素*/
  2484. void nba_oth_dis(void)
  2485. {
  2486.   uchar save[2];
  2487.   if(resu[7]==1) display_cnasc(0x80,5,"加时时间:");
  2488.   else display_cnasc(0x80,5,"比赛时间:");
  2489.   display_cnasc(0x98,1,nba_oppo[opera[0][0]]);
  2490.   display_cnasc(0x9e,1,nba_oppo[opera[1][0]]);
  2491.   display_cnasc(0x99,1,"队");
  2492.   display_cnasc(0x9f,1,"队");
  2493.   save[0]='0';
  2494.   save[1]=char_num[resu[6]+1];
  2495.   display_cnasc(0x9b,1,save);
  2496.   display_cnasc(0x9c,1,"st");
  2497.   con_disp(0xff,0xff,0x83,0x90,2,1); // 画正方框
  2498.   con_disp(0xff,0xff,0x8b,0x8f,2,1);
  2499.   con_disp(0x80,0x00,0x83,0x91,1,15);
  2500.   con_disp(0x00,0x01,0x84,0x91,1,15);
  2501.   con_disp(0x80,0x00,0x8b,0x80,1,15);
  2502.   con_disp(0x00,0x01,0x8c,0x80,1,15);
  2503.   nba_dis_time();
  2504.   if(resu[0]==0) display_cnasc(0x93,2,"\x07--\x07");
  2505.   display_cnasc(0x8b,2," S! ");
  2506. }



  2507. /*篮球器主函数*/
  2508. void nba_timer(void)
  2509. {
  2510.   uchar save,key,nba=0;
  2511.   als=di0=1;alm=keb=di1=oth_run=0;
  2512.   time_init();  
  2513.   display_cnasc(0x82,3,"篮球器");
  2514.   dis_title_e();
  2515.   removal_data(0,1);
  2516.   while(1)          // 使用说明
  2517.   {
  2518.         display_cnasc(0x90,8,timer_tips[nba]);
  2519.         display_cnasc(0x88,8,timer_tips[nba+1]);
  2520.         display_cnasc(0x98,8,timer_tips[nba+2]);
  2521.         key=gotkey();
  2522.         if(key==11)
  2523.         {
  2524.           nba+=3;
  2525.           if(nba>9) break;
  2526.         }
  2527.         if(key==10)
  2528.         {
  2529.           if(nba>0) nba-=3 ;
  2530.         }
  2531.   }
  2532. nn:
  2533.   nba_set();
  2534.   clear_dis();
  2535.   nba_oth_dis();
  2536.   nba_tim=1;
  2537.   while(1)
  2538.   {       
  2539.         for(save=0x80,nba=0;nba<2;nba++)
  2540.         {
  2541.           if(opera[nba][1]>99)        // 分数显示
  2542.           {
  2543.             num2_asc_dis(opera[nba][1]/100,save);
  2544.                 num2_asc_dis(opera[nba][1]/10%10,save+1);
  2545.                 num2_asc_dis(opera[nba][1]%10,save+2);
  2546.           }
  2547.           else
  2548.           {
  2549.                 num2_asc_dis(opera[nba][1]/10,save);
  2550.                 num2_asc_dis(opera[nba][1]%10,save+1);
  2551.       }
  2552.           if(opera[1][1]>99) save=0x85;
  2553.           else save=0x86;
  2554.         }
  2555.        
  2556.         do
  2557.         {
  2558.         key=gotkey();
  2559.   ss:
  2560.         switch(key)
  2561.         {
  2562.           case 12:
  2563.           case 13:
  2564.                    if(key==12)
  2565.                              {if(opera[0][1]<250) opera[0][1]++;}
  2566.                    else
  2567.                              {if(opera[0][1]>0) opera[0][1]--;}
  2568.                            save=110;
  2569.                             break;
  2570.           case 14:
  2571.           case 15:
  2572.                    if(key==14)
  2573.                              {if(opera[1][1]<250) opera[1][1]++;}
  2574.                    else
  2575.                              {if(opera[1][1]>0) opera[1][1]--;}
  2576.                            save=110;
  2577.                            break;
  2578.           case  7:
  2579.                    TR1=TR0=EA=0;
  2580.                    if((++resu[3])>59)
  2581.                    {
  2582.                      resu[3]=0;
  2583.                          if((++resu[2])>59)
  2584.                                  {
  2585.                                    resu[3]=0;
  2586.                                    if(++resu[2]>60) resu[2]=0;
  2587.                                  }
  2588.                            }
  2589.                        if(resu[4]<24) resu[4]++;
  2590.                            nba_dis_time();
  2591.                            break;
  2592.           case  8:
  2593.                    if(resu[0]==1)
  2594.                            {
  2595.                              TL1=(time_count&0x00FF);
  2596.                  TH1=(time_count>>8);
  2597.                              resu[4]=24; nba_dis_time();
  2598.                                  TR0=TR1=EA=1;
  2599.                            }
  2600.                            break;
  2601.           case  9:
  2602.                    if(resu[2]==0&&resu[3]==0)
  2603.                    {
  2604.                      resu[2]=resu[5];resu[4]=24;
  2605.                                  if(resu[6]==resu[1])
  2606.                                  {                                                          // 判断比分进行加时赛
  2607.                                    if(opera[0][1]==opera[1][1]){nba_tim=0;resu[7]=1; goto nn;}
  2608.                                    while(gotkey()!=10);                  // 否则只能退出
  2609.                                    signs=r1302(d02_signs+1);
  2610.                                    nba_tim=0;
  2611.                                    return;
  2612.                                  }
  2613.                                  else nba_oth_dis();
  2614.                                  break;
  2615.                    }
  2616.                            if(EA) {TR0=TR1=EA=0;break;}
  2617.                    if(!EA&resu[4]!=0){ EA=TR0=1;if(resu[0]==1) TR1=1;}
  2618.                            break;                                                                                                                 
  2619.           case 10:
  2620.           case 11:
  2621.                    if(!EA)                        // 暂停状态下 ok键两次返回时钟界面
  2622.                            {                //  ./s 键两次退出
  2623.                              delay(6000);
  2624.                                  save=gotkey();
  2625.                                  if(save==key)
  2626.                                  {
  2627.                                    if(key==11)
  2628.                                    {
  2629.                                      clear_dis();oth_run=1;
  2630.                                      rds1302_time();
  2631.                                          init_d2=1;
  2632.                                      dis_mode2();
  2633.                                          init_d2=0;
  2634.                                      while(gotkey()!=11);
  2635.                                      oth_run=0;
  2636.                                          save=110;
  2637.                                      clear_dis();
  2638.                                      nba_oth_dis();
  2639.                                    }
  2640.                                    else{ signs=r1302(d02_signs+1); nba_tim=0;return;}
  2641.                              }
  2642.                                  else{ key=save;goto ss;}
  2643.                            }
  2644.                            break;          
  2645.         }
  2646.         if(save==110)  break;
  2647.     }while(1);       
  2648.   }  
  2649. }

  2650.          
  2651. /*=====================================================================================
  2652. 函数名称:设置功能
  2653. 功能描述:系统状态设置  
  2654. 全局变量:signs
  2655. 参数说明:见函数
  2656. 返回说明:无
  2657. 设 计 人:LIJH
  2658. 版    本:1.0
  2659. 说    明:
  2660. ======================================================================================*/


  2661. /*设置调整内容 参数格式:选中设置项,设置项子值*/
  2662. uchar set_dis(uchar menu,uchar sub)
  2663. {
  2664.   uchar save;
  2665.   con_disp(0xff,0xff,0x8e,0x80,2,16);
  2666.   con_disp(0x00,0x00,0x8a,0x80,4,16);
  2667.   display_cnasc(0x96,1,"\x1e ");
  2668.   display_cnasc(0x9e,1,"\x1f ");
  2669.   display_cnasc(0x92,1,"  ");
  2670.   display_cnasc(0x9a,1,"  ");
  2671.   display_cnasc(0x8d,1,"\x11 ");
  2672.   display_cnasc(0x8a,1,"  ");
  2673.   while(1)
  2674.   {
  2675.    
  2676.     if(menu<2)
  2677.       display_cnasc(0x8e,2,set_bl_dm[menu][sub]);
  2678.     else
  2679.           display_cnasc(0x8e,2,set_mka[menu-2][sub]);
  2680.         save=gotkey();
  2681.         if(save==5)
  2682.         {
  2683.           key_dis(0x96);
  2684.           if(sub==0&&menu<2) sub=2;
  2685.           else if(sub==0&&menu>1) sub=1;
  2686.           else sub--;
  2687.     }
  2688.         if(save==2)
  2689.         {
  2690.           key_dis(0x9e);
  2691.           if(sub==2&&menu<2) sub=0;
  2692.           else if(sub==1&&menu>1) sub=0;
  2693.           else sub++;
  2694.         }
  2695.         if(save==1||save==11)
  2696.         {
  2697.           display_cnasc(0x8d,1,"\x04 ");
  2698.         delay(30000);
  2699.           con_disp(0x00,0x00,0x8e,0x80,2,16);
  2700.       con_disp(0xff,0xff,0x8a,0x80,4,16);
  2701.       display_cnasc(0x92,1,"\x1e ");
  2702.       display_cnasc(0x9a,1,"\x1f ");
  2703.       display_cnasc(0x96,1,"  ");
  2704.       display_cnasc(0x9e,1,"  ");
  2705.           display_cnasc(0x8a,1,"【");
  2706.           display_cnasc(0x8d,3,"】\x10 \x04 ");
  2707.           return(sub);          // 返回设置值
  2708.         }
  2709.   }
  2710. }


  2711. /*设置调整*/
  2712. void set_func(void)
  2713. {
  2714.   uchar d,key,save;
  2715.   display_cnasc(0x81,2,"设置");
  2716.   dis_title();
  2717.   display_cnasc(0x88,8,selected[1]);
  2718.   con_disp(0xff,0xff,0x8a,0x80,4,16);
  2719.   save=d=0;
  2720.   do
  2721.   {          
  2722.         display_cnasc(0x93,2,set_menu[index_s[save].lnum]);
  2723.         display_cnasc(0x8b,2,set_menu[save]);
  2724.         display_cnasc(0x9b,2,set_menu[index_s[save].rnum]);
  2725.         d=save;
  2726.         while(1)
  2727.         {
  2728.           key=gotkey();
  2729.           if(key==11||key==3){ enter_dis();break;}
  2730.           if(key==5){save=index_s[d].lnum;key_dis(0x92); break;}
  2731.           if(key==2){save=index_s[d].rnum;key_dis(0x9a); break;}
  2732.           if(key==1){ wds1302_data(d02_signs,signs); return;}
  2733.     }
  2734.         if(key==11||key==3)
  2735.         {
  2736.       save=0;
  2737.       for(key=0;key<2;key++)  //  进行两次比较 首次为现时值 其次为设定置更改
  2738.       {
  2739.         switch(d)
  2740.         {
  2741.           case 0:
  2742.                           if(key==1)
  2743.                           {
  2744.                                     bl0=bl1=0;
  2745.                                         if(save==1) bl0=1;
  2746.                                         if(save==2)        bl1=1;
  2747.                           }
  2748.                       else
  2749.                                   {if(bl0) save=1; if(bl1) save=2;}
  2750.                                   if(bl1) lcd_bl=close;
  2751.                                   else lcd_bl=open;
  2752.                               break;
  2753.               case 1:
  2754.                           if(key==1)
  2755.                           {
  2756.                                     di0=di1=0;
  2757.                                         if(save==1) di0=1;
  2758.                                         if(save==2)        di1=1;
  2759.                           }
  2760.                               else {if(di0) save=1; if(di1) save=2;}
  2761.                               break;
  2762.               case 2:
  2763.                           if(key==1) meu=(bit)save;
  2764.                       else {if(meu) save++;}             
  2765.                               break;
  2766.           case 3:
  2767.                           if(key==1) keb=(bit)save;
  2768.                       else{if(keb) save++;}             
  2769.                               break;
  2770.           case 4:
  2771.                           if(key==1) als=(bit)save;
  2772.                       else{if(als) save++;}             
  2773.                               break;
  2774.           case 5: wds1302_data(d02_signs,signs);
  2775.                       return;
  2776.         }
  2777.         if(key==0) save=set_dis(d,save);
  2778.       }
  2779.           save=d;
  2780.         }
  2781.   }while(1);
  2782. }


  2783. /*=====================================================================================
  2784. 函数名称:保密功能
  2785. 功能描述:系统重设  密码锁  密码更改  
  2786. 全局变量:resu  
  2787. 参数说明:见函数
  2788. 返回说明:无
  2789. 设 计 人:LIJH
  2790. 版    本:1.0
  2791. 说    明:
  2792. ======================================================================================*/


  2793. /*密码整理*/
  2794. void passwork_finish()
  2795. {
  2796.   uchar i;
  2797.   for(i=0;i<6;i+=2)
  2798.   {
  2799.     resu[i]<<=4;
  2800.         resu[i]+=resu[i+1];
  2801.   }
  2802. }



  2803. /*读取密码*/
  2804. uchar input_passwork()
  2805. {
  2806.   uchar i,save[2];
  2807.   save[0]=' ';
  2808.   display_cnasc(0x9d,3,"(./S)\x10");
  2809.   for(i=0;i<6;i++)
  2810.   {
  2811.     while(1)
  2812.         {
  2813.           resu[i]=gotkey();
  2814.           if(resu[i]>=0&&resu[i]<10) break;
  2815.           if(resu[i]==10) return 10;
  2816.         }
  2817.     save[1]=char_num[resu[i]];
  2818.         display_cnasc(0x89+i,1,save);
  2819.         delay(20000);
  2820.         display_cnasc(0x89+i,1," *");
  2821.   }
  2822.   return 11;
  2823. }



  2824. /*密码确认*/
  2825. void input_second_passwork()
  2826. {
  2827.   uchar i,save[2];
  2828.   save[0]=' ';
  2829.   display_cnasc(0x89,6,"            ");
  2830.   for(i=0;i<6;i++)
  2831.   {   
  2832.         if(resu[i]!=gotkey())        break;
  2833.         save[1]=char_num[resu[i]];
  2834.         display_cnasc(0x89+i,1,save);
  2835.         delay(20000);
  2836.         display_cnasc(0x89+i,1," *");
  2837.   }
  2838.   if(i!=6)
  2839.   {
  2840.     display_cnasc(0x89,6,"密码不相同!");
  2841.         delay(50000);
  2842.         display_cnasc(0x9a,6,"任意键 \x10    ");
  2843.         while(gotkey()==0xf0);
  2844.         return;
  2845.   }
  2846.   else
  2847.   {
  2848.         passwork_finish();
  2849.         for(i=0;i<6;i+=2)
  2850.           wds1302_data(d02_passw+i,resu[i]);
  2851.         for(i=0;i<6;i+=2)
  2852.           if(resu[i]!=r1302(d02_passw+i+1)) break;
  2853.         if(i==6)
  2854.          {display_cnasc(0x98,8,"\x10 更改成功!(OK) ");
  2855.           while(gotkey()!=11);return;}
  2856.         else
  2857.           display_cnasc(0x9a,6,"更改失败!  ");
  2858.   }
  2859.   delay_pw();
  2860. }                               



  2861. /*密码比较*/
  2862. uchar passwork_comp()
  2863. {
  2864.   uchar i;
  2865.   passwork_finish();
  2866.   for(i=0;i<6;i+=2)
  2867.         if(resu[i]!=r1302(d02_passw+i+1)) break;
  2868.   if(i==6)         return 1;
  2869.   else
  2870.   {
  2871.     display_cnasc(0x89,6,"  密码错误!");
  2872.         delay_pw();
  2873.         display_cnasc(0x89,6,"            ");
  2874.         return 110;
  2875.   }
  2876. }



  2877. /*保密导航*/
  2878. void passw_func(void)
  2879. {
  2880.   uchar save,d,key;
  2881.   d=0;save=0;
  2882.   do
  2883.   {
  2884.     clear_dis();
  2885.         display_cnasc(0x81,2,"保密");
  2886.     dis_title();
  2887.     display_cnasc(0x88,8,selected[0]);
  2888.     con_disp(0xff,0xff,0x8a,0x80,5,16);
  2889.     do
  2890.     {          
  2891.           display_cnasc(0x93,3,secrets_menu[index_p[save].lnum]);
  2892.           display_cnasc(0x8b,3,secrets_menu[save]);
  2893.           display_cnasc(0x9b,3,secrets_menu[index_p[save].rnum]);  
  2894.           d=save;
  2895.           while(1)
  2896.           {
  2897.             key=gotkey();
  2898.             if(key==11||key==3){enter_dis();break;}
  2899.             if(key==2){save=index_p[d].rnum; key_dis(0x9a);break;}
  2900.             if(key==5){save=index_p[d].lnum; key_dis(0x92);break;}
  2901.                 if(key==1){return;}
  2902.       }
  2903.       if(key==11||key==3)
  2904.           {       
  2905.                 if(d==3) return;               
  2906.                 clear_dis();
  2907.                 dis_title_e();
  2908.         switch(d)
  2909.         {
  2910.           case 0:
  2911.                           display_cnasc(0x82,3,"密码锁");
  2912.                                   display_cnasc(0x90,5,"输入密码:");
  2913.                                   while(1)
  2914.                                   {
  2915.                                     key=input_passwork();
  2916.                                     if(key==10) break;
  2917.                                     key=passwork_comp();
  2918.                                     if(key==1)
  2919.                             {
  2920.                                       display_cnasc(0x90,8,"处开启状态,按键");
  2921.                               display_cnasc(0x88,8,"□1-常开□2-关闭");
  2922.                                       display_cnasc(0x98,8,"■自动延时30秒  ");
  2923.                                           pw_oc=open;
  2924.                                       save1=i=0;   
  2925.                                       lock_op=1;   // 开启标记等待延时
  2926.                                       while(1)
  2927.                                       {
  2928.                                             key=gotkey(); // 返回255为延时时间到达
  2929.                                             if(key==255){ lock_op=0;pw_oc=close;break;}
  2930.                                             if(key==1)
  2931.                                             {
  2932.                                               display_cnasc(0x88,1,"■");
  2933.                                               display_cnasc(0x98,1,"□");
  2934.                                               lock_op=0;
  2935.                                             }
  2936.                                             if(key==2)
  2937.                                             {
  2938.                                               display_cnasc(0x88,1,"□");
  2939.                                                   display_cnasc(0x98,1,"□");
  2940.                                                   display_cnasc(0x8c,1,"■");
  2941.                                                   delay(60000);
  2942.                                                   clear_dis();
  2943.                                               dis_title_e();
  2944.                                   display_cnasc(0x82,3,"密码锁");
  2945.                                               display_cnasc(0x90,5,"密码锁将在");
  2946.                                                   display_cnasc(0x8a,6," 5秒后关闭:");
  2947.                                               for(save=0;save<5;save++)
  2948.                                               {
  2949.                                                 display_cnasc(0x99+save,1,"→");
  2950.                                                     delay_pw();
  2951.                                               }
  2952.                                                   display_cnasc(0x9e,1,"√");
  2953.                                                   pw_oc=open;
  2954.                                                   delay(30000);
  2955.                                                   pw_oc=close;
  2956.                                               lock_op=0;
  2957.                                               break;
  2958.                                             }
  2959.                                       }
  2960.                                           break;
  2961.                                     }
  2962.                                   }
  2963.                                break;
  2964.               case 1:
  2965.                           display_cnasc(0x82,3,"更  改");
  2966.                                   display_cnasc(0x90,6,"输入旧密码:");
  2967.                                   while(1)
  2968.                                   {
  2969.                                     key=input_passwork();
  2970.                                     if(key==10) break;
  2971.                                     key=passwork_comp();
  2972.                                     if(key==1)
  2973.                                     {
  2974.                                       display_cnasc(0x92,1,"新");
  2975.                                           display_cnasc(0x89,6,"            ");
  2976.                                       key=input_passwork();
  2977.                                           if(key==10) break;
  2978.                                           display_cnasc(0x90,6,"确认密码:  ");
  2979.                                           input_second_passwork();
  2980.                                           break;               
  2981.                                     }
  2982.                                   }
  2983.                                   break;
  2984.               case 2:
  2985.                           display_cnasc(0x82,3,"初始化");
  2986.                             display_cnasc(0x91,6,"是否初始化? ");
  2987.                   display_cnasc(0x89,6,"Y(OK)\\N(./S)");
  2988.                                   while(1)
  2989.                                   {
  2990.                                     key=gotkey();
  2991.                                         if(key==11)
  2992.                                         {
  2993.                                           clear_dis();
  2994.                                           dis_title_e();
  2995.                                           display_cnasc(0x82,3,"初始化");
  2996.                                           display_cnasc(0x90,5,"输入密码:");
  2997.                                           do
  2998.                                           {
  2999.                                             key=input_passwork();
  3000.                                             if(key==10) break;
  3001.                                             key=passwork_comp();
  3002.                                             if(key==1)
  3003.                                             {
  3004.                                                   display_cnasc(0x90,5,"密码正确!");
  3005.                                                   display_cnasc(0x89,7,"\x10 初始化中... ");
  3006.                                                   init_ds1302();
  3007.                                                   rds1302_data();
  3008.                                                   delay_pw();
  3009.                                                   display_cnasc(0x9a,6,"\x10 完成!(OK)");
  3010.                                                   while(gotkey()!=11);
  3011.                                                   key=10;
  3012.                                                   break;
  3013.                                             }
  3014.                                           }while(1);
  3015.                                         }
  3016.                                         if(key==10) break;
  3017.                                   }
  3018.                                   break;
  3019.                 }
  3020.                 key=99;save=d;
  3021.           }
  3022.           if(key==99) break;
  3023.         }while(1);
  3024.   }while(1);
  3025. }


  3026. /*=====================================================================================
  3027. 函数名称:版本信息
  3028. 功能描述:  
  3029. 全局变量:
  3030. 参数说明:见函数
  3031. 返回说明:无
  3032. 设 计 人:LIJH
  3033. 版    本:1.0
  3034. 说    明:
  3035. ======================================================================================*/

  3036. void version_func(void)
  3037. {
  3038.   uchar save,v=0;
  3039.   display_cnasc(0x82,3,"版  本");
  3040.   dis_title_e();
  3041.   do
  3042.   {
  3043.         display_cnasc(0x90,7,version[v]);
  3044.         display_cnasc(0x88,7,version[v+1]);
  3045.         display_cnasc(0x98,7,version[v+2]);
  3046.         if(v!=0) display_cnasc(0x97,1," \x1e");
  3047.         else if(v==0)
  3048.           display_cnasc(0x97,1,"院");
  3049.         else display_cnasc(0x97,1,"  ");
  3050.         if(v!=7) display_cnasc(0x9f,1," \x1f");
  3051.         else display_cnasc(0x9f,1,"  ");
  3052.         save=gotkey();
  3053.         if(save==2&&v<7)
  3054.         {
  3055.           display_cnasc(0x9f,1," \x04");
  3056.       delay(30000);
  3057.           v++;
  3058.         }
  3059.         if(save==5&&v>0)
  3060.         {
  3061.           display_cnasc(0x97,1," \x04");
  3062.       delay(30000);
  3063.           v--;
  3064.         }
  3065.         if(save==1) return;
  3066.         if((save==11||save==3)&&v==7)
  3067.         {
  3068.           display_cnasc(0x9e,2,") \x09 ");
  3069.       delay(30000);
  3070.           return;          
  3071.         }
  3072.   }while(1);
  3073. }



  3074. /*=====================================================================================
  3075. 函数名称:系统主函数
  3076. 功能描述:  
  3077. 全局变量:
  3078. 参数说明:见函数
  3079. 返回说明:无
  3080. 设 计 人:LIJH
  3081. 版    本:1.0
  3082. 说    明:
  3083. ======================================================================================*/
  3084. main()
  3085. {
  3086.   uchar key;                                                          
  3087.   init_lcd();                                                  // 初始化lcd
  3088.   lcd_bl=als_tl=als_th=buzzer=pw_oc=close;
  3089.   key=r1302(d02_initsi+1);            // 读出1302初始化标记位
  3090.   if(bl1) lcd_bl=close;
  3091.   else lcd_bl=open;
  3092.   display_cnasc(0x92,4,"欢迎使用");   // 显示开机画面“欢迎使用”
  3093.   display_cnasc(0x9d,3,"—LiJH");
  3094.   if(key!=0xb4)  init_ds1302();       // DS1302初始化
  3095.   rds1302_data();                                          // 开机读回设置数据
  3096.   rds1302_date();
  3097.   rds1302_time();                     // 读日期时间   
  3098.   if(!ds18b20) init_ds18b20();                  // 初始化18b20
  3099.   if(ds18b20)
  3100.   {                                              
  3101.         ds18b20_func();                                           // 读出温度
  3102.   }
  3103.   time_init();                         // 定时器初始化
  3104.   delay_pw();resu[11]=0;
  3105.   while(1)
  3106.   {  
  3107.         EA=1;
  3108.         TR0=1;
  3109.         dis_sig=1;       
  3110.         clear_dis();
  3111.         if(di0){init_d2=1;dis_mode2();init_d2=0;}
  3112.     else if(di1) dis_mode3();
  3113.     else dis_mode1();       
  3114.         do
  3115.         {
  3116.           key=gotkey();
  3117.           if(key==255)                        // 键盘密码输入
  3118.           {
  3119.                 TR0=0;
  3120.                 dis_sig=0;
  3121.                 clear_dis();
  3122.                 dis_title_e();
  3123.                 display_cnasc(0x82,3,"键盘锁");
  3124.                 display_cnasc(0x90,5,"输入密码:");
  3125.                 while(1)
  3126.                 {
  3127.                   keb=0;
  3128.                   key=input_passwork();
  3129.                   if(key==10) {keb=1;resu[11]=2;break;}
  3130.                   key=passwork_comp();
  3131.                   if(key==1) {keb=1;resu[11]=0;break;}           
  3132.                 }
  3133.                 rds1302_date();
  3134.         rds1302_time();
  3135.             save_time=now;
  3136.                 break;
  3137.           }
  3138.           if(key==11)
  3139.           {
  3140.             dis_menu_key(1);
  3141.                 delay(35000);
  3142.                 do
  3143.                 {
  3144.                   dis_sig=0;
  3145.                   TR0=0;
  3146.                   clear_dis();
  3147.                   key=dis_menu();
  3148.                   clear_dis();
  3149.                   if(key==0) adjust_func();
  3150.                   else if(key==1) // 调用相应程序功能S
  3151.                   {
  3152.                     while(1)
  3153.                         {
  3154.                           clear_dis();
  3155.                       key=tool_func();
  3156.                           if(key==4) break;
  3157.                           clear_dis();
  3158.                           switch(key)
  3159.                           {
  3160.                             case 0:        calculator();
  3161.                                         break;
  3162.                                 case 1: temp_func();
  3163.                                             break;
  3164.                                 case 2: alarm_func();
  3165.                                         break;
  3166.                                 case 3: nba_timer();
  3167.                                         break;
  3168.                           }
  3169.                         }
  3170.                   }
  3171.                   else if(key==2)        set_func();
  3172.                   else if(key==3)        passw_func();
  3173.                   else if(key==4) version_func();
  3174.                   else
  3175.                   {
  3176.                     rds1302_date();
  3177.             rds1302_time();
  3178.                         save_time=now;
  3179.                         resu[11]=0;
  3180.                         dis_sig=1;
  3181.                         break;
  3182.                   }
  3183.                 }while(1);
  3184.           }
  3185.           if(dis_sig) break;
  3186.         }while(1);
  3187.   }
  3188. }
复制代码
论坛里的代码,说是很强大没试过

出0入0汤圆

 楼主| 发表于 2012-10-26 17:08:55 | 显示全部楼层
HeP028 发表于 2012-10-26 16:44
论坛里的代码,说是很强大没试过

亲,谢谢了。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-26 14:20

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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