c语言程序加仿真,求助。C语言的程序和仿真
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
#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语言的程序和仿真相关推荐
- c语言图片加水印,[求助]C语言 bmp文件加上水印
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 给一张图片加水印后存起来然后显示出来 有部分源码 求高手帮忙完成~! #include #include /* structure defiens bit ...
- c语言visit函数作用,[求助]二叉树遍历的程序里面的visit函数如何实现
[求助]二叉树遍历的程序里面的visit函数如何实现 我在没懂的后面加注释 希望大家指教 #include #include #define MAXSIZE 100 typedef struct bi ...
- linux 程序加启动项,linux 让一个程序开机自启动并把一个程序加为服务
linux 让一个程序开机自启动并把一个程序加为服务 來源:互聯網 2016-05-27 08:31:00 評論 linux 让一个程序开机自启动并把一个程序加为服务 本文以tomcat7为例 首 ...
- 怎么给c语言程序加个个密码,C语言对文件加上密码
博主刚刚学完C语言的基础语法知识 一直想写一些自己的程序 而博主又是一个很懒的人 特别是对于记忆的东西很懒 我平时都把重要的东西放在一个txt文档里面 于是我便想对我的那个文件进行加密码 没错就是加密 ...
- c语言程序 三角形问题,[求助]C语言问题(定义三角形结构)
以下是引用honkerman在2006-9-11 21:04:13的发言: 题目是这样的: 定义一个三角形结构,包括三个成员,分别为三角形的三条边.编写一个函数,用来判断三角形的类型是等边三角形.等腰 ...
- c语言读取png文件大小,求助: C语言- 利用libpng读取png大小,并转换为jpg类型图片...
大家好, 最近研究C语言图像处理这方面遇到一个难题,详情如下: 目标: 将png类型图片的信息读入内存,提取所需要的数据并保存,然后转换为如jpg等其它图片格式. 1. libpng库已经装好,通过m ...
- c语言图片见水印,[求助]C语言 bmp文件加上水印
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 给一张图片加水印后存起来然后显示出来 有部分源码 求高手帮忙完成~! #include #include /* structure defiens bit ...
- c语言开发 .c .h,求助C语言大佬 , 只会写到一个.c文件里 ,不会用.h头文件
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 简答题] 实验任务:学生成绩统计 从键盘输入一个班(全班最多不超过30人)学生某门课的成绩,当输入成绩为负值时,输入结束,分别实现下列功能: (1)统计不 ...
- c语言怎么加分数,用C语言编程平均分数
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 当个反面典型,让大家见识下丑陋无比的程序好了,主要是想练练打字,HOHO.应该用二维数组且全部函数化的,rand的%后面或是101或是100,可能和编译器 ...
- c语言sleep延迟小数,求助C语言Sleep延迟输入问题
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 printf(" ######################################\n"); for(i=0;i<= ...
最新文章
- php 不可以连接远程mysql数据库
- SQL Server 监控系列(文章索引)
- golang 指定范围 生成随机数
- iis占用服务器内存,W3wp.exe 进程占用内存高消耗CPU近100%导致网站反应速度缓慢的解决方案...
- 深度学习算法原理_用于对象检测的深度学习算法的基本原理
- leetcode1338. 数组大小减半(贪心算法)
- 【OS学习笔记】十七 保护模式五:保护模式下如何进行内存保护 与 别名段的意义与作用
- luogu P1659 养猪 dp 好理解
- PHP 错误与异常 笔记与总结(12 )异常
- OpenCV环境搭建(一)
- Mysql查询高速缓存区
- 租用服务器怎么免去后顾之忧?
- JavaMail操作的总结(2)
- 程序员代码面试指南第二版 8.单调栈结构(普通及进阶)
- WPF实例系列一:登录、注册界面设计
- 无线网络密码破解方法大全(附破解软件下载)
- negative和passive的反义词_消极的近义词和反义词
- 产品沉思录精选:如何像管理金融投资组合一样来管理知识?
- 使用python做王者荣耀挂机刷金币脚本
- Google网络硬盘GDrive在几个月内即将成真?!
热门文章
- 再谈poj2965(高效算法)
- ajax 调用后台的方法
- 一个美国老工程师的心理话: 给年轻工程师的十大忠告
- 机器学习实战_09_树回归_源代码错误修正
- ASP.NET MVC 使用 FluentScheduler 定时器计划任务
- 存储过程或视图的字符串查询
- python算法与数据结构-数据结构中常用树的介绍(45)
- 反思转变:多努力以积累 多动脑以应变
- Redis基础高级学习笔记
- tankwar的java坦克子弹撞墙_TankWar 单机(JAVA版)版本2.0.5 坦克撞墙的处理