有人能告诉我为什么在我基于VC ++对话框的应用程序中调用消息框之前调用UpdateData(FALSE)
不起作用?在我调用之前,运行时窗口保持不变:
MessageBoxW(cDisp, L"!!!Data Count!!!", MB_OK | MB_ICONINFORMATION)
我的代码段的一部分是这样的......
for(int j=0;j<50;j++)
{
if(ferr==0)
{
double X[15][4],splusn[15],m_dBiasC,WOld[1][4],alpha,err,WNew[1][4],y[15][1],WTransOld[4][1];
//do
// {
int iGraphX,iGraphY;
CString cDisp1(""),cDisp;
m_dBiasC=m_dC;
err=m_dError;
alpha=m_dAlpha;
char ch;
double dummy1,dummy2;
cDisp.Format(L"%d",j);
m_sCount.Format(L"%d",m_iInterval);
UpdateData(FALSE);
BeginWaitCursor();
for(int i=0;i<15;i++)
{
f[0]>>dummy1>>ch>>dummy2;
Time[i]=dummy1;
m_dAccX[i]=dummy2;
if(!f[0].good())
{
MessageBox(L"The end of first data file encountered",L"Caution");
MessageBoxW(L"Quiting Program ",L"Caution");
ferr=2;
//break;
exit(1);
}
iGraphX=static_cast<int>(Time[i]*100.0);
iGraphY=static_cast<int>(m_dAccX[i]);
m_Graph[0].RemovePoint(0,0);
m_Graph[0].AddPoint(iGraphX,iGraphY);
cDisp.Format(L"%lf %lf",Time[i],m_dAccX[i]);
cDisp1+=cDisp;
cDisp1+="\r\n";
f[1]>>dummy1>>ch>>dummy2;
Time[i]=dummy1;
m_dAccY[i]=dummy2;
if(!f[1].good())
{
MessageBox(L"The end of second data file encountered",L"Caution");
MessageBoxW(L"Quiting Program ",L"Caution");
ferr=3;
//break;
exit(1);
}
iGraphX=static_cast<int>(Time[i]*50.0);
iGraphY=static_cast<int>(m_dAccY[i]*10);
m_Graph[1].RemovePoint(0,0);
m_Graph[1].AddPoint(iGraphX,iGraphY);
f[2]>>dummy1>>ch>>dummy2;
Time[i]=dummy1;
m_dAccZ[i]=dummy2;
if(!f[2].good())
{
MessageBox(L"The end of third data file encountered",L"Caution");
MessageBoxW(L"Quiting Program ",L"Caution");
ferr=4;
//break;
exit(1);
}
iGraphX=static_cast<int>(Time[i]*50.0);
iGraphY=static_cast<int>(m_dAccZ[i]);
m_Graph[2].RemovePoint(0,0);
m_Graph[2].AddPoint(iGraphX,iGraphY);
f[3]>>dummy1>>ch>>dummy2;
Time[i]=dummy1;
m_dECG[i]=dummy2;
if(!f[3].good())
{
MessageBox(L"The end of fourth data file encountered",L"Caution");
MessageBoxW(L"Quiting Program ",L"Caution");
ferr=5;
//break;
exit(1);
}
iGraphX=static_cast<int>(Time[i]*100.0);
iGraphY=static_cast<int>(m_dECG[i]*100);
m_Graph[3].RemovePoint(0,0);
m_Graph[3].AddPoint(iGraphX,iGraphY);
}
Sleep(500);
GetDlgItem(IDC_DISPLAYFILE)->SetWindowTextW(cDisp1);
UpdateData(FALSE);
EndWaitCursor();
cDisp.Format(L"Data Read till now: %d",((j+1)*15));
MessageBox(cDisp,L"!!!Data Count!!!",MB_OK|MB_ICONINFORMATION);
UpdateData(FALSE);
//This part is for adaptive filter calculations
for(int r=0;r<15;r++)
{
splusn[r]=static_cast<double>(m_dECG[r]);
X[r][0]=m_dBiasC;
X[r][1]=static_cast<double>(m_dAccX[r]*m_dScaleX);
X[r][2]=static_cast<double>(m_dAccY[r]*m_dScaleY);
X[r][3]=static_cast<double>(m_dAccZ[r]*m_dScaleZ);
}
WOld[0][0]=m_dW0;
WOld[0][1]=m_dW1;
WOld[0][2]=m_dW2;
WOld[0][3]=m_dW3;
for(int q=0;q<4;q++)
WNew[0][q]=WOld[0][q];
for(int p=0;p<15;p++)
{
for(int iRectCnt=0;iRectCnt<60;iRectCnt++)
{
f[4]<<setiosflags(ios::fixed)<<setw(8)<<setprecision(4)<<p<<" ";
for(int iWCnt=0;iWCnt<4;iWCnt++)
f[4]<<setw(8)<<setprecision(2)<<WOld[0][iWCnt];
f[4]<<endl;
y[p][0]=0.0;
for(int q=0;q<4;q++)
WTransOld[q][0]=WOld[0][q];
for(int r=0;r<4;r++)
{
y[p][0]=y[p][0]+(X[p][r]*WTransOld[r][0]);
}
err=splusn[p]-y[p][0];
for(int q=0;q<4;q++)
WNew[0][q]=WOld[0][q]+(2.0*alpha*err*X[p][q]);
for(int q=0;q<4;q++)
WOld[0][q]=WNew[0][q];
}
cDisp.Format(L"%lf",err);
GetDlgItem(IDC_ERROR)->SetWindowTextW(cDisp);
splusn[p]=splusn[p]-err;
}
for(int p=0;p<15;p++)
{
iGraphX=static_cast<int>(Time[p]*100.0);
iGraphY=static_cast<int>(splusn[p]*100);
m_Graph[4].RemovePoint(0,0);
m_Graph[4].AddPoint(iGraphX,iGraphY);
}
cDisp.Format(L"%lf",WNew[0][0]);
GetDlgItem(IDC_W0C)->SetWindowTextW(cDisp);
cDisp.Format(L"%lf",WNew[0][1]);
GetDlgItem(IDC_W1C)->SetWindowTextW(cDisp);
cDisp.Format(L"%lf",WNew[0][2]);
GetDlgItem(IDC_W2C)->SetWindowTextW(cDisp);
cDisp.Format(L"%lf",WNew[0][3]);
GetDlgItem(IDC_W3C)->SetWindowTextW(cDisp);
m_sCount.Format(L"%d",0);
// End of Adaptive filter
//close files here if already end of file is encountered
if((f[0].eof()||f[1].eof()||f[2].eof()||f[3].eof()))
{
MessageBox(L"End of File encountered");
ferr=1;
exit(1);
}
//}while(!(f[0].eof())&&!(f[1].eof())&&!(f[2].eof())&&!(f[3].eof()));
}
}
答案 0 :(得分:4)
该代码存在很多问题,我甚至不知道从哪里开始。对于初学者:
你为什么打电话给Sleep()
?我无法想象你需要在精心设计的应用程序中执行此操作的原因。 特别是不重复,正如您在代码中所示。 Sleep
函数会导致您的线程暂停指定的毫秒数。尝试完全取消对Sleep
的调用,看看是否无法解决您的问题。如果线程被挂起,UI将如何更新?
为什么要将UpdateData
与GetDlgItem
混合并调用SetWindowText
?如果您让MFC负责使用对话框控件中显示的值来协调成员变量的值,则不需要自己设置其属性。
您也没有向我们展示足够的代码来了解CDisp1
是什么,或IDC_DISPLAYFILE
是什么。你最终想要完成什么?您希望在处理数据时进行实时更新吗?如果我们知道目标是什么,而不仅仅是不起作用的代码,我们肯定可以提供更好的帮助来构建代码。
更新:啊,我看到您刚刚在评论中添加了上述代码处于for
循环中。所以你的问题实际上很简单:一个for
循环将CPU置于一个紧密循环中,除了代码执行之外别无其他。当循环执行指定的次数时,所有消息处理(特别是更新UI)都会暂停。
调用UpdateData
对象中的控件值没有任何结果,因为计算机的处理器当前正忙着忙循环。通过创建自己的消息泵,显示消息框会暂时阻止for
循环的执行,从而允许更新UI。从for
循环中取出代码,然后移除对Sleep
的调用,您的问题就会消失。
从评论中看,对你来说最好的事情是创建一个工作线程并将你的循环放在那里,将它与你的主(GUI)线程隔离开来。然后,工作线程可以向主线程发送消息以更新对话框中的控件。已提供完整的解决方案和更多信息作为此问题的答案:How can I show a modeless dialog and display information in it immediately?
答案 1 :(得分:0)
可能是因为对MessageBox的调用包含一个消息泵。正如您所做的那样使用Sleep意味着用户界面无法响应。