该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

#include "msp430x14x.h"

#define uint unsigned int

#define uchar unsigned char

#define DQ_OUT P1DIR|=BIT0

#define DQ_IN P1DIR&=~BIT0

#define DQ_LOW P1OUT&=~BIT0

#define DQ_HIGH P1OUT|=BIT0

#define DQ_DATA P1IN&BIT0

//共阳数码管编码表

uchar Code[18]={0xC0,0xF9,0xA4,0xB0,//0,1,2,3

0x99,0x92,0x82,0xF8,//4,5,6,7

0x80,0x90,0x88,0x83,//8,9,A,b

0xC6,0xA1,0x86,0x8E,//C,d,E,F

0xBF,0xFF};//-,全灭

uchar Bit[4]={0,0,0,17}; //数码管各位显示的数字

uchar BitCode=0x01; //数码管位码初值

uchar wei[]={0x01,0x02,0x04,0x08};

uint j=0;

uint l=0;

uchar MSB; //温度高字节

uchar LSB; //温度低字节

int t1=0; //温度整数部分数值

uint t2=0; //温度小数部分数值

uchar flag; //负温度标志

//时钟初始化函数

void InitClock(void){

BCSCTL1=RSEL2+RSEL1+RSEL0;//XT2 开启 LFXT1 工作在低频模式 ACLK

//不分频 最高的标称频率

DCOCTL=DCO2+DCO1+DCO0;//DCO 为最高频率

do{

IFG1&=~OFIFG;//清除振荡器失效标志

for(uint i=255;i>0;i--);

}while(IFG1&OFIFG);//判断XT2 是否起振

BCSCTL2=SELM1+SELS;//MCLK SMCLK 时钟源为TX2CLK 不分频

}

//端口初始化函数

void InitPort(void){

P2SEL=0x00;//P2 口所有引脚设置为一般的IO 口

P3SEL=0x00;//P3 口所有引脚设置为一般的IO 口

P2DIR=0xFF;//P2 口所有引脚设置为输出方向

P3DIR=0xFF;//P3 口所有引脚设置为输出方向

P2OUT=0x00;//P2 口先输出低电平

P3OUT=0x80;//P3 口先输出低电平

P5SEL&=~BIT7;//P5. 设7置为一般的IO 口

P5DIR|=BIT7;//P5.7 设置为输出方向

P5OUT&=~BIT7;//P5.7 输出低电平来使能74HC573 来驱动数码管

}

//ms 级延时子程序

void DelayMs(uint ms){

while(ms--){

for(uint i=0;i<700;i++);

}

}

//数码管扫描显示程序

void Display(void){

for(uchar i=0;i<4;i++){

P3OUT=BitCode; //输出位码

if(i==3){ //输出段码,如果第三位显示小数点

P2OUT=Code[Bit[i]]&0x7F;

}else{

P2OUT=Code[Bit[i]];

}

BitCode<<=1;//位码右移一位

if(BitCode==0x10) BitCode=0x01;

DelayMs(2); //延时1ms

//P2OUT=0XFF;

}

}

//10us 级延时子程序

void Delayus(uint us){

while(us--){

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

_NOP();_NOP();_NOP();_NOP();_NOP();

}

}

//初始化DS18B20

void DS18B20Init(void){

DQ_OUT;//设置为输出方向

DQ_LOW;//拉低总线

Delayus(50);

DQ_HIGH;//释放总线

Delayus(6);

DQ_IN;//设置为输入方向

while(DQ_DATA);//等待应答信号

while(~DQ_DATA);//等待释放总线

}

//读一个字节

uchar ReadByte(void){

uchar i;

uchar ReadData=0;

for(i=0;i<8;i++){

DQ_OUT;

DQ_LOW;

ReadData>>=1;

DQ_HIGH;

Delayus(1);

DQ_IN;

if(DQ_DATA) ReadData|=0x80;

Delayus(6);

}

return ReadData;

}

//写一个字节

void WriteByte(uchar WriteData){

uchar i;

uchar tmpData;

for(i=0;i<8;i++){

tmpData=WriteData&0x01;

WriteData>>=1;

DQ_OUT;

DQ_LOW;

if(tmpData){

DQ_HIGH;

}

else{

DQ_LOW;

}

Delayus(5);

DQ_HIGH;

}

}

//温度计算程序

void GetT(){

if((MSB&0xF0)>0){ //判断是否为负温度

flag=1;

}else{

flag=0;

}

if(flag){ //如果为负温度取反加1

MSB=~MSB;

LSB=~LSB+1;

}

t1=MSB<<4; //得到温度整数部分

t1|=(LSB>>4);

t2=(uint)((LSB&0x0F)*0.0625*10000); //得到温度小数部分并扩大10000 倍

//计算各位数码管要显示的数值

if(flag){

Bit[1]=16; //如果为负温度则显示"-"

}else{

Bit[1]=t1/100;

}

Bit[2]=t1%100/10;

Bit[3]=t1%10;

//Bit[4]=t2/1000;

//Bit[5]=t2%1000/100;

//Bit[6]=t2%100/10;

//Bit[7]=t2%10;

}

void main(){

WDTCTL=WDTPW+WDTHOLD;//关闭看门狗

InitClock();

InitPort();

_DINT();//关闭中断

j=0;l=0;

while(1){

DS18B20Init();

WriteByte(0xCC); //跳过ROM 配置

WriteByte(0x44);//启动温度转换

DS18B20Init();

WriteByte(0xCC);

WriteByte(0xBE); //读温度寄存器

LSB=ReadByte(); //读温度数据低字节

MSB=ReadByte(); //读温度数据高字节

GetT(); //计算温度

Display();

}

}

c语言程序加仿真,求助。C语言的程序和仿真相关推荐

  1. c语言图片加水印,[求助]C语言 bmp文件加上水印

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 给一张图片加水印后存起来然后显示出来 有部分源码 求高手帮忙完成~! #include #include /* structure defiens bit ...

  2. c语言visit函数作用,[求助]二叉树遍历的程序里面的visit函数如何实现

    [求助]二叉树遍历的程序里面的visit函数如何实现 我在没懂的后面加注释 希望大家指教 #include #include #define MAXSIZE 100 typedef struct bi ...

  3. linux 程序加启动项,linux 让一个程序开机自启动并把一个程序加为服务

    linux 让一个程序开机自启动并把一个程序加为服务 來源:互聯網  2016-05-27 08:31:00  評論 linux 让一个程序开机自启动并把一个程序加为服务 本文以tomcat7为例 首 ...

  4. 怎么给c语言程序加个个密码,C语言对文件加上密码

    博主刚刚学完C语言的基础语法知识 一直想写一些自己的程序 而博主又是一个很懒的人 特别是对于记忆的东西很懒 我平时都把重要的东西放在一个txt文档里面 于是我便想对我的那个文件进行加密码 没错就是加密 ...

  5. c语言程序 三角形问题,[求助]C语言问题(定义三角形结构)

    以下是引用honkerman在2006-9-11 21:04:13的发言: 题目是这样的: 定义一个三角形结构,包括三个成员,分别为三角形的三条边.编写一个函数,用来判断三角形的类型是等边三角形.等腰 ...

  6. c语言读取png文件大小,求助: C语言- 利用libpng读取png大小,并转换为jpg类型图片...

    大家好, 最近研究C语言图像处理这方面遇到一个难题,详情如下: 目标: 将png类型图片的信息读入内存,提取所需要的数据并保存,然后转换为如jpg等其它图片格式. 1. libpng库已经装好,通过m ...

  7. c语言图片见水印,[求助]C语言 bmp文件加上水印

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 给一张图片加水印后存起来然后显示出来 有部分源码 求高手帮忙完成~! #include #include /* structure defiens bit ...

  8. c语言开发 .c .h,求助C语言大佬 , 只会写到一个.c文件里 ,不会用.h头文件

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 简答题] 实验任务:学生成绩统计 从键盘输入一个班(全班最多不超过30人)学生某门课的成绩,当输入成绩为负值时,输入结束,分别实现下列功能: (1)统计不 ...

  9. c语言怎么加分数,用C语言编程平均分数

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 当个反面典型,让大家见识下丑陋无比的程序好了,主要是想练练打字,HOHO.应该用二维数组且全部函数化的,rand的%后面或是101或是100,可能和编译器 ...

  10. c语言sleep延迟小数,求助C语言Sleep延迟输入问题

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 printf(" ######################################\n"); for(i=0;i<= ...

最新文章

  1. php 不可以连接远程mysql数据库
  2. SQL Server 监控系列(文章索引)
  3. golang 指定范围 生成随机数
  4. iis占用服务器内存,W3wp.exe 进程占用内存高消耗CPU近100%导致网站反应速度缓慢的解决方案...
  5. 深度学习算法原理_用于对象检测的深度学习算法的基本原理
  6. leetcode1338. 数组大小减半(贪心算法)
  7. 【OS学习笔记】十七 保护模式五:保护模式下如何进行内存保护 与 别名段的意义与作用
  8. luogu P1659 养猪 dp 好理解
  9. PHP 错误与异常 笔记与总结(12 )异常
  10. OpenCV环境搭建(一)
  11. Mysql查询高速缓存区
  12. 租用服务器怎么免去后顾之忧?
  13. JavaMail操作的总结(2)
  14. 程序员代码面试指南第二版 8.单调栈结构(普通及进阶)
  15. WPF实例系列一:登录、注册界面设计
  16. 无线网络密码破解方法大全(附破解软件下载)
  17. negative和passive的反义词_消极的近义词和反义词
  18. 产品沉思录精选:如何像管理金融投资组合一样来管理知识?
  19. 使用python做王者荣耀挂机刷金币脚本
  20. Google网络硬盘GDrive在几个月内即将成真?!

热门文章

  1. 再谈poj2965(高效算法)
  2. ajax 调用后台的方法
  3. 一个美国老工程师的心理话: 给年轻工程师的十大忠告
  4. 机器学习实战_09_树回归_源代码错误修正
  5. ASP.NET MVC 使用 FluentScheduler 定时器计划任务
  6. 存储过程或视图的字符串查询
  7. python算法与数据结构-数据结构中常用树的介绍(45)
  8. 反思转变:多努力以积累  多动脑以应变
  9. Redis基础高级学习笔记
  10. tankwar的java坦克子弹撞墙_TankWar 单机(JAVA版)版本2.0.5 坦克撞墙的处理