//全域變數
int LineHight[122];
int LHTemp[120];
CString DTemp;
int LineNum=0;
int NextTime;
int RightLeftNum=0;
int check='n';
int gogo=0;
int speed=9600;
int tab=0;
CString FilePath="c:\\data.txt";
// 畫圖函式
// 演算法:運用LineTo函式把120個點連成折線
void CCommDlg::OnPaint()
{
int hoc;
if (NextTime<600 && stop==FALSE) hoc = 600;
else hoc = NextTime;
CString TabStr="";
CPaintDC dc(this);// 用于繪制的設備背景關系
dc.GetNearestColor(RGB(128,0,0));//設備能顯示的最接近crColor值
dc.MoveTo(108,250);//移動到坐標(108,250)
if (NextTime<=600 && stop==FALSE) //將點連成線
for (int i=0;i<(NextTime/5);i++)
{
dc.LineTo(108+(5*i),250-LineHight[i]*5+99);//
}
else
for (int i=0;i<121;i++)
{
dc.LineTo(108+(5*i),250-LineHight[i]*5+99);
}
TabStr.Format("%d",hoc/5-120); //X軸對應的時間坐標值,使時間對應資料改變
SetDlgItemText(IDC_TAB1,TabStr);
TabStr.Format("%d",hoc/5-100);
SetDlgItemText(IDC_TAB2,TabStr);
TabStr.Format("%d",hoc/5-80);
SetDlgItemText(IDC_TAB3,TabStr);
TabStr.Format("%d",hoc/5-60);
SetDlgItemText(IDC_TAB4,TabStr);
TabStr.Format("%d",hoc/5-40);
SetDlgItemText(IDC_TAB5,TabStr);
TabStr.Format("%d",hoc/5-20);
SetDlgItemText(IDC_TAB6,TabStr);
TabStr.Format("%d",hoc/5);
SetDlgItemText(IDC_TAB7,TabStr);
}
void CCommDlg::OnComm()
{
if(stop)return;//若暫停,不接受資料
VARIANT m_input1;//定義VARIANT型變數,用于存放接收到的資料
COleSafeArray m_input2;;//定義safearray型變數
long length,i;
BYTE data[600];//定義BYTE型陣列
CString str;//定義字串
if(m_Comm.GetCommEvent()==2) //接識訓沖區內有字符
{
m_input1=m_Comm.GetInput(); //讀取緩沖區內的資料,把接收到的資料存放到VARIANT型變數里
m_input2=m_input1; //將VARIANT型變數轉換為ColeSafeArray型變數
length=m_input2.GetOneDimSize(); //確定資料長度
//.GetOneDimSize()是回傳一維陣列元素的個數,這個一維陣列里面每個元素都是陣列型別,依次存放到data[]中
for(i=0;i<length;i++)
m_input2.GetElement(&i,data+i); //將資料轉換為BYTE型陣列,存在data[i]中。
for(i=0;i<length;i++) //將陣列轉換為Cstring型變數
{
CFile file;
CString tempstr;
BYTE a=* (char *)(data+i);
BYTE b=* (char *)(data+(++i));
float c=(float)a+(float)(b%10)/10;
str.Format("%2.1f ",c); //將c格式化
if (str.GetLength()<5) str="0"+str;
str = str.Right(5); //從陣列中提取5個字符
m_ReceiveData+=str; //將剛采集的數加到編輯框中
LineHight[121]=a;
Display();//對資料顯示前的處理
//將資料保存到檔案中
if (m_ReceiveData.GetLength()>=600)//600個字符剛好對應120個資料
{
CStdioFile readfile;
CString readstr,readstr2;
if(readfile.Open(FilePath,CFile::modeRead))
{
while(readfile.ReadString(readstr))//逐行查詢,至到檔案尾
{
readstr2+=readstr;
}
readfile.Close();
}
if (file.Open(FilePath,CFile::modeCreate|CFile::modeReadWrite))
{
file.Write(readstr2,readstr2.GetLength());//原來的資料
file.Write(m_ReceiveData,600);//寫入新的120個資料
file.Close();
m_ReceiveData="";//清除編輯框內容
break;
}
}
}
}
UpdateData(FALSE);//更新編輯框內容
}
//對資料顯示前的處理:將新數年據加到左邊,原來的右移一位
void CCommDlg::Display()
{
if (NextTime <= 600 && stop==FALSE)
{
LineHight[NextTime/5] = LineHight[121];
}
else
{
for (int i=0;i<120;i++)
{
LineHight[i] = LineHight[i+1];
}
LineHight[120]=LineHight[121];
}
NextTime = NextTime+5;
this->Invalidate();
return;
}
//這三個函式之間的運行先后順序是怎么樣的?沒有main函式一下子不會看代碼了。
//我的問題是dc.LineTo(108+(5*i),250-LineHight[i]*5+99);
//以及BYTE a=* (char *)(data+i);
// BYTE b=* (char *)(data+(++i));
// float c=(float)a+(float)(b%10)/10;
// str.Format("%2.1f ",c); //將c格式化
// if (str.GetLength()<5) str="0"+str;
// str = str.Right(5); //從陣列中提取5個字符
// m_ReceiveData+=str; //將剛采集的數加到編輯框中
// LineHight[121]=a;
//這兩個演算法看不懂。。。希望大家能幫我講解一下。
uj5u.com熱心網友回復:
建議樓主將此問題移動到MFC版塊之下……uj5u.com熱心網友回復:
無非就是一個mscom控制元件的使用uj5u.com熱心網友回復:
多謝,已移動~
uj5u.com熱心網友回復:
COM的通信協議uj5u.com熱心網友回復:
但是讀出來的值和我串口除錯助手里讀出來的不一致啊。。
uj5u.com熱心網友回復:


兩個東西讀出來的數值差好多。。。
uj5u.com熱心網友回復:
推薦使用portmon軟體輔助除錯串口通訊程式。uj5u.com熱心網友回復:
自己頂一下。串口除錯助手和自己撰寫的程式讀出來的值不一致。。怎么辦。。。轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/145212.html
