【现场直播】一个数字温控仪表的实现(能显示了)

[复制链接]
13927|83
comelon 发表于 2009-12-17 10:04 | 显示全部楼层
看热闹!:)
yewuyi 发表于 2009-12-17 11:46 | 显示全部楼层
嘿嘿,SVN收不收费?

免费的版本管理软件哪里有?!
一朝成名 发表于 2009-12-17 11:50 | 显示全部楼层
嘿嘿,SVN收不收费?

免费的版本管理软件哪里有?!
yewuyi 发表于 2009-12-17 11:46


开源的,免费~~linux下的
windows也可以装server,不过我没搞过,问小狼吧
客户端windows下也有~
yewuyi 发表于 2009-12-17 11:53 | 显示全部楼层
想用VSS,但不知道能否免费!?
一朝成名 发表于 2009-12-17 12:34 | 显示全部楼层
话说这么多年了,还真没用过收费的东西哈哈~~~~
 楼主| 原野之狼 发表于 2009-12-17 16:52 | 显示全部楼层
白天去了趟少管所 现在接着写~
 楼主| 原野之狼 发表于 2009-12-17 16:54 | 显示全部楼层
本帖最后由 原野之狼 于 2009-12-17 17:43 编辑

回复一些提问:
通讯部分再说 我慢慢写
外扩32KRAM是想做一些复杂点的程序
SVN是免费的
VSS不免费的 MS的东西咋可能免费呢 除非你使用DB
 楼主| 原野之狼 发表于 2009-12-17 17:35 | 显示全部楼层
本帖最后由 原野之狼 于 2009-12-17 17:38 编辑

六、详细设计之硬件篇
    硬件上比较简单的,我一步一步讲,不仅讲我是怎么做的,还要讲我为什么要这么做。
    6.1、MCU部分
    使用ATMEGA64单片机,此单片机资源还是比较丰富的。从收据手册上摘录一段如下:
Features
• High-performance, Low-power AVR® 8-bit Microcontroller
• Advanced RISC Architecture
– 130 Powerful Instructions – Most Single Clock Cycle Execution
– 32 x 8 General Purpose Working Registers + Peripheral Control Registers
– Fully Static Operation
– Up to 16 MIPS Throughput at 16 MHz
– On-chip 2-cycle Multiplier
• Non-volatile Program and Data Memories
– 64K Bytes of In-System Reprogrammable Flash
Endurance: 10,000 Write/Erase Cycles
– Optional Boot Code Section with Independent Lock Bits
In-System Programming by On-chip Boot Program
True Read-While-Write Operation
– 2K Bytes EEPROM
Endurance: 100,000 Write/Erase Cycles
– 4K Bytes Internal SRAM
– Up to 64K Bytes Optional External Memory Space
– Programming Lock for Software Security
– SPI Interface for In-System Programming
• JTAG (IEEE std. 1149.1 Compliant) Interface
– Boundary-scan Capabilities According to the JTAG Standard
– Extensive On-chip Debug Support
– Programming of Flash, EEPROM, Fuses, and Lock Bits through the JTAG Interface
• Peripheral Features
– Two 8-bit Timer/Counters with Separate Prescalers and Compare Modes
– Two Expanded 16-bit Timer/Counters with Separate Prescaler, Compare Mode, and
Capture Mode
– Real Time Counter with Separate Oscillator
– Two 8-bit PWM Channels
– 6 PWM Channels with Programmable Resolution from 1 to 16 Bits
– 8-channel, 10-bit ADC
8 Single-ended Channels
7 Differential Channels
2 Differential Channels with Programmable Gain (1x, 10x, 200x)
– Byte-oriented Two-wire Serial Interface
– Dual Programmable Serial USARTs
– Master/Slave SPI Serial Interface
– Programmable Watchdog Timer with On-chip Oscillator
– On-chip Analog Comparator
• Special Microcontroller Features
– Power-on Reset and Programmable Brown-out Detection
– Internal Calibrated RC Oscillator
– External and Internal Interrupt Sources
– Six Sleep Modes: Idle, ADC Noise Reduction, Power-save, Power-down, Standby
and Extended Standby
– Software Selectable Clock Frequency
– ATmega103 Compatibility Mode Selected by a Fuse
– Global Pull-up Disable
• I/O and Packages
– 53 Programmable I/O Lines
– 64-lead TQFP and 64-pad MLF
• Operating Voltages
– 2.7 - 5.5V for ATmega64L
– 4.5 - 5.5V for ATmega64
• Speed Grades
– 0 - 8 MHz for ATmega64L
– 0 - 16 MHz for ATmega64
    我要用到的资源主要有:
    JTAG调试:便于快速的找出错误,以前公司穷买不起仿真器,所以俺都是一遍遍的下载看现象调试,很费劲,当然也总结了一套调试的方法,以后有机会再讲这个。今年自己失业后冒着挨饿的风险买了个JTAG仿真器,初次使用,用着感觉很良好,再也不用瞎子摸象了。建议新手们买一个,老手也可以买一个的,呵呵。
    XRAM接口:能够扩展外部RAM,原来俺在PC上搞编程,所以鄙人喜欢大RAM大FLASH,当然这不好,成本是蹭蹭地上去了,不过用来练练软件技术也是不错的。既然要扩展,那肯定就少不了锁存器和存储芯片了。存储芯片使用的是常用的CY62256,这没什么好说的。锁存器用的是74AHC573,为什么要用这个呢?原因有二,第一,HC系列芯片速度慢,当MCU在16M时钟下运行会有问题的(其实也能用,但是手册上讲要用AHC系列,所以咱还是乖点吧~);第二,573的管脚排列比373更有规律,便于布线。另外地址线是打乱的,也是为了好布线。这部分的原理图和PCB如下:

图4 MCU和存储器接口的原理图

图5 MCU和存储器接口的PCB走线
    PWM:用来实现模拟电压(或电流)输出。
    EEPROM、TIMER、IO:这没什么好说的。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
 楼主| 原野之狼 发表于 2009-12-17 17:58 | 显示全部楼层
6.2 显示部分
    根据需求部分描述,本系统采用了两个五位显示窗口,那么就是十位数码管,另外加上四个LED。俺使用动态扫描的方法,可以节约几个锁存器件。
   驱动芯片采用两片74HC595。其中一片作为段驱动。另外一片作为位驱动,只能驱动8个位,实际上需要11个位,所以剩下的3个位有MCU直接驱动。这部分的原理图如下:
   
图6 显示部分原理图一

图7 显示部分原理图二

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
 楼主| 原野之狼 发表于 2009-12-17 18:18 | 显示全部楼层
本帖最后由 原野之狼 于 2009-12-17 18:22 编辑

6.3 DS18B20部分
   采用两线制来工作。手册上提供的电路是这样的,MCU和18B20通讯的时候采用4.7K上拉电阻的方式供电,而当18B20进行温度转换的时候采用MOS关上拉来进行供电,但是俺看国内基本上都是只用一个上拉电阻来搞定。试验证明,只用一个上拉电阻也是行的,我通常使用1K做上拉,如果采用4.7K做上拉可能在高温区会出错。
   6.4 按键部分
   采用动态扫描的方式来获取按键事件。电路图很简单:
   
图8 按键部分原理图

   6.5 电源部分
   采用变压器供电,然后再经过78XX系列稳压器进行稳压,有两组电源,一组供给数字系统,一组供给模拟部分,两个地层单点连接。电路图也很简单:

图9 电源部分原理图

    关于硬件部分就先说这么多,鄙人硬件方面比较弱,欢迎各位批评指正。详细的图纸还得整理,因为以上截图均来自于于另外一个地方,但是俺编程的时候都得靠它了。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
 楼主| 原野之狼 发表于 2009-12-17 21:01 | 显示全部楼层
七、详细设计之软件篇
      做软件设计的时候最忌讳不规划就敲键盘编码了,这种代码质量一般不会太高。如果是一个大型软件,没有规划的话我无法想象直接编码是怎么个样子。当然对于这点鄙人做得也不好,有时候也是把那些软件工程的理论抛之脑后然后信手敲来。
      软件工程的那些理论比较繁杂,我就不说了,也说不好。还是各位自己悟去吧。我主要给推荐一个工具,那就是微软的VISIO,一个用于画各种图表的东东,有框图,有流程图等等,各位慢慢发掘。另外还有一个工具,RATIONAL ROSE,搞面向对象的时候可以玩玩,可惜俺不怎么懂这个玩意儿。下面贴一个图,想象一下如果这个状态迁移图不记录下来的话直接去敲键盘编码是件多么费脑细胞的事情,而且以后还无据可查。

图10 使用VISIO的一个示例

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
mantianbingxue 发表于 2009-12-17 21:18 | 显示全部楼层
学习了
 楼主| 原野之狼 发表于 2009-12-17 22:25 | 显示全部楼层
本帖最后由 原野之狼 于 2009-12-17 22:29 编辑

7.1 软件平台介绍
    俺习惯用source insight编辑软件,用gcc编译器,在MS自带的CMD窗口下用命令行调用gcc,用winavr通过JTAG进行硬件级仿真调试,截取一些图片来占篇幅,呵呵~

图11 硬件以及仿真器

图12 编辑工具

图13 编译工具

图14 仿真界面

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
程序匠人 发表于 2009-12-17 23:14 | 显示全部楼层
VISIO 是不错的软件
 楼主| 原野之狼 发表于 2009-12-18 15:27 | 显示全部楼层
王大哥说的有道理,谢谢支持~
 楼主| 原野之狼 发表于 2009-12-18 15:34 | 显示全部楼层
7.2 C和C++混合编程
      这个很简单,只要在C的头文件中加上几句代码就是了。那就是:

  1. #ifdef __cplusplus
  2. extern "C" {
  3. #endif

  4. //do something here

  5. #ifdef __cplusplus
  6. }
  7. #endif

    还有在makefile文件中也需要添上和C++编译有关的东西,在稍后上传的代码中有具体实现。
    当然,我这里说的也忒简单了,还有更深的内容在接下来的篇章中叙述。这里叙述的比较简单,是因为在7.3小结中会用到这些简单内容。
 楼主| 原野之狼 发表于 2009-12-18 15:59 | 显示全部楼层
本帖最后由 原野之狼 于 2009-12-18 16:07 编辑

7.3 点亮数码管
    这人好面子,东西也好面子,先得有点靓的东西装点下门面吧,呵呵,其实还是人好面子,关东西鸟事?
    OK!废话少扯!
    接下来我们要实现:
    (1) 点亮所有能亮的东西。
    (2) 维持一秒。
    (3) 在主显示窗显示 “-21IC”,在副显示窗显示“VER1.0”。
    无图无真相,先看实际效果:
   
图15 全部点亮

图16 版本信息

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
 楼主| 原野之狼 发表于 2009-12-18 16:06 | 显示全部楼层
接下来就该贴代码了。
7.3.1 74HC595驱动部分
     在这里用了两片595,共用移位时钟和所存时钟,详细介绍在代码里头有,俺就不重复了。

  1. /************************************************************
  2. FileName: hc595.h
  3. Author: 原野之狼
  4. Version :V1.0      
  5. Date: 2009.12.17
  6. Description:
  7.   1 Be care of that the two hc595s are share of the shift clk & latch clk,but the dat line is not share.
  8.      First make the dat line of the two hc595s ready,
  9.      then just shift it through the shift clk,when 8 bits are done,latch it through the latch clk.
  10. History:
  11.       <author>      <time>      <version >      <desc>

  12. ************************************************************/
  13. #ifndef _H_HC595_H_
  14. #define _H_HC595_H_
  15. #include "type.h"
  16. #ifdef __cplusplus
  17. extern "C" {
  18. #endif
  19. //some define of the shift clk io
  20. #define PORT_SHCP PORTE
  21. #define DDR_SHCP DDRE
  22. #define BIT_SHCP 5
  23. //some define of the latch clk io
  24. #define PORT_STCP PORTE
  25. #define DDR_STCP DDRE
  26. #define BIT_STCP 4
  27. //set & reset the shift clk
  28. #define SET_SHCP PORT_SHCP|=(0x01<<BIT_SHCP)
  29. #define RST_SHCP PORT_SHCP&=(~(0x01<<BIT_SHCP))
  30. //set & reset the latch clk
  31. #define SET_STCP PORT_STCP|=(0x01<<BIT_STCP)
  32. #define RST_STCP PORT_STCP&=(~(0x01<<BIT_STCP))
  33. //some define of the dat line,it's about the 1# hc595 which is used for segment driver
  34. #define PORT_DAT1 PORTE
  35. #define DDR_DAT1 DDRE
  36. #define BIT_DAT1 2
  37. #define SET_DAT1 PORT_DAT1|=(0x01<<BIT_DAT1)
  38. #define RST_DAT1 PORT_DAT1&=(~(0x01<<BIT_DAT1))
  39. //some define of the dat line,it's about the 2# hc595 which is used for bit driver
  40. #define PORT_DAT2 PORTE
  41. #define DDR_DAT2 DDRE
  42. #define BIT_DAT2 3
  43. #define SET_DAT2 PORT_DAT2|=(0x01<<BIT_DAT2)
  44. #define RST_DAT2 PORT_DAT2&=(~(0x01<<BIT_DAT2))
  45. //delay time slot
  46. #define DELAY595 do{\
  47. asm("nop");asm("nop");asm("nop");asm("nop");asm("nop");\
  48. asm("nop");asm("nop");asm("nop");asm("nop");asm("nop");\
  49. asm("nop");asm("nop");asm("nop");asm("nop");asm("nop");\
  50. }while(0)
  51. //this can genarate a positive pulse at the shift clk pin of the two hc595s
  52. #define SH_POSITIVE_PULSE do{\
  53. RST_SHCP;\
  54. DELAY595;\
  55. SET_SHCP;\
  56. DELAY595;\
  57. } while(0)
  58. //this can genarate a negtive  pulse at the latch clk pin of the two hc595s
  59. #define LT_NEGATIVE_PULSE do{\
  60. RST_STCP;\
  61. DELAY595;\
  62. SET_STCP;\
  63. DELAY595;\
  64. }while(0)

  65. void init_595(void);
  66. void driver_595(UINT8 dat1,UINT8 dat2);
  67. #ifdef __cplusplus
  68. }
  69. #endif
  70. #endif



  1. /************************************************************
  2. FileName: hc595.c
  3. Author: 原野之狼
  4. Version :V1.0      
  5. Date: 2009.12.17
  6. Description:

  7. History:
  8.       <author>      <time>      <version >      <desc>

  9. ************************************************************/
  10. #include "includes.h"

  11. /***********************************************************
  12. Description:
  13.   intial the port
  14. Modify Record:

  15. ***********************************************************/
  16. void init_595(void)
  17. {
  18. SET_SHCP;
  19. DDR_SHCP |= (0x01 << BIT_SHCP);

  20. SET_STCP;
  21. DDR_STCP |= (0x01 << BIT_STCP);
  22. SET_DAT1;
  23. DDR_DAT1 |= (0x01 << BIT_DAT1);

  24. SET_DAT2;
  25. DDR_DAT2 |= (0x01 << BIT_DAT2);
  26. }
  27. /***********************************************************
  28. Description:
  29.   driver the two hc595s
  30.   
  31. Input:
  32.   dat1:data of the 1# hc595
  33.   dat2:data of the 2# hc595
  34. Modify Record:

  35. ***********************************************************/
  36. void driver_595(UINT8 dat1,UINT8 dat2)
  37. {
  38. UINT8 i;

  39. for (i = 0; i < 8; i++)
  40. {
  41.   if (dat1&0x80)
  42.   {
  43.    SET_DAT1;
  44.   }
  45.   else
  46.   {
  47.    RST_DAT1;
  48.   }
  49.   
  50.   if (dat2&0x80)
  51.   {
  52.    SET_DAT2;
  53.   }
  54.   else
  55.   {
  56.    RST_DAT2;
  57.   }
  58.   
  59.   SH_POSITIVE_PULSE;
  60.   dat1 <<= 0x01;
  61.   dat2 <<= 0x01;
  62. }

  63. LT_NEGATIVE_PULSE;
  64. }

piter_tan 发表于 2009-12-18 16:27 | 显示全部楼层
:D支持一下!晚上再来看连载
韩秋婷 发表于 2009-12-18 16:49 | 显示全部楼层
硬件设计不合理
实现楼主的功能几毛钱就能搞定了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 在线客服 返回列表 返回顶部