找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3392|回复: 0
打印 上一主题 下一主题
收起左侧

基于PICf16877的ADC源码

[复制链接]
跳转到指定楼层
楼主
国内关于PIC的内容太少了, 希望大家都相互交流学习.


单片机源程序如下:
  1. //从零到项目开发学PIC单片机与C语言技术视频教程配套实验源码
  2. #include<pic.h>
  3. #define uchar unsigned char
  4. #define uint  unsigned int
  5. __CONFIG(0x3B31);
  6. const uchar table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
  7.                         0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
  8. const uchar table1[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,
  9.                         0x87,0xff,0xef};
  10. void delay(uint x);
  11. void init();
  12. void disp(uchar num1,uchar num2,uchar num3,uchar num4,uchar num5);
  13. void disp1(uchar num1,uchar num2,uchar num3,uchar num4);
  14. uint get_ad();
  15. void main()
  16. {
  17.         uint lednum,u1,u2,r1,r2;
  18.           float n;
  19.         uchar a1,a2,a3,a4,a5;
  20.         init();
  21.         while(1)
  22.         {/*
  23.                 lednum=get_ad();
  24.                 a1=lednum/1000;
  25.                 a2=lednum%1000/100;
  26.                 a3=lednum%100/10;
  27.                 a4=lednum%10;
  28.                 disp(a1,a2,a3,a4);
  29.             */
  30.                           lednum=get_ad();
  31.                    // n=(lednum*10)/(10240-lednum);
  32.                     n=lednum;
  33.                     //u1=5120-lednum;
  34.                     //r1=u2/u1;
  35.                    // r2=r2*1000;
  36.                    // r2=lednum;
  37.                     //r1=u1/i;
  38.                    // r2=lednum*10/i*10
  39.                    // r2=i;
  40.                    // i=i*10000
  41.                    // r2=lednum;
  42.                    // r2=u2/i;
  43.                     //i=(5000-lednum)/10000;
  44.                    // r2=lednum/i;
  45.                     //lednum=(int)r2;
  46.                    // n=n*1000;
  47.                     r2=n;
  48.                     //r2=lednum;
  49. /*                  
  50.                 a1=r2/10000;
  51.                 a2=r2%10000/1000;
  52.                 a3=r2%1000/100;
  53.                 a4=r2%100/10;
  54.                     a5=r2%10;
  55.                 disp1(a1,a2,a3,a4,A5);
  56. */
  57.                     a1=r2/1000;
  58.                 a2=r2%1000/100;
  59.                 a3=r2%100/10;
  60.                 a4=r2%10;
  61.                 disp1(a1,a2,a3,a4);
  62.         }       
  63. }
  64. void delay(uint x)
  65. {
  66.         uint a,b;
  67.         for(a=x;a>0;a--)
  68.                 for(b=110;b>0;b--);
  69. }
  70. void init()
  71. {
  72.         TRISA=0x01;//0000 0001
  73.         TRISD=0;
  74.         PORTA=0;
  75.         PORTD=0;
  76.           TRISB=0;
  77.         PORTB=0;
  78.         ADCON0=0x41;
  79.         ADCON1=0x80;
  80.         delay(10);
  81. }
  82. uint get_ad()
  83. {
  84.         uint adval;
  85.         float advalf;
  86.         GO=1;
  87.         while(GO);
  88.         adval=ADRESH;//00000000 00000011
  89.         adval=adval<<8|ADRESL;//00000011 11111111
  90.         //advalf=adval/1023.0*5.0;//==2.3843
  91.           //advalf=adval/1023.0*5.0;//==2.3843
  92.         //adval=advalf*1000;
  93.          // adval=adval*1024;
  94.           adval=adval;
  95.         return (adval);       
  96. }
  97. void disp(uchar num1,uchar num2,uchar num3,uchar num4,uchar num5)
  98. {
  99.         PORTD=table1[num1];//显示第一个数码管
  100.         PORTA=0x20;//0010 0000
  101.         delay(2);
  102.         PORTD=table[num2];//显示第二个数码管
  103.         PORTA=0x10;//0001 0000
  104.         delay(2);
  105.         PORTD=table[num3];//显示第三个数码管
  106.         PORTA=0x08;//0000 1000
  107.         delay(2);
  108.         PORTD=table[num4];//显示第四个数码管
  109.         PORTA=0x04;//0000 0100
  110.         delay(2);
  111.           PORTD=table[num5];//显示第四个数码管
  112.         PORTB=0x20;//0000 0100
  113.         delay(2);
  114. }
  115. void disp1(uchar num1,uchar num2,uchar num3,uchar num4)
  116. ……………………

  117. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
ADC.zip (110.4 KB, 下载次数: 31)




评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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