-
现在做出来了 非常感谢各位的回复
现在我还有个小问题就是动态扫描的闪烁问题 老是一闪一闪的 不能达到直观是静态显示的效果
-
我是根据压力传感器 采集数据 然后送入单片机转换显示 问题是现在我的程序只是显示采集的气压数据 要怎么修改才能显示高度呢 气压与高度的关系 是一个指数关系H=44.3308-439645*P0.190263
-
我图传不上去 你有QQ吗 ?我是根据气压传感器送信号到V/F转换 最后送入单片机 显示
-
/*---------------------------------------------*/
#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long
//------------------------------------------
#include
//#include
//#include
//#include
sfr DisDat =0x90;
sfr DisCs =0xa0;
//sbit P35 =P3^5;
uchar code table[10] ={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,
0x7F,0x6F};
bit overflag=0; //一次测量结束标志
uchar T0cnt; //T0_count
uchar tcnt; //Time_count
uchar datbuf[6]; //计数值数据存储数组
ulong total; //计数值缓存单元
ulong total_low;
//time delay subproram
void Delay(uchar dcnt)// 延时程序,T=DCNT*6+11
{
uchar j;
j=dcnt;
while (j--){;}
}
//data display subproram
void Display(void)
{
uchar i,j,temp=0xdf;
for(i=0;i>1;
temp=temp|0x80;
DisCs=0xff;
}
}
/*
sfr DisDat =0x90;
sfr DisCs =0xa0;
*/
//外部计数中断
void tcount0(void) interrupt 1 using 1
{
TH0=0;
TL0=0;
T0cnt++;
}
//50MS定时中断
void timer1(void) interrupt 3 using 2
{
ulong temp;
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
tcnt++;
if(tcnt==20)
{
TR0=0; //先关闭TR0,以保证计数精确
EA=0;
TR1=0;
//完成一次测量,关闭所有定时器,以重新开始下一次测量
tcnt=0;
overflag = 1;
total = (T0cnt*65536)+(TH0*256)+TL0;//TOTAL存放了1S内T0的计数值
temp=total*10+15280;
total=temp/1059 ;
total_low=(temp%1059)/10;
total = (total%10000);
datbuf[0] = (uchar)(total/1000);//千位送datbuf[0]
total = total%1000;
datbuf[1] = (uchar)(total/100); //百位送datbuf[1]
total = total%100;
datbuf[2] = (uchar)(total/10); //十位送datbuf[2]
datbuf[3] = total%10; //个位送datbuf[3]
datbuf[4] = (uchar)total_low/10;
datbuf[5] = (uchar)total_low%10;
T0cnt = 0;
}
}
//------------------------------------------
void main(void)
{
TMOD=0x15;
/*------------------------
定时记数器工作状态设置,
定时器0工作在内部定时1方式
定时器1工作在外部计数1方式
--------------------------*/
TH0=0;
TL0=0;
TH1=(65536-50000)/256; //初值设置
TL1=(65536-50000)%256; //50MS定时常数
EA=1;
ET0=1;
ET1=1;
TR1=1;
TR0=1;
while(1)
{
Display();
if(overflag!=0)//一次转换结束,重新装载数据,开始下一次转换
{
TH0=0;
TL0=0;
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
EA=1;
ET0=1;
ET1=1;
TR1=1;
TR0=1; //重启定时器 ,开始下一次测量
overflag=0;
}
}
}
-
谢了
-
顶一个 下了 收藏
-
谢谢各位的回复 我总结了下 第一proteus的效率低 第二 有些器件的电气特性仿真时候慢 第三 时间是根据仿真环境的记时为准
不过有可能是程序繁琐的问题吗 还有那个仿真的记时 他怎么是按100分制的啊 时间不是60分制吗 有知道的解答下 谢谢
-
在此 还是先谢谢各位的回复 我都记下了
-
是的 T0计数 1S读取计数脉冲数 然后显示
-
在频率比较低的时候 显示的是比较快 但是到高频率 反映就慢了 大家看看附件 希望多提意见 谢谢
-
我写了程序 大家帮忙看下 功能能实现吗?有什么需要修改的地方
程序设定设定内容:(1)T0是工作在计数状态下,对输入的信号进行计数,但对工作在最大计数状态下的T0,最大计数值为fosc/24,fosc=12MHz,因此:T0的最大计数频率为250KHz。对于频率的概念就是在一秒只数脉冲的个数,既为频率值。所以T1工作在定时状态下,每定时1秒种到,就停止T0的计数单元中读取计数的数值,然后进行数据处理。送到数码管现实出来。
(2)T1为定时器,基本的定时时基为50ms。共定时20次,即可完成1秒的定时功能。T0为计数器,运用内部中断1可保证T1定时满1s后就读取此时计数器的值,以计算气压值。如使T1、T0均工作于方式1,并在P1口送字型码,同时可用P3.0~P3.3做位选线,那么,其相应的函数如下:
#include
unsigned char temp[8];
unsigned char dispcount;
unsigned char T0count;
unsigned char timecount;
unsigned seg[21]={0xfc,0x60,0xda,0xf2,0x66,0xb6,0xbe,0xe0,0xfe,0xf6,0xee,0x3e,0x9c,0x7a,0x9e,0x8e,0x02,0x6e,0x1c,0x5e,0x00} ;
//unsigned long count;
int led_[4];
int k=200;
int j;
long count;
int p;
int m;
void delay()
//延迟-------------------------------------------------------------------------
{
j=0;
while (j
-
是气压计的设计程序 详细的附件里面有 请求帮助 谢谢
-
两个调用函数如下 没有主程序 大家帮忙看下程序有问题吗 另外帮忙写个主程序 不胜感激 (1)定时器T0中断函数: void timer0(void) interrupt 1 using 1 {uint x, y; uint count_ pluse; ET0=0; //关闭T/C0中断 Tcount++; //中断次数 ,可减少输入电压中的干扰脉冲,提高转换精度。 if?Tcount == 10){ TR1=0; //停止计数器计数 Tcount=0; x=TH1; y=TL1; count_pulse=(x*256+y)*2; ph=(uint)(10 * ((float)(count pulse+1520)/105.9? ?? //计算气压值 TH1 = 0x00; //重设计数初值 TL1=0x00; } TH0 = -50000/256; //重设50ms初值 TL0 = -50000%256; if(TL0!= 0) TH0--; ET0=1; TR1=1; return; } 该中断函数主要用于完成脉冲的读取和气压值的计算。ph是个全局变量,可用来保存气压值。 (2)在显示函数里,将气压值先按位进行分离并保存到数组,然后送段码和相应位选就可以显示出相应的气压值了。具体程序如下: void display(uint ph_in) { uchar i=0; uchar j=0; uchar select_bit=0; //位选 do { cur_buf[i]=ph_in%10; i++; j=i; }while(ph_in=ph_in/10);? //当高位为零时?结束循环 i=0; select_bit=0xfe; do { P1=tab[*p]; P3=select_bit; dl_ms();? select_bit=(select bit<<1)+1; //从最右边一位开始显示,循环左移 p++; i++; }while(i<j); p=cur_buf; //指针归位 return;} 这样,在主程序中,只要在程序第一次运行时进行初始化,然后再循环调用显示函数即可实现实时显示功能。