pic16f877a的AD实验学习
一、主函数
- //采集AD值
- #include <pic.h>
- #include "ad.h"
- #include "usart.h"
- __CONFIG(0xFF32);
- const uchar disp[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
- 0x07,0x7f,0x6f};
- //延时函数
- void delayms(uint x)
- {
- uint j,k;
- for(j=x;j>0;j--)
- for(k=110;k>0;k--);
- }
- //显示4位,低位数码管显示不正常
- void display(uint x)
- {
- PORTD= disp[x/1000]|0x80;
- PORTA= 0x10;
- delayms(2);
- PORTD= disp[x/100%10];
- PORTA= 0x08;
- delayms(4);
- PORTD= disp[x/10%10];
- PORTA= 0x04;
- delayms(2);
- PORTD= disp[x%10];
- PORTA= 0x02;
- delayms(2);
- }
- //初始化IO
- void init()
- {
- TRISA = 0x01; //RA0 input mode
- TRISC = 0xff; //RC output mode
- TRISD = 0;
- PORTC = 0x01;
- ADCON0 = 0x41; //ADCS1:ADCS0=01,AN0,,A/D On
- ADCON1 = 0x8E; //right justified,ADCS2=0,1110
- delayms(10);
- }
- //获取AD值
- uint getad()
- {
- uint adval;
- float advalf;
- GO = 1;
- while(GO);
- adval = ADRESH;
- adval = adval<<8|ADRESL;
- advalf = adval/1023.0*5.0; //转换成电压
- adval = (uint)(advalf*1000); //转换成4位整型
- return (adval);
- }
- void main()
- {
- uint i = 0;
- uint temp;
- init();
- usart_init();
- while(1)
- {
- temp = getad();
- display(temp);
- if(i == 100)
- {
- usart_tx(temp>>8);
- usart_tx(temp);
- i=0;
- }
- delayms(5);
- i++;
- }
- }
二、usart函数
- #include <pic.h>
- #include "usart.h"
- //串口初始化
- void usart_init(void)
- {
- SPBRG = 0xC; //波特率19200
- TXSTA = 0x24; //开启发送,高速模式
- RCSTA = 0X90; //使能TXRX引脚,接收到CREN直到被清零
- RCIE = 0X1; //使能接受中断
- GIE = 0X1; //开启总中断
- PEIE = 0X1; //开启串口中断
- }
- void interrupt usart(void)
- {
- if(RCIE && RCIF)
- {
- TXREG = RCREG; //返回接收的数据
- }
- }
- void usart_tx(unsigned char date)
- {
- TXREG = date;
- while(TRMT!=1);
- }
pic16f877a的AD实验学习的更多相关文章
- pic16f877a的PWM实验学习
遇到的问题,编译时找不到TRISC.一开始以为头文件中没有定义,发现定义了. 所以是自己创建工程的时候,设备类型选错了. #include <pic.h> __CONFIG(0xFF32) ...
- Sharepoint2013 AD组用户不同步
背景: SP2013列表库使用AD安全组授权访问,向AD安全组添加一个用户A,在Sharepoint AD同步(增量和完全)后,用户A仍然无法访问列表库:原因: 参考:安全令牌上的缓存 SP2013 ...
- freeradius整合AD域作anyconncet认证服务器
一.服务器要求 Radius服务器:centos6.6.hostname.selinux disabled.stop iptables AD域服务器:Windows Server 2008 R2 E ...
- 讲座:Modeling User Engagement for Ad and Search
讲座:http://bdai.ruc.edu.cn/?p=118 Modeling User Engagement for Ad and Search ppt 链接: Dr. Ke(Adam) Zho ...
- Azure AD Connect 手动同步
我们目前采用工具Azure AD Connect 目录同步工具将本地域控制器的用户信息同步至office365和Azure 在之前目录同步工具中使用Windows 任务计划程序或单独的 Windows ...
- SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问
delphi ado 跨数据库访问 语句如下 ' and db = '帐套1' 报错内容是:SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATE ...
- 如何查看/统计当前AD域控制器的活动用户?
最近公司想知道某台AD域控制器上当前连接了多少活动用户? 此前个人只知道以下不是非常完善且统计起来比较麻烦的方法: 方法1:查看共享会话数.(不完全准确) 方法2:查看当前的DNS记录.(这种方法统计 ...
- AD域-让共享目录只显示用户有权限访问的文件夹
问题: 在AD域中,我们一般都会用到共享,如果有很多部门,我们可能还会按部门.职位配置权限.比如CSD,IT,PA等,但文件夹一多,用户看着就头大,而且用户没权限访问的文件夹误点击进去还会提示无权限访 ...
- AD域的安装(在Windows Server 2003中安装Active Directory)
在Active Directory中提供了一组服务器作为身份验证服务器或登录服务器,这类服务器被称作域控制器(Domain Controller,简称DC).建立一个AD域的过程实际就是在一台运行Wi ...
随机推荐
- idea将本地项目推送到git远程库
如何将本地项目推送到github远程仓库? 1. 在github上创建一个仓库,取名mybatis 2. 在idea中将项目交由git管理 注意,文件名会变红了, 说明这些文件在git工作区,但还没规 ...
- 【Gitlab】git clone http连接,带用户名和密码
test项目在gitlab的http请求的url: http://gitlab.com/test.git 用以下方式请求不需要再输入用户名和密码 git clone http://username: ...
- Python读取文件时出现UnicodeDecodeError 'gbk' codec can't decode byte 0x80 in position x
Python在读取文件时 with open('article.txt') as f: # 打开新的文本 text_new = f.read() # 读取文本数据出现错误: UnicodeDecode ...
- 启动Nginx、查看nginx进程、nginx帮助命令、Nginx平滑重启、Nginx服务器的升级
1.启动nginx的方式: cd /usr/local/nginx ls
- 颁发不受浏览器信任的SSL证书
xshell登录服务器,使用openssl生成RSA密钥及证书 # 生成一个RSA密钥 $ openssl genrsa -des3 -out tfjybj.key 1024 # 生成一个证书请求$ ...
- Nuget-Doc:NuGet 介绍
ylbtech-Nuget-Doc:NuGet 介绍 NuGet 是适用于 .NET 的包管理器. 它使开发人员能够创建.共享和使用有用的 .NET 库. NuGet 客户端工具可生成这些库并将其作为 ...
- 记录一些比较长的adb命令,复制用
adb shell content query --uri content://settings/secure --projection value --where "name=\'andr ...
- Iconv作用以及安装问题解决
当我们在使用Window操作系统的时候,可能使用最多的文本格式就是txt了,但是当我们将Window平台下的txt文本文档拷贝到Linux平台下查看时,发现原来的中文全部变成了乱码.没错, 引起这个结 ...
- Html5 学习笔记 【PC固定布局】 实战2 导航栏搜索区域
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8& ...
- left join right inner join 区别
连表查询 select a, b, c from table_a tb_a left (right) join table_b tb_b on tb_a.id = tb_b.id left : tab ...