我按照前人已经提供的方法如下:在toolbar 里创建个按钮,ID是 IDC_SLIDER。
打开MainFrm.h,添加一个滑动条对象:
public:
CSliderCtrl m_Slider;
打开MainFrm.cpp
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
......
// TODO: Delete these three lines if you don 't want the toolbar to
// be dockable
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockControlBar(&m_wndToolBar);
int index = m_wndToolBar.CommandToIndex(IDC_SLIDER);
m_wndToolBar.SetButtonInfo(index, IDC_SLIDER, TBBS_SEPARATOR, 80);
CRect rect;
m_wndToolBar.GetItemRect(index, &rect);
if (!m_Slider.Create(WS_CHILD|WS_VISIBLE | TBS_HORZ | TBS_AUTOTICKS |TBS_BOTTOM ,
rect, &m_wndToolBar, IDC_SLIDER))
{
TRACE0( "Failed to create slider ctrl\n ");
return FALSE;
}
m_Slider.SetRange(0,100);
m_Slider.SetPos(20);
m_Slider.ShowWindow(SW_SHOW);
return 0;
}
按这个步骤我自己新建了一个MDI程序,可以编译运行成功,
但是我加到我现在在做的一个工程中时却出问题了。
编译没问题,但运行时出错,提示0x7c930cce指令引用0x00000000内存不能为“read”我做了下测试,发现在调用int index = m_wndToolBar.CommandToIndex(IDC_SLIDER);时就会出问题。
以下是四种情况下的测试结果
一。
1。定义 CSliderCtrl m_Slider; 编译无错,运行无错
2。调用int index = m_wndToolBar.CommandToIndex(ID_APP_ABOUT); 编译无错,运行报错。
报错: 0x7c930cce指令引用0x00000000内存不能为“read”二。
1。定义 CSliderCtrl m_Slider; 编译无错,运行无错
2。调用int index = m_wndToolBar.CommandToIndex(IDC_SLIDER); 编译无错,运行报错。/*IDC_SLIDER是工具栏上新建的一个控件ID,作为后面生成的滑动条控件。*/
报错:0x7c930cce指令引用0x00000000内存不能为“read”三。
1。调用int index = m_wndToolBar.CommandToIndex(ID_APP_ABOUT);编译无错,运行无错
2。定义 CSliderCtrl m_Slider; 编译出错,40个错误
四。
1。int index = m_wndToolBar.CommandToIndex(IDC_SLIDER); /*IDC_SLIDER是工具栏上新建的一个控件ID,作为后面生成的滑动条控件。*/ 编译无错,运行无错
2。定义 CSliderCtrl m_Slider; 编译出错,40个错误
打开MainFrm.h,添加一个滑动条对象:
public:
CSliderCtrl m_Slider;
打开MainFrm.cpp
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
......
// TODO: Delete these three lines if you don 't want the toolbar to
// be dockable
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockControlBar(&m_wndToolBar);
int index = m_wndToolBar.CommandToIndex(IDC_SLIDER);
m_wndToolBar.SetButtonInfo(index, IDC_SLIDER, TBBS_SEPARATOR, 80);
CRect rect;
m_wndToolBar.GetItemRect(index, &rect);
if (!m_Slider.Create(WS_CHILD|WS_VISIBLE | TBS_HORZ | TBS_AUTOTICKS |TBS_BOTTOM ,
rect, &m_wndToolBar, IDC_SLIDER))
{
TRACE0( "Failed to create slider ctrl\n ");
return FALSE;
}
m_Slider.SetRange(0,100);
m_Slider.SetPos(20);
m_Slider.ShowWindow(SW_SHOW);
return 0;
}
按这个步骤我自己新建了一个MDI程序,可以编译运行成功,
但是我加到我现在在做的一个工程中时却出问题了。
编译没问题,但运行时出错,提示0x7c930cce指令引用0x00000000内存不能为“read”我做了下测试,发现在调用int index = m_wndToolBar.CommandToIndex(IDC_SLIDER);时就会出问题。
以下是四种情况下的测试结果
一。
1。定义 CSliderCtrl m_Slider; 编译无错,运行无错
2。调用int index = m_wndToolBar.CommandToIndex(ID_APP_ABOUT); 编译无错,运行报错。
报错: 0x7c930cce指令引用0x00000000内存不能为“read”二。
1。定义 CSliderCtrl m_Slider; 编译无错,运行无错
2。调用int index = m_wndToolBar.CommandToIndex(IDC_SLIDER); 编译无错,运行报错。/*IDC_SLIDER是工具栏上新建的一个控件ID,作为后面生成的滑动条控件。*/
报错:0x7c930cce指令引用0x00000000内存不能为“read”三。
1。调用int index = m_wndToolBar.CommandToIndex(ID_APP_ABOUT);编译无错,运行无错
2。定义 CSliderCtrl m_Slider; 编译出错,40个错误
四。
1。int index = m_wndToolBar.CommandToIndex(IDC_SLIDER); /*IDC_SLIDER是工具栏上新建的一个控件ID,作为后面生成的滑动条控件。*/ 编译无错,运行无错
2。定义 CSliderCtrl m_Slider; 编译出错,40个错误
解决方案 »
- jrtp3.7.1通信测试example4服务器例子//没死循环怎么卡住了?
- 改变CTabCtrl标签的宽度
- vb调用vc的dll的问题
- 文件名全是数字,可不可以直接转换成数字?
- 请问怎么得到一个函数的执行时间,单位毫秒!
- 怎么在调试状态给main(int argc, char **argv)传参数
- 那里有PB可用的功能齐全的免费的FTP Active控件下载
- Win98(第一版)下显示字体和Win2000下显示的不一样,怎么解决???????????
- vc++实现鼠标在视区描绘任意长度和任意点的折线
- 请教用进程B激活进程A的对话框的疑惑!!
- 命名管道,是不是只能用于1对1通信?
- MDI 如何发消息 弹出系统菜单,我忘记怎么操作了!
百思不得其解,
求高人解答
这个应该是NULL指针异常了。把你下面的代码放到自定义的消息函数中去
int index = m_wndToolBar.CommandToIndex(IDC_SLIDER);
m_wndToolBar.SetButtonInfo(index, IDC_SLIDER, TBBS_SEPARATOR, 80);
CRect rect;
m_wndToolBar.GetItemRect(index, &rect);
if (!m_Slider.Create(WS_CHILD|WS_VISIBLE | TBS_HORZ | TBS_AUTOTICKS |TBS_BOTTOM ,
rect, &m_wndToolBar, IDC_SLIDER))
{
TRACE0( "Failed to create slider ctrl\n ");
return FALSE;
}
m_Slider.SetRange(0,100);
m_Slider.SetPos(20);
m_Slider.ShowWindow(SW_SHOW);
在int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) 函数中利用
PostMessage(UM_SETSLIDER, 0, 0);发送自定义的消息。
然后在自定义的消息响应函数中加入上面的那一大段代码即可。
copy楼主的代码过来,做了一个,工作得挺正常的。
以下是代码,但愿对你有所有帮助 。
我是个toolbar上加了个按钮(最后)
改了下id,看了下资源描述文件,id重复了,把 这个id改在唯一的。 一次调试通过。int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CMDIFrameWndEx::OnCreate(lpCreateStruct) == -1)
return -1; BOOL bNameValid; // 设置用于绘制所有用户界面元素的视觉管理器
CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerVS2008)); if (!m_wndMenuBar.Create(this))
{
TRACE0("未能创建菜单栏\n");
return -1; // 未能创建
} m_wndMenuBar.SetPaneStyle(m_wndMenuBar.GetPaneStyle() | CBRS_SIZE_DYNAMIC | CBRS_TOOLTIPS | CBRS_FLYBY); // 防止菜单栏在激活时获得焦点
CMFCPopupMenu::SetForceMenuFocus(FALSE); if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP | CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
!m_wndToolBar.LoadToolBar(theApp.m_bHiColorIcons ? IDR_MAINFRAME_256 : IDR_MAINFRAME))
{
TRACE0("未能创建工具栏\n");
return -1; // 未能创建
} CString strToolBarName;
bNameValid = strToolBarName.LoadString(IDS_TOOLBAR_STANDARD);
ASSERT(bNameValid);
m_wndToolBar.SetWindowText(strToolBarName); CString strCustomize;
bNameValid = strCustomize.LoadString(IDS_TOOLBAR_CUSTOMIZE);
ASSERT(bNameValid);
m_wndToolBar.EnableCustomizeButton(TRUE, ID_VIEW_CUSTOMIZE, strCustomize); // 允许用户定义的工具栏操作:
InitUserToolbars(NULL, uiFirstUserToolBarId, uiLastUserToolBarId); ////////////////////////////////////////
int index = m_wndToolBar.CommandToIndex(ID_Test);
m_wndToolBar.SetButtonInfo(index, ID_Test, TBBS_SEPARATOR, 80);
CRect rect;
m_wndToolBar.GetItemRect(index, &rect);
if (!m_Slider.Create(WS_CHILD|WS_VISIBLE | TBS_HORZ | TBS_AUTOTICKS |TBS_BOTTOM ,
rect, &m_wndToolBar, ID_Test))
{
TRACE0( "Failed to create slider ctrl\n ");
return FALSE;
}
m_Slider.SetRange(0,100);
m_Slider.SetPos(20);
m_Slider.ShowWindow(SW_SHOW);
/////////////////////////////////////////// if (!m_wndStatusBar.Create(this))
{
TRACE0("未能创建状态栏\n");
return -1; // 未能创建
}
m_wndStatusBar.SetIndicators(indicators, sizeof(indicators)/sizeof(UINT)); // TODO: 如果您不希望工具栏和菜单栏可停靠,请删除这五行
m_wndMenuBar.EnableDocking(CBRS_ALIGN_ANY);
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockPane(&m_wndMenuBar);
DockPane(&m_wndToolBar);
// 启用 Visual Studio 2005 样式停靠窗口行为
CDockingManager::SetDockingMode(DT_SMART);
// 启用 Visual Studio 2005 样式停靠窗口自动隐藏行为
EnableAutoHidePanes(CBRS_ALIGN_ANY); // 启用增强的窗口管理对话框
EnableWindowsDialog(ID_WINDOW_MANAGER, ID_WINDOW_MANAGER, TRUE); // 启用工具栏和停靠窗口菜单替换
EnablePaneMenu(TRUE, ID_VIEW_CUSTOMIZE, strCustomize, ID_VIEW_TOOLBAR); // 启用快速(按住 Alt 拖动)工具栏自定义
CMFCToolBar::EnableQuickCustomization(); if (CMFCToolBar::GetUserImages() == NULL)
{
// 加载用户定义的工具栏图像
if (m_UserImages.Load(_T(".\\UserImages.bmp")))
{
CMFCToolBar::SetUserImages(&m_UserImages);
}
} // 启用菜单个性化(最近使用的命令)
// TODO: 定义您自己的基本命令,确保每个下拉菜单至少有一个基本命令。
CList<UINT, UINT> lstBasicCommands; lstBasicCommands.AddTail(ID_FILE_NEW);
lstBasicCommands.AddTail(ID_FILE_OPEN);
lstBasicCommands.AddTail(ID_FILE_SAVE);
lstBasicCommands.AddTail(ID_FILE_PRINT);
lstBasicCommands.AddTail(ID_APP_EXIT);
lstBasicCommands.AddTail(ID_EDIT_CUT);
lstBasicCommands.AddTail(ID_EDIT_PASTE);
lstBasicCommands.AddTail(ID_EDIT_UNDO);
lstBasicCommands.AddTail(ID_APP_ABOUT);
lstBasicCommands.AddTail(ID_VIEW_STATUS_BAR);
lstBasicCommands.AddTail(ID_VIEW_TOOLBAR); CMFCToolBar::SetBasicCommands(lstBasicCommands); return 0;
}
我把m_slider定义成全局变量,就不出问题了,总算是解决了,虽然至今不明其中道理