我按照前人已经提供的方法如下:在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个错误

解决方案 »

  1.   

    请问这个是什么问题??另外新建一个MDI程序能够按前人方法实现,但是加到正在做的这个项目工程中却报错了。
    百思不得其解
    求高人解答
      

  2.   

    int index = m_wndToolBar.CommandToIndex(ID_APP_ABOUT);这句没问题啊 
      

  3.   

    编译没问题,但运行时出错,提示0x7c930cce指令引用0x00000000内存不能为“read”
    这个应该是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);发送自定义的消息。
    然后在自定义的消息响应函数中加入上面的那一大段代码即可。
      

  4.   

    刚好我这几个需要一个这样的东东。
    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;
    }
      

  5.   

    多谢ls各位,
    我把m_slider定义成全局变量,就不出问题了,总算是解决了,虽然至今不明其中道理