AVR與VB通信模擬量輸入簡單程序
void uart_init()
{
UCSRB=0x00; //串口不使能
UCSRA=0x02; //串口倍速模式
UCSRC=0x06; //數據長度設置為8位
UBRRL=0x67; //串口設置為9600波特率
UBRRH=0x00;
UCSRB=0x98; //串口接受和發送使能,接受中斷使能
}
void uart_send(uchar k) //串口發送函數
{
while(!(UCSRA&(1< UDR=k;
}
uchar uart_receive()
{
while(!(UCSRA&(1<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 定義字節數組
Dim strbuf As String 定義字符串變量
Select Case MSComm1.CommEvent
Case comEvReceive 接受事件發生
Text2 = MSComm1.InBufferCount 顯示接受緩沖區字節數
strbuf = MSComm1.Input 從輸入緩沖區讀取字符
bytereceive() = strbuf 字符串賦值給字符數組,低字節在前,高字節在后
Dim i As Integer
For i = 0 To UBound(bytereceive) UBound返回數組可用的最大長度
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 十六進制顯示
Text3.Text = Val("&H" & strdata) 十進制顯示
評論