| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1047 人关注过本帖
标题:拜托大神帮帮忙,想了好久不知道哪出错了,51单片机C语言编程的
取消只看楼主 加入收藏
大眼萌
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2015-12-28
收藏
 问题点数:0 回复次数:1 
拜托大神帮帮忙,想了好久不知道哪出错了,51单片机C语言编程的
哪位大神能帮帮忙,我设计了个温度报警系统,可是报警不管用,单片机的P3.0接口没有高低电平,与蜂鸣器连接没有用
下面是部分程序
void ber(int s,int x) //这是报警的程序,sx是上限,xx是下限,BJ就是报警的接口,想着应该BJ=0,P3.0高电平,BJ=1,P3.0低电平,结果P3.0一直是高的
{                     
    sx=SX*10;
    xx=XX*10;
BJ=!s>sx;
BJ=!x>sx;
BJ=!s<xx;
BJ=!x<xx;
}
搜索更多相关主题的帖子: 报警系统 单片机 C语言 蜂鸣器 高电平 
2015-12-28 18:26
大眼萌
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2015-12-28
收藏
得分:0 
这是全部程序,    求哪里出错了,报警器不作用   
#include<reg51.H>
#include<absacc.H>
#include <intrins.h>
#include<stdio.h>
#define uchar unsigned char
#define uint unsigned int  
sbit K1=P3^5;
sbit K2=P3^6;
sbit K3=P3^7;
sbit K4=P3^4;
sbit BJ=P3^0;
uchar num=50;
extern int SX;
extern int XX;
int sx,xx;
uchar code TAB[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xc6}; //数字
uchar code TAB1[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};      //小数     
sbit DQ=P3^3; //1温度输入口
sbit DE=P3^2;//2温度输入口
void delay(uint i)   //延时
 {
        while(i--);
 }
void DelayMS(uint ms)  //DS延迟12秒
 {
        uchar i;
        while(ms--)
            for(i=0;i<120;i++);
 }
void display(int k)//数码管显示,DS18B20一输出温度值,p0输出段码。
 {
    P2=0x08;  //数码管倒着00001000,p2位码
        P0=0xc6;//个位
        DelayMS(5);  
    P2=0x04;
        P0=TAB[k/10%10]; //十位
        DelayMS(7);
    P2=0x02;
        P0=TAB1[k/100%10];//百位,采用小数码   
        DelayMS(7);  
    P2=0x01;
        P0=TAB[k/1000]; //千位
        DelayMS(7);  
    }  
void play(int k)//数码管显示,DS18B20二温度输出,P1输出段码。
    {
     P2=0x80;  
        P1=0xc6; //个
        DelayMS(5);  
     P2=0x40;
        P1=TAB[k/10%10]; //十
        DelayMS(7);
     P2=0x20;
        P1=TAB1[k/100%10];  //百
        DelayMS(7);  
     P2=0x10;
        P1=TAB[k/1000]; //千
        DelayMS(7);   
    }  
void init_DS() //B20一复位
    {
        uchar x=0;
        DQ=1;  
     delay(8);
        DQ=0;  
     delay(85);
        DQ=1;  
     delay(14);
        x=DQ;
     delay(20);
    }   
void init_DX() //B20二复位
    {
        uchar x=0;
        DE=1;  
     delay(8);
        DE=0;  
     delay(85);
        DE=1;  
     delay(14);
        x=DE;
     delay(20);
    }   
 
Read(void) //18B20一写字节
    {  
        uchar i=0;
        uchar dat=0;
        for(i=8;i>0;i--)
            {  
                DQ=1;   
                delay(1);  
                DQ=0;   
                dat>>=1;   
                DQ=1;   
                if(DQ)   
                    dat|=0x80;
                delay(4);   
            }
        return(dat);
    }
rd(void)  //18B20二写字节
    {
        uchar j=0;
        uchar date=0;
        for(j=8;j>0;j--)
            {
                DE=1;   
                delay(1);  
                DE=0;   
                date>>=1;   
                DE=1;   
                if(DE)   
                    date|=0x80;
                delay(4);   
            }
     return(date);
  }
 
write(uchar dat)// 18B20一读字节
    {  
        uchar i=0;
        for(i=8;i>0;i--)  
            {   
                DQ=0;   
                DQ=dat&0x01;
                delay(5);  
                DQ=1;
                dat>>=1;     
            }
        delay(4);
  }
wr(uchar date) //18B20二读字节
    {
        uchar j=0;
        for(j=8;j>0;j--)  
            {  
                DE=0;   
                DE=date&0x01;
                delay(5);  
                DE=1;
                date>>=1;     
            }
        delay(4);
  }
 
Readtem(void)//读出温度函数一
    {
        uchar a=0;
        uchar b=0;   
    uchar t=0,t1;
      t=0;
        init_DS();
        write(0xcc);//skip ROM
        write(0x44); //发转换命令
        delay(125);  
        init_DS();  //总线复位   
        write(0xcc); //发skip ROM命令
        write(0xbe); //发读命令
        a=Read();//温度低八位
        b=Read();//温度高八位
        t1=(a&0x0f)*0.0625;
        t=((b<<4)|(a>>4));
        if(t>128)  
            {   
                t=~t+1;
            }  
        t=t+t1;  
        return(t);
    }


rtem(void)//读出温度函数二
    {
        uchar c=0;
        uchar d=0;   
        uchar T=0,T1;
        T=0;
        init_DX();  
        wr(0xcc);
        wr(0x44);
        delay(125);  
        init_DX();  
        wr(0xcc);
        wr(0xbe);
        c=rd();//低八位
        d=rd();//高八位
        T1=(c&0x0f)*0.0625;
        T=((d<<4)|(c>>4));
        if(T>128)  
            {   
                T=~T+1;
            }  
        T=T+T1;  
        return(T);  
    }

void shangxian(int m)//上限输出,在B20一中输出
{
     P2=0x08;  
     P0=TAB[m%10]; //个
     DelayMS(5);  
   P2=0x04;
     P0=TAB1[m/10%10]; //十
     DelayMS(7);
     P2=0x02;
     P0=TAB[m/100%10];   //百
     DelayMS(7);  
     P2=0x01;
     P0=TAB1[5];//千,规定为"S."
     DelayMS(7);
}

void xiaxian(int n)//下限输出,B20一输出
 {
   
  P2=0x08;  
  P0=TAB[n%10];
  DelayMS(5);  
  P2=0x04;
  P0=TAB1[n/10%10];
  DelayMS(7);
  P2=0x02;
  P0=TAB[n/100%10];   
  DelayMS(7);  
  P2=0x01;
  P0=TAB1[5];//千,规定为"S."
  DelayMS(7);
 }
void Keyscan()//按键设置
{
    if(K1==0)//K1加
    {
        DelayMS(2);//延时去抖
        if(K1==0)
            {
                while(!K1);//等待按键释放
                num++;//如果数值键被按下数值增加
                if(num==120)//num==120时,复原num=50
                    num=50;
            }
   
    }
    if(K2==0)//K2减
    {
        DelayMS(2);
        if(K2==0)
            {
                while(!K2);
                num--;
                if(num==20)
                num=50;
            }
    }
    if(K3==1)//转换上限显示
    {
        DelayMS(2);
        if(K3==1)
        {
            while(!K3);
            num++;
            if(num%2==0)
            num=0;
        }   
        if(K4==1)//转换下限显示
        {
            DelayMS(2);
            if(K4==1)
                {
                    while(!K4);
                    num++;
                    if(num%2==0)
                    num=0;
                }
        }
    }
}
   
void ber(int s,int x) //
{
    sx=SX*10;
    xx=XX*10;
BJ=!s>sx;
BJ=!x>sx;
BJ=!s<xx;
BJ=!x<xx;
}   
                 
void main()
{  
    float tp;
  float TP;
  int BJ=1;
    while(1)
    {
            if(K3==1)  
        {

            tp=Readtem();
            TP=rtem();
            tp=tp*100;
            TP=TP*100;
            display(tp);
            play(TP);

            }
        else if(K4==0)
        {
            XX=200;
            Keyscan();
            XX=XX+(num-50)*10;
            xiaxian(XX);
        }            
        else
        {   
            SX=300;
            Keyscan();
            SX=SX+(num-50)*10;
            shangxian(SX);
        }
    }
    ber(tp,TP);
}
2015-12-28 18:38
快速回复:拜托大神帮帮忙,想了好久不知道哪出错了,51单片机C语言编程的
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.030948 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved