久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

專注電子技術(shù)學(xué)習(xí)與研究
當(dāng)前位置:單片機(jī)教程網(wǎng) >> MCU設(shè)計實(shí)例 >> 瀏覽文章

AVR與VB通信模擬量輸入簡單程序

作者:佚名   來源:本站原創(chuàng)   點(diǎn)擊數(shù):  更新時間:2013年10月23日   【字體:

 

 
//----------------------------------------AVR代碼------------------------
#include <iom16.h>
#include <intrinsics.h>

 
#define uchar unsigned char
#define uint unsigned int

 
uchar seg[10]={0x3f,0x06,0x5b, //共陰極數(shù)碼管0~9的字形碼
0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar tab[4]={0xfe,0xfd,0xfb,0xf7};//4位共陰極數(shù)碼管的位選碼

 
#define UDRE 5
#define RXC 7

 
uchar datt;  //接受到的數(shù)據(jù)比較變量
uchar adc_val;  //模擬量轉(zhuǎn)換值

 
void delay(uint k)
{
 while(k--); 
}

 
void port_init()
{
PORTA=0x7f;    // 通道7作為模擬量輸入
DDRA=0x7f;
PORTB=0xff;
DDRB=0xff;
PORTC=0xff;
DDRC=0xff;
PORTD=0xff;
DDRD=0xff;  
}

 
void adc_init()  //模擬量初始化
{
  ADCSRA=0xe3;
  ADMUX=0xc7; 
}

 
uint adc_vert()
{
 uint temp1,temp2;
 temp1=(uint)ADCL;
 temp2=(uint)ADCH;
 temp2=(temp2<<8)+temp1;
 return temp2; 
}

 

 
void time0_init()  //定時器0初始化
{
  TCNT0=0x83;
  TCCR0=0x03;
  TIMSK=0x01;  //定時器0溢出中斷 
}

 
#pragma vector = 0x24
__interrupt void time0_vef()
{
 static uchar i;
  TCNT0=0x83;
  i++;
  if(i>3)i=0;
  switch(i)
  {
  case 0:PORTA=seg[adc_val%10];PORTC=tab[0];break;
  case 1:PORTA=seg[adc_val%100/10];PORTC=tab[1];break;
  case 2:PORTA=seg[adc_val%1000/100];PORTC=tab[2];break;
  case 3:PORTA=seg[adc_val/1000];PORTC=tab[3];break;
  default:break; 
  } 
}

 

 
void uart_init()
{
  UCSRB=0x00;     //串口不使能
  UCSRA=0x02;    //串口倍速模式
  UCSRC=0x06;    //數(shù)據(jù)長度設(shè)置為8位
  UBRRL=0x67;    //串口設(shè)置為9600波特率
  UBRRH=0x00;
  UCSRB=0x98;    //串口接受和發(fā)送使能,接受中斷使能
}

 
void uart_send(uchar k)  //串口發(fā)送函數(shù)
{
  while(!(UCSRA&(1<<UDRE)));
        UDR=k;
  
}

 
uchar uart_receive()
{
 while(!(UCSRA&(1<<RXC))); //接受結(jié)束讀出數(shù)據(jù)
 return UDR;
  
}

 
void send_number(uint k)
{
uart_send((uchar)(k>>8));
uart_send((uchar)(k));
}

 
#pragma vector = 0x2c
__interrupt void uart_rxc()
{
 datt=UDR;
 if(datt=='a')PORTB=0xff;
 else PORTB=0x00; 
 
}
     

 

 
void main()
{
 
 port_init();
 uart_init(); 
 time0_init();
 adc_init();
 SREG=0x80;
 while(1)
 {
  adc_val=adc_vert();
  delay(50000);
  delay(50000);
  delay(50000);
  send_number(adc_val);  
 }  
}

 
//----------------------VB代碼----------------------------
Private Sub Command1_Click()
MSComm1.CommPort = 4
MSComm1.PortOpen = True
MSComm1.InputMode = comInputModeBinary

 
MSComm1.InputLen = 0

 
Private Sub MSComm1_OnComm()
Dim bytereceive() As Byte  '定義字節(jié)數(shù)組
Dim strbuf As String     '定義字符串變量
Select Case MSComm1.CommEvent
Case comEvReceive   '接受事件發(fā)生
Text2 = MSComm1.InBufferCount   '顯示接受緩沖區(qū)字節(jié)數(shù)
strbuf = MSComm1.Input   '從輸入緩沖區(qū)讀取字符
bytereceive() = strbuf   '字符串賦值給字符數(shù)組,低字節(jié)在前,高字節(jié)在后
Dim i As Integer
For i = 0 To UBound(bytereceive)  'UBound返回數(shù)組可用的最大長度
If Len(Hex(bytereceive(i))) = 1 Then
strdata = strdata & "0" & Hex(bytereceive(i))
Else
strdata = strdata & Hex(bytereceive(i))
End If
Next
Text1.Text = strdata   '十六進(jìn)制顯示

 
Text3.Text = Val("&H" & strdata)  '十進(jìn)制顯示
strdata = ""

 
End Select

 
End Sub
關(guān)閉窗口

相關(guān)文章

主站蜘蛛池模板: 久精品久久 | 亚洲成人免费电影 | 国产高清免费视频 | 国产a区 | 久久久女女女女999久久 | 国产精品不卡 | 久久久久亚洲 | 中文字幕在线免费观看 | 日本亚洲一区二区 | 亚洲一区二区不卡在线观看 | 五月激情婷婷在线 | 欧美一级欧美三级在线观看 | 中文字幕视频在线看 | 亚洲人va欧美va人人爽 | 久久久久国产精品午夜一区 | 亚洲精品在线免费观看视频 | 羞羞网站在线观看 | 日韩中文字幕视频在线观看 | 精品日韩一区二区 | 国产成人精品免高潮在线观看 | 久草久草久草 | 欧美亚洲国语精品一区二区 | 久久99蜜桃综合影院免费观看 | av高清毛片| 国产成人免费视频网站视频社区 | 中文字幕日韩一区二区 | 奇米四色在线观看 | 精品国产欧美一区二区三区成人 | 日本在线观看视频 | 一区二区三区四区在线播放 | 波多野吉衣久久 | 国产成人精品久久二区二区91 | 国产精品高潮呻吟久久 | 国产2区| 一级毛片免费完整视频 | 美国a级毛片免费视频 | 午夜精品福利视频 | 免费同性女女aaa免费网站 | 毛片一级电影 | 国产精品久久久久无码av | 久久精品视频一区二区三区 |