protues没响应怎么办

2019-07-18 09:45发布

123.png

    display();   
}
}
        /*********延时K*1ms,12.000mhz**********/
void delay(uint k)
{
    uint i,j;
    for(i=0;i<k;i++)
    {
        for(j=0;j<60;j++)
         {;}
    }
}
/**********写指令到ICM子函数************/
void WriteCommandLCM(uchar WCLCM,uchar BusyC)
{
if(BusyC) lcd_wait();
DATAPORT=WCLCM;
LCM_RS=0;                   // 选中指令寄存器
LCM_RW=0;                // 写模式
LCM_EN=1;   
_nop_();   
_nop_();
_nop_();
LCM_EN=0;

}
/**********写数据到LCM子函数************/
void WriteDataLCM(uchar WDLCM)
{
lcd_wait( );             //检测忙信号   
DATAPORT=WDLCM;
LCM_RS=1;                // 选中数据寄存器
LCM_RW=0;             // 写模式
LCM_EN=1;
_nop_();
_nop_();
_nop_();
LCM_EN=0;
}
/***********lcm内部等待函数*************/
void lcd_wait(void)
{
DATAPORT=0xff;      //读LCD前若单片机输出低电平,而读出LCD为高电平,则冲突,proteus仿真会有显示逻辑黄 {MOD}
LCM_EN=1;
LCM_RS=0;   
LCM_RW=1;   
_nop_();
_nop_();
_nop_();
while(DATAPORT&BUSY)  
{  LCM_EN=0;
_nop_();
_nop_();
LCM_EN=1;
_nop_();
_nop_();
}  
LCM_EN=0;

}
/**********LCM初始化子函数***********/
void initLCM( )
{   
DATAPORT=0;
delay(15);
WriteCommandLCM(0x38,0);    //三次显示模式设置,不检测忙信号
delay(5);
WriteCommandLCM(0x38,0);
delay(5);
WriteCommandLCM(0x38,0);
delay(5);
WriteCommandLCM(0x38,1);    //8bit数据传送,2行显示,5*7字型,检测忙信号
WriteCommandLCM(0x08,1);    //关闭显示,检测忙信号
WriteCommandLCM(0x01,1);    //清屏,检测忙信号
WriteCommandLCM(0x06,1);    //显示光标右移设置,检测忙信号
WriteCommandLCM(0x0c,1);    //显示屏打开,光标不显示,不闪烁,检测忙信号
}
/****显示指定坐标的一个字符子函数****/
void DisplayOneChar(uchar X,uchar Y,uchar DData)
{
Y&=1;
X&=15;
if(Y)X|=0x40;               //若y为1(显示第二行),地址码+0X40
X|=0x80;                    //指令码为地址码+0X80
WriteCommandLCM(X,0);
WriteDataLCM(DData);
}
/*******显示指定坐标的一串字符子函数*****/

void DisplayListChar(uchar X,uchar Y,uchar code *DData)
{
uchar ListLength=0;
Y&=0x01;
X&=0x0f;
while(X<16)
{
DisplayOneChar(X,Y,DData[ListLength]);
ListLength++;
X++;
    }
}
/*****************系统显示子函数*****************/
void display(void)
{
uchar flagdat;
WriteCommandLCM(0x0c,1);        //显示屏打开,光标不显示,不闪烁,检测忙信号
DisplayListChar(0,0,str0);
DisplayListChar(0,1,str1);
DisplayOneChar(7,0,press_bai+0x30);
DisplayOneChar(8,0,press_shi+0x30);
DisplayOneChar(9,0,press_ge +0x30);
DisplayOneChar(11,0,press_dot+0x30);
disdata[0]=tvalue/1000+0x30;//百位数
disdata[1]=tvalue%1000/100+0x30;//十位数
disdata[2]=tvalue%100/10+0x30;//个位数
disdata[3]=tvalue%10+0x30;//小数位
if(tflag==0)
flagdat=0x20;//正温度不显示符号
else
flagdat=0x2d;//负温度显示负号:-
if(disdata[0]==0x30)
{
disdata[0]=0x20;//如果百位为0,不显示
if(disdata[1]==0x30)
{
disdata[1]=0x20;//如果百位为0,十位为0也不显示
}
}
WriteCommandLCM(0xc3,0xc3);
WriteDataLCM(flagdat);//显示符号?
WriteCommandLCM(0xc4,0xc4);
WriteDataLCM(disdata[0]);//显示百位
WriteCommandLCM(0xc5,0xc5);
WriteDataLCM(disdata[1]);//显示十位
WriteCommandLCM(0xc6,0xc6);
WriteDataLCM(disdata[2]);//显示个位
WriteCommandLCM(0xc7,0xc7);
WriteDataLCM(0x2e);//显示小数点
WriteCommandLCM(0xc8,0xc8);
WriteDataLCM(disdata[3]);//显示小数位
delay(1000);                               //稳定显示
}
/************读ADC0832函数************/
uchar Adc0832(unsigned char channel)     //AD转换,返回结果
{
uchar i=0;
uchar j;
uint dat=0;
uchar ndat=0;
if(channel==0)channel=2;
if(channel==1)channel=3;
ADDI=1;
_nop_();
_nop_();
ADCS=0;//拉低CS端
_nop_();
_nop_();
ADCLK=1;//拉高CLK端
_nop_();
_nop_();
ADCLK=0;//拉低CLK端,形成下降沿1
_nop_();
_nop_();
ADCLK=1;//拉高CLK端
ADDI=channel&0x1;
_nop_();
_nop_();
ADCLK=0;//拉低CLK端,形成下降沿2
_nop_();
_nop_();
ADCLK=1;//拉高CLK端
ADDI=(channel>>1)&0x1;
_nop_();
_nop_();
ADCLK=0;//拉低CLK端,形成下降沿3
ADDI=1;//控制命令结束
_nop_();
_nop_();
dat=0;
for(i=0;i<8;i++)
{
dat|=ADDO;//收数据
ADCLK=1;
_nop_();
_nop_();
ADCLK=0;//形成一次时钟脉冲
_nop_();
_nop_();
dat<<=1;
if(i==7)dat|=ADDO;
}  
for(i=0;i<8;i++)
{
j=0;
j=j|ADDO;//收数据
ADCLK=1;
_nop_();
_nop_();
ADCLK=0;//形成一次时钟脉冲
_nop_();
_nop_();
j=j<<7;
ndat=ndat|j;
if(i<7)ndat>>=1;
}
ADCS=1;//拉低CS端
ADCLK=0;//拉低CLK端
ADDO=1;//拉高数据端,回到初始状态
dat<<=8;
dat|=ndat;
return(dat);            //return ad k
}
void data_pro(void)
{
unsigned int temp;
float  press;      
if(14<ad_data<243)        //当压力值介于15kpa到115kpa之间时,遵循线性变换
{      
int vary=ad_data;      //y=(115-15)/(243-13)*X+15kpa   
press=((10.0/23.0)*vary)+9.3;   //测试时补偿值为9.3
temp=(int)(press*10);                 //放大10倍,便于后面的计算press_bai=temp/1000;         //取压力值百位
press_shi=(temp%1000)/100;       //取压力值十位
press_ge=((temp%1000)%100)/10;      //取压力值个位
press_dot=((temp%1000)%100)%10;   //取压力值十分位
}     
}
/*****************报警子函数*******************/
unsigned int a;
void alARM(void)
{
if(ad_data>=243)                           //如果当前压力值大于115kpa,
{  Alarm_led_red=0;
a=10000;
while(a--);
{
}
Alarm_led_red=1;
a=10000;
while(a--);
{
}
}               
else                    //则启动red led报警
{
Alarm_led_red=1;
}                      //关闭red led 报警
if(ad_data<=14)       //如果当前压力值小于16kpa
{  
Alarm_led_green=0;
a=10000;
while(a--);
{
}
Alarm_led_green=1;                 //则启动green led报警

a=10000;
while(a--);
{
}
}               
else
{  
Alarm_led_green=1;           //关闭green  led 报警
}                            //关闭green  led 报警

}
/****************************ds1820程序**********************************/
void delay_18B20(unsigned int i)          //延时1微秒
{
while(i--);
}
void ds1820rst()                         /*ds1820复位*/
{
unsigned char x=0;
DQ = 1;                                //DQ复位
delay_18B20(4);                         //延时
DQ = 0;                                 //DQ拉低
delay_18B20(100);                       //精确延时大于480us
DQ = 1;                                 //拉高
delay_18B20(40);
}
uchar ds1820rd()                         /*读数据*/
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i>0;i--)
{   
DQ = 0;                                    //给脉冲信号
dat>>=1;
DQ = 1;                                    //给脉冲信号
if(DQ)
dat|=0x80;
delay_18B20(10);
}
return(dat);
}
void ds1820wr(uchar wdata)                   /*写数据*/
{
unsigned char i=0;
for (i=8; i>0; i--)
{
DQ = 0;
DQ = wdata&0x01;
delay_18B20(10);
DQ = 1;
wdata>>=1;
}
}
void read_temp()                           /*读取温度值并转换*/
{
uchar a,b;
ds1820rst();   
ds1820wr(0xcc);                        //*跳过读序列号*/
ds1820wr(0x44);                        //*启动温度转换*/
ds1820rst();   
ds1820wr(0xcc);                       //*跳过读序列号*/
ds1820wr(0xbe);                         //*读取温度*/
a=ds1820rd();
b=ds1820rd();
tvalue=b;
tvalue<<=8;
tvalue=tvalue|a;
if(tvalue<0x0fff)
tflag=0;
else
{
tvalue=~tvalue+1;
tflag=1;
}
tvalue=tvalue*(0.625);            //温度值扩大10倍,精确到1位小?
//return(tvalue);
}  

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。