关于OnTimer

fjw666 2011-03-08 03:30:57
我在构造函数当中定义了一个double X[25]的数组
目的是一秒钟读取该数组的一个值,并循环的读取

但是发现数据无法传递过去,为什么!!!



private:
int yNum;
double X[25];

.........
.........

OnTimer里面的部分函数:
{

if(yNum==24)
{
yNum=0;
}
double nRandomY=X[yNum];
...............
yNum++;
................
}
...全文
402 26 打赏 收藏 转发到动态 举报
写回复
用AI写文章
26 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaoguailong3 2011-03-09
  • 打赏
  • 举报
回复
应该没问题的。。。
fjw666 2011-03-08
  • 打赏
  • 举报
回复
上面代码贴错了,我已经把X[25],yNum定义为类的成员变量!!!!!!!

BOOL CMeasureDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标

// TODO: 在此添加额外的初始化代码
CRect rect;
GetClientRect(rect);
//创建曲线控件实例
m_Interface.Create(_T(""),_T(""),WS_VISIBLE | WS_CHILD, rect, this,0,NULL) ;
m_pointCount = 0;


X[25]=41.822,41.823,41.823,41.826,41.829,41.827,41.826,41.820,41.822,41.819,41.827,41.827,41.824,41.828,41.824,41.827,41.826,41.821,41.826,41.822,41.825,41.827,41.827,41.828,41.821 };
yNum=0;
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CMeasureDlg::OnBtnCollect()
{
// TODO: 在此添加控件通知处理程序代码
CString str;

if(GetDlgItemText(IDC_BTN_COLLECT,str),str==_T("采集"))
{
if(m_bFirstSet)
{
CCollectDlg dlg_Collect;

if(IDOK==dlg_Collect.DoModal())[/color]{
m_Interface.m_dUpLimite=dlg_Collect.m_dUp;
m_Interface.m_dStandar=dlg_Collect.m_dStandar;
m_Interface.m_dDownLimite=dlg_Collect.m_dDown;
}
m_bFirstSet = FALSE;
}
SetDlgItemText(IDC_BTN_COLLECT,_T("停止"));
SetTimer(1,1000,NULL);[/color]
}
else
{
SetDlgItemText(IDC_BTN_COLLECT,_T("采集"));
KillTimer(1);
}
}
void CMeasureDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值

double nRandomY;
if(yNum < 25) nRandomY = X[yNum++];
else
{
yNum=0;
nRandomY = X[yNum++];
}[/color]//如果曲线点数大于10个点,则删除第1个点。
if (m_pointCount > 7 )
{
m_Interface.DeleteFirstPoint();
m_pointCount--;
}
//给曲线添加点
m_Interface.AppendPoint(nRandomY);


TRACE(L" y = %d \n",nRandomY);
m_pointCount++;
CDialog::OnTimer(nIDEvent);
}

xiaoguailong3 2011-03-08
  • 打赏
  • 举报
回复
double X[25]={41.822,41.823,41.823,41.826,41.829,41.827,41.826,41.820,41.822,41.819,41.827,41.827,41.824,41.828,...
你的这个是局部变量当然不行了。。。走完函数就释放了。要定义成类的成员
fjw666 2011-03-08
  • 打赏
  • 举报
回复
看红色部分即可,谢谢各位了


BOOL CMeasureDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标

// TODO: 在此添加额外的初始化代码
CRect rect;
GetClientRect(rect);
//创建曲线控件实例
m_Interface.Create(_T(""),_T(""),WS_VISIBLE | WS_CHILD, rect, this,0,NULL) ;
m_pointCount = 0;


double X[25]={41.822,41.823,41.823,41.826,41.829,41.827,41.826,41.820,41.822,41.819,41.827,41.827,41.824,41.828,41.824,41.827,41.826,41.821,41.826,41.822,41.825,41.827,41.827,41.828,41.821 };
yNum=0;
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CMeasureDlg::OnBtnCollect()
{
// TODO: 在此添加控件通知处理程序代码
CString str;

if(GetDlgItemText(IDC_BTN_COLLECT,str),str==_T("采集"))
{
if(m_bFirstSet)
{
CCollectDlg dlg_Collect;

if(IDOK==dlg_Collect.DoModal()){
m_Interface.m_dUpLimite=dlg_Collect.m_dUp;
m_Interface.m_dStandar=dlg_Collect.m_dStandar;
m_Interface.m_dDownLimite=dlg_Collect.m_dDown;
}
m_bFirstSet = FALSE;
}
SetDlgItemText(IDC_BTN_COLLECT,_T("停止"));
SetTimer(1,1000,NULL);
}
else
{
SetDlgItemText(IDC_BTN_COLLECT,_T("采集"));
KillTimer(1);
}
}
void CMeasureDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值

double nRandomY;
if(yNum < 25) nRandomY = X[yNum++];
else
{
yNum=0;
nRandomY = X[yNum++];
}
//如果曲线点数大于10个点,则删除第1个点。
if (m_pointCount > 7 )
{
m_Interface.DeleteFirstPoint();
m_pointCount--;
}
//给曲线添加点
m_Interface.AppendPoint(nRandomY);


TRACE(L" y = %d \n",nRandomY);
m_pointCount++;
CDialog::OnTimer(nIDEvent);
}


fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 20 楼 leotody 的回复:]
你是不是设置了多个timer,在响应函数OnTimer里面要先判断一下timer的ID
[/Quote]
只有一个
leotody 2011-03-08
  • 打赏
  • 举报
回复
你是不是设置了多个timer,在响应函数OnTimer里面要先判断一下timer的ID
fjw666 2011-03-08
  • 打赏
  • 举报
回复

BOOL CMeasureDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标

// TODO: 在此添加额外的初始化代码
CRect rect;
GetClientRect(rect);
//创建曲线控件实例
m_Interface.Create(_T(""),_T(""),WS_VISIBLE | WS_CHILD, rect, this,0,NULL) ;
m_pointCount = 0;


double X[25]={41.822,41.823,41.823,41.826,41.829,41.827,41.826,41.820,41.822,41.819,41.827,41.827,41.824,41.828,41.824,41.827,41.826,41.821,41.826,41.822,41.825,41.827,41.827,41.828,41.821 };
yNum=0;

return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CMeasureDlg::OnBtnCollect()
{
// TODO: 在此添加控件通知处理程序代码
CString str;

if(GetDlgItemText(IDC_BTN_COLLECT,str),str==_T("采集"))
{
if(m_bFirstSet)
{
CCollectDlg dlg_Collect;

if(IDOK==dlg_Collect.DoModal())
{
m_Interface.m_dUpLimite=dlg_Collect.m_dUp;
m_Interface.m_dStandar=dlg_Collect.m_dStandar;
m_Interface.m_dDownLimite=dlg_Collect.m_dDown;
}
m_bFirstSet = FALSE;
}
SetDlgItemText(IDC_BTN_COLLECT,_T("停止"));
//Invalidate();
SetTimer(1,1000,NULL);

}
else
{
SetDlgItemText(IDC_BTN_COLLECT,_T("采集"));
KillTimer(1);
}
}
void CMeasureDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值

double nRandomY;
if(yNum < 25) nRandomY = X[yNum++];
else
{
yNum=0;
nRandomY = X[yNum++];
}

//如果曲线点数大于10个点,则删除第1个点。
if (m_pointCount > 7 )
{
m_Interface.DeleteFirstPoint();
m_pointCount--;
}
//给曲线添加点
m_Interface.AppendPoint(nRandomY);


TRACE(L" y = %d \n",nRandomY);
m_pointCount++;
CDialog::OnTimer(nIDEvent);
}
fjw666 2011-03-08
  • 打赏
  • 举报
回复

BOOL CMeasureDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标

// TODO: 在此添加额外的初始化代码
CRect rect;
GetClientRect(rect);
//创建曲线控件实例
m_Interface.Create(_T(""),_T(""),WS_VISIBLE | WS_CHILD, rect, this,0,NULL) ;
m_pointCount = 0;


double X[25]={41.822,41.823,41.823,41.826,41.829,41.827,41.826,41.820,41.822,41.819,41.827,41.827,41.824,41.828,41.824,41.827,41.826,41.821,41.826,41.822,41.825,41.827,41.827,41.828,41.821 };
yNum=0;

return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CMeasureDlg::OnBtnCollect()
{
// TODO: 在此添加控件通知处理程序代码
CString str;

if(GetDlgItemText(IDC_BTN_COLLECT,str),str==_T("采集"))
{
if(m_bFirstSet)
{
CCollectDlg dlg_Collect;

if(IDOK==dlg_Collect.DoModal())
{
m_Interface.m_dUpLimite=dlg_Collect.m_dUp;
m_Interface.m_dStandar=dlg_Collect.m_dStandar;
m_Interface.m_dDownLimite=dlg_Collect.m_dDown;
}
m_bFirstSet = FALSE;
}
SetDlgItemText(IDC_BTN_COLLECT,_T("停止"));
//Invalidate();
SetTimer(1,1000,NULL);

}
else
{
SetDlgItemText(IDC_BTN_COLLECT,_T("采集"));
KillTimer(1);
}
}
void CMeasureDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值

double nRandomY;
if(yNum < 25) nRandomY = X[yNum++];
else
{
yNum=0;
nRandomY = X[yNum++];
}

//如果曲线点数大于10个点,则删除第1个点。
if (m_pointCount > 7 )
{
m_Interface.DeleteFirstPoint();
m_pointCount--;
}
//给曲线添加点
m_Interface.AppendPoint(nRandomY);


TRACE(L" y = %d \n",nRandomY);
m_pointCount++;
CDialog::OnTimer(nIDEvent);
}
xiaoguailong3 2011-03-08
  • 打赏
  • 举报
回复
把换界面和启动定时器的代码贴出了
fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 tandyt 的回复:]
不知道楼主的定义和初始化到底是怎么写的。我这里简单测试下,我的是基于对话框的,把浮点数显示到Edit控件里,正常显示:

......
double X[25]={1.0,2.0,1.454,5.345};
int yNum=3;
char papa[250];
double nRandomY;
nRandomY=X[yNum];
_gcvt(nRandomY,10,papa);
……
[/Quote]
我现在发现的问题是:我在构造函数里面初始化了,但是在OnTimer里面,这个X[25]内部的值确是没有赋值的。
我在程序中实现的功能是:在界面a上点击某按钮,进入界面b,点击界面b上的OK按钮,回到界面a,然后进入OnTimer开始读取数值,但是里面的值确是乱码,同时X[25]里面的数据也是乱码,求解
fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 stonewater 的回复:]
你调试的时候把断点设在double nRandomY=X[yNum];这句后面的一句,然后分别看看nRandomY,X数组的每个值
[/Quote]
乱码,如1.485397053725e-313#DEN
我现在发现的问题是:我在构造函数里面初始化了,但是在OnTimer里面,这个X[25]内部的值确是没有赋值的。
我在程序中实现的功能是:在界面a上点击某按钮,进入界面b,点击界面b上的OK按钮,回到界面a,然后进入OnTimer开始读取数值,但是里面的值确是乱码,同时X[25]里面的数据也是乱码,求解
stonewater 2011-03-08
  • 打赏
  • 举报
回复
你调试的时候把断点设在double nRandomY=X[yNum];这句后面的一句,然后分别看看nRandomY,X数组的每个值
TandyT 2011-03-08
  • 打赏
  • 举报
回复
不知道楼主的定义和初始化到底是怎么写的。我这里简单测试下,我的是基于对话框的,把浮点数显示到Edit控件里,正常显示:

......
double X[25]={1.0,2.0,1.454,5.345};
int yNum=3;
char papa[250];
double nRandomY;
nRandomY=X[yNum];
_gcvt(nRandomY,10,papa);
SetDlgItemText(IDC_EDIT1,papa);

.....

编辑框Edit 里正常显示 5.345 ;

如果楼主的代码和我上面的一样,还是不行,那我只能说:楼主你找微软去理论吧!!
stock999 2011-03-08
  • 打赏
  • 举报
回复
yNum与数组double X[25]均要初始化。
TandyT 2011-03-08
  • 打赏
  • 举报
回复
如果确定初始化了,而且能正常进入到 OnTimer() 函数里的话,那肯定是可以的啊,除非你没有正确初始化,或者是你 OnTimer() 里面的代码有问题,你把OnTimer 里的代码全贴出来看看?或者先把其他的都屏蔽,只留下 你用 yNum 和X[] 的代码,再看看
TandyT 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 fjw666 的回复:]
引用 5 楼 luciferstar 的回复:
设初始值了么?
不管是X,还是yNum,都要。
int yNum;
不代表yNum第一次使用的时候就是0。

yNum和X[25]都已经初始化了,在构造函数中初始化的
[/Quote]

你确定初始化了?初始化为多少了?
fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 mayudong1 的回复:]
数据无法传递时什么意思?

你SetTimer了吗?
[/Quote]
SetTimer了,可以运行到OnTimer里面
但是
double nRandomY;
nRandomY=X[yNum];之后
发现nRandomY=1.485397053725e-313#DEN ,不是一个具体的值
本来具体的值是41.831,但是它却不是
fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 luciferstar 的回复:]
设初始值了么?
不管是X,还是yNum,都要。
int yNum;
不代表yNum第一次使用的时候就是0。
[/Quote]
yNum和X[25]都已经初始化了,在构造函数中初始化的
fjw666 2011-03-08
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 fjw666 的回复:]
????
[/Quote]

SetTimer了,可以运行到OnTimer里面
但是
double nRandomY;
nRandomY=X[yNum];之后
发现nRandomY=1.485397053725e-313#DEN ,不是一个具体的值
本来具体的值是41.831,但是它却不是
xiaoguailong3 2011-03-08
  • 打赏
  • 举报
回复
无法传递??你怎么传递的。。。你可以设置个类成员变量i,初值为0,在OnTimer里面:
if(i < 25)double fa = X[i++];
这样就每1秒读X[25]里的一个值
加载更多回复(4)
代码转载自:https://pan.quark.cn/s/8ce4326d996e 对于在 CentOS 7 系统中修改网卡配置文件后无法使设置生效的情况,经过实践验证,可以通过使用 nmcli 命令来进行调整。完成修改之后,需要重新启动虚拟机以使更改生效,这样操作流程即告完成。如果设置仍然无法生效,则表明虚拟机在启动过程中所获取的 IP 地址配置并非针对 eth0,此时可以对其它网卡的配置文件进行修改或将其移除。在 CentOS 7 系统中,网络配置的管理机制与早期版本存在差异,主要体现为采用了 Network Manager 服务来负责网络接口的管理。在某些情形下,尽管修改了 `/etc/sysconfig/network-scripts` 目录下的 `ifcfg-eth0` 文件,但网络配置却未能即时生效。此类问题的发生通常源于 CentOS 7 采用了不同于以往的配置读取方法。接下来将具体阐述如何借助 nmcli 命令来处理这一挑战。 以 root 用户身份登录系统并打开终端界面。nmcli 是 Network Manager 提供的命令行界面工具,它支持在命令行环境下执行网络连接的建立、编辑、查询及管理任务。针对修改 eth0 网卡配置的需求,可以遵循以下步骤进行操作: 1. 导航至 `/etc/sysconfig/network-scripts` 目录: ``` cd /etc/sysconfig/network-scripts ``` 2. 检查该目录内是否存在 `ifcfg-eth0.bak` 文件,该备份文件可能是先前调整配置时遗留下来的,若存在可能造成冲突。若发现该文件,可以选择将其删除: ``` [root@localhost netw...
代码转载自:https://pan.quark.cn/s/46fd08fb879c 网管教程 从入门到精通软件篇 ★一。★详尽的xp修复控制台指令及其应用!!! 放入xp(2000)的光盘,安装时选择R,执行修复! Windows XP(涵盖 Windows 2000)的控制台指令是在系统遭遇某些意外状况时的一种极具效用的诊断、检测以及恢复系统功能的工具。笔者确实一直期望能够将这方面的指令进行归纳,此次由老范辛苦整理了这份极具价值的秘籍。 Bootcfg bootcfg 命令用于启动配置与故障恢复(对大多数计算机而言,即 boot.ini 文件)。 带有特定参数的 bootcfg 命令仅在运用故障恢复控制台时方可使用。能够在命令行界面下运用带有不同参数的 bootcfg 命令。 用法: bootcfg /default 设定默认引导选项。 bootcfg /add 向引导清单中增添 Windows 安装。 bootcfg /rebuild 重复整个 Windows 安装流程并让用户选择需添加的项目。 注意:运用 bootcfg /rebuild 之前,应先借助 bootcfg /copy 命令备份 boot.ini 文件。 bootcfg /scan 探查用于 Windows 安装的全部磁盘并展示结果。 注意:这些结果被静态存储,并用于当前会话。若在当前会话期间磁盘配置发生变动,为获取更新的探查结果,必须先重启计算机,然后再次探查磁盘。 bootcfg /list 列示引导清单中已有的项目。 bootcfg /disableredirect 在启动引导程序中禁用重定向。 bootcfg /redirect [ PortBaudRrate] |[ useBio...

16,550

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧